Odoo18-Base/addons/hr_holidays/populate/hr_leave.py
2025-03-10 10:52:11 +07:00

68 lines
2.8 KiB
Python

# -*- coding: utf-8 -*-
# Part of Odoo. See LICENSE file for full copyright and licensing details.
import datetime
from odoo import models
from odoo.tools import populate
from dateutil.relativedelta import relativedelta
from itertools import groupby
class HolidaysType(models.Model):
_inherit = "hr.leave.type"
_populate_sizes = {"small": 10, "medium": 30, "large": 100}
_populate_dependencies = ['res.company']
def _populate_factories(self):
company_ids = self.env.registry.populated_models['res.company']
return [
('name', populate.constant('leave_type_{counter}')),
('company_id', populate.randomize(company_ids)),
('requires_allocation', populate.randomize(['yes', 'no'], [0.3, 0.7])),
('employee_requests', populate.randomize(['yes', 'no'], [0.2, 0.8])),
('request_unit', populate.randomize(['hour', 'day'], [0.2, 0.8])),
]
class HolidaysRequest(models.Model):
_inherit = "hr.leave"
_populate_sizes = {"small": 100, "medium": 800, "large": 10000}
_populate_dependencies = ['hr.employee', 'hr.leave.type']
def _populate_factories(self):
employee_ids = self.env.registry.populated_models['hr.employee']
hr_leave_type_ids = self.env.registry.populated_models['hr.leave.type']
hr_leave_type_records = self.env['hr.leave.type'].browse(hr_leave_type_ids)
allocationless_leave_type_ids = hr_leave_type_records.filtered(lambda lt: lt.requires_allocation == 'no').ids
employee_records = self.env['hr.employee'].browse(employee_ids)
employee_by_company = {k: list(v) for k, v in groupby(employee_records, key=lambda rec: rec['company_id'].id)}
company_by_type = {rec.id: rec.company_id.id for rec in self.env['hr.leave.type'].browse(hr_leave_type_ids)}
def compute_employee_id(random=None, values=None, **kwargs):
company_id = company_by_type[values['holiday_status_id']]
return random.choice(employee_by_company[company_id]).id
def compute_request_date_from(counter, **kwargs):
return datetime.datetime.today() + relativedelta(days=int(3 * int(counter)))
def compute_request_date_to(counter, random=None, **kwargs):
return datetime.datetime.today() + relativedelta(days=int(3 * int(counter)) + random.randint(0, 2))
return [
('holiday_status_id', populate.randomize(allocationless_leave_type_ids)),
('employee_id', populate.compute(compute_employee_id)),
('holiday_type', populate.constant('employee')),
('request_date_from', populate.compute(compute_request_date_from)),
('request_date_to', populate.compute(compute_request_date_to)),
('state', populate.randomize([
'draft',
'confirm',
])),
]