mirror of
https://github.com/bringout/oca-ocb-hr.git
synced 2026-04-24 21:32:00 +02:00
58 lines
3.1 KiB
Python
58 lines
3.1 KiB
Python
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from odoo import api, fields, models
|
|
|
|
|
|
class ResPartnerBank(models.Model):
|
|
_inherit = 'res.partner.bank'
|
|
|
|
bank_street = fields.Char(related='bank_id.street', readonly=False)
|
|
bank_street2 = fields.Char(related='bank_id.street2', readonly=False)
|
|
bank_zip = fields.Char(related='bank_id.zip', readonly=False)
|
|
bank_city = fields.Char(related='bank_id.city', readonly=False)
|
|
bank_state = fields.Many2one(related='bank_id.state', readonly=False)
|
|
bank_country = fields.Many2one(related='bank_id.country', readonly=False)
|
|
bank_email = fields.Char(related='bank_id.email', readonly=False)
|
|
bank_phone = fields.Char(related='bank_id.phone', readonly=False)
|
|
employee_id = fields.Many2many('hr.employee', 'Employee', compute="_compute_employee_id", search="_search_employee_id")
|
|
employee_salary_amount = fields.Float(string='Salary Allocation', compute='_compute_salary_amount', digits=(16, 4), readonly=True, store=False)
|
|
employee_salary_amount_is_percentage = fields.Boolean(compute='_compute_salary_amount', readonly=True, store=False)
|
|
currency_symbol = fields.Char(related='currency_id.symbol')
|
|
employee_has_multiple_bank_accounts = fields.Boolean(related="employee_id.has_multiple_bank_accounts")
|
|
|
|
@api.depends('employee_id.salary_distribution')
|
|
def _compute_salary_amount(self):
|
|
for bank in self:
|
|
if bank.employee_id and bank.employee_id.salary_distribution:
|
|
bank.employee_salary_amount, bank.employee_salary_amount_is_percentage = bank.employee_id.get_bank_account_salary_allocation(bank.id)
|
|
continue
|
|
bank.employee_salary_amount_is_percentage = True
|
|
if bank.employee_id.salary_distribution:
|
|
bank.employee_salary_amount = bank.employee_id.get_remaining_percentage()
|
|
else:
|
|
bank.employee_salary_amount = 0
|
|
|
|
def _search_employee_id(self, operator, value):
|
|
matching_employees = self.env['hr.employee'].sudo().search([('id', operator, value)])
|
|
return [('id', 'in', matching_employees.bank_account_ids.ids)]
|
|
|
|
def action_open_allocation_wizard(self):
|
|
self.ensure_one()
|
|
return self.employee_id.action_open_allocation_wizard()
|
|
|
|
@api.depends('partner_id')
|
|
def _compute_employee_id(self):
|
|
for bank in self:
|
|
if bank.partner_id.employee:
|
|
bank.employee_id = bank.partner_id.employee_ids.filtered(lambda e: e.company_id in self.env.companies)[:1]
|
|
else:
|
|
bank.employee_id = False
|
|
|
|
def _compute_display_name(self):
|
|
account_employee = self.browse()
|
|
if not self.env.user.has_group('hr.group_hr_user'):
|
|
account_employee = self.sudo().filtered("partner_id.employee_ids")
|
|
for account in account_employee:
|
|
account.sudo(self.env.su).display_name = \
|
|
account.acc_number[:2] + "*" * len(account.acc_number[2:-4]) + account.acc_number[-4:]
|
|
super(ResPartnerBank, self - account_employee)._compute_display_name()
|