Merge pull request #22944 from anupamvs/opportunity-status
fix: Opportunity Status fix
This commit is contained in:
		
						commit
						c92da35997
					
				| @ -25,7 +25,6 @@ class Quotation(SellingController): | ||||
| 	def validate(self): | ||||
| 		super(Quotation, self).validate() | ||||
| 		self.set_status() | ||||
| 		self.update_opportunity() | ||||
| 		self.validate_uom_is_integer("stock_uom", "qty") | ||||
| 		self.validate_valid_till() | ||||
| 		self.set_customer_name() | ||||
| @ -50,21 +49,20 @@ class Quotation(SellingController): | ||||
| 			lead_name, company_name = frappe.db.get_value("Lead", self.party_name, ["lead_name", "company_name"]) | ||||
| 			self.customer_name = company_name or lead_name | ||||
| 
 | ||||
| 	def update_opportunity(self): | ||||
| 	def update_opportunity(self, status): | ||||
| 		for opportunity in list(set([d.prevdoc_docname for d in self.get("items")])): | ||||
| 			if opportunity: | ||||
| 				self.update_opportunity_status(opportunity) | ||||
| 				self.update_opportunity_status(status, opportunity) | ||||
| 
 | ||||
| 		if self.opportunity: | ||||
| 			self.update_opportunity_status() | ||||
| 			self.update_opportunity_status(status) | ||||
| 
 | ||||
| 	def update_opportunity_status(self, opportunity=None): | ||||
| 	def update_opportunity_status(self, status, opportunity=None): | ||||
| 		if not opportunity: | ||||
| 			opportunity = self.opportunity | ||||
| 
 | ||||
| 		opp = frappe.get_doc("Opportunity", opportunity) | ||||
| 		opp.status = None | ||||
| 		opp.set_status(update=True) | ||||
| 		opp.set_status(status=status, update=True) | ||||
| 
 | ||||
| 	def declare_enquiry_lost(self, lost_reasons_list, detailed_reason=None): | ||||
| 		if not self.has_sales_order(): | ||||
| @ -82,7 +80,7 @@ class Quotation(SellingController): | ||||
| 				else: | ||||
| 					frappe.throw(_("Invalid lost reason {0}, please create a new lost reason").format(frappe.bold(reason.get('lost_reason')))) | ||||
| 
 | ||||
| 			self.update_opportunity() | ||||
| 			self.update_opportunity('Lost') | ||||
| 			self.update_lead() | ||||
| 			self.save() | ||||
| 
 | ||||
| @ -95,7 +93,7 @@ class Quotation(SellingController): | ||||
| 			self.company, self.base_grand_total, self) | ||||
| 
 | ||||
| 		#update enquiry status | ||||
| 		self.update_opportunity() | ||||
| 		self.update_opportunity('Quotation') | ||||
| 		self.update_lead() | ||||
| 
 | ||||
| 	def on_cancel(self): | ||||
| @ -105,7 +103,7 @@ class Quotation(SellingController): | ||||
| 
 | ||||
| 		#update enquiry status | ||||
| 		self.set_status(update=True) | ||||
| 		self.update_opportunity() | ||||
| 		self.update_opportunity('Open') | ||||
| 		self.update_lead() | ||||
| 
 | ||||
| 	def print_other_charges(self,docname): | ||||
|  | ||||
| @ -158,7 +158,6 @@ class SalesOrder(SellingController): | ||||
| 					frappe.throw(_("Quotation {0} is cancelled").format(quotation)) | ||||
| 
 | ||||
| 				doc.set_status(update=True) | ||||
| 				doc.update_opportunity() | ||||
| 
 | ||||
| 	def validate_drop_ship(self): | ||||
| 		for d in self.get('items'): | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user