Skip to content
Extraits de code Groupes Projets
Sélectionner une révision Git
  • 829d04f3b792de530d196461f7fd4df07e566673
  • 14.0 par défaut
  • 12.0 protégée
  • 13.0
4 résultats

res_partner.py

Blame
  • scop_deces_wizard.py 1,86 Kio
    # © 2019 Le Filament (<http://www.le-filament.com>)
    # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
    
    from odoo import api, fields, models
    from odoo.exceptions import ValidationError
    
    
    class ScopDecesWizard(models.TransientModel):
        _name = 'scop.deces.wizard'
        _description = "Décés"
    
        # Default functions
        @api.model
        def _default_partner_id(self):
            return self.env.context.get('active_id')
    
        @api.model
        def _default_last_period_id(self):
            return self.env['scop.period'].search(
                [('partner_id', '=', self.env.context.get('active_id')),
                 ('end_reason', '=', False)],
                limit=1).id
    
        # Fields common
        partner_id = fields.Integer('Partner', default=_default_partner_id)
    
        # Fields previous period
        last_period_id = fields.Integer(default=_default_last_period_id)
        end = fields.Date(
            'Fin de validité', required=True, default=fields.Date.today())
        dissolution_reason_id = fields.Many2one(
            'res.partner.dissolution.reason',
            string="Motif Décés",
            on_delete='restrict',
            required=True)
        comments = fields.Text('Commentaires')
    
        @api.multi
        def deces_action(self):
            # Close previous period
            last_period_id = self.env['scop.period'].browse(
                self.last_period_id)
            if last_period_id:
                last_period_id.write({
                    'end': self.end,
                    'end_reason': 'autr',
                    'comments': self.comments,
                })
    
                # Update partner
                partner = self.env['res.partner'].browse(self.partner_id)
                partner.write({
                    'dissolution_date': self.end,
                    'dissolution_reason_id': self.dissolution_reason_id.id
                })
            else:
                raise ValidationError(
                    "Il n'existe pas de période à fermer.")