[WIP]partner_skills:replace radio button by dropdown and allow to check many skills at once
This commit is contained in:
@@ -34,8 +34,8 @@ msgstr ""
|
|||||||
|
|
||||||
#. module: partner_skills
|
#. module: partner_skills
|
||||||
#: model_terms:ir.ui.view,arch_db:partner_skills.partner_skill_line_view_form
|
#: model_terms:ir.ui.view,arch_db:partner_skills.partner_skill_line_view_form
|
||||||
msgid "Add all skills of this type"
|
msgid "Check all boxes"
|
||||||
msgstr "Ajouter toutes les compétences du domaine"
|
msgstr "Cocher toutes les cases"
|
||||||
|
|
||||||
#. module: partner_skills
|
#. module: partner_skills
|
||||||
#: model_terms:ir.ui.view,arch_db:partner_skills.partner_skill_type_view_form
|
#: model_terms:ir.ui.view,arch_db:partner_skills.partner_skill_type_view_form
|
||||||
|
|||||||
@@ -26,6 +26,14 @@ class PartnerSkillLine(models.Model):
|
|||||||
'partner.skill.type',
|
'partner.skill.type',
|
||||||
default=lambda self: self.env['partner.skill.type'].search([], limit=1),
|
default=lambda self: self.env['partner.skill.type'].search([], limit=1),
|
||||||
required=True, ondelete='cascade')
|
required=True, ondelete='cascade')
|
||||||
|
# Form helper to allow multi-selection of skills in the "Select Skills"
|
||||||
|
# dialog. Each picked skill ends up as its own partner.skill.line via
|
||||||
|
# action_save_skill_selection.
|
||||||
|
skill_ids = fields.Many2many(
|
||||||
|
'partner.skill',
|
||||||
|
string="Skills",
|
||||||
|
domain="[('skill_type_id', '=', skill_type_id)]",
|
||||||
|
)
|
||||||
level_progress = fields.Integer(related='skill_level_id.level_progress')
|
level_progress = fields.Integer(related='skill_level_id.level_progress')
|
||||||
color = fields.Integer(related='skill_type_id.color')
|
color = fields.Integer(related='skill_type_id.color')
|
||||||
|
|
||||||
@@ -56,14 +64,21 @@ class PartnerSkillLine(models.Model):
|
|||||||
# type=record.skill_type_id.name,
|
# type=record.skill_type_id.name,
|
||||||
# ))
|
# ))
|
||||||
|
|
||||||
@api.depends('skill_type_id')
|
@api.depends('skill_type_id', 'skill_ids')
|
||||||
def _compute_skill_id(self):
|
def _compute_skill_id(self):
|
||||||
for record in self:
|
for record in self:
|
||||||
if record.skill_type_id:
|
if record.skill_ids:
|
||||||
|
record.skill_id = record.skill_ids[0]
|
||||||
|
elif record.skill_type_id:
|
||||||
record.skill_id = record.skill_type_id.skill_ids[0] if record.skill_type_id.skill_ids else False
|
record.skill_id = record.skill_type_id.skill_ids[0] if record.skill_type_id.skill_ids else False
|
||||||
else:
|
else:
|
||||||
record.skill_id = False
|
record.skill_id = False
|
||||||
|
|
||||||
|
@api.onchange('skill_type_id')
|
||||||
|
def _onchange_skill_type_id_reset_skill_ids(self):
|
||||||
|
for record in self:
|
||||||
|
record.skill_ids = False
|
||||||
|
|
||||||
# Temporarily disabled: references skill_type_id.skill_level_ids which is
|
# Temporarily disabled: references skill_type_id.skill_level_ids which is
|
||||||
# commented out on partner.skill.type while levels are hidden.
|
# commented out on partner.skill.type while levels are hidden.
|
||||||
# @api.depends('skill_id')
|
# @api.depends('skill_id')
|
||||||
@@ -75,18 +90,20 @@ class PartnerSkillLine(models.Model):
|
|||||||
# skill_levels = record.skill_type_id.skill_level_ids
|
# skill_levels = record.skill_type_id.skill_level_ids
|
||||||
# record.skill_level_id = skill_levels.filtered('default_level') or skill_levels[0] if skill_levels else False
|
# record.skill_level_id = skill_levels.filtered('default_level') or skill_levels[0] if skill_levels else False
|
||||||
|
|
||||||
def action_add_all_skills_of_type(self):
|
def action_save_skill_selection(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
if not self.skill_type_id:
|
if not self.skill_type_id:
|
||||||
raise UserError(_("Please select a skill type first."))
|
raise UserError(_("Please select a skill type first."))
|
||||||
|
if not self.skill_ids:
|
||||||
|
raise UserError(_("Please select at least one skill."))
|
||||||
if not isinstance(self.partner_id.id, int):
|
if not isinstance(self.partner_id.id, int):
|
||||||
raise UserError(_("Please save the contact before adding skills in bulk."))
|
raise UserError(_("Please save the contact before adding skills."))
|
||||||
existing_skills = self.partner_id.partner_skill_ids.filtered(
|
existing_skills = self.partner_id.partner_skill_ids.filtered(
|
||||||
lambda l: l.skill_type_id == self.skill_type_id
|
lambda l: l.skill_type_id == self.skill_type_id
|
||||||
).skill_id
|
).skill_id
|
||||||
skills_to_add = self.skill_type_id.skill_ids - existing_skills
|
skills_to_add = self.skill_ids - existing_skills
|
||||||
if skills_to_add:
|
if skills_to_add:
|
||||||
self.create([{
|
self.env['partner.skill.line'].create([{
|
||||||
'partner_id': self.partner_id.id,
|
'partner_id': self.partner_id.id,
|
||||||
'skill_type_id': self.skill_type_id.id,
|
'skill_type_id': self.skill_type_id.id,
|
||||||
'skill_id': skill.id,
|
'skill_id': skill.id,
|
||||||
@@ -96,6 +113,12 @@ class PartnerSkillLine(models.Model):
|
|||||||
'tag': 'soft_reload',
|
'tag': 'soft_reload',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def action_check_all_skills(self):
|
||||||
|
self.ensure_one()
|
||||||
|
if not self.skill_type_id:
|
||||||
|
raise UserError(_("Please select a skill type first."))
|
||||||
|
self.skill_ids = self.skill_type_id.skill_ids
|
||||||
|
|
||||||
@api.depends('skill_id', 'skill_level_id')
|
@api.depends('skill_id', 'skill_level_id')
|
||||||
def _compute_display_name(self):
|
def _compute_display_name(self):
|
||||||
for record in self:
|
for record in self:
|
||||||
|
|||||||
@@ -145,19 +145,20 @@
|
|||||||
<group>
|
<group>
|
||||||
<group>
|
<group>
|
||||||
<field name="partner_id" invisible="1"/>
|
<field name="partner_id" invisible="1"/>
|
||||||
<field name="skill_type_id" widget="radio"/>
|
<field name="skill_type_id" options="{'no_open': True, 'no_create': True}"/>
|
||||||
</group>
|
</group>
|
||||||
<group>
|
<group>
|
||||||
<div class="text-end mb-2" invisible="not skill_type_id">
|
<field name="skill_id" invisible="1"/>
|
||||||
<button name="action_add_all_skills_of_type"
|
<field name="skill_ids"
|
||||||
type="object"
|
widget="many2many_checkboxes"
|
||||||
string="Add all skills of this type"
|
|
||||||
class="btn btn-link btn-sm p-0"/>
|
|
||||||
</div>
|
|
||||||
<field name="skill_id" options="{'no_open': True, 'no_create': True}"
|
|
||||||
context="{'default_skill_type_id': skill_type_id}"
|
|
||||||
domain="[('skill_type_id', '=', skill_type_id)]"
|
domain="[('skill_type_id', '=', skill_type_id)]"
|
||||||
invisible="not skill_type_id"/>
|
invisible="not skill_type_id"/>
|
||||||
|
<div class="text-end mb-2" invisible="not skill_type_id">
|
||||||
|
<button name="action_check_all_skills"
|
||||||
|
type="object"
|
||||||
|
string="Check all boxes"
|
||||||
|
class="btn btn-link btn-sm p-0"/>
|
||||||
|
</div>
|
||||||
<!-- SKILL LEVEL BLOCK (hidden for now)
|
<!-- SKILL LEVEL BLOCK (hidden for now)
|
||||||
<label for="skill_level_id"
|
<label for="skill_level_id"
|
||||||
invisible="not (skill_id or skill_type_id)"/>
|
invisible="not (skill_id or skill_type_id)"/>
|
||||||
@@ -177,7 +178,11 @@
|
|||||||
</group>
|
</group>
|
||||||
</sheet>
|
</sheet>
|
||||||
<footer>
|
<footer>
|
||||||
<button string="Save" special="save" class="btn-primary" data-hotkey="q"/>
|
<button string="Save"
|
||||||
|
name="action_save_skill_selection"
|
||||||
|
type="object"
|
||||||
|
class="btn-primary"
|
||||||
|
data-hotkey="q"/>
|
||||||
<button string="Discard" special="cancel" data-hotkey="x"/>
|
<button string="Discard" special="cancel" data-hotkey="x"/>
|
||||||
</footer>
|
</footer>
|
||||||
</form>
|
</form>
|
||||||
|
|||||||
Reference in New Issue
Block a user