Adapt hr_holidays post wiz to new field
This commit is contained in:
@@ -21,7 +21,7 @@
|
|||||||
'security/holiday_security.xml',
|
'security/holiday_security.xml',
|
||||||
'security/ir.model.access.csv',
|
'security/ir.model.access.csv',
|
||||||
'wizard/hr_holidays_mass_allocation_view.xml',
|
'wizard/hr_holidays_mass_allocation_view.xml',
|
||||||
'wizard/hr_holidays_post_view.xml',
|
'wizard/hr_holidays_to_payslip_view.xml',
|
||||||
],
|
],
|
||||||
'installable': True,
|
'installable': True,
|
||||||
}
|
}
|
||||||
|
|||||||
22
hr_holidays_usability/base_config_settings_view.xml
Normal file
22
hr_holidays_usability/base_config_settings_view.xml
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
© 2015-2017 Akretion (http://www.akretion.com)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
-->
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="view_general_configuration" model="ir.ui.view">
|
||||||
|
<field name="name">hr_holidays_usability.base.config.settings.form</field>
|
||||||
|
<field name="model">base.config.settings</field>
|
||||||
|
<field name="inherit_id" ref="base_setup.view_general_configuration"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<group name="report" position="after">
|
||||||
|
<group string="Leaves" name="holidays">
|
||||||
|
<field name="mass_allocation_default_holiday_status_id"/>
|
||||||
|
</group>
|
||||||
|
</group>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
||||||
@@ -163,6 +163,21 @@ class HrHolidays(models.Model):
|
|||||||
holi.current_leaves_taken = current_leaves_taken
|
holi.current_leaves_taken = current_leaves_taken
|
||||||
holi.current_remaining_leaves = current_remaining_leaves
|
holi.current_remaining_leaves = current_remaining_leaves
|
||||||
|
|
||||||
|
@api.depends('payslip_date')
|
||||||
|
def _compute_payslip_status(self):
|
||||||
|
for holi in self:
|
||||||
|
if holi.payslip_date:
|
||||||
|
holi.payslip_status = True
|
||||||
|
else:
|
||||||
|
holi.payslip_status = False
|
||||||
|
|
||||||
|
def _set_payslip_status(self):
|
||||||
|
for holi in self:
|
||||||
|
if holi.payslip_status:
|
||||||
|
holi.payslip_date = fields.Date.context_today(self)
|
||||||
|
else:
|
||||||
|
holi.payslip_date = False
|
||||||
|
|
||||||
vacation_date_from = fields.Date(
|
vacation_date_from = fields.Date(
|
||||||
string='First Day of Vacation', track_visibility='onchange',
|
string='First Day of Vacation', track_visibility='onchange',
|
||||||
readonly=True, states={
|
readonly=True, states={
|
||||||
@@ -209,8 +224,17 @@ class HrHolidays(models.Model):
|
|||||||
limit = fields.Boolean( # pose des pbs de droits
|
limit = fields.Boolean( # pose des pbs de droits
|
||||||
related='holiday_status_id.limit', string='Allow to Override Limit',
|
related='holiday_status_id.limit', string='Allow to Override Limit',
|
||||||
readonly=True)
|
readonly=True)
|
||||||
posted_date = fields.Date(
|
payslip_date = fields.Date(
|
||||||
string='Posted Date', track_visibility='onchange')
|
string='Transfer to Payslip Date', track_visibility='onchange',
|
||||||
|
readonly=True)
|
||||||
|
# even with the new boolean field "payslip_status", I want to keep
|
||||||
|
# the "posted_date" (renamed payslip_date) field, because I want structured
|
||||||
|
# info. The main argument is that, if I don't write down the info at the end
|
||||||
|
# of the wizard "Post Leave Requests", I want to easily
|
||||||
|
# re-display the info
|
||||||
|
payslip_status = fields.Boolean(
|
||||||
|
readonly=True, compute='_compute_payslip_status',
|
||||||
|
inverse='_set_payslip_status', store=True, track_visibility='onchange')
|
||||||
number_of_days_temp = fields.Float(string="Number of days")
|
number_of_days_temp = fields.Float(string="Number of days")
|
||||||
# The 'name' field is displayed publicly in the calendar
|
# The 'name' field is displayed publicly in the calendar
|
||||||
# So the label should not be 'Description' but 'Public Title'
|
# So the label should not be 'Description' but 'Public Title'
|
||||||
|
|||||||
@@ -59,8 +59,8 @@ hr_holidays.edit_holiday_new is used for both leaves and allocation -->
|
|||||||
</group>
|
</group>
|
||||||
</group>
|
</group>
|
||||||
</field>
|
</field>
|
||||||
<field name="department_id" position="after">
|
<field name="payslip_status" position="after">
|
||||||
<field name="posted_date" groups="hr_holidays.group_hr_holidays_manager"/>
|
<field name="payslip_date"/>
|
||||||
<field name="company_id" groups="base.group_multi_company"/>
|
<field name="company_id" groups="base.group_multi_company"/>
|
||||||
</field>
|
</field>
|
||||||
</field>
|
</field>
|
||||||
@@ -85,10 +85,10 @@ hr_holidays.edit_holiday_new is used for both leaves and allocation -->
|
|||||||
<field name="vacation_date_to"/>
|
<field name="vacation_date_to"/>
|
||||||
<field name="vacation_time_to"/>
|
<field name="vacation_time_to"/>
|
||||||
</field>
|
</field>
|
||||||
<field name="holiday_status_id" position="after">
|
<button name="toggle_payslip_status" position="after">
|
||||||
<field name="posted_date" groups="hr_holidays.group_hr_holidays_manager"/>
|
<field name="payslip_date"/>
|
||||||
<field name="company_id" groups="base.group_multi_company"/>
|
<field name="company_id" groups="base.group_multi_company"/>
|
||||||
</field>
|
</button>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
@@ -122,8 +122,11 @@ hr_holidays.edit_holiday_new is used for both leaves and allocation -->
|
|||||||
<field name="model">hr.holidays</field>
|
<field name="model">hr.holidays</field>
|
||||||
<field name="inherit_id" ref="hr_holidays.view_hr_holidays_filter"/>
|
<field name="inherit_id" ref="hr_holidays.view_hr_holidays_filter"/>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<filter name="validated" position="after">
|
<filter name="gray" position="after">
|
||||||
<filter name="posted" string="Posted" domain="[('posted_date', '!=', False)]"/>
|
<filter string="Reported in Payslip" name="green" domain="[('payslip_status', '=', True)]" groups="hr_holidays.group_hr_holidays_manager"/>
|
||||||
|
</filter>
|
||||||
|
<filter name="group_type" position="after">
|
||||||
|
<filter name="group_payslip_date" string="Transfer to Payslip Date" context="{'group_by': 'payslip_date:day'}"/>
|
||||||
</filter>
|
</filter>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|||||||
@@ -17,9 +17,9 @@ class HrHolidaysEmployeeCounter(models.Model):
|
|||||||
holiday_status_id = fields.Many2one(
|
holiday_status_id = fields.Many2one(
|
||||||
"hr.holidays.status", string="Leave Type")
|
"hr.holidays.status", string="Leave Type")
|
||||||
leaves_validated_current = fields.Float(string='Current Leaves Validated')
|
leaves_validated_current = fields.Float(string='Current Leaves Validated')
|
||||||
leaves_validated_posted = fields.Float(string='Leaves Posted')
|
leaves_validated_payslip = fields.Float(string='Leaves in Payslip')
|
||||||
leaves_remaining_current = fields.Float(string='Current Remaining Leaves')
|
leaves_remaining_current = fields.Float(string='Current Remaining Leaves')
|
||||||
leaves_remaining_posted = fields.Float(string='Posted Remaining Leaves')
|
leaves_remaining_payslip = fields.Float(string='Remaining Leaves in Payslip')
|
||||||
allocated_leaves = fields.Float(string='Allocated Leaves')
|
allocated_leaves = fields.Float(string='Allocated Leaves')
|
||||||
|
|
||||||
@api.model_cr
|
@api.model_cr
|
||||||
@@ -38,18 +38,18 @@ class HrHolidaysEmployeeCounter(models.Model):
|
|||||||
END) AS leaves_validated_current,
|
END) AS leaves_validated_current,
|
||||||
sum(
|
sum(
|
||||||
CASE WHEN hh.type='remove'
|
CASE WHEN hh.type='remove'
|
||||||
AND hh.posted_date IS NOT null
|
AND hh.payslip_date IS NOT null
|
||||||
THEN hh.number_of_days * -1
|
THEN hh.number_of_days * -1
|
||||||
ELSE 0
|
ELSE 0
|
||||||
END) AS leaves_validated_posted,
|
END) AS leaves_validated_payslip,
|
||||||
sum(hh.number_of_days) AS leaves_remaining_current,
|
sum(hh.number_of_days) AS leaves_remaining_current,
|
||||||
sum(
|
sum(
|
||||||
CASE WHEN (
|
CASE WHEN (
|
||||||
hh.type='remove' AND hh.posted_date IS NOT null)
|
hh.type='remove' AND hh.payslip_date IS NOT null)
|
||||||
OR hh.type='add'
|
OR hh.type='add'
|
||||||
THEN hh.number_of_days
|
THEN hh.number_of_days
|
||||||
ELSE 0
|
ELSE 0
|
||||||
END) as leaves_remaining_posted,
|
END) as leaves_remaining_payslip,
|
||||||
sum(
|
sum(
|
||||||
CASE WHEN hh.type = 'add'
|
CASE WHEN hh.type = 'add'
|
||||||
THEN hh.number_of_days
|
THEN hh.number_of_days
|
||||||
|
|||||||
@@ -11,10 +11,9 @@
|
|||||||
<field name="holiday_status_id"/>
|
<field name="holiday_status_id"/>
|
||||||
<field name="allocated_leaves"/>
|
<field name="allocated_leaves"/>
|
||||||
<field name="leaves_validated_current"/>
|
<field name="leaves_validated_current"/>
|
||||||
<field name="leaves_validated_posted"/>
|
<field name="leaves_validated_payslip"/>
|
||||||
<field name="leaves_remaining_current"/>
|
<field name="leaves_remaining_current"/>
|
||||||
<field name="leaves_remaining_posted"
|
<field name="leaves_remaining_payslip" sum="Total"/>
|
||||||
sum="Total Posted Remaining Leaves"/>
|
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
<!--
|
<!--
|
||||||
Employee : only see his holidays
|
Employee : only see his holidays
|
||||||
Officer = the manager of some employees : see his holidays and the ones of his subordinates
|
Officer = the manager of some employees : see his holidays and the ones of his subordinates
|
||||||
Manager = person that administrates the holidays process : can see everything, do mass allocation, post holidays, etc...
|
Manager = person that administrates the holidays process : can see everything, do mass allocation, transfer to payslip, etc...
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<record id="hr_holidays_counter_personal_rule" model="ir.rule">
|
<record id="hr_holidays_counter_personal_rule" model="ir.rule">
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
# -*- encoding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
from . import hr_holidays_mass_allocation
|
from . import hr_holidays_mass_allocation
|
||||||
from . import hr_holidays_post
|
from . import hr_holidays_to_payslip
|
||||||
|
|||||||
@@ -7,9 +7,9 @@ from odoo import models, fields, api, _
|
|||||||
from odoo.exceptions import UserError
|
from odoo.exceptions import UserError
|
||||||
|
|
||||||
|
|
||||||
class HrHolidaysPost(models.TransientModel):
|
class HrHolidaysToPayslip(models.TransientModel):
|
||||||
_name = 'hr.holidays.post'
|
_name = 'hr.holidays.to.payslip'
|
||||||
_description = 'Wizard for post holidays'
|
_description = 'Wizard for transfer holidays to payslip'
|
||||||
|
|
||||||
before_date = fields.Date(
|
before_date = fields.Date(
|
||||||
string='Select Leave Requests That Ended Before', required=True,
|
string='Select Leave Requests That Ended Before', required=True,
|
||||||
@@ -17,13 +17,13 @@ class HrHolidaysPost(models.TransientModel):
|
|||||||
help="The wizard will select the validated holidays "
|
help="The wizard will select the validated holidays "
|
||||||
"that ended before that date (including holidays that "
|
"that ended before that date (including holidays that "
|
||||||
"ended on that date).")
|
"ended on that date).")
|
||||||
holidays_to_post_ids = fields.Many2many(
|
holidays_to_payslip_ids = fields.Many2many(
|
||||||
'hr.holidays', string='Leave Requests to Post',
|
'hr.holidays', string='Leave Requests to Transfer to Payslip',
|
||||||
domain=[
|
domain=[
|
||||||
('type', '=', 'remove'),
|
('type', '=', 'remove'),
|
||||||
('holiday_type', '=', 'employee'),
|
('holiday_type', '=', 'employee'),
|
||||||
('state', '=', 'validate'),
|
('state', '=', 'validate'),
|
||||||
('posted_date', '=', False),
|
('payslip_date', '=', False),
|
||||||
])
|
])
|
||||||
state = fields.Selection([
|
state = fields.Selection([
|
||||||
('draft', 'Draft'),
|
('draft', 'Draft'),
|
||||||
@@ -37,35 +37,35 @@ class HrHolidaysPost(models.TransientModel):
|
|||||||
('type', '=', 'remove'),
|
('type', '=', 'remove'),
|
||||||
('holiday_type', '=', 'employee'),
|
('holiday_type', '=', 'employee'),
|
||||||
('state', '=', 'validate'),
|
('state', '=', 'validate'),
|
||||||
('posted_date', '=', False),
|
('payslip_date', '=', False),
|
||||||
('vacation_date_to', '<=', self.before_date),
|
('vacation_date_to', '<=', self.before_date),
|
||||||
('company_id', '=', self.env.user.company_id.id),
|
('company_id', '=', self.env.user.company_id.id),
|
||||||
])
|
])
|
||||||
self.write({
|
self.write({
|
||||||
'state': 'done',
|
'state': 'done',
|
||||||
'holidays_to_post_ids': [(6, 0, hols.ids)],
|
'holidays_to_payslip_ids': [(6, 0, hols.ids)],
|
||||||
})
|
})
|
||||||
action = self.env['ir.actions.act_window'].for_xml_id(
|
action = self.env['ir.actions.act_window'].for_xml_id(
|
||||||
'hr_holidays_usability', 'hr_holidays_post_action')
|
'hr_holidays_usability', 'hr_holidays_to_payslip_action')
|
||||||
action['res_id'] = self.id
|
action['res_id'] = self.id
|
||||||
return action
|
return action
|
||||||
|
|
||||||
@api.multi
|
@api.multi
|
||||||
def run(self):
|
def run(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
# I have to make a copy of self.holidays_to_post_ids in a variable
|
# I have to make a copy of self.holidays_to_payslip_ids in a variable
|
||||||
# because, after the write, it doesn't have a value any more !!!
|
# because, after the write, it doesn't have a value any more !!!
|
||||||
holidays_to_post = self.holidays_to_post_ids
|
holidays_to_payslip = self.holidays_to_payslip_ids
|
||||||
today = fields.Date.context_today(self)
|
today = fields.Date.context_today(self)
|
||||||
if not self.holidays_to_post_ids:
|
if not self.holidays_to_payslip_ids:
|
||||||
raise UserError(_('No leave request to post.'))
|
raise UserError(_('No leave request to transfer to payslip.'))
|
||||||
self.holidays_to_post_ids.write({'posted_date': today})
|
self.holidays_to_payslip_ids.write({'payslip_date': today})
|
||||||
view_id = self.env.ref('hr_holidays_usability.hr_holiday_pivot').id
|
view_id = self.env.ref('hr_holidays_usability.hr_holiday_pivot').id
|
||||||
action = {
|
action = {
|
||||||
'name': _('Leave Requests'),
|
'name': _('Leave Requests'),
|
||||||
'res_model': 'hr.holidays',
|
'res_model': 'hr.holidays',
|
||||||
'type': 'ir.actions.act_window',
|
'type': 'ir.actions.act_window',
|
||||||
'domain': [('id', 'in', holidays_to_post.ids)],
|
'domain': [('id', 'in', holidays_to_payslip.ids)],
|
||||||
'view_mode': 'pivot',
|
'view_mode': 'pivot',
|
||||||
'view_id': view_id,
|
'view_id': view_id,
|
||||||
}
|
}
|
||||||
@@ -7,22 +7,22 @@
|
|||||||
|
|
||||||
<odoo>
|
<odoo>
|
||||||
|
|
||||||
<record id="hr_holidays_post_form" model="ir.ui.view">
|
<record id="hr_holidays_to_payslip_form" model="ir.ui.view">
|
||||||
<field name="name">hr_holidays_post_form</field>
|
<field name="name">hr_holidays_to_payslip_form</field>
|
||||||
<field name="model">hr.holidays.post</field>
|
<field name="model">hr.holidays.to.payslip</field>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<form string="Post Leaves">
|
<form string="Transfer Leaves to Payslip">
|
||||||
<group name="main" string="Leave Requests to Post">
|
<group name="main" string="Leave Requests to Transfer to Payslip">
|
||||||
<field name="state" invisible="1"/>
|
<field name="state" invisible="1"/>
|
||||||
<field name="before_date" states="draft"/>
|
<field name="before_date" states="draft"/>
|
||||||
<field name="holidays_to_post_ids" nolabel="1" colspan="2"
|
<field name="holidays_to_payslip_ids" nolabel="1" colspan="2"
|
||||||
context="{'tree_view_ref': 'hr_holidays.view_holiday'}"
|
context="{'tree_view_ref': 'hr_holidays.view_holiday'}"
|
||||||
states="done"/>
|
states="done"/>
|
||||||
</group>
|
</group>
|
||||||
<footer>
|
<footer>
|
||||||
<button name="select_date" type="object" string="Get Holiday Requests"
|
<button name="select_date" type="object" string="Get Holiday Requests"
|
||||||
class="oe_highlight" states="draft"/>
|
class="oe_highlight" states="draft"/>
|
||||||
<button name="run" type="object" string="Post"
|
<button name="run" type="object" string="Transfer to Payslip"
|
||||||
class="oe_highlight" states="done"/>
|
class="oe_highlight" states="done"/>
|
||||||
<button special="cancel" string="Cancel" class="oe_link"/>
|
<button special="cancel" string="Cancel" class="oe_link"/>
|
||||||
</footer>
|
</footer>
|
||||||
@@ -30,15 +30,15 @@
|
|||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record id="hr_holidays_post_action" model="ir.actions.act_window">
|
<record id="hr_holidays_to_payslip_action" model="ir.actions.act_window">
|
||||||
<field name="name">Post Leave Requests</field>
|
<field name="name">Transfer to Payslip</field>
|
||||||
<field name="res_model">hr.holidays.post</field>
|
<field name="res_model">hr.holidays.to.payslip</field>
|
||||||
<field name="view_mode">form</field>
|
<field name="view_mode">form</field>
|
||||||
<field name="target">new</field>
|
<field name="target">new</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<menuitem id="hr_holidays_post_menu"
|
<menuitem id="hr_holidays_to_payslip_menu"
|
||||||
action="hr_holidays_post_action"
|
action="hr_holidays_to_payslip_action"
|
||||||
parent="hr_holidays_administration_menu"
|
parent="hr_holidays_administration_menu"
|
||||||
groups="hr_holidays.group_hr_holidays_manager"/>
|
groups="hr_holidays.group_hr_holidays_manager"/>
|
||||||
|
|
||||||
Reference in New Issue
Block a user