[IMP] improve the newly created wizard as per requirment suggested
bzr revid: psi@tinyerp.co.in-20110426102656-s2lfltvnkkvzz6ve
This commit is contained in:
parent
ea9ab772d6
commit
e425496f88
|
@ -265,7 +265,7 @@ class hr_payslip(osv.osv):
|
|||
'contract_id': fields.many2one('hr.contract', 'Contract', required=False, readonly=True, states={'draft': [('readonly', False)]}),
|
||||
'details_by_salary_head': fields.function(_get_lines_salary_head, method=True, type='one2many', relation='hr.payslip.line', string='Details by Salary Head'),
|
||||
'credit_note': fields.boolean('Credit Note', help="Indicates this payslip has a refund of another"),
|
||||
'payslip_group_id': fields.many2one('hr.payslip.groups', 'Group', readonly=True, states={'draft': [('readonly', False)]}),
|
||||
'payslip_group_id': fields.many2one('hr.payslip.groups', 'Payslip Group', readonly=True, states={'draft': [('readonly', False)]}),
|
||||
}
|
||||
_defaults = {
|
||||
'date_from': lambda *a: time.strftime('%Y-%m-01'),
|
||||
|
|
|
@ -601,12 +601,23 @@
|
|||
|
||||
<act_window domain="[('slip_id', '=', active_id)]" id="act_payslip_lines" name="Payslip Lines" res_model="hr.payslip.line" src_model="hr.payslip"/>
|
||||
|
||||
<record id="hr_payslip_category_filter" model="ir.ui.view">
|
||||
<field name="name">hr.payslip.category.search</field>
|
||||
<field name="model">hr.payslip.groups</field>
|
||||
<field name="type">search</field>
|
||||
<field name="arch" type="xml">
|
||||
<search string="Search Payslips Group">
|
||||
<field name="name"/>
|
||||
</search>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<record id="hr_payslip_category_tree" model="ir.ui.view">
|
||||
<field name="name">hr.payslip.category.tree</field>
|
||||
<field name="model">hr.payslip.groups</field>
|
||||
<field name="type">tree</field>
|
||||
<field name="arch" type="xml">
|
||||
<tree string="Payslip Groups">
|
||||
<tree string="Payslips Group">
|
||||
<field name="name"/>
|
||||
</tree>
|
||||
</field>
|
||||
|
@ -617,7 +628,7 @@
|
|||
<field name="model">hr.payslip.groups</field>
|
||||
<field name="type">form</field>
|
||||
<field name="arch" type="xml">
|
||||
<form string="Payslip by Category">
|
||||
<form string="Payslips Group">
|
||||
<group colspan="4">
|
||||
<field name="name"/>
|
||||
</group>
|
||||
|
@ -627,10 +638,11 @@
|
|||
</record>
|
||||
|
||||
<record id="action_hr_payslip_category_tree" model="ir.actions.act_window">
|
||||
<field name="name">Payslips by Category</field>
|
||||
<field name="name">Payslip Groups</field>
|
||||
<field name="res_model">hr.payslip.groups</field>
|
||||
<field name="view_type">form</field>
|
||||
<field name="view_id" ref="hr_payslip_category_tree"/>
|
||||
<field name="search_view_id" ref="hr_payslip_category_filter"/>
|
||||
</record>
|
||||
<menuitem action="action_hr_payslip_category_tree" id="menu_hr_payslip_category" parent="menu_hr_root_payroll"/>
|
||||
</data>
|
||||
|
|
|
@ -20,39 +20,43 @@
|
|||
##############################################################################
|
||||
|
||||
from osv import fields, osv
|
||||
import netsvc
|
||||
from tools.translate import _
|
||||
|
||||
class hr_payroll_payslip_groups(osv.osv_memory):
|
||||
class hr_payslip_category(osv.osv_memory):
|
||||
|
||||
_name ='hr.payroll.payslip.groups'
|
||||
_name ='hr.payslip.category'
|
||||
_columns = {
|
||||
'employee_category': fields.many2one('hr.employee.category', 'Employee Category', required=True),
|
||||
'category_id': fields.many2one('hr.employee.category', 'Employee Category', required=True),
|
||||
}
|
||||
|
||||
def compute_sheet(self, cr, uid, ids, context=None):
|
||||
emp_pool = self.pool.get('hr.employee')
|
||||
slip_pool = self.pool.get('hr.payslip')
|
||||
wf_service = netsvc.LocalService("workflow")
|
||||
if context is None:
|
||||
context = {}
|
||||
data = self.read(cr, uid, ids, context=context)[0]
|
||||
cr.execute('SELECT DISTINCT emp_id FROM employee_category_rel WHERE category_id = %s', (data['employee_category'][0], ))
|
||||
emp_ids = filter(None, map(lambda x:x[0], cr.fetchall()))
|
||||
cr.execute('SELECT DISTINCT emp_id FROM employee_category_rel WHERE category_id = %s', (data['category_id'][0], ))
|
||||
emp_ids = [x[0] for x in cr.fetchall()]
|
||||
if not emp_ids:
|
||||
raise osv.except_osv(_("Warning !"), _("No employee(s) found for '%s' category!") % (data['category_id'][1]))
|
||||
slip_ids = []
|
||||
for emp in emp_pool.browse(cr, uid, emp_ids, context=context):
|
||||
old_slips = slip_pool.search(cr, uid, [('employee_id','=', emp.id)], context=context)
|
||||
old_slips = slip_pool.search(cr, uid, [('employee_id', '=', emp.id),('state', '=', 'draft')], context=context)
|
||||
if old_slips:
|
||||
slip_pool.write(cr, uid, old_slips, {'payslip_group_id': context.get('active_id', False)}, context=context)
|
||||
for sid in old_slips:
|
||||
wf_service.trg_validate(uid, 'hr.payslip', sid, 'compute_sheet', cr)
|
||||
for id in context.get('active_ids'):
|
||||
slip_pool.write(cr, uid, old_slips, {'payslip_group_id': id}, context=context)
|
||||
slip_ids.extend(old_slips)
|
||||
else:
|
||||
res = {
|
||||
'employee_id': emp.id,
|
||||
'payslip_group_id': context.get('active_id', False),
|
||||
}
|
||||
slip_id = slip_pool.create(cr, uid, res, context=context)
|
||||
wf_service.trg_validate(uid, 'hr.payslip', slip_id, 'compute_sheet', cr)
|
||||
for id in context.get('active_ids'):
|
||||
res = {
|
||||
'employee_id': emp.id,
|
||||
'payslip_group_id': id,
|
||||
}
|
||||
slip_id = slip_pool.create(cr, uid, res, context=context)
|
||||
slip_ids.append(slip_id)
|
||||
slip_pool.compute_sheet(cr, uid, slip_ids, context=context)
|
||||
return {'type': 'ir.actions.act_window_close'}
|
||||
|
||||
hr_payroll_payslip_groups()
|
||||
hr_payslip_category()
|
||||
|
||||
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
|
||||
|
|
|
@ -4,27 +4,27 @@
|
|||
|
||||
<record id="view_hr_payslip_by_category" model="ir.ui.view">
|
||||
<field name="name">hr_payroll_payslip_category</field>
|
||||
<field name="model">hr.payroll.payslip.groups</field>
|
||||
<field name="model">hr.payslip.category</field>
|
||||
<field name="type">form</field>
|
||||
<field name="arch" type="xml">
|
||||
<form string="Employee Category">
|
||||
<group colspan="4" >
|
||||
<separator string="Select Employee Category" colspan="4"/>
|
||||
<field name="employee_category"/>
|
||||
<separator string="This wizard will generate payslips based on employee(s) category" colspan="4"/>
|
||||
<field name="category_id"/>
|
||||
</group>
|
||||
<separator string="" colspan="4" />
|
||||
<group colspan="4" col="6">
|
||||
<label string ="" colspan="2"/>
|
||||
<button icon="gtk-cancel" special="cancel" string="Cancel"/>
|
||||
<button icon="terp-gtk-go-back-rtl" string="Generate Payslip" name="compute_sheet" type="object"/>
|
||||
<button icon="terp-gtk-go-back-rtl" string="Generate" name="compute_sheet" type="object"/>
|
||||
</group>
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
<record id="action_hr_payslip_by_category" model="ir.actions.act_window">
|
||||
<field name="name">Generate Payslips by Category</field>
|
||||
<field name="res_model">hr.payroll.payslip.groups</field>
|
||||
<field name="name">Generate Payslips</field>
|
||||
<field name="res_model">hr.payslip.category</field>
|
||||
<field name="view_type">form</field>
|
||||
<field name="view_mode">tree,form</field>
|
||||
<field name="view_id" ref="view_hr_payslip_by_category"/>
|
||||
|
@ -34,10 +34,9 @@
|
|||
<record id="action_idea_post_vote_values" model="ir.values">
|
||||
<field name="model_id" ref="model_hr_payslip_groups" />
|
||||
<field name="object" eval="1" />
|
||||
<field name="name">Generate Payslips by Category</field>
|
||||
<field name="name">Generate Payslips</field>
|
||||
<field name="key2">client_action_multi</field>
|
||||
<field name="value" eval="'ir.actions.act_window,' + str(ref('action_hr_payslip_by_category'))"/>
|
||||
<field name="key">action</field>
|
||||
<field name="model">hr.payslip.groups</field>
|
||||
</record>
|
||||
|
||||
|
|
Loading…
Reference in New Issue