diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/hr_skills/models/hr_skills.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/hr_skills/models/hr_skills.py')
| -rw-r--r-- | addons/hr_skills/models/hr_skills.py | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/addons/hr_skills/models/hr_skills.py b/addons/hr_skills/models/hr_skills.py new file mode 100644 index 00000000..759607a8 --- /dev/null +++ b/addons/hr_skills/models/hr_skills.py @@ -0,0 +1,61 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import api, fields, models, _ +from odoo.exceptions import ValidationError + + +class Skill(models.Model): + _name = 'hr.skill' + _description = "Skill" + + name = fields.Char(required=True) + skill_type_id = fields.Many2one('hr.skill.type', ondelete='cascade') + + +class EmployeeSkill(models.Model): + _name = 'hr.employee.skill' + _description = "Skill level for an employee" + _rec_name = 'skill_id' + _order = "skill_level_id" + + employee_id = fields.Many2one('hr.employee', required=True, ondelete='cascade') + skill_id = fields.Many2one('hr.skill', required=True) + skill_level_id = fields.Many2one('hr.skill.level', required=True) + skill_type_id = fields.Many2one('hr.skill.type', required=True) + level_progress = fields.Integer(related='skill_level_id.level_progress') + + _sql_constraints = [ + ('_unique_skill', 'unique (employee_id, skill_id)', "Two levels for the same skill is not allowed"), + ] + + @api.constrains('skill_id', 'skill_type_id') + def _check_skill_type(self): + for record in self: + if record.skill_id not in record.skill_type_id.skill_ids: + raise ValidationError(_("The skill %(name)s and skill type %(type)s doesn't match", name=record.skill_id.name, type=record.skill_type_id.name)) + + @api.constrains('skill_type_id', 'skill_level_id') + def _check_skill_level(self): + for record in self: + if record.skill_level_id not in record.skill_type_id.skill_level_ids: + raise ValidationError(_("The skill level %(level)s is not valid for skill type: %(type)s", level=record.skill_level_id.name, type=record.skill_type_id.name)) + + +class SkillLevel(models.Model): + _name = 'hr.skill.level' + _description = "Skill Level" + _order = "level_progress desc" + + skill_type_id = fields.Many2one('hr.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%).") + + +class SkillType(models.Model): + _name = 'hr.skill.type' + _description = "Skill Type" + + name = fields.Char(required=True) + skill_ids = fields.One2many('hr.skill', 'skill_type_id', string="Skills") + skill_level_ids = fields.One2many('hr.skill.level', 'skill_type_id', string="Levels") |
