mirror of
https://github.com/guohuadeng/app-odoo.git
synced 2025-02-23 04:11:36 +02:00
72 lines
3.2 KiB
Python
72 lines
3.2 KiB
Python
# -*- coding: utf-8 -*-
|
||
|
||
# Created on 2018-11-28
|
||
# author: 欧度智能,https://www.odooai.cn
|
||
# email: 300883@qq.com
|
||
# resource of odooai
|
||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||
|
||
# Odoo在线中文用户手册(长期更新)
|
||
# https://www.odooai.cn/documentation/user/10.0/zh_CN/index.html
|
||
|
||
# Odoo10离线中文用户手册下载
|
||
# https://www.odooai.cn/odoo10_user_manual_document_offline/
|
||
# Odoo10离线开发手册下载-含python教程,jquery参考,Jinja2模板,PostgresSQL参考(odoo开发必备)
|
||
# https://www.odooai.cn/odoo10_developer_document_offline/
|
||
# description:
|
||
|
||
from odoo import api, fields, models, _
|
||
from odoo.exceptions import UserError, ValidationError
|
||
|
||
class AccountAccount(models.Model):
|
||
_inherit = ['account.account']
|
||
_parent_name = "parent_id"
|
||
_parent_store = True
|
||
_parent_order = 'code'
|
||
# _rec_name = 'complete_name'
|
||
|
||
parent_id = fields.Many2one('account.account', 'Parent Chart', index=True, ondelete='cascade')
|
||
child_ids = fields.One2many('account.account', 'parent_id', 'Child Chart')
|
||
parent_path = fields.Char(index=True, unaccent=False)
|
||
|
||
@api.model
|
||
def _search_new_account_code(self, company, digits, prefix, cache=None):
|
||
# 分隔符,金蝶为 ".",用友为"",注意odoo中一级科目,现金默认定义是4位头,银行是6位头
|
||
delimiter = '.'
|
||
for num in range(1, 100):
|
||
new_code = str(prefix.ljust(digits - 1, '0')) + delimiter + '%02d' % (num)
|
||
if new_code in (cache or []):
|
||
continue
|
||
rec = self.search([('code', '=', new_code), ('company_id', 'child_of', company.root_id.id)], limit=1)
|
||
if not rec:
|
||
return new_code
|
||
raise UserError(_('Cannot generate an unused account code.'))
|
||
|
||
def refresh_account_parent(self, company=None):
|
||
if not company:
|
||
company = self.env.user.company_id
|
||
self = self.filtered(lambda r: len(r.code) > 2).sorted(key=lambda r: r.code)
|
||
done = 0
|
||
# 分隔符 delimiter,用友为"",金蝶为 ".",注意odoo中一级科目,现金默认定义是4位头,银行是6位头
|
||
# 我们使用 用友的多级科目方式,自动生成下级,此处直接覆盖原生
|
||
delimiter = company.coa_delimiter or ''
|
||
for rec in self:
|
||
if len(rec.code) > 2:
|
||
p_code = rec.code[:len(rec.code) - 2]
|
||
if delimiter and delimiter != '':
|
||
p_code = rec.code[:len(rec.code) - 2 - len(delimiter)]
|
||
p_acc = self.search([('company_id', '=', company.id), ('code', '=', p_code)])
|
||
if p_acc and rec.parent_id != p_acc:
|
||
rec.write({'parent_id': p_acc.id})
|
||
done += 1
|
||
|
||
return {
|
||
'effect': {
|
||
'fadeout': 'fast',
|
||
'message': _('Update parent account chart done.<br/>【%s】 records updated.' % done),
|
||
'img_url': '/web/image/%s/%s/image_1024' % (self.env.user._name,
|
||
self.env.user.id) if self.env.user.image_1024 else '/web/static/src/img/smile.svg',
|
||
'type': 'rainbow_man',
|
||
}
|
||
}
|