# -*- coding: utf-8 -*- # © 2016 Akretion (http://www.akretion.com) # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # @author Alexis de Lattre from openerp import models, fields, api, _, workflow from openerp.exceptions import Warning as UserError class SaleOrder(models.Model): _inherit = 'sale.order' lead_id = fields.Many2one( 'crm.lead', string='Opportunity') @api.multi def action_button_confirm(self): res = super(SaleOrder, self).action_button_confirm() won_stage = self.env.ref('crm.stage_lead6') for order in self: if order.lead_id: order.lead_id.stage_id = won_stage order.lead_id.message_post(_( "Stage automatically updated to Won upon " "confirmation of the quotation %s" % order.name)) return res class CrmLead(models.Model): _inherit = 'crm.lead' sale_ids = fields.One2many( 'sale.order', 'lead_id', string='Quotations', readonly=True) @api.multi def view_sale_orders(self): self.ensure_one() if self.sale_ids: action = { 'name': _('Quotations'), 'type': 'ir.actions.act_window', 'res_model': 'sale.order', 'target': 'current', 'context': "{'default_partner_id': %s, 'default_lead_id': %s}" % ( self.partner_id.id or False, self[0].id), } if len(self.sale_ids) == 1: action.update({ 'view_mode': 'form,tree,calendar,graph', 'res_id': self.sale_ids[0].id, }) else: action.update({ 'view_mode': 'tree,form,calendar,graph', 'domain': "[('id', 'in', %s)]" % self.sale_ids.ids, }) return action else: raise UserError(_( 'There are no quotations linked to this opportunity')) @api.model def create(self, vals): if vals is None: vals = {} if self._context.get('usability_default_stage_xmlid'): stage = self.env.ref(self._context['usability_default_stage_xmlid']) vals['stage_id'] = stage.id return super(CrmLead, self).create(vals) @api.multi def case_mark_lost(self): """When opportunity is marked as lost, cancel the related quotations I don't inherit the write but the button, because it leaves a waty to mask lead as lost and not cancel the quotations """ res = super(CrmLead, self).case_mark_lost() sales = self.env['sale.order'].search([ ('lead_id', 'in', self.ids), ('state', 'in', ('draft', 'sent'))]) for so in sales: workflow.trg_validate( self._uid, 'sale.order', so.id, 'cancel', self._cr) so.message_post(_( 'The related opportunity has been marked as lost, ' 'therefore this quotation has been automatically cancelled.')) return res