You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
84 lines
3.2 KiB
84 lines
3.2 KiB
# -*- coding: utf-8 -*-
|
|
###################################################################################
|
|
# A part of OpenHRMS Project <https://www.openhrms.com>
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
# Copyright (C) 2018-TODAY Cybrosys Technologies (<https://www.cybrosys.com>).
|
|
# Author: Avinash Nk, Jesni Banu (<https://www.cybrosys.com>)
|
|
#
|
|
# This program is free software: you can modify
|
|
# it under the terms of the GNU Affero General Public License (AGPL) as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
#
|
|
###################################################################################
|
|
from odoo import models, fields, tools
|
|
|
|
|
|
class CustodyHistory(models.Model):
|
|
_name = "report.custody"
|
|
_description = "Custody Analysis"
|
|
_auto = False
|
|
|
|
name = fields.Char(string='Code')
|
|
date_request = fields.Date(string='Requested Date')
|
|
employee = fields.Many2one('hr.employee', string='Employee')
|
|
purpose = fields.Char(string='Reason')
|
|
custody_name = fields.Many2one('custody.property', string='Custody Name')
|
|
return_date = fields.Date(string='Return Date')
|
|
renew_date = fields.Date(string='Renewal Return Date')
|
|
renew_return_date = fields.Boolean(string='Renewal Return Date')
|
|
state = fields.Selection([('draft', 'Draft'), ('to_approve', 'Waiting For Approval'), ('approved', 'Approved'),
|
|
('returned', 'Returned'), ('rejected', 'Refused')], string='Status')
|
|
|
|
_order = 'name desc'
|
|
|
|
def _select(self):
|
|
select_str = """
|
|
SELECT
|
|
(select 1 ) AS nbr,
|
|
t.id as id,
|
|
t.name as name,
|
|
t.date_request as date_request,
|
|
t.employee as employee,
|
|
t.purpose as purpose,
|
|
t.custody_name as custody_name,
|
|
t.return_date as return_date,
|
|
t.renew_date as renew_date,
|
|
t.renew_return_date as renew_return_date,
|
|
t.state as state
|
|
"""
|
|
return select_str
|
|
|
|
def _group_by(self):
|
|
group_by_str = """
|
|
GROUP BY
|
|
t.id,
|
|
name,
|
|
date_request,
|
|
employee,
|
|
purpose,
|
|
custody_name,
|
|
return_date,
|
|
renew_date,
|
|
renew_return_date,
|
|
state
|
|
"""
|
|
return group_by_str
|
|
|
|
def init(self):
|
|
tools.sql.drop_view_if_exists(self._cr, 'report_custody')
|
|
self._cr.execute("""
|
|
CREATE view report_custody as
|
|
%s
|
|
FROM hr_custody t
|
|
%s
|
|
""" % (self._select(), self._group_by()))
|
|
|