You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

39 lines
1.6 KiB
Python

# -*- coding: utf-8 -*-
from odoo import api, models, fields
from odoo.exceptions import UserError, MissingError
class DetailInquiryWizard(models.TransientModel):
"""明细帐查询向导"""
_name = 'detail.inquiry.wizard'
_inherit = 'inquiry.wizard.mixin'
_description = '明细帐查询向导'
partner_ids = fields.Many2many('res.partner', string="业务伙伴")
company_id = fields.Many2one('res.company', string='公司', default=lambda self: self.env.company.id)
def confirm(self):
self.ensure_one()
# 获取总账窗口动作
act_window = self.env['ir.actions.act_window']._for_xml_id('account_ledger.AccountMoveLineActionList')
act_window['domain'] = eval(act_window['domain'])
act_window['context'] = eval(act_window['context'])
periods = self.env['fr.account.period'].search(
[('date_start', '>=', self.period_from.date_start), ('date_start', '<=', self.period_to.date_start)])
# 添加会计期间筛选
if self.period_from and self.period_to:
act_window['domain'] += [('fr_period_id', 'in', periods.ids)]
act_window['display_name'] = f'明细账:{self.period_from.name} - {self.period_to.name}'
# 添加会计科目筛选
if len(self.account_ids) > 0:
act_window['domain'] += [('account_id', 'in', self.account_ids.ids)]
# 添加业务伙伴筛选
if len(self.partner_ids) > 0:
act_window['domain'] += [('partner_id', 'in', self.partner_ids.ids)]
return act_window