Initial import from Docker volume

This commit is contained in:
root
2025-12-26 13:11:43 +00:00
commit 4998dc066a
13336 changed files with 1767801 additions and 0 deletions

View File

@@ -0,0 +1,13 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
from trytond.pool import Pool
from . import sale
def register():
Pool.register(
sale.Line,
sale.AnalyticAccountEntry,
module='analytic_sale', type_='model')

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@@ -0,0 +1,16 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Аналитични сметки"
#, fuzzy
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Аналитични сметки"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Comptes analítics"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Mida dels comptes analítics"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analítica"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Kostenstellen"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Kostenstellengröße"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Kostenstelle"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Cuentas analíticas"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Tamaño de cuentas analíticas"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analítica"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Analüütilised kontod"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Analüütiliste kontode suurus"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analüütiline"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "تجزیه و تحلیل حساب ها"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "اندازه تجزیه و تحلیل حساب ها"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "تحلیلی"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Comptes analytiques"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Taille des comptes analytiques"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analytique"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "conti analitici"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "dimensione conti analitici"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analitico"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "ບັນຊີວິເຄາະ"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "ຂະໜາດບັນຊີວິເຄາະ"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Analytische rekeningen"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Grootte analyserekeningen"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "analytisch"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Contas Analíticas"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Tamanho da Conta Analítica"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analítico"

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Conturi Analitice"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Mărimea Conturilor Analitice"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr "Analitic"

View File

@@ -0,0 +1,16 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Счета аналитики"
#, fuzzy
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Счета аналитики"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr "Analitični konti"
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr "Število analitičnih kontov"
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

View File

@@ -0,0 +1,15 @@
#
msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:sale.line,analytic_accounts:"
msgid "Analytic Accounts"
msgstr ""
msgctxt "field:sale.line,analytic_accounts_size:"
msgid "Analytic Accounts Size"
msgstr ""
msgctxt "view:sale.line:"
msgid "Analytic"
msgstr ""

61
modules/analytic_sale/sale.py Executable file
View File

@@ -0,0 +1,61 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
from trytond.model import fields
from trytond.modules.analytic_account import AnalyticMixin
from trytond.pool import Pool, PoolMeta
from trytond.pyson import Eval
class Line(AnalyticMixin, metaclass=PoolMeta):
__name__ = 'sale.line'
@classmethod
def __setup__(cls):
super().__setup__()
cls.analytic_accounts.domain = [
('company', '=', Eval('company', -1)),
]
cls.analytic_accounts.states = {
'invisible': Eval('type') != 'line',
'readonly': Eval('sale_state') != 'draft',
}
def get_invoice_line(self, lots=None, action=None):
pool = Pool()
AnalyticAccountEntry = pool.get('analytic.account.entry')
invoice_lines = super().get_invoice_line(lots,action)
for invoice_line in invoice_lines:
new_entries = AnalyticAccountEntry.copy(self.analytic_accounts,
default={
'origin': None,
})
invoice_line.analytic_accounts = new_entries
return invoice_lines
class AnalyticAccountEntry(metaclass=PoolMeta):
__name__ = 'analytic.account.entry'
@classmethod
def _get_origin(cls):
origins = super(AnalyticAccountEntry, cls)._get_origin()
return origins + ['sale.line']
@fields.depends('origin')
def on_change_with_company(self, name=None):
pool = Pool()
SaleLine = pool.get('sale.line')
company = super().on_change_with_company(name)
if isinstance(self.origin, SaleLine) and self.origin.sale:
company = self.origin.sale.company
return company
@classmethod
def search_company(cls, name, clause):
domain = super(AnalyticAccountEntry, cls).search_company(name, clause),
if domain:
domain = ['OR', domain]
domain.append(('origin.sale.' + clause[0],
*clause[1:3], 'sale.line', *clause[3:]))
return domain

12
modules/analytic_sale/sale.xml Executable file
View File

@@ -0,0 +1,12 @@
<?xml version="1.0"?>
<!-- This file is part of Tryton. The COPYRIGHT file at the top level of
this repository contains the full copyright notices and license terms. -->
<tryton>
<data>
<record model="ir.ui.view" id="sale_line_view_form">
<field name="model">sale.line</field>
<field name="inherit" ref="sale.sale_line_view_form"/>
<field name="name">sale_line_form</field>
</record>
</data>
</tryton>

View File

@@ -0,0 +1,2 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.

View File

@@ -0,0 +1,157 @@
======================
Analytic Sale Scenario
======================
Imports::
>>> from decimal import Decimal
>>> from proteus import Model, Wizard
>>> from trytond.modules.account.tests.tools import (
... create_chart, create_fiscalyear, get_accounts)
>>> from trytond.modules.account_invoice.tests.tools import (
... create_payment_term, set_fiscalyear_invoice_sequences)
>>> from trytond.modules.company.tests.tools import create_company, get_company
>>> from trytond.tests.tools import activate_modules, assertEqual, set_user
Activate modules::
>>> config = activate_modules('analytic_sale')
Create company::
>>> _ = create_company()
>>> company = get_company()
Create sale user::
>>> User = Model.get('res.user')
>>> Group = Model.get('res.group')
>>> sale_user = User()
>>> sale_user.name = 'Sale'
>>> sale_user.login = 'sale'
>>> sale_group, = Group.find([('name', '=', 'Sales')])
>>> sale_user.groups.append(sale_group)
>>> sale_user.save()
Create fiscal year::
>>> fiscalyear = set_fiscalyear_invoice_sequences(
... create_fiscalyear(company))
>>> fiscalyear.click('create_period')
Create chart of accounts::
>>> _ = create_chart(company)
>>> accounts = get_accounts(company)
>>> revenue = accounts['revenue']
>>> expense = accounts['expense']
Create analytic accounts::
>>> AnalyticAccount = Model.get('analytic_account.account')
>>> root = AnalyticAccount(type='root', name='Root')
>>> root.save()
>>> analytic_account = AnalyticAccount(root=root, parent=root,
... name='Analytic')
>>> analytic_account.save()
Create parties::
>>> Party = Model.get('party.party')
>>> customer = Party(name='Customer')
>>> customer.save()
Create account category::
>>> ProductCategory = Model.get('product.category')
>>> account_category = ProductCategory(name="Account Category")
>>> account_category.accounting = True
>>> account_category.account_expense = expense
>>> account_category.account_revenue = revenue
>>> account_category.save()
Create product::
>>> ProductUom = Model.get('product.uom')
>>> unit, = ProductUom.find([('name', '=', 'Unit')])
>>> ProductTemplate = Model.get('product.template')
>>> template = ProductTemplate()
>>> template.name = 'product'
>>> template.default_uom = unit
>>> template.type = 'goods'
>>> template.salable = True
>>> template.list_price = Decimal('10')
>>> template.account_category = account_category
>>> template.save()
>>> product, = template.products
Create payment term::
>>> payment_term = create_payment_term()
>>> payment_term.save()
Sale with analytic accounts::
>>> set_user(sale_user)
>>> Sale = Model.get('sale.sale')
>>> SaleLine = Model.get('sale.line')
>>> sale = Sale()
>>> sale.party = customer
>>> sale.payment_term = payment_term
>>> sale.invoice_method = 'order'
>>> sale_line = sale.lines.new()
>>> entry, = sale_line.analytic_accounts
>>> assertEqual(entry.root, root)
>>> entry.account = analytic_account
>>> sale_line.product = product
>>> sale_line.quantity = 5
>>> sale.click('quote')
>>> sale.click('confirm')
>>> sale.state
'processing'
Check analytic accounts on invoice::
>>> Invoice = Model.get('account.invoice')
>>> invoice = Invoice(sale.invoices[0].id)
>>> invoice_line, = invoice.lines
>>> entry, = invoice_line.analytic_accounts
>>> assertEqual(entry.account, analytic_account)
Sale with an empty analytic account::
>>> set_user(sale_user)
>>> Sale = Model.get('sale.sale')
>>> SaleLine = Model.get('sale.line')
>>> sale = Sale()
>>> sale.party = customer
>>> sale.payment_term = payment_term
>>> sale.invoice_method = 'order'
>>> sale_line = sale.lines.new()
>>> entry, = sale_line.analytic_accounts
>>> sale_line.product = product
>>> sale_line.quantity = 5
>>> sale.click('quote')
>>> sale.click('confirm')
>>> sale.state
'processing'
>>> invoice, = sale.invoices
Check invoice analytic accounts::
>>> invoice_line, = invoice.lines
>>> entry, = invoice_line.analytic_accounts
>>> entry.account
Return sales using the wizard::
>>> set_user(sale_user)
>>> return_sale = Wizard('sale.return_sale', [sale])
>>> return_sale.execute('return_')
>>> returned_sale, = Sale.find([
... ('state', '=', 'draft'),
... ])
>>> sale_line, = returned_sale.lines
>>> entry, = sale_line.analytic_accounts
>>> entry.account

View File

@@ -0,0 +1,12 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
from trytond.tests.test_tryton import ModuleTestCase
class AnalyticSaleTestCase(ModuleTestCase):
'Test AnalyticSale module'
module = 'analytic_sale'
del ModuleTestCase

View File

@@ -0,0 +1,8 @@
# This file is part of Tryton. The COPYRIGHT file at the top level of
# this repository contains the full copyright notices and license terms.
from trytond.tests.test_tryton import load_doc_tests
def load_tests(*args, **kwargs):
return load_doc_tests(__name__, __file__, *args, **kwargs)

View File

@@ -0,0 +1,8 @@
[tryton]
version=7.2.0
depends:
analytic_account
analytic_invoice
sale
xml:
sale.xml

View File

@@ -0,0 +1,10 @@
<?xml version="1.0"?>
<!-- This file is part of Tryton. The COPYRIGHT file at the top level of
this repository contains the full copyright notices and license terms. -->
<data>
<xpath expr="/form/notebook" position="inside">
<page string="Analytic" id="analytic_accounts">
<field name="analytic_accounts" colspan="4"/>
</page>
</xpath>
</data>