Files
suite/hr_payroll_slip_ytd/models/payslip.py
2022-03-21 16:47:51 +00:00

20 lines
769 B
Python

from odoo import models
class Payslip(models.Model):
_inherit = 'hr.payslip'
def ytd(self, code, allow_draft=False):
to_date = self.date_to
from_date = str(self.date_to.year) + '-01-01'
state_allowed = ('done', 'verify') if not allow_draft else ('done', 'verify', 'draft')
self.env.cr.execute("""
SELECT sum(total) as sum
FROM hr_payslip as hp
JOIN hr_payslip_line as pi ON hp.id = pi.slip_id
WHERE hp.employee_id = %s
AND hp.state in %s
AND hp.date_to >= %s AND hp.date_to <= %s AND pi.code = %s""",
(self.employee_id.id, state_allowed, from_date, to_date, code))
return self.env.cr.fetchone()[0] or 0.0