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.
		
		
		
		
		
			
		
			
				
					
					
						
							106 lines
						
					
					
						
							4.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							106 lines
						
					
					
						
							4.3 KiB
						
					
					
				
								# -*- coding: utf-8 -*-
							 | 
						|
								###################################################################################
							 | 
						|
								#
							 | 
						|
								#    Cybrosys Technologies Pvt. Ltd.
							 | 
						|
								#    Copyright (C) 2022-TODAY Cybrosys Technologies(<http://www.cybrosys.com>).
							 | 
						|
								#    Author: cybrosys(<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 <http://www.gnu.org/licenses/>.
							 | 
						|
								#
							 | 
						|
								###################################################################################
							 | 
						|
								from odoo import tools
							 | 
						|
								from odoo import models, fields, api, _
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class HrEmployee(models.Model):
							 | 
						|
								    _inherit = 'hr.employee'
							 | 
						|
								
							 | 
						|
								    device_id = fields.Char(string='Biometric Device ID')
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class ZkMachine(models.Model):
							 | 
						|
								    _name = 'zk.machine.attendance'
							 | 
						|
								    _inherit = 'hr.attendance'
							 | 
						|
								
							 | 
						|
								    @api.constrains('check_in', 'check_out', 'employee_id')
							 | 
						|
								    def _check_validity(self):
							 | 
						|
								        """overriding the __check_validity function for employee attendance."""
							 | 
						|
								        pass
							 | 
						|
								
							 | 
						|
								    device_id = fields.Char(string='Biometric Device ID')
							 | 
						|
								    punch_type = fields.Selection([('0', 'Check In'),
							 | 
						|
								                                   ('1', 'Check Out'),
							 | 
						|
								                                   ('2', 'Break Out'),
							 | 
						|
								                                   ('3', 'Break In'),
							 | 
						|
								                                   ('4', 'Overtime In'),
							 | 
						|
								                                   ('5', 'Overtime Out')],
							 | 
						|
								                                  string='Punching Type')
							 | 
						|
								
							 | 
						|
								    attendance_type = fields.Selection([('1', 'Finger'),
							 | 
						|
								                                        ('15', 'Face'),
							 | 
						|
								                                        ('2','Type_2'),
							 | 
						|
								                                        ('3','Password'),
							 | 
						|
								                                        ('4','Card')], string='Category')
							 | 
						|
								    punching_time = fields.Datetime(string='Punching Time')
							 | 
						|
								    address_id = fields.Many2one('res.partner', string='Working Address')
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								class ReportZkDevice(models.Model):
							 | 
						|
								    _name = 'zk.report.daily.attendance'
							 | 
						|
								    _auto = False
							 | 
						|
								    _order = 'punching_day desc'
							 | 
						|
								
							 | 
						|
								    name = fields.Many2one('hr.employee', string='Employee')
							 | 
						|
								    punching_day = fields.Datetime(string='Date')
							 | 
						|
								    address_id = fields.Many2one('res.partner', string='Working Address')
							 | 
						|
								    attendance_type = fields.Selection([('1', 'Finger'),
							 | 
						|
								                                        ('15', 'Face'),
							 | 
						|
								                                        ('2','Type_2'),
							 | 
						|
								                                        ('3','Password'),
							 | 
						|
								                                        ('4','Card')],
							 | 
						|
								                                       string='Category')
							 | 
						|
								    punch_type = fields.Selection([('0', 'Check In'),
							 | 
						|
								                                   ('1', 'Check Out'),
							 | 
						|
								                                   ('2', 'Break Out'),
							 | 
						|
								                                   ('3', 'Break In'),
							 | 
						|
								                                   ('4', 'Overtime In'),
							 | 
						|
								                                   ('5', 'Overtime Out')], string='Punching Type')
							 | 
						|
								    punching_time = fields.Datetime(string='Punching Time')
							 | 
						|
								
							 | 
						|
								    def init(self):
							 | 
						|
								        tools.drop_view_if_exists(self._cr, 'zk_report_daily_attendance')
							 | 
						|
								        query = """
							 | 
						|
								            create or replace view zk_report_daily_attendance as (
							 | 
						|
								                select
							 | 
						|
								                    min(z.id) as id,
							 | 
						|
								                    z.employee_id as name,
							 | 
						|
								                    z.write_date as punching_day,
							 | 
						|
								                    z.address_id as address_id,
							 | 
						|
								                    z.attendance_type as attendance_type,
							 | 
						|
								                    z.punching_time as punching_time,
							 | 
						|
								                    z.punch_type as punch_type
							 | 
						|
								                from zk_machine_attendance z
							 | 
						|
								                    join hr_employee e on (z.employee_id=e.id)
							 | 
						|
								                GROUP BY
							 | 
						|
								                    z.employee_id,
							 | 
						|
								                    z.write_date,
							 | 
						|
								                    z.address_id,
							 | 
						|
								                    z.attendance_type,
							 | 
						|
								                    z.punch_type,
							 | 
						|
								                    z.punching_time
							 | 
						|
								            )
							 | 
						|
								        """
							 | 
						|
								        self._cr.execute(query)
							 | 
						|
								
							 | 
						|
								
							 | 
						|
								
							 |