52 lines
1.9 KiB
Python
52 lines
1.9 KiB
Python
|
# Copyright 2017 ACSONE SA/NV
|
||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||
|
|
||
|
from odoo import api, fields, models, SUPERUSER_ID, _
|
||
|
from odoo.exceptions import UserError
|
||
|
|
||
|
|
||
|
class AccountUpdateLockDate(models.TransientModel):
|
||
|
_name = 'account.update.lock_date'
|
||
|
_description = 'Account Update Lock_date'
|
||
|
|
||
|
company_id = fields.Many2one(
|
||
|
comodel_name='res.company', string="Company", required=True)
|
||
|
period_lock_date = fields.Date(
|
||
|
string="Lock Date for Non-Advisers",
|
||
|
help="Only users with the 'Adviser' role can edit accounts prior to "
|
||
|
"and inclusive of this date. Use it for period locking inside an "
|
||
|
"open fiscal year, for example.")
|
||
|
fiscalyear_lock_date = fields.Date(
|
||
|
string="Lock Date",
|
||
|
help="No users, including Advisers, can edit accounts prior to and "
|
||
|
"inclusive of this date. Use it for fiscal year locking for "
|
||
|
"example.")
|
||
|
|
||
|
@api.model
|
||
|
def default_get(self, field_list):
|
||
|
res = super(AccountUpdateLockDate, self).default_get(field_list)
|
||
|
company = self.env.user.company_id
|
||
|
res.update({
|
||
|
'company_id': company.id,
|
||
|
'period_lock_date': company.period_lock_date,
|
||
|
'fiscalyear_lock_date': company.fiscalyear_lock_date,
|
||
|
})
|
||
|
return res
|
||
|
|
||
|
@api.multi
|
||
|
def _check_execute_allowed(self):
|
||
|
self.ensure_one()
|
||
|
has_adviser_group = self.env.user.has_group(
|
||
|
'account.group_account_manager')
|
||
|
if not (has_adviser_group or self.env.uid == SUPERUSER_ID):
|
||
|
raise UserError(_("You are not allowed to execute this action."))
|
||
|
|
||
|
@api.multi
|
||
|
def execute(self):
|
||
|
self.ensure_one()
|
||
|
self._check_execute_allowed()
|
||
|
self.company_id.sudo().write({
|
||
|
'period_lock_date': self.period_lock_date,
|
||
|
'fiscalyear_lock_date': self.fiscalyear_lock_date,
|
||
|
})
|