56 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
 | |
| # License: GNU General Public License v3. See license.txt
 | |
| 
 | |
| from __future__ import unicode_literals
 | |
| import frappe
 | |
| from frappe.model import rename_field
 | |
| from frappe.modules import scrub, get_doctype_module
 | |
| 
 | |
| selling_doctypes = ("Quotation", "Sales Order", "Delivery Note", "Sales Invoice")
 | |
| 
 | |
| buying_doctypes = ("Supplier Quotation", "Purchase Order", "Purchase Receipt", "Purchase Invoice")
 | |
| 
 | |
| selling_renamed_fields = (
 | |
| 	("net_total", "base_net_total"),
 | |
| 	("net_total_export", "net_total"),
 | |
| 	("other_charges_total", "base_total_taxes_and_charges"),
 | |
| 	("other_charges_total_export", "total_taxes_and_charges"),
 | |
| 	("grand_total", "base_grand_total"),
 | |
| 	("grand_total_export", "grand_total"),
 | |
| 	("rounded_total", "base_rounded_total"),
 | |
| 	("rounded_total_export", "rounded_total"),
 | |
| 	("in_words", "base_in_words"),
 | |
| 	("in_words_export", "in_words")
 | |
| )
 | |
| 
 | |
| buying_renamed_fields = (
 | |
| 	("net_total", "base_net_total"),
 | |
| 	("net_total_import", "net_total"),
 | |
| 	("grand_total", "base_grand_total"),
 | |
| 	("grand_total_import", "grand_total"),
 | |
| 	("rounded_total", "base_rounded_total"),
 | |
| 	("in_words", "base_in_words"),
 | |
| 	("in_words_import", "in_words"),
 | |
| 	("other_charges_added", "base_taxes_and_charges_added"),
 | |
| 	("other_charges_added_import", "taxes_and_charges_added"),
 | |
| 	("other_charges_deducted", "base_taxes_and_charges_deducted"),
 | |
| 	("other_charges_deducted_import", "taxes_and_charges_deducted"),
 | |
| 	("total_tax", "base_total_taxes_and_charges")
 | |
| )
 | |
| 
 | |
| def execute():
 | |
| 	for doctypes, fields in [[selling_doctypes, selling_renamed_fields], [buying_doctypes, buying_renamed_fields]]:
 | |
| 		for dt in doctypes:
 | |
| 			meta = frappe.get_meta(dt)
 | |
| 			frappe.reload_doc(get_doctype_module(dt), "doctype", scrub(dt))
 | |
| 			base_net_total = frappe.db.sql("select sum(ifnull({0}, 0)) from `tab{1}`".format(fields[0][1], dt))[0][0]
 | |
| 			if not base_net_total:
 | |
| 				for f in fields:
 | |
| 					if meta.get_field(f[0]):
 | |
| 						rename_field(dt, f[0], f[1])
 | |
| 
 | |
| 				# Added new field "total_taxes_and_charges" in buying cycle, updating value
 | |
| 				if dt in ("Supplier Quotation", "Purchase Order", "Purchase Receipt", "Purchase Invoice"):
 | |
| 					frappe.db.sql("""update `tab{0}` set total_taxes_and_charges =
 | |
| 						round(base_total_taxes_and_charges/conversion_rate, 2)""".format(dt))
 |