Merge pull request #23079 from marination/item-tax-update-items
fix: Item Tax Updating via `Update Items` in SO/PO
This commit is contained in:
		
						commit
						15f698251b
					
				| @ -202,6 +202,53 @@ class TestPurchaseOrder(unittest.TestCase): | ||||
| 		self.assertRaises(frappe.ValidationError, update_child_qty_rate,'Purchase Order', trans_item, po.name) | ||||
| 		frappe.set_user("Administrator") | ||||
| 
 | ||||
| 	def test_update_child_with_tax_template(self): | ||||
| 		tax_template = "_Test Account Excise Duty @ 10" | ||||
| 		item =  "_Test Item Home Desktop 100" | ||||
| 
 | ||||
| 		if not frappe.db.exists("Item Tax", {"parent":item, "item_tax_template":tax_template}): | ||||
| 			item_doc = frappe.get_doc("Item", item) | ||||
| 			item_doc.append("taxes", { | ||||
| 				"item_tax_template": tax_template, | ||||
| 				"valid_from": nowdate() | ||||
| 			}) | ||||
| 			item_doc.save() | ||||
| 		else: | ||||
| 			# update valid from | ||||
| 			frappe.db.sql("""UPDATE `tabItem Tax` set valid_from = CURDATE() | ||||
| 				where parent = %(item)s and item_tax_template = %(tax)s""", | ||||
| 					{"item": item, "tax": tax_template}) | ||||
| 
 | ||||
| 		po = create_purchase_order(item_code=item, qty=1, do_not_save=1) | ||||
| 
 | ||||
| 		po.append("taxes", { | ||||
| 			"account_head": "_Test Account Excise Duty - _TC", | ||||
| 			"charge_type": "On Net Total", | ||||
| 			"cost_center": "_Test Cost Center - _TC", | ||||
| 			"description": "Excise Duty", | ||||
| 			"doctype": "Purchase Taxes and Charges", | ||||
| 			"rate": 10 | ||||
| 		}) | ||||
| 		po.insert() | ||||
| 		po.submit() | ||||
| 
 | ||||
| 		self.assertEqual(po.taxes[0].tax_amount, 50) | ||||
| 		self.assertEqual(po.taxes[0].total, 550) | ||||
| 
 | ||||
| 		items = json.dumps([ | ||||
| 			{'item_code' : item, 'rate' : 500, 'qty' : 1, 'docname': po.items[0].name}, | ||||
| 			{'item_code' : item, 'rate' : 100, 'qty' : 1} # added item | ||||
| 		]) | ||||
| 		update_child_qty_rate('Purchase Order', items, po.name) | ||||
| 
 | ||||
| 		po.reload() | ||||
| 		self.assertEqual(po.taxes[0].tax_amount, 60) | ||||
| 		self.assertEqual(po.taxes[0].total, 660) | ||||
| 
 | ||||
| 		frappe.db.sql("""UPDATE `tabItem Tax` set valid_from = NULL | ||||
| 				where parent = %(item)s and item_tax_template = %(tax)s""", | ||||
| 					{"item": item, "tax": tax_template}) | ||||
| 
 | ||||
| 	def test_update_child_uom_conv_factor_change(self): | ||||
| 		po = create_purchase_order(item_code="_Test FG Item", is_subcontracted="Yes") | ||||
| 		total_reqd_qty = sum([d.get("required_qty") for d in po.as_dict().get("supplied_items")]) | ||||
|  | ||||
| @ -20,7 +20,7 @@ from erpnext.accounts.doctype.pricing_rule.utils import (apply_pricing_rule_on_t | ||||
| from erpnext.exceptions import InvalidCurrency | ||||
| from six import text_type | ||||
| from erpnext.accounts.doctype.accounting_dimension.accounting_dimension import get_accounting_dimensions | ||||
| from erpnext.stock.get_item_details import get_item_warehouse | ||||
| from erpnext.stock.get_item_details import get_item_warehouse, _get_item_tax_template, get_item_tax_map | ||||
| from erpnext.stock.doctype.packed_item.packed_item import make_packing_list | ||||
| 
 | ||||
| force_item_fields = ("item_group", "brand", "stock_uom", "is_fixed_asset", "item_tax_rate", "pricing_rules") | ||||
| @ -1158,6 +1158,18 @@ def get_supplier_block_status(party_name): | ||||
| 	} | ||||
| 	return info | ||||
| 
 | ||||
| def set_child_tax_template_and_map(item, child_item, parent_doc): | ||||
| 	args = { | ||||
| 			'item_code': item.item_code, | ||||
| 			'posting_date': parent_doc.transaction_date, | ||||
| 			'tax_category': parent_doc.get('tax_category'), | ||||
| 			'company': parent_doc.get('company') | ||||
| 		} | ||||
| 
 | ||||
| 	child_item.item_tax_template = _get_item_tax_template(args, item.taxes) | ||||
| 	if child_item.get("item_tax_template"): | ||||
| 		child_item.item_tax_rate = get_item_tax_map(parent_doc.get('company'), child_item.item_tax_template, as_json=True) | ||||
| 
 | ||||
| def set_sales_order_defaults(parent_doctype, parent_doctype_name, child_docname, trans_item): | ||||
| 	""" | ||||
| 	Returns a Sales Order Item child item containing the default values | ||||
| @ -1172,6 +1184,7 @@ def set_sales_order_defaults(parent_doctype, parent_doctype_name, child_docname, | ||||
| 	child_item.uom = trans_item.get("uom") or item.stock_uom | ||||
| 	conversion_factor = flt(get_conversion_factor(item.item_code, child_item.uom).get("conversion_factor")) | ||||
| 	child_item.conversion_factor = flt(trans_item.get('conversion_factor')) or conversion_factor | ||||
| 	set_child_tax_template_and_map(item, child_item, p_doc) | ||||
| 	child_item.warehouse = get_item_warehouse(item, p_doc, overwrite_warehouse=True) | ||||
| 	if not child_item.warehouse: | ||||
| 		frappe.throw(_("Cannot find {} for item {}. Please set the same in Item Master or Stock Settings.") | ||||
| @ -1195,6 +1208,7 @@ def set_purchase_order_defaults(parent_doctype, parent_doctype_name, child_docna | ||||
| 	child_item.conversion_factor = flt(trans_item.get('conversion_factor')) or conversion_factor | ||||
| 	child_item.base_rate = 1 # Initiallize value will update in parent validation | ||||
| 	child_item.base_amount = 1 # Initiallize value will update in parent validation | ||||
| 	set_child_tax_template_and_map(item, child_item, p_doc) | ||||
| 	return child_item | ||||
| 
 | ||||
| def validate_and_delete_children(parent, data): | ||||
| @ -1232,7 +1246,7 @@ def update_child_qty_rate(parent_doctype, trans_items, parent_doctype_name, chil | ||||
| 
 | ||||
| 			frappe.throw(_("You do not have permissions to {} items in a {}.") | ||||
| 				.format(actions[perm_type], parent_doctype), title=_("Insufficient Permissions")) | ||||
| 	 | ||||
| 
 | ||||
| 	def validate_workflow_conditions(doc): | ||||
| 		workflow = get_workflow_name(doc.doctype) | ||||
| 		if not workflow: | ||||
| @ -1267,7 +1281,7 @@ def update_child_qty_rate(parent_doctype, trans_items, parent_doctype_name, chil | ||||
| 
 | ||||
| 	sales_doctypes = ['Sales Order', 'Sales Invoice', 'Delivery Note', 'Quotation'] | ||||
| 	parent = frappe.get_doc(parent_doctype, parent_doctype_name) | ||||
| 	 | ||||
| 
 | ||||
| 	check_doc_permissions(parent, 'cancel') | ||||
| 	validate_and_delete_children(parent, data) | ||||
| 
 | ||||
| @ -1315,7 +1329,7 @@ def update_child_qty_rate(parent_doctype, trans_items, parent_doctype_name, chil | ||||
| 				child_item.conversion_factor = 1 | ||||
| 			else: | ||||
| 				child_item.conversion_factor = flt(d.get('conversion_factor')) | ||||
| 		 | ||||
| 
 | ||||
| 		if d.get("uom"): | ||||
| 			child_item.uom = d.get("uom") | ||||
| 			conversion_factor = flt(get_conversion_factor(child_item.item_code, child_item.uom).get("conversion_factor")) | ||||
|  | ||||
| @ -595,7 +595,7 @@ erpnext.taxes_and_totals = erpnext.payments.extend({ | ||||
| 			$.each(actual_taxes_dict, function(key, value) { | ||||
| 				if (value) total_actual_tax += value; | ||||
| 			}); | ||||
| 			 | ||||
| 
 | ||||
| 			return flt(this.frm.doc.grand_total - total_actual_tax, precision("grand_total")); | ||||
| 		} | ||||
| 	}, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user