[ADD]partner_skills
This commit is contained in:
39
partner_skills/models/partner_skill_level.py
Normal file
39
partner_skills/models/partner_skill_level.py
Normal file
@@ -0,0 +1,39 @@
|
||||
from odoo import api, fields, models
|
||||
|
||||
|
||||
class PartnerSkillLevel(models.Model):
|
||||
_name = 'partner.skill.level'
|
||||
_description = "Partner Skill Level"
|
||||
_order = "sequence, level_progress desc"
|
||||
|
||||
sequence = fields.Integer(default=10)
|
||||
skill_type_id = fields.Many2one('partner.skill.type', ondelete='cascade')
|
||||
name = fields.Char(required=True)
|
||||
level_progress = fields.Integer(string="Progress", help="Progress from zero knowledge (0%) to fully mastered (100%).")
|
||||
default_level = fields.Boolean(help="If checked, this level will be the default one selected when choosing this skill.")
|
||||
|
||||
_sql_constraints = [
|
||||
('check_level_progress', 'CHECK(level_progress BETWEEN 0 AND 100)', "Progress should be a number between 0 and 100."),
|
||||
]
|
||||
|
||||
@api.depends('level_progress')
|
||||
@api.depends_context('from_skill_level_dropdown')
|
||||
def _compute_display_name(self):
|
||||
if not self._context.get('from_skill_level_dropdown'):
|
||||
return super()._compute_display_name()
|
||||
for record in self:
|
||||
record.display_name = f"{record.name} ({record.level_progress}%)"
|
||||
|
||||
@api.model_create_multi
|
||||
def create(self, vals_list):
|
||||
skill_levels = super().create(vals_list)
|
||||
for level in skill_levels:
|
||||
if level.default_level:
|
||||
level.skill_type_id.skill_level_ids.filtered(lambda r: r.id != level.id).default_level = False
|
||||
return skill_levels
|
||||
|
||||
def write(self, vals):
|
||||
res = super().write(vals)
|
||||
if vals.get('default_level'):
|
||||
self.skill_type_id.skill_level_ids.filtered(lambda r: r.id != self.id).default_level = False
|
||||
return res
|
||||
Reference in New Issue
Block a user