summaryrefslogtreecommitdiff
path: root/addons/hr/models/hr_employee_public.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/hr/models/hr_employee_public.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/hr/models/hr_employee_public.py')
-rw-r--r--addons/hr/models/hr_employee_public.py65
1 files changed, 65 insertions, 0 deletions
diff --git a/addons/hr/models/hr_employee_public.py b/addons/hr/models/hr_employee_public.py
new file mode 100644
index 00000000..6ac8091f
--- /dev/null
+++ b/addons/hr/models/hr_employee_public.py
@@ -0,0 +1,65 @@
+# -*- 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_location = fields.Char(readonly=True)
+ user_id = fields.Many2one(readonly=True)
+ resource_id = fields.Many2one(readonly=True)
+ resource_calendar_id = fields.Many2one(readonly=True)
+ tz = fields.Selection(readonly=True)
+ color = fields.Integer(readonly=True)
+
+ # hr.employee.public specific fields
+ child_ids = fields.One2many('hr.employee.public', 'parent_id', string='Direct subordinates', readonly=True)
+ image_1920 = fields.Image("Original Image", compute='_compute_image', compute_sudo=True)
+ image_1024 = fields.Image("Image 1024", compute='_compute_image', compute_sudo=True)
+ image_512 = fields.Image("Image 512", compute='_compute_image', compute_sudo=True)
+ image_256 = fields.Image("Image 256", compute='_compute_image', compute_sudo=True)
+ image_128 = fields.Image("Image 128", compute='_compute_image', 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")
+
+ def _compute_image(self):
+ for employee in self:
+ # We have to be in sudo to have access to the images
+ employee_id = self.sudo().env['hr.employee'].browse(employee.id)
+ employee.image_1920 = employee_id.image_1920
+ employee.image_1024 = employee_id.image_1024
+ employee.image_512 = employee_id.image_512
+ employee.image_256 = employee_id.image_256
+ employee.image_128 = employee_id.image_128
+
+ @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()))