123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- # -*- coding:utf-8 -*-
- # Part of Odoo. See LICENSE file for full copyright and licensing details.
- from datetime import datetime
- from odoo import fields, models
- from odoo.osv.expression import AND
- class ResourceCalendar(models.Model):
- _inherit = 'resource.calendar'
- contracts_count = fields.Integer("# Contracts using it", compute='_compute_contracts_count', groups="hr_contract.group_hr_contract_manager")
- def transfer_leaves_to(self, other_calendar, resources=None, from_date=None):
- """
- Transfer some resource.calendar.leaves from 'self' to another calendar 'other_calendar'.
- Transfered leaves linked to `resources` (or all if `resources` is None) and starting
- after 'from_date' (or today if None).
- """
- from_date = from_date or fields.Datetime.now().replace(hour=0, minute=0, second=0, microsecond=0)
- domain = [
- ('calendar_id', 'in', self.ids),
- ('date_from', '>=', from_date),
- ]
- domain = AND([domain, [('resource_id', 'in', resources.ids)]]) if resources else domain
- self.env['resource.calendar.leaves'].search(domain).write({
- 'calendar_id': other_calendar.id,
- })
- def _compute_contracts_count(self):
- count_data = self.env['hr.contract']._read_group(
- [('resource_calendar_id', 'in', self.ids)],
- ['resource_calendar_id'],
- ['resource_calendar_id'])
- mapped_counts = {cd['resource_calendar_id'][0]: cd['resource_calendar_id_count'] for cd in count_data}
- for calendar in self:
- calendar.contracts_count = mapped_counts.get(calendar.id, 0)
- def action_open_contracts(self):
- self.ensure_one()
- action = self.env["ir.actions.actions"]._for_xml_id("hr_contract.action_hr_contract")
- action.update({'domain': [('resource_calendar_id', '=', self.id)]})
- return action
|