# -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. from odoo import fields, models from odoo.addons.onboarding.models.onboarding_progress import ONBOARDING_PROGRESS_STATES class OnboardingProgressStep(models.Model): _name = 'onboarding.progress.step' _description = 'Onboarding Progress Step Tracker' _rec_name = 'step_id' progress_ids = fields.Many2many('onboarding.progress', string='Related Onboarding Progress Tracker') step_state = fields.Selection( ONBOARDING_PROGRESS_STATES, string='Onboarding Step Progress', default='not_done') step_id = fields.Many2one( 'onboarding.onboarding.step', string='Onboarding Step', required=True, ondelete='cascade') company_id = fields.Many2one('res.company', ondelete='cascade') def init(self): """Make sure there aren't multiple records for the same onboarding step and company.""" # not in _sql_constraint because COALESCE is not supported for PostgreSQL constraint self.env.cr.execute(""" CREATE UNIQUE INDEX IF NOT EXISTS onboarding_progress_step_company_uniq ON onboarding_progress_step (step_id, COALESCE(company_id, 0)) """) def action_consolidate_just_done(self): was_just_done = self.filtered(lambda progress: progress.step_state == 'just_done') was_just_done.step_state = 'done' return was_just_done def action_set_just_done(self): not_done = self.filtered_domain([('step_state', '=', 'not_done')]) not_done.step_state = 'just_done' return not_done