mirror of
https://github.com/bringout/oca-ocb-hr.git
synced 2026-04-27 16:12:09 +02:00
Initial commit: Hr packages
This commit is contained in:
commit
62531cd146
2820 changed files with 1432848 additions and 0 deletions
|
|
@ -0,0 +1,3 @@
|
|||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from . import hr_employee_skill_report
|
||||
|
|
@ -0,0 +1,40 @@
|
|||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from odoo import fields, models, tools
|
||||
|
||||
class HrEmployeeSkillReport(models.BaseModel):
|
||||
_auto = False
|
||||
_name = 'hr.employee.skill.report'
|
||||
_description = 'Employee Skills Report'
|
||||
_order = 'employee_id, level_progress desc'
|
||||
|
||||
id = fields.Id()
|
||||
display_name = fields.Char(related='employee_id.name')
|
||||
employee_id = fields.Many2one('hr.employee', readonly=True)
|
||||
company_id = fields.Many2one('res.company', readonly=True)
|
||||
department_id = fields.Many2one('hr.department', readonly=True)
|
||||
|
||||
skill_id = fields.Many2one('hr.skill', readonly=True)
|
||||
skill_type_id = fields.Many2one('hr.skill.type', readonly=True)
|
||||
skill_level = fields.Char(readonly=True)
|
||||
level_progress = fields.Float(readonly=True, group_operator='avg')
|
||||
|
||||
def init(self):
|
||||
tools.drop_view_if_exists(self.env.cr, self._table)
|
||||
|
||||
self.env.cr.execute("""
|
||||
CREATE OR REPLACE VIEW %s AS (
|
||||
SELECT
|
||||
row_number() OVER () AS id,
|
||||
e.id AS employee_id,
|
||||
e.company_id AS company_id,
|
||||
e.department_id AS department_id,
|
||||
s.skill_id AS skill_id,
|
||||
s.skill_type_id AS skill_type_id,
|
||||
sl.level_progress / 100.0 AS level_progress,
|
||||
sl.name AS skill_level
|
||||
FROM hr_employee e
|
||||
LEFT OUTER JOIN hr_employee_skill s ON e.id = s.employee_id
|
||||
LEFT OUTER JOIN hr_skill_level sl ON sl.id = s.skill_level_id
|
||||
)
|
||||
""" % (self._table, ))
|
||||
|
|
@ -0,0 +1,66 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<odoo>
|
||||
<record id="hr_employee_skill_report_view_pivot" model="ir.ui.view">
|
||||
<field name="model">hr.employee.skill.report</field>
|
||||
<field name="arch" type="xml">
|
||||
<pivot disable_linking="True">
|
||||
<field name="employee_id" type="row"/>
|
||||
<field name="skill_type_id" type="col"/>
|
||||
<field name="skill_id" type="col"/>
|
||||
<field name="level_progress" type="measure" widget="percentage"/>
|
||||
</pivot>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<record id="hr_employee_skill_report_view_list" model="ir.ui.view">
|
||||
<field name="model">hr.employee.skill.report</field>
|
||||
<field name="arch" type="xml">
|
||||
<tree expand="1">
|
||||
<field name="employee_id"/>
|
||||
<field name="skill_type_id"/>
|
||||
<field name="skill_id"/>
|
||||
<field name="skill_level"/>
|
||||
<field name="level_progress" widget="percentage"/>
|
||||
</tree>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<record id="hr_employee_skill_report_view_search" model="ir.ui.view">
|
||||
<field name="model">hr.employee.skill.report</field>
|
||||
<field name="arch" type="xml">
|
||||
<search>
|
||||
<field name="employee_id"/>
|
||||
<field name="department_id"/>
|
||||
<field name="skill_id"/>
|
||||
<field name="skill_type_id"/>
|
||||
<separator/>
|
||||
<filter string="Employees with Skills" name="employees_with_skills" domain="[('skill_id', '!=', False)]"/>
|
||||
<filter string="Employees without Skills" name="employees_without_skills" domain="[('skill_id', '=', False)]"/>
|
||||
<separator/>
|
||||
<filter string="Employee" name="employee" context="{'group_by': 'employee_id'}"/>
|
||||
<filter string="Department" name="department" context="{'group_by': 'department_id'}"/>
|
||||
<separator/>
|
||||
<filter string="Skill Type" name="skill_type" context="{'group_by': 'skill_type_id'}"/>
|
||||
<filter string="Skill" name="skill" context="{'group_by': 'skill_id'}"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<record id="hr_employee_skill_report_action" model="ir.actions.act_window">
|
||||
<field name="name">Employee Skills</field>
|
||||
<field name="res_model">hr.employee.skill.report</field>
|
||||
<field name="search_view_id" ref="hr_employee_skill_report_view_search"/>
|
||||
<field name="view_mode">tree,pivot</field>
|
||||
<field name="context">{
|
||||
'search_default_employee': 1,
|
||||
'search_default_employees_with_skills': 1,
|
||||
}</field>
|
||||
</record>
|
||||
|
||||
<menuitem
|
||||
id="hr_employee_skill_report_menu"
|
||||
name="Skills"
|
||||
action="hr_employee_skill_report_action"
|
||||
parent="hr.hr_menu_hr_reports"
|
||||
sequence="15"/>
|
||||
</odoo>
|
||||
Loading…
Add table
Add a link
Reference in a new issue