Add employee wizard to mission
This commit is contained in:
parent
03a0a78fc4
commit
2f4892f18f
|
|
@ -1,3 +1,4 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
from . import models
|
||||
from . import wizard
|
||||
|
|
|
|||
|
|
@ -26,6 +26,7 @@
|
|||
'views/course_view.xml',
|
||||
'views/appraisal_view.xml',
|
||||
'views/training_menus.xml',
|
||||
'wizard/employee_selection_wizard.xml',
|
||||
|
||||
],
|
||||
'installable': True,
|
||||
|
|
|
|||
|
|
@ -2551,7 +2551,7 @@ msgstr "تم التصديق"
|
|||
#: model:ir.model.fields.selection,name:exp_official_mission.selection__hr_official_mission_employee__status__draft
|
||||
#, python-format
|
||||
msgid "Draft"
|
||||
msgstr "مسوده"
|
||||
msgstr "مسودة"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: code:addons/exp_official_mission/models/hr_official_mission.py:0
|
||||
|
|
@ -2579,5 +2579,31 @@ msgstr "مرفوض"
|
|||
msgid "Set to Draft"
|
||||
msgstr "ارجاع الى مسودة"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: model_terms:ir.ui.view,arch_db:exp_official_mission.employee_training_form_view
|
||||
msgid "Add Employees"
|
||||
msgstr "إضافة موظفين"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: model:ir.model.fields,field_description:exp_official_mission.field_employee_mission_selection_wizard__employee_ids
|
||||
msgid "Employees"
|
||||
msgstr "الموظفين"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: model_terms:ir.ui.view,arch_db:exp_official_mission.view_employee_mission_selection_wizard_form
|
||||
msgid "Add"
|
||||
msgstr "إضافه"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: model_terms:ir.ui.view,arch_db:exp_official_mission.view_employee_mission_selection_wizard_form
|
||||
msgid "Cancel"
|
||||
msgstr "إلغاء"
|
||||
|
||||
#. module: exp_official_mission
|
||||
#: code:addons/exp_official_mission/models/hr_official_mission.py:0
|
||||
#, python-format
|
||||
msgid "Add Employees to Mission"
|
||||
msgstr "إضافة موظفين للدورة التدريبية"
|
||||
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -136,6 +136,31 @@ class HrOfficialMission(models.Model):
|
|||
}
|
||||
return res
|
||||
|
||||
def action_add_employees(self):
|
||||
self.ensure_one()
|
||||
ctx = dict(self.env.context)
|
||||
if not self.id:
|
||||
ctx.update({
|
||||
'default_mission_vals': {
|
||||
'name': self.name,
|
||||
}
|
||||
})
|
||||
else:
|
||||
ctx['default_official_mission_id'] = self.id
|
||||
|
||||
# if self.percentage:
|
||||
# ctx['default_percentage'] = self.percentage
|
||||
|
||||
ctx['default_employee_id'] = self.env['hr.employee'].search([('user_id', '=', self.env.uid)], limit=1)
|
||||
|
||||
return {
|
||||
'name': _('Add Employees to Mission'),
|
||||
'view_mode': 'form',
|
||||
'res_model': 'employee.mission.selection.wizard',
|
||||
'type': 'ir.actions.act_window',
|
||||
'target': 'new',
|
||||
'context': ctx,
|
||||
}
|
||||
|
||||
def get_user_id(self):
|
||||
employee_id = self.env['hr.employee'].search([('user_id', '=', self.env.uid)], limit=1)
|
||||
|
|
@ -987,8 +1012,10 @@ class HrOfficialMissionEmployee(models.Model):
|
|||
date_from += delta
|
||||
|
||||
def get_permission_domain(self, date_from, date_to):
|
||||
|
||||
hour_from = (datetime.min + timedelta(hours=self.hour_from) - timedelta(hours=3)).time()
|
||||
hour_to = (datetime.min + timedelta(hours=self.hour_to) - timedelta(hours=3)).time()
|
||||
|
||||
date_from = str(
|
||||
datetime.combine(datetime.strptime(str(date_from), DEFAULT_SERVER_DATETIME_FORMAT).date(), hour_from))
|
||||
date_to = str(datetime.combine(datetime.strptime(str(date_to), DEFAULT_SERVER_DATETIME_FORMAT).date(), hour_to))
|
||||
|
|
|
|||
|
|
@ -10,3 +10,4 @@ access_mission_destination_line_hr,access_mission_destination_line_hr,model_miss
|
|||
access_employee_course_name_emp,access_employee_course_name_emp,model_employee_course_name,base.group_user,1,0,0,0
|
||||
access_employee_course_name_hr,access_employee_course_name_hr,model_employee_course_name,hr.group_hr_user,1,1,1,1
|
||||
access_ticket_class_user,access_ticket_class_user,model_ticket_class,hr.group_hr_user,1,1,1,0
|
||||
access_employee_mission_selection_wizard,employee.mission.selection.wizard,model_employee_mission_selection_wizard,base.group_user,1,1,1,1
|
||||
|
|
|
|||
|
|
|
@ -134,6 +134,8 @@
|
|||
<page string="Employees" name="employees">
|
||||
<field name="related_with_financial" invisible="1"/>
|
||||
<group>
|
||||
<button name="action_add_employees" string=" Add Employees " type="object" class="oe_highlight"
|
||||
icon="fa-cogs"/>
|
||||
<button name="re_compute" string=" Re-Compute " type="object" class="oe_highlight"
|
||||
icon="fa-cogs"
|
||||
attrs="{'invisible':[('state','in',('approve','refused','send'))]}"/>
|
||||
|
|
|
|||
|
|
@ -0,0 +1,9 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
##############################################################################
|
||||
#
|
||||
# LCT, Life Connection Technology
|
||||
# Copyright (C) 2024-2025 LCT
|
||||
#
|
||||
##############################################################################
|
||||
|
||||
from . import employee_selection_wizard
|
||||
|
|
@ -0,0 +1,124 @@
|
|||
from odoo import api, fields, models, _
|
||||
from datetime import datetime, date, timedelta
|
||||
from odoo.exceptions import ValidationError
|
||||
from odoo.tools import DEFAULT_SERVER_DATETIME_FORMAT, DEFAULT_SERVER_DATE_FORMAT
|
||||
|
||||
|
||||
|
||||
class EmployeeMissionSelectionWizard(models.TransientModel):
|
||||
_name = 'employee.mission.selection.wizard'
|
||||
_description = 'Employee Selection Wizard'
|
||||
|
||||
|
||||
employee_ids = fields.Many2many(
|
||||
'hr.employee',
|
||||
string='Employees',
|
||||
required=True,
|
||||
)
|
||||
|
||||
employee_mission_id = fields.Many2one(comodel_name='hr.official.mission',string='Employee Mission')
|
||||
|
||||
|
||||
|
||||
# @api.onchange('employee_ids')
|
||||
# def _onchange_employee_ids(self):
|
||||
# return {
|
||||
# 'domain': {
|
||||
# 'employee_ids': [
|
||||
# ('id', 'not in', self.employee_ids.ids),
|
||||
# ('active', '=', True)
|
||||
# ]
|
||||
# }
|
||||
# }
|
||||
|
||||
def _get_active_employee_mission(self):
|
||||
mission_id = self.env.context.get('default_employee_mission_id')
|
||||
if not mission_id and self.env.context.get('active_model') == 'hr.official.mission':
|
||||
mission_id = self.env.context.get('active_id')
|
||||
return mission_id
|
||||
|
||||
@api.onchange('employee_ids')
|
||||
def _onchange_employee_ids(self):
|
||||
|
||||
mission = self.env['hr.official.mission'].browse(self._get_active_employee_mission())
|
||||
|
||||
if mission.department_id:
|
||||
# for dep in self.official_mission_id.department_id:
|
||||
|
||||
if mission.course_name and mission.course_name.job_ids:
|
||||
employee_id = self.env['hr.employee'].search(
|
||||
[('department_id', 'in', mission.department_id.ids), ('state', '=', 'open'),
|
||||
('job_id', 'in', mission.course_name.job_ids.ids)]).ids
|
||||
else:
|
||||
employee_id = self.env['hr.employee'].search(
|
||||
[('department_id', 'in', mission.department_id.ids),
|
||||
('state', '=', 'open')]).ids
|
||||
if employee_id:
|
||||
for line in mission.employee_ids:
|
||||
if line.employee_id:
|
||||
if line.employee_id.id in employee_id:
|
||||
employee_id.remove(line.employee_id.id)
|
||||
return {'domain': {'employee_ids': [('id', 'in', employee_id)]}}
|
||||
else:
|
||||
if mission.course_name and mission.course_name.job_ids:
|
||||
employee_id = self.env['hr.employee'].search(
|
||||
[('state', '=', 'open'), ('job_id', 'in', mission.course_name.job_ids.ids)]).ids
|
||||
else:
|
||||
employee_id = self.env['hr.employee'].search([('state', '=', 'open')]).ids
|
||||
if employee_id:
|
||||
for line in mission.employee_ids:
|
||||
if line.employee_id:
|
||||
if line.employee_id.id in employee_id:
|
||||
employee_id.remove(line.employee_id.id)
|
||||
return {'domain': {'employee_ids': [('id', 'in', employee_id)]}}
|
||||
|
||||
def action_confirm(self):
|
||||
"""
|
||||
Action to add employees to current employee reward record
|
||||
"""
|
||||
self.ensure_one()
|
||||
|
||||
# Get the current mission record or create a new one
|
||||
mission = self.env['hr.official.mission'].browse(self._get_active_employee_mission())
|
||||
|
||||
if not mission.exists():
|
||||
# Get values from context
|
||||
mission_vals = self.env.context.get('default_mission_vals', {})
|
||||
mission = self.env['hr.official.mission'].create(mission_vals)
|
||||
|
||||
date_to = datetime.strptime(str(mission.date_to), DEFAULT_SERVER_DATE_FORMAT)
|
||||
date_from = datetime.strptime(str(mission.date_from), DEFAULT_SERVER_DATE_FORMAT)
|
||||
|
||||
# Prepare values for mission lines
|
||||
vals_list = [
|
||||
{
|
||||
'employee_id': employee.id,
|
||||
'date_from': date_from,
|
||||
'date_to': date_to,
|
||||
'hour_from': mission.hour_from,
|
||||
'hour_to': mission.hour_to,
|
||||
}
|
||||
for employee in self.employee_ids
|
||||
]
|
||||
|
||||
existing_employees = mission.employee_ids.mapped('employee_id').ids
|
||||
duplicate_employees = set(self.employee_ids.ids) & set(existing_employees)
|
||||
|
||||
if duplicate_employees:
|
||||
duplicate_names = self.env['hr.employee'].browse(list(duplicate_employees)).mapped('name')
|
||||
raise ValidationError(_(
|
||||
"The following employees are already in reward lines: %s" % ', '.join(duplicate_names)
|
||||
))
|
||||
|
||||
# Create all records in a single operation
|
||||
mission.write({
|
||||
'employee_ids': [(0, 0, vals) for vals in vals_list]
|
||||
})
|
||||
for line in mission.employee_ids:
|
||||
line.compute_number_of_days()
|
||||
line.compute_number_of_hours()
|
||||
line.compute_day_price()
|
||||
line.compute_Training_cost_emp()
|
||||
line.chick_not_overtime()
|
||||
|
||||
return {'type': 'ir.actions.act_window_close'}
|
||||
|
|
@ -0,0 +1,36 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<odoo>
|
||||
<record id="view_employee_mission_selection_wizard_form" model="ir.ui.view">
|
||||
<field name="name">employee.mission.election.wizard.form</field>
|
||||
<field name="model">employee.mission.selection.wizard</field>
|
||||
<field name="arch" type="xml">
|
||||
<form string="Select Employees">
|
||||
<sheet>
|
||||
<group>
|
||||
<field name="employee_ids"
|
||||
options="{'no_create': True, 'no_create_edit': True}"/>
|
||||
<field name="employee_mission_id" invisible="1"/>
|
||||
</group>
|
||||
</sheet>
|
||||
<footer>
|
||||
<button name="action_confirm"
|
||||
string="Add"
|
||||
type="object"
|
||||
class="btn-primary"/>
|
||||
<button string="Cancel"
|
||||
class="btn-secondary"
|
||||
special="cancel"/>
|
||||
</footer>
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<!-- Action to open the wizard -->
|
||||
<record id="action_employee_mission_selection_wizard" model="ir.actions.act_window">
|
||||
<field name="name">Select Employees</field>
|
||||
<field name="type">ir.actions.act_window</field>
|
||||
<field name="res_model">employee.mission.selection.wizard</field>
|
||||
<field name="view_mode">form</field>
|
||||
<field name="target">new</field>
|
||||
</record>
|
||||
</odoo>
|
||||
Loading…
Reference in New Issue