onboarding/models/onboarding_progress_step.py

38 lines
1.6 KiB
Python
Raw Permalink Normal View History

2024-05-03 12:58:20 +03:00
# -*- 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