add new module

This commit is contained in:
sonal arora
2020-07-21 10:09:46 +00:00
parent 800e7fdceb
commit c0d10e3fbe
1063 changed files with 243750 additions and 5 deletions

View File

@@ -0,0 +1,3 @@
# -*- coding: utf-8 -*-
from . import res_partner_agency
from . import employee_verification

View File

@@ -0,0 +1,68 @@
# -*- coding: utf-8 -*-
from datetime import date
from odoo import models, fields, api, _
from odoo.exceptions import UserError
import requests
class EmployeeVerification(models.Model):
_name = 'employee.verification'
_rec_name = 'verification_id'
verification_id = fields.Char('ID', readonly=True, copy=False, help="Verification Id")
employee = fields.Many2one('hr.employee', string='Employee', required=True, help='You can choose the employee for background verification')
address = fields.Many2one(related='employee.address_home_id', string='Address', readonly=False)
assigned_by = fields.Many2one('res.users', string='Assigned By', readonly=1, default=lambda self: self.env.uid, help="Assigned Login User")
agency = fields.Many2one('res.partner', string='Agency', domain=[('verification_agent', '=', True)], help='You can choose a Verification Agent')
resume_uploaded = fields.Many2many('ir.attachment', string="Resume of Applicant",
help='You can attach the copy of your document', copy=False)
description_by_agency = fields.Char(string='Description', readonly=True, help="Description")
agency_attachment_id = fields.Many2one('ir.attachment', string='Attachment', help='Attachment from Agency')
field_check = fields.Boolean(string='Check', invisible=True)
assigned_date = fields.Date(string="Assigned Date", readonly=True, default=date.today(), help="Record Assigned Date")
expected_date = fields.Date(state='Expected Date', help='Expected date of completion of background verification')
state = fields.Selection([
('draft', 'Draft'),
('assign', 'Assigned'),
('submit', 'Varification Completed'),
], string='Status', default='draft')
company_id = fields.Many2one('res.company', 'Company',
default=lambda self: self.env['res.company'].browse(1))
def download_attachment(self):
if self.agency_attachment_id:
return {
'type': 'ir.actions.act_url',
'url': '/web/binary/image?model=ir.attachment&field=datas&id=%s&filename=%s' % (self.agency_attachment_id.id,self.agency_attachment_id.name),
'target': 'new',
}
else:
raise UserError(_("No attachments available."))
def assign_statusbar(self):
if self.agency:
if self.address or self.resume_uploaded:
self.state = 'assign'
template = self.env.ref('employee_background.assign_agency_email_template')
self.env['mail.template'].browse(template.id).send_mail(self.id, force_send=True)
else:
raise UserError(_("There should be at least address or resume of the employee."))
else:
raise UserError(_("Agency is not assigned. Please select one of the Agency."))
# sequence generation for employee verification
@api.model
def create(self, vals):
seq = self.env['ir.sequence'].next_by_code('res.users') or '/'
vals['verification_id'] = seq
return super(EmployeeVerification, self).create(vals)
def unlink(self):
if self.state not in 'draft':
raise UserError(_('You cannot delete the verification created.'))
super(EmployeeVerification, self).unlink()

View File

@@ -0,0 +1,10 @@
# -*- coding: utf-8 -*-
from odoo import models, fields, api
class ResPartnerAgency(models.Model):
_inherit = 'res.partner'
verification_agent = fields.Boolean(string='Employee Verification agent',
default=False,
help="Mark it if the partner is an Employee Verification Agent")

View File

@@ -0,0 +1,43 @@
# -*- coding: utf-8 -*-
import logging
from odoo import models
class DefaultTemplateXls(models.AbstractModel):
_name = 'report.employee_background.default_verification_details'
# _inherit = 'report.report_xlsx.abstract'
_logger = logging.getLogger(__name__)
try:
_inherit = 'report.report_xlsx.abstract'
except ImportError:
_logger.debug('Cannot find report_xlsx module for version 11')
def generate_xlsx_report(self, workbook, data, obj):
sheet = workbook.add_worksheet()
format1 = workbook.add_format({'font_size': 16, 'align': 'center', 'bg_color': '#D3D3D3', 'bold': True})
format2 = workbook.add_format({'font_size': 10, 'bold': True})
format3 = workbook.add_format({'font_size': 10})
sheet.merge_range('B1:E1', 'Required Details', format1)
sheet.merge_range('A2:B2', 'Applicant Name:', format3)
sheet.merge_range('A3:C3', 'Information Required', format2)
sheet.merge_range('D3:F3', 'Details Given', format2)
sheet.merge_range('G3:I3', 'Details(Correct/Wrong)', format2)
sheet.merge_range('A5:C5', 'Education Details', format3)
sheet.merge_range('B6:C6', 'Graduation', format3)
sheet.merge_range('D6:F6', '', format3)
sheet.merge_range('G6:I6', '', format3)
sheet.merge_range('B7:C7', 'Plus Two', format3)
sheet.merge_range('D7:F7', '', format3)
sheet.merge_range('G7:I7', '', format3)
sheet.merge_range('A9:C9', 'Work Details', format3)
sheet.merge_range('D9:F9', '', format3)
sheet.merge_range('G9:I9', '', format3)
sheet.merge_range('A11:C11', 'Criminal Background', format3)
sheet.merge_range('D11:F11', '', format3)
sheet.merge_range('G11:I11', '', format3)
sheet.merge_range('A13:C13', 'Disciplinary Allegation in Previous Work Locations', format3)
sheet.merge_range('D13:F13', '', format3)
sheet.merge_range('G13:I13', '', format3)