Merge branch 'develop' into refactor/report/item-shortage-report
This commit is contained in:
		
						commit
						dad40b8d51
					
				| @ -1091,7 +1091,7 @@ frappe.ui.form.on('Payment Entry', { | |||||||
| 
 | 
 | ||||||
| 			$.each(tax_fields, function(i, fieldname) { tax[fieldname] = 0.0; }); | 			$.each(tax_fields, function(i, fieldname) { tax[fieldname] = 0.0; }); | ||||||
| 
 | 
 | ||||||
| 			frm.doc.paid_amount_after_tax = frm.doc.paid_amount; | 			frm.doc.paid_amount_after_tax = frm.doc.base_paid_amount; | ||||||
| 		}); | 		}); | ||||||
| 	}, | 	}, | ||||||
| 
 | 
 | ||||||
| @ -1182,7 +1182,7 @@ frappe.ui.form.on('Payment Entry', { | |||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			cumulated_tax_fraction += tax.tax_fraction_for_current_item; | 			cumulated_tax_fraction += tax.tax_fraction_for_current_item; | ||||||
| 			frm.doc.paid_amount_after_tax = flt(frm.doc.paid_amount/(1+cumulated_tax_fraction)) | 			frm.doc.paid_amount_after_tax = flt(frm.doc.base_paid_amount/(1+cumulated_tax_fraction)) | ||||||
| 		}); | 		}); | ||||||
| 	}, | 	}, | ||||||
| 
 | 
 | ||||||
| @ -1214,6 +1214,7 @@ frappe.ui.form.on('Payment Entry', { | |||||||
| 		frm.doc.total_taxes_and_charges = 0.0; | 		frm.doc.total_taxes_and_charges = 0.0; | ||||||
| 		frm.doc.base_total_taxes_and_charges = 0.0; | 		frm.doc.base_total_taxes_and_charges = 0.0; | ||||||
| 
 | 
 | ||||||
|  | 		let company_currency = frappe.get_doc(":Company", frm.doc.company).default_currency; | ||||||
| 		let actual_tax_dict = {}; | 		let actual_tax_dict = {}; | ||||||
| 
 | 
 | ||||||
| 		// maintain actual tax rate based on idx
 | 		// maintain actual tax rate based on idx
 | ||||||
| @ -1234,8 +1235,8 @@ frappe.ui.form.on('Payment Entry', { | |||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			tax.tax_amount = current_tax_amount; | 			// tax accounts are only in company currency
 | ||||||
| 			tax.base_tax_amount = tax.tax_amount * frm.doc.source_exchange_rate; | 			tax.base_tax_amount = current_tax_amount; | ||||||
| 			current_tax_amount *= (tax.add_deduct_tax == "Deduct") ? -1.0 : 1.0; | 			current_tax_amount *= (tax.add_deduct_tax == "Deduct") ? -1.0 : 1.0; | ||||||
| 
 | 
 | ||||||
| 			if(i==0) { | 			if(i==0) { | ||||||
| @ -1244,9 +1245,29 @@ frappe.ui.form.on('Payment Entry', { | |||||||
| 				tax.total = flt(frm.doc["taxes"][i-1].total + current_tax_amount, precision("total", tax)); | 				tax.total = flt(frm.doc["taxes"][i-1].total + current_tax_amount, precision("total", tax)); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			tax.base_total = tax.total * frm.doc.source_exchange_rate; | 			// tac accounts are only in company currency
 | ||||||
|  | 			tax.base_total = tax.total | ||||||
|  | 
 | ||||||
|  | 			// calculate total taxes and base total taxes
 | ||||||
|  | 			if(frm.doc.payment_type == "Pay") { | ||||||
|  | 				// tax accounts only have company currency
 | ||||||
|  | 				if(tax.currency != frm.doc.paid_to_account_currency) { | ||||||
|  | 					//total_taxes_and_charges has the target currency. so using target conversion rate
 | ||||||
|  | 					frm.doc.total_taxes_and_charges += flt(current_tax_amount / frm.doc.target_exchange_rate); | ||||||
|  | 
 | ||||||
|  | 				} else { | ||||||
| 					frm.doc.total_taxes_and_charges += current_tax_amount; | 					frm.doc.total_taxes_and_charges += current_tax_amount; | ||||||
| 			frm.doc.base_total_taxes_and_charges += current_tax_amount * frm.doc.source_exchange_rate; | 				} | ||||||
|  | 			} else if(frm.doc.payment_type == "Receive") { | ||||||
|  | 				if(tax.currency != frm.doc.paid_from_account_currency) { | ||||||
|  | 					//total_taxes_and_charges has the target currency. so using source conversion rate
 | ||||||
|  | 					frm.doc.total_taxes_and_charges += flt(current_tax_amount / frm.doc.source_exchange_rate); | ||||||
|  | 				} else { | ||||||
|  | 					frm.doc.total_taxes_and_charges += current_tax_amount; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			frm.doc.base_total_taxes_and_charges += tax.base_tax_amount; | ||||||
| 
 | 
 | ||||||
| 			frm.refresh_field('taxes'); | 			frm.refresh_field('taxes'); | ||||||
| 			frm.refresh_field('total_taxes_and_charges'); | 			frm.refresh_field('total_taxes_and_charges'); | ||||||
|  | |||||||
| @ -940,6 +940,13 @@ class PaymentEntry(AccountsController): | |||||||
| 			) | 			) | ||||||
| 
 | 
 | ||||||
| 			if not d.included_in_paid_amount: | 			if not d.included_in_paid_amount: | ||||||
|  | 				if get_account_currency(payment_account) != self.company_currency: | ||||||
|  | 					if self.payment_type == "Receive": | ||||||
|  | 						exchange_rate = self.target_exchange_rate | ||||||
|  | 					elif self.payment_type in ["Pay", "Internal Transfer"]: | ||||||
|  | 						exchange_rate = self.source_exchange_rate | ||||||
|  | 					base_tax_amount = flt((tax_amount / exchange_rate), self.precision("paid_amount")) | ||||||
|  | 
 | ||||||
| 				gl_entries.append( | 				gl_entries.append( | ||||||
| 					self.get_gl_dict( | 					self.get_gl_dict( | ||||||
| 						{ | 						{ | ||||||
| @ -1033,7 +1040,7 @@ class PaymentEntry(AccountsController): | |||||||
| 			for fieldname in tax_fields: | 			for fieldname in tax_fields: | ||||||
| 				tax.set(fieldname, 0.0) | 				tax.set(fieldname, 0.0) | ||||||
| 
 | 
 | ||||||
| 		self.paid_amount_after_tax = self.paid_amount | 		self.paid_amount_after_tax = self.base_paid_amount | ||||||
| 
 | 
 | ||||||
| 	def determine_exclusive_rate(self): | 	def determine_exclusive_rate(self): | ||||||
| 		if not any(cint(tax.included_in_paid_amount) for tax in self.get("taxes")): | 		if not any(cint(tax.included_in_paid_amount) for tax in self.get("taxes")): | ||||||
| @ -1052,7 +1059,7 @@ class PaymentEntry(AccountsController): | |||||||
| 
 | 
 | ||||||
| 			cumulated_tax_fraction += tax.tax_fraction_for_current_item | 			cumulated_tax_fraction += tax.tax_fraction_for_current_item | ||||||
| 
 | 
 | ||||||
| 		self.paid_amount_after_tax = flt(self.paid_amount / (1 + cumulated_tax_fraction)) | 		self.paid_amount_after_tax = flt(self.base_paid_amount / (1 + cumulated_tax_fraction)) | ||||||
| 
 | 
 | ||||||
| 	def calculate_taxes(self): | 	def calculate_taxes(self): | ||||||
| 		self.total_taxes_and_charges = 0.0 | 		self.total_taxes_and_charges = 0.0 | ||||||
| @ -1075,7 +1082,7 @@ class PaymentEntry(AccountsController): | |||||||
| 					current_tax_amount += actual_tax_dict[tax.idx] | 					current_tax_amount += actual_tax_dict[tax.idx] | ||||||
| 
 | 
 | ||||||
| 			tax.tax_amount = current_tax_amount | 			tax.tax_amount = current_tax_amount | ||||||
| 			tax.base_tax_amount = tax.tax_amount * self.source_exchange_rate | 			tax.base_tax_amount = current_tax_amount | ||||||
| 
 | 
 | ||||||
| 			if tax.add_deduct_tax == "Deduct": | 			if tax.add_deduct_tax == "Deduct": | ||||||
| 				current_tax_amount *= -1.0 | 				current_tax_amount *= -1.0 | ||||||
| @ -1089,14 +1096,20 @@ class PaymentEntry(AccountsController): | |||||||
| 					self.get("taxes")[i - 1].total + current_tax_amount, self.precision("total", tax) | 					self.get("taxes")[i - 1].total + current_tax_amount, self.precision("total", tax) | ||||||
| 				) | 				) | ||||||
| 
 | 
 | ||||||
| 			tax.base_total = tax.total * self.source_exchange_rate | 			tax.base_total = tax.total | ||||||
| 
 | 
 | ||||||
| 			if self.payment_type == "Pay": | 			if self.payment_type == "Pay": | ||||||
| 				self.base_total_taxes_and_charges += flt(current_tax_amount / self.source_exchange_rate) | 				if tax.currency != self.paid_to_account_currency: | ||||||
| 					self.total_taxes_and_charges += flt(current_tax_amount / self.target_exchange_rate) | 					self.total_taxes_and_charges += flt(current_tax_amount / self.target_exchange_rate) | ||||||
| 				else: | 				else: | ||||||
| 				self.base_total_taxes_and_charges += flt(current_tax_amount / self.target_exchange_rate) | 					self.total_taxes_and_charges += current_tax_amount | ||||||
|  | 			elif self.payment_type == "Receive": | ||||||
|  | 				if tax.currency != self.paid_from_account_currency: | ||||||
| 					self.total_taxes_and_charges += flt(current_tax_amount / self.source_exchange_rate) | 					self.total_taxes_and_charges += flt(current_tax_amount / self.source_exchange_rate) | ||||||
|  | 				else: | ||||||
|  | 					self.total_taxes_and_charges += current_tax_amount | ||||||
|  | 
 | ||||||
|  | 			self.base_total_taxes_and_charges += tax.base_tax_amount | ||||||
| 
 | 
 | ||||||
| 		if self.get("taxes"): | 		if self.get("taxes"): | ||||||
| 			self.paid_amount_after_tax = self.get("taxes")[-1].base_total | 			self.paid_amount_after_tax = self.get("taxes")[-1].base_total | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ | |||||||
| import unittest | import unittest | ||||||
| 
 | 
 | ||||||
| import frappe | import frappe | ||||||
|  | from frappe import qb | ||||||
| from frappe.tests.utils import FrappeTestCase | from frappe.tests.utils import FrappeTestCase | ||||||
| from frappe.utils import flt, nowdate | from frappe.utils import flt, nowdate | ||||||
| 
 | 
 | ||||||
| @ -722,6 +723,46 @@ class TestPaymentEntry(FrappeTestCase): | |||||||
| 			flt(payment_entry.total_taxes_and_charges, 2), flt(10 / payment_entry.target_exchange_rate, 2) | 			flt(payment_entry.total_taxes_and_charges, 2), flt(10 / payment_entry.target_exchange_rate, 2) | ||||||
| 		) | 		) | ||||||
| 
 | 
 | ||||||
|  | 	def test_gl_of_multi_currency_payment_with_taxes(self): | ||||||
|  | 		payment_entry = create_payment_entry( | ||||||
|  | 			party="_Test Supplier USD", paid_to="_Test Payable USD - _TC", save=True | ||||||
|  | 		) | ||||||
|  | 		payment_entry.append( | ||||||
|  | 			"taxes", | ||||||
|  | 			{ | ||||||
|  | 				"account_head": "_Test Account Service Tax - _TC", | ||||||
|  | 				"charge_type": "Actual", | ||||||
|  | 				"tax_amount": 100, | ||||||
|  | 				"add_deduct_tax": "Add", | ||||||
|  | 				"description": "Test", | ||||||
|  | 			}, | ||||||
|  | 		) | ||||||
|  | 		payment_entry.target_exchange_rate = 80 | ||||||
|  | 		payment_entry.received_amount = 12.5 | ||||||
|  | 		payment_entry = payment_entry.submit() | ||||||
|  | 		gle = qb.DocType("GL Entry") | ||||||
|  | 		gl_entries = ( | ||||||
|  | 			qb.from_(gle) | ||||||
|  | 			.select( | ||||||
|  | 				gle.account, | ||||||
|  | 				gle.debit, | ||||||
|  | 				gle.credit, | ||||||
|  | 				gle.debit_in_account_currency, | ||||||
|  | 				gle.credit_in_account_currency, | ||||||
|  | 			) | ||||||
|  | 			.orderby(gle.account) | ||||||
|  | 			.where(gle.voucher_no == payment_entry.name) | ||||||
|  | 			.run() | ||||||
|  | 		) | ||||||
|  | 
 | ||||||
|  | 		expected_gl_entries = ( | ||||||
|  | 			("_Test Account Service Tax - _TC", 100.0, 0.0, 100.0, 0.0), | ||||||
|  | 			("_Test Bank - _TC", 0.0, 1100.0, 0.0, 1100.0), | ||||||
|  | 			("_Test Payable USD - _TC", 1000.0, 0.0, 12.5, 0), | ||||||
|  | 		) | ||||||
|  | 
 | ||||||
|  | 		self.assertEqual(gl_entries, expected_gl_entries) | ||||||
|  | 
 | ||||||
| 	def test_payment_entry_against_onhold_purchase_invoice(self): | 	def test_payment_entry_against_onhold_purchase_invoice(self): | ||||||
| 		pi = make_purchase_invoice() | 		pi = make_purchase_invoice() | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -39,6 +39,7 @@ | |||||||
|   { |   { | ||||||
|    "columns": 2, |    "columns": 2, | ||||||
|    "fetch_from": "payment_term.description", |    "fetch_from": "payment_term.description", | ||||||
|  |    "fetch_if_empty": 1, | ||||||
|    "fieldname": "description", |    "fieldname": "description", | ||||||
|    "fieldtype": "Small Text", |    "fieldtype": "Small Text", | ||||||
|    "in_list_view": 1, |    "in_list_view": 1, | ||||||
| @ -159,7 +160,7 @@ | |||||||
|  "index_web_pages_for_search": 1, |  "index_web_pages_for_search": 1, | ||||||
|  "istable": 1, |  "istable": 1, | ||||||
|  "links": [], |  "links": [], | ||||||
|  "modified": "2021-04-28 05:41:35.084233", |  "modified": "2022-09-16 13:57:06.382859", | ||||||
|  "modified_by": "Administrator", |  "modified_by": "Administrator", | ||||||
|  "module": "Accounts", |  "module": "Accounts", | ||||||
|  "name": "Payment Schedule", |  "name": "Payment Schedule", | ||||||
| @ -168,5 +169,6 @@ | |||||||
|  "quick_entry": 1, |  "quick_entry": 1, | ||||||
|  "sort_field": "modified", |  "sort_field": "modified", | ||||||
|  "sort_order": "DESC", |  "sort_order": "DESC", | ||||||
|  |  "states": [], | ||||||
|  "track_changes": 1 |  "track_changes": 1 | ||||||
| } | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user