Total Purchase Cost added to Projects
This commit is contained in:
		
							parent
							
								
									5e13799704
								
							
						
					
					
						commit
						9a56764bf2
					
				| @ -5,21 +5,6 @@ | |||||||
|  "docstatus": 0,  |  "docstatus": 0,  | ||||||
|  "doctype": "DocType",  |  "doctype": "DocType",  | ||||||
|  "fields": [ |  "fields": [ | ||||||
|   { |  | ||||||
|    "fieldname": "supplier_section",  |  | ||||||
|    "fieldtype": "Section Break",  |  | ||||||
|    "label": "",  |  | ||||||
|    "options": "icon-user",  |  | ||||||
|    "permlevel": 0 |  | ||||||
|   },  |  | ||||||
|   { |  | ||||||
|    "fieldname": "column_break0",  |  | ||||||
|    "fieldtype": "Column Break",  |  | ||||||
|    "oldfieldtype": "Column Break",  |  | ||||||
|    "permlevel": 0,  |  | ||||||
|    "read_only": 0,  |  | ||||||
|    "width": "50%" |  | ||||||
|   },  |  | ||||||
|   { |   { | ||||||
|    "fieldname": "naming_series",  |    "fieldname": "naming_series",  | ||||||
|    "fieldtype": "Select",  |    "fieldtype": "Select",  | ||||||
| @ -91,6 +76,14 @@ | |||||||
|    "print_hide": 1,  |    "print_hide": 1,  | ||||||
|    "read_only": 1 |    "read_only": 1 | ||||||
|   },  |   },  | ||||||
|  |   { | ||||||
|  |    "fieldname": "project",  | ||||||
|  |    "fieldtype": "Link",  | ||||||
|  |    "label": "Project",  | ||||||
|  |    "options": "Project",  | ||||||
|  |    "permlevel": 0,  | ||||||
|  |    "precision": "" | ||||||
|  |   },  | ||||||
|   { |   { | ||||||
|    "fieldname": "column_break1",  |    "fieldname": "column_break1",  | ||||||
|    "fieldtype": "Column Break",  |    "fieldtype": "Column Break",  | ||||||
|  | |||||||
| @ -239,6 +239,7 @@ class PurchaseInvoice(BuyingController): | |||||||
| 		self.update_against_document_in_jv() | 		self.update_against_document_in_jv() | ||||||
| 		self.update_prevdoc_status() | 		self.update_prevdoc_status() | ||||||
| 		self.update_billing_status_for_zero_amount_refdoc("Purchase Order") | 		self.update_billing_status_for_zero_amount_refdoc("Purchase Order") | ||||||
|  | 		self.update_project() | ||||||
| 
 | 
 | ||||||
| 	def make_gl_entries(self): | 	def make_gl_entries(self): | ||||||
| 		auto_accounting_for_stock = \ | 		auto_accounting_for_stock = \ | ||||||
| @ -373,9 +374,14 @@ class PurchaseInvoice(BuyingController): | |||||||
| 		self.update_prevdoc_status() | 		self.update_prevdoc_status() | ||||||
| 		self.update_billing_status_for_zero_amount_refdoc("Purchase Order") | 		self.update_billing_status_for_zero_amount_refdoc("Purchase Order") | ||||||
| 		self.make_gl_entries_on_cancel() | 		self.make_gl_entries_on_cancel() | ||||||
|  | 		self.update_project() | ||||||
| 		 | 		 | ||||||
| 	def on_update(self): | 	def update_project(self): | ||||||
| 		pass | 		if self.project and frappe.db.exists("Project", self.project): | ||||||
|  | 			project = frappe.get_doc("Project", self.project) | ||||||
|  | 			project.flags.dont_sync_tasks = True | ||||||
|  | 			project.update_purchase_costing() | ||||||
|  | 			project.save() | ||||||
| 
 | 
 | ||||||
| @frappe.whitelist() | @frappe.whitelist() | ||||||
| def get_expense_account(doctype, txt, searchfield, start, page_len, filters): | def get_expense_account(doctype, txt, searchfield, start, page_len, filters): | ||||||
|  | |||||||
| @ -303,6 +303,15 @@ | |||||||
|    "precision": "",  |    "precision": "",  | ||||||
|    "read_only": 1 |    "read_only": 1 | ||||||
|   },  |   },  | ||||||
|  |   { | ||||||
|  |    "fieldname": "total_purchase_cost",  | ||||||
|  |    "fieldtype": "Currency",  | ||||||
|  |    "hidden": 0,  | ||||||
|  |    "label": "Total Purchase Cost (via Purchase Invoice)",  | ||||||
|  |    "permlevel": 0,  | ||||||
|  |    "precision": "",  | ||||||
|  |    "read_only": 1 | ||||||
|  |   },  | ||||||
|   { |   { | ||||||
|    "fieldname": "margin",  |    "fieldname": "margin",  | ||||||
|    "fieldtype": "Section Break",  |    "fieldtype": "Section Break",  | ||||||
| @ -347,7 +356,7 @@ | |||||||
|  "icon": "icon-puzzle-piece",  |  "icon": "icon-puzzle-piece",  | ||||||
|  "idx": 1,  |  "idx": 1,  | ||||||
|  "max_attachments": 4,  |  "max_attachments": 4,  | ||||||
|  "modified": "2015-04-23 05:51:53.642253",  |  "modified": "2015-04-27 07:37:44.239930",  | ||||||
|  "modified_by": "Administrator",  |  "modified_by": "Administrator",  | ||||||
|  "module": "Projects",  |  "module": "Projects",  | ||||||
|  "name": "Project",  |  "name": "Project",  | ||||||
|  | |||||||
| @ -90,6 +90,10 @@ class Project(Document): | |||||||
| 		if self.total_billing_amount: | 		if self.total_billing_amount: | ||||||
| 			self.per_gross_margin = (self.gross_margin / flt(self.total_billing_amount)) *100 | 			self.per_gross_margin = (self.gross_margin / flt(self.total_billing_amount)) *100 | ||||||
| 			 | 			 | ||||||
|  | 	def update_purchase_costing(self): | ||||||
|  | 		self.total_purchase_cost = frappe.db.sql("""select sum(grand_total) as cost | ||||||
|  | 			from `tabPurchase Invoice` where project = %s and docstatus=1 """, self.name, as_dict=1)[0].cost | ||||||
|  | 
 | ||||||
| @frappe.whitelist() | @frappe.whitelist() | ||||||
| def get_cost_center_name(project_name): | def get_cost_center_name(project_name): | ||||||
| 	return frappe.db.get_value("Project", project_name, "cost_center") | 	return frappe.db.get_value("Project", project_name, "cost_center") | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user