feat(UAE VAT 21): Move standard rated expense from Sales invoice to Purchase invoice

This commit is contained in:
Mohammad Hasnain 2020-10-11 01:40:22 +05:30
parent fc2ace1a31
commit ac451b3a54
4 changed files with 13 additions and 12 deletions

View File

@ -242,15 +242,13 @@ doc_events = {
"erpnext.regional.italy.utils.sales_invoice_on_cancel",
"erpnext.erpnext_integrations.taxjar_integration.delete_transaction"
],
"validate": [
"erpnext.regional.united_arab_emirates.utils.validate_returns",
],
"on_trash": "erpnext.regional.check_deletion_permission"
},
"Purchase Invoice": {
"validate": [
"erpnext.regional.india.utils.update_grand_total_for_rcm",
"erpnext.regional.united_arab_emirates.utils.update_grand_total_for_rcm",
"erpnext.regional.united_arab_emirates.utils.validate_returns"
]
},
"Payment Entry": {

View File

@ -277,7 +277,7 @@ def get_standard_rated_expenses_total(filters):
conditions = get_conditions(filters)
return frappe.db.sql("""
select sum(total) from
`tabSales Invoice`
`tabPurchase Invoice`
where
standard_rated_expenses > 0
and docstatus = 1 {where_conditions} ;
@ -288,7 +288,7 @@ def get_standard_rated_expenses_tax(filters):
conditions = get_conditions(filters)
return frappe.db.sql("""
select sum(standard_rated_expenses) from
`tabSales Invoice`
`tabPurchase Invoice`
where
standard_rated_expenses > 0
and docstatus = 1 {where_conditions} ;

View File

@ -38,8 +38,11 @@ def make_custom_fields():
dict(fieldname='supplier_name_in_arabic', label='Supplier Name in Arabic',
fieldtype='Read Only', insert_after='supplier_name',
fetch_from='supplier.supplier_name_in_arabic', print_hide=1),
dict(fieldname='standard_rated_expenses', label='Standard Rated Expenses (AED)',
insert_after='permit_no', fieldtype='Currency', print_hide=1, default='0',
depends_on="eval:doc.reverse_charge=='N'",),
dict(fieldname='reverse_charge', label='Reverse Charge Applicable',
fieldtype='Select', insert_after='permit_no', print_hide=1,
fieldtype='Select', insert_after='standard_rated_expenses', print_hide=1,
options='Y\nN', default='N'),
dict(fieldname='claimable_reverse_charge', label='Claimable Reverse Charge (Percentage)',
insert_after='reverse_charge', fieldtype='Percent', print_hide=1,
@ -57,8 +60,6 @@ def make_custom_fields():
fieldtype='Read Only', fetch_from='customer_address.emirates'),
dict(fieldname='tourist_tax_return', label='Tax Refund provided to Tourists (AED)',
insert_after='permit_no', fieldtype='Currency', print_hide=1, default='0'),
dict(fieldname='standard_rated_expenses', label='Standard Rated Expenses (AED)',
insert_after='tourist_tax_return', fieldtype='Currency', print_hide=1, default='0'),
]
invoice_item_fields = [

View File

@ -143,11 +143,13 @@ def make_regional_gl_entries(gl_entries, doc):
return gl_entries
def validate_returns(doc, method):
"""Sum of Tourist Returns and Standard Rated Expenses should be less than Total Tax."""
"""Standard Rated expenses should not be set when Reverse Charge Applicable is set."""
country = frappe.get_cached_value('Company', doc.company, 'country')
print("-"*50)
print(doc.reverse_charge)
print(flt(doc.standard_rated_expenses))
if country != 'United Arab Emirates':
return
if flt(doc.tourist_tax_return) + flt(doc.standard_rated_expenses) > flt(doc.total_taxes_and_charges):
frappe.throw(_("The Total Returns(Tax Refund provided to Tourists (AED) + Standard Rated Expenses (AED)) should be less than the Total Taxes and Charges (Company Currency)"))
if doc.reverse_charge == 'Y' and flt(doc.standard_rated_expenses) != 0:
frappe.throw(_("Standard Rated expenses should not be set when Reverse Charge Applicable is Y"))