# -*- coding: utf-8 -*- # Part of Odoo. See LICENSE file for full copyright and licensing details. from odoo import api, fields, models, tools class HrEmployeePublic(models.Model): _name = "hr.employee.public" _inherit = ["hr.employee.base"] _description = 'Public Employee' _order = 'name' _auto = False _log_access = True # Include magic fields # Fields coming from hr.employee.base create_date = fields.Datetime(readonly=True) name = fields.Char(readonly=True) active = fields.Boolean(readonly=True) department_id = fields.Many2one(readonly=True) job_id = fields.Many2one(readonly=True) job_title = fields.Char(readonly=True) company_id = fields.Many2one(readonly=True) address_id = fields.Many2one(readonly=True) mobile_phone = fields.Char(readonly=True) work_phone = fields.Char(readonly=True) work_email = fields.Char(readonly=True) work_contact_id = fields.Many2one(readonly=True) work_location_id = fields.Many2one(readonly=True) user_id = fields.Many2one(readonly=True) resource_id = fields.Many2one(readonly=True) tz = fields.Selection(readonly=True) color = fields.Integer(readonly=True) # Manager-only fields is_manager = fields.Boolean(compute='_compute_is_manager') employee_id = fields.Many2one('hr.employee', 'Employee', compute="_compute_employee_id", search="_search_employee_id", compute_sudo=True) # hr.employee.public specific fields child_ids = fields.One2many('hr.employee.public', 'parent_id', string='Direct subordinates', readonly=True) image_1920 = fields.Image("Image", related='employee_id.image_1920', compute_sudo=True) image_1024 = fields.Image("Image 1024", related='employee_id.image_1024', compute_sudo=True) image_512 = fields.Image("Image 512", related='employee_id.image_512', compute_sudo=True) image_256 = fields.Image("Image 256", related='employee_id.image_256', compute_sudo=True) image_128 = fields.Image("Image 128", related='employee_id.image_128', compute_sudo=True) avatar_1920 = fields.Image("Avatar", related='employee_id.avatar_1920', compute_sudo=True) avatar_1024 = fields.Image("Avatar 1024", related='employee_id.avatar_1024', compute_sudo=True) avatar_512 = fields.Image("Avatar 512", related='employee_id.avatar_512', compute_sudo=True) avatar_256 = fields.Image("Avatar 256", related='employee_id.avatar_256', compute_sudo=True) avatar_128 = fields.Image("Avatar 128", related='employee_id.avatar_128', compute_sudo=True) parent_id = fields.Many2one('hr.employee.public', 'Manager', readonly=True) coach_id = fields.Many2one('hr.employee.public', 'Coach', readonly=True) user_partner_id = fields.Many2one(related='user_id.partner_id', related_sudo=False, string="User's partner") @api.depends_context('uid') @api.depends('parent_id') def _compute_is_manager(self): all_reports = self.env['hr.employee.public'].search([('id', 'child_of', self.env.user.employee_id.id)]).ids for employee in self: employee.is_manager = employee.id in all_reports def _get_manager_only_fields(self): return [] @api.depends_context('uid') def _compute_manager_only_fields(self): manager_fields = self._get_manager_only_fields() for employee in self: if employee.is_manager: employee_sudo = employee.employee_id.sudo() for f in manager_fields: employee[f] = employee_sudo[f] else: for f in manager_fields: employee[f] = False def _search_employee_id(self, operator, value): return [('id', operator, value)] def _compute_employee_id(self): for employee in self: employee.employee_id = self.env['hr.employee'].browse(employee.id) @api.model def _get_fields(self): return ','.join('emp.%s' % name for name, field in self._fields.items() if field.store and field.type not in ['many2many', 'one2many']) def init(self): tools.drop_view_if_exists(self.env.cr, self._table) self.env.cr.execute("""CREATE or REPLACE VIEW %s as ( SELECT %s FROM hr_employee emp )""" % (self._table, self._get_fields()))