Compare commits
31 Commits
14-formatL
...
14.0
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
993fb49ab5 | ||
|
|
1ba485392a | ||
|
|
faca51f126 | ||
|
|
3a9a97c742 | ||
|
|
647106f508 | ||
|
|
b289980665 | ||
|
|
93e62455ad | ||
|
|
9fff149835 | ||
|
|
59148b0522 | ||
|
|
bfb499d4ca | ||
|
|
e8f8069a87 | ||
|
|
f12218c4a0 | ||
|
|
204df0e1e8 | ||
|
|
cfb1d2ce1e | ||
|
|
00ca8789de | ||
|
|
dfdd09260d | ||
|
|
79032cb217 | ||
|
|
d83bc929aa | ||
|
|
58ff5677dd | ||
|
|
adf62785d9 | ||
|
|
eaa9a6fa2d | ||
|
|
3a4d79b1b2 | ||
|
|
2f0f66280c | ||
|
|
7dee4a7d5b | ||
|
|
a8d93ed2a9 | ||
|
|
a98490706f | ||
|
|
47afd81567 | ||
|
|
1247e99f3c | ||
|
|
e5632abb97 | ||
|
|
041aae3e17 | ||
|
|
75a3f69508 |
@@ -1,10 +1,9 @@
|
|||||||
# Copyright 2025 Akretion France (https://www.akretion.com/)
|
# Copyright 2016-2025 Akretion France (https://www.akretion.com/)
|
||||||
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
from odoo import models, api
|
from odoo import models
|
||||||
from odoo.tools import misc
|
from odoo.tools import misc, float_compare
|
||||||
from openerp.tools import float_compare
|
|
||||||
|
|
||||||
|
|
||||||
class BaseUsabilityInstalled(models.AbstractModel):
|
class BaseUsabilityInstalled(models.AbstractModel):
|
||||||
@@ -16,22 +15,20 @@ formatLang_original = misc.formatLang
|
|||||||
|
|
||||||
|
|
||||||
def formatLang(
|
def formatLang(
|
||||||
self, value, digits=None, grouping=True,
|
env, value, digits=None, grouping=True,
|
||||||
monetary=False, dp=False, currency_obj=False, int_no_digits=True):
|
monetary=False, dp=False, currency_obj=False, int_no_digits=True):
|
||||||
with api.Environment.manage():
|
if (
|
||||||
env = api.Environment(self.cr, self.uid, {})
|
'base.usability.installed' in env and
|
||||||
if (
|
int_no_digits and
|
||||||
'base.usability.installed' in env and
|
not monetary and
|
||||||
int_no_digits and
|
isinstance(value, float) and
|
||||||
not monetary and
|
dp):
|
||||||
isinstance(value, float) and
|
prec = env['decimal.precision'].precision_get(dp)
|
||||||
dp):
|
if not float_compare(value, int(value), precision_digits=prec):
|
||||||
prec = env['decimal.precision'].precision_get(dp)
|
digits = 0
|
||||||
if not float_compare(value, int(value), precision_digits=prec):
|
dp = False
|
||||||
digits = 0
|
|
||||||
dp = False
|
|
||||||
res = formatLang_original(
|
res = formatLang_original(
|
||||||
self, value, digits=digits, grouping=grouping,
|
env, value, digits=digits, grouping=grouping,
|
||||||
monetary=monetary, dp=dp, currency_obj=currency_obj)
|
monetary=monetary, dp=dp, currency_obj=currency_obj)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|||||||
@@ -24,6 +24,9 @@
|
|||||||
<xpath expr="//div[hasclass('o_address_format')]/field[@name='city']" position="before">
|
<xpath expr="//div[hasclass('o_address_format')]/field[@name='city']" position="before">
|
||||||
<field name="zip" position="move"/>
|
<field name="zip" position="move"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
|
<field name="industry_id" position="attributes">
|
||||||
|
<attribute name="attrs">{'invisible': [('parent_id', '!=', False)]}</attribute>
|
||||||
|
</field>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
@@ -60,6 +63,9 @@
|
|||||||
<field name="phone" position="after">
|
<field name="phone" position="after">
|
||||||
<field name="mobile" optional="show" widget="phone" class="o_force_ltr"/>
|
<field name="mobile" optional="show" widget="phone" class="o_force_ltr"/>
|
||||||
</field>
|
</field>
|
||||||
|
<field name="category_id" position="after">
|
||||||
|
<field name="industry_id" optional="hide"/>
|
||||||
|
</field>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
@@ -73,6 +79,9 @@
|
|||||||
<!-- for 'ref', change '=' to 'start with' -->
|
<!-- for 'ref', change '=' to 'start with' -->
|
||||||
<attribute name="filter_domain">['|','|',('display_name','ilike',self),('ref','=ilike',self + '%'),('email','ilike',self)]</attribute>
|
<attribute name="filter_domain">['|','|',('display_name','ilike',self),('ref','=ilike',self + '%'),('email','ilike',self)]</attribute>
|
||||||
</field>
|
</field>
|
||||||
|
<filter name="group_country" position="after">
|
||||||
|
<filter name="industry_groupby" string="Industry" context="{'group_by': 'industry_id'}"/>
|
||||||
|
</filter>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
|
|||||||
@@ -1,2 +1,3 @@
|
|||||||
from . import models
|
from . import models
|
||||||
from . import wizards
|
from . import wizards
|
||||||
|
from . import reports
|
||||||
|
|||||||
@@ -30,16 +30,17 @@ This module has been written by Alexis de Lattre from Akretion
|
|||||||
'depends': [
|
'depends': [
|
||||||
'account',
|
'account',
|
||||||
'date_range',
|
'date_range',
|
||||||
|
'report_xlsx',
|
||||||
],
|
],
|
||||||
'data': [
|
'data': [
|
||||||
'security/ir.model.access.csv',
|
'security/ir.model.access.csv',
|
||||||
'security/rule.xml',
|
'security/rule.xml',
|
||||||
|
'reports/report.xml',
|
||||||
'data/decimal_precision.xml',
|
'data/decimal_precision.xml',
|
||||||
'views/commission_profile.xml',
|
'views/commission_profile.xml',
|
||||||
'views/commission_rule.xml',
|
'views/commission_rule.xml',
|
||||||
'views/commission_result.xml',
|
'views/commission_result.xml',
|
||||||
'views/account_move_line.xml',
|
'views/account_move_line.xml',
|
||||||
'views/res_config_settings.xml',
|
|
||||||
'wizards/commission_compute_view.xml',
|
'wizards/commission_compute_view.xml',
|
||||||
],
|
],
|
||||||
'installable': True,
|
'installable': True,
|
||||||
|
|||||||
@@ -4,17 +4,28 @@
|
|||||||
#
|
#
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Odoo Server 16.0\n"
|
"Project-Id-Version: Odoo Server 14.0\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2024-11-29 23:38+0000\n"
|
"POT-Creation-Date: 2025-10-17 20:36+0000\n"
|
||||||
"PO-Revision-Date: 2024-11-29 23:38+0000\n"
|
"PO-Revision-Date: 2025-10-17 20:36+0000\n"
|
||||||
"Last-Translator: \n"
|
"Last-Translator: Alexis de Lattre <alexis.delattre@akretion.com>\n"
|
||||||
"Language-Team: \n"
|
"Language-Team: \n"
|
||||||
|
"Language: fr\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"Content-Transfer-Encoding: \n"
|
"Content-Transfer-Encoding: \n"
|
||||||
"Plural-Forms: \n"
|
"Plural-Forms: \n"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid ""
|
||||||
|
"%(count)s commissions already exist(s) with start date %(date_start)s in "
|
||||||
|
"company %(company)s."
|
||||||
|
msgstr ""
|
||||||
|
"%(count)s il existe déjà des commissions avec la date de début "
|
||||||
|
"%(date_start)s dans la société %(company)s."
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.constraint,message:commission_simple.constraint_commission_result_salesman_period_company_unique
|
#: model:ir.model.constraint,message:commission_simple.constraint_commission_result_salesman_period_company_unique
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -25,7 +36,6 @@ msgstr ""
|
|||||||
"période."
|
"période."
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple/models/commission_profile.py:0
|
#: code:addons/commission_simple/models/commission_profile.py:0
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "A salesman must be selected when the assignment type is 'Salesman'."
|
msgid "A salesman must be selected when the assignment type is 'Salesman'."
|
||||||
@@ -33,6 +43,12 @@ msgstr ""
|
|||||||
"Un vendeur doit être sélectionné lorsque le type d'affectation est "
|
"Un vendeur doit être sélectionné lorsque le type d'affectation est "
|
||||||
"\"Vendeur\"."
|
"\"Vendeur\"."
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/models/commission_rule.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "AND"
|
||||||
|
msgstr "ET"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_needaction
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_needaction
|
||||||
msgid "Action Needed"
|
msgid "Action Needed"
|
||||||
@@ -64,6 +80,12 @@ msgstr "État de l'activité"
|
|||||||
msgid "Activity Type Icon"
|
msgid "Activity Type Icon"
|
||||||
msgstr "Îcone du type d'activité"
|
msgstr "Îcone du type d'activité"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Amount Total"
|
||||||
|
msgstr "Montant Total"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__applied_on
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__applied_on
|
||||||
msgid "Apply On"
|
msgid "Apply On"
|
||||||
@@ -71,6 +93,7 @@ msgstr "Conditions"
|
|||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_form
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_search
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_search
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_search
|
||||||
msgid "Archived"
|
msgid "Archived"
|
||||||
msgstr "Archivé"
|
msgstr "Archivé"
|
||||||
@@ -102,34 +125,54 @@ msgstr "Nombre de pièces jointes"
|
|||||||
msgid "Back to Draft"
|
msgid "Back to Draft"
|
||||||
msgstr "Remettre en brouillon"
|
msgstr "Remettre en brouillon"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Base Total"
|
||||||
|
msgstr "Total Base"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_compute_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_compute_form
|
||||||
msgid "Cancel"
|
msgid "Cancel"
|
||||||
msgstr "Annuler"
|
msgstr "Annuler"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.view_move_line_form
|
||||||
|
msgid "Commission"
|
||||||
|
msgstr "Commission"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_invoice_report__commission_amount
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_amount
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_amount
|
||||||
|
#, python-format
|
||||||
msgid "Commission Amount"
|
msgid "Commission Amount"
|
||||||
msgstr "Montant de la commission"
|
msgstr "Montant de la commission"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_base
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_base
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__base
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__base
|
||||||
|
#, python-format
|
||||||
msgid "Commission Base"
|
msgid "Commission Base"
|
||||||
msgstr "Base de la commission"
|
msgstr "Base de la commission"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__base_total
|
||||||
|
msgid "Commission Base Total"
|
||||||
|
msgstr "Total base des commissions"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__line_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__line_ids
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
msgid "Commission Lines"
|
msgid "Commission Lines"
|
||||||
msgstr "Lignes commission"
|
msgstr "Lignes de commission"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__date_range_type_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__date_range_type_id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_res_company__commission_date_range_type_id
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_search
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_res_config_settings__commission_date_range_type_id
|
|
||||||
msgid "Commission Periodicity"
|
msgid "Commission Periodicity"
|
||||||
msgstr "Périodicité de commission"
|
msgstr "Périodicité des commissions"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model,name:commission_simple.model_commission_profile
|
#: model:ir.model,name:commission_simple.model_commission_profile
|
||||||
@@ -140,7 +183,7 @@ msgstr "Profil de commission"
|
|||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model,name:commission_simple.model_commission_profile_assignment
|
#: model:ir.model,name:commission_simple.model_commission_profile_assignment
|
||||||
msgid "Commission Profile Assignment"
|
msgid "Commission Profile Assignment"
|
||||||
msgstr "Affectation du profil de commission"
|
msgstr "Affectation des profils de commission"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.actions.act_window,name:commission_simple.commission_profile_action
|
#: model:ir.actions.act_window,name:commission_simple.commission_profile_action
|
||||||
@@ -149,8 +192,10 @@ msgid "Commission Profiles"
|
|||||||
msgstr "Profils de commission"
|
msgstr "Profils de commission"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_rate
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_rate
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__rate
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__rate
|
||||||
|
#, python-format
|
||||||
msgid "Commission Rate"
|
msgid "Commission Rate"
|
||||||
msgstr "Taux de commission"
|
msgstr "Taux de commission"
|
||||||
|
|
||||||
@@ -160,6 +205,11 @@ msgstr "Taux de commission"
|
|||||||
msgid "Commission Result"
|
msgid "Commission Result"
|
||||||
msgstr "État des commissions"
|
msgstr "État des commissions"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model,name:commission_simple.model_report_commission_simple_report_xlsx
|
||||||
|
msgid "Commission Result XLSX"
|
||||||
|
msgstr "État des commission XLSX"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model,name:commission_simple.model_commission_rule
|
#: model:ir.model,name:commission_simple.model_commission_rule
|
||||||
msgid "Commission Rule"
|
msgid "Commission Rule"
|
||||||
@@ -182,22 +232,14 @@ msgstr "Total des commissions"
|
|||||||
#: model:ir.ui.menu,name:commission_simple.commission_config_root
|
#: model:ir.ui.menu,name:commission_simple.commission_config_root
|
||||||
#: model:ir.ui.menu,name:commission_simple.commission_result_menu
|
#: model:ir.ui.menu,name:commission_simple.commission_result_menu
|
||||||
#: model:ir.ui.menu,name:commission_simple.commission_root
|
#: model:ir.ui.menu,name:commission_simple.commission_root
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.res_config_settings_view_form
|
|
||||||
msgid "Commissions"
|
msgid "Commissions"
|
||||||
msgstr ""
|
msgstr "Commissions"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#. odoo-python
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "Commissions already exist for %(period)s in company %(company)s."
|
msgid "Commissions of %(partner)s for period %(period)s"
|
||||||
msgstr ""
|
msgstr "Commissions de %(partner)s pour la période %(period)s"
|
||||||
"Des commissions existent déjà pour %(period)s dans la société %(company)s."
|
|
||||||
|
|
||||||
#. module: commission_simple
|
|
||||||
#: model:ir.model,name:commission_simple.model_res_company
|
|
||||||
msgid "Companies"
|
|
||||||
msgstr "Sociétés"
|
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__company_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__company_id
|
||||||
@@ -226,11 +268,6 @@ msgstr "Calculer"
|
|||||||
msgid "Compute Commissions"
|
msgid "Compute Commissions"
|
||||||
msgstr "Calculer les commissions"
|
msgstr "Calculer les commissions"
|
||||||
|
|
||||||
#. module: commission_simple
|
|
||||||
#: model:ir.model,name:commission_simple.model_res_config_settings
|
|
||||||
msgid "Config Settings"
|
|
||||||
msgstr "Configuration"
|
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
msgid "Confirm"
|
msgid "Confirm"
|
||||||
@@ -254,17 +291,43 @@ msgstr "Créé par"
|
|||||||
msgid "Created on"
|
msgid "Created on"
|
||||||
msgstr "Créé le"
|
msgstr "Créé le"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Currency"
|
||||||
|
msgstr "Devise"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Customer"
|
||||||
|
msgstr "Client"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__partner_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__partner_ids
|
||||||
msgid "Customers"
|
msgid "Customers"
|
||||||
msgstr "Clients"
|
msgstr "Clients"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/models/commission_rule.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Customers:"
|
||||||
|
msgstr "Clients :"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
|
msgid "Disc.%"
|
||||||
|
msgstr "Rem.%"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_invoice_report__display_name
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__display_name
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__display_name
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__display_name
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__display_name
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__display_name
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__display_name
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__display_name
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__display_name
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__display_name
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__display_name
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__display_name
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_report_commission_simple_report_xlsx__display_name
|
||||||
msgid "Display Name"
|
msgid "Display Name"
|
||||||
msgstr "Nom affiché"
|
msgstr "Nom affiché"
|
||||||
|
|
||||||
@@ -272,7 +335,7 @@ msgstr "Nom affiché"
|
|||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_result__state__done
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_result__state__done
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
||||||
msgid "Done"
|
msgid "Done"
|
||||||
msgstr "Validé"
|
msgstr "Terminé"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_result__state__draft
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_result__state__draft
|
||||||
@@ -281,21 +344,37 @@ msgid "Draft"
|
|||||||
msgstr "Brouillon"
|
msgstr "Brouillon"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: model:ir.actions.report,name:commission_simple.commission_result_xlsx_report
|
||||||
|
msgid "Détails Excel"
|
||||||
|
msgstr "Détails Excel"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__date_end
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__date_end
|
||||||
|
#, python-format
|
||||||
msgid "End Date"
|
msgid "End Date"
|
||||||
msgstr "Date de fin"
|
msgstr "Date de fin"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__date_end
|
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_end
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_end
|
||||||
msgid "End date"
|
msgid "End date"
|
||||||
msgstr "Date de fin"
|
msgstr "Date de fin"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
|
msgid "Excel Export"
|
||||||
|
msgstr "Export Excel"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_follower_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_follower_ids
|
||||||
msgid "Followers"
|
msgid "Followers"
|
||||||
msgstr "Abonnés"
|
msgstr "Abonnés"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_channel_ids
|
||||||
|
msgid "Followers (Channels)"
|
||||||
|
msgstr "Suiveurs (chaînes)"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_partner_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_partner_ids
|
||||||
msgid "Followers (Partners)"
|
msgid "Followers (Partners)"
|
||||||
@@ -307,23 +386,29 @@ msgid "Font awesome icon e.g. fa-tasks"
|
|||||||
msgstr "Îcone font-awesome, par exemple fa-task"
|
msgstr "Îcone font-awesome, par exemple fa-task"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Generated from Odoo on %s by %s"
|
||||||
|
msgstr "Généré à partir d'Odoo le %s par %s"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/models/commission_rule.py:0
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_rule__applied_on__4_global
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_rule__applied_on__4_global
|
||||||
|
#, python-format
|
||||||
msgid "Global"
|
msgid "Global"
|
||||||
msgstr ""
|
msgstr "Global"
|
||||||
|
|
||||||
#. module: commission_simple
|
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__has_message
|
|
||||||
msgid "Has Message"
|
|
||||||
msgstr "A un message"
|
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_invoice_report__id
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__id
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_report_commission_simple_report_xlsx__id
|
||||||
msgid "ID"
|
msgid "ID"
|
||||||
msgstr ""
|
msgstr "ID"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__activity_exception_icon
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__activity_exception_icon
|
||||||
@@ -337,6 +422,7 @@ msgstr "Îcone pour indiquer une activité-alerte"
|
|||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_needaction
|
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_needaction
|
||||||
|
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_unread
|
||||||
msgid "If checked, new messages require your attention."
|
msgid "If checked, new messages require your attention."
|
||||||
msgstr "Si activé, de nouveaux messages nécessitent votre attention."
|
msgstr "Si activé, de nouveaux messages nécessitent votre attention."
|
||||||
|
|
||||||
@@ -347,11 +433,25 @@ msgstr "Si activé, des messages ont une erreur d'envoi."
|
|||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__in_payment
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__in_payment
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_search
|
||||||
msgid "In Payment and Paid"
|
msgid "In Payment and Paid"
|
||||||
msgstr "En paiement et payé"
|
msgstr "En paiement et payé"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Invoice"
|
||||||
|
msgstr "Facture"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Invoice Date"
|
||||||
|
msgstr "Date de facture"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__invoice
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__invoice
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_search
|
||||||
msgid "Invoiced"
|
msgid "Invoiced"
|
||||||
msgstr "Facturé"
|
msgstr "Facturé"
|
||||||
|
|
||||||
@@ -361,6 +461,11 @@ msgstr "Facturé"
|
|||||||
msgid "Invoiced Amount"
|
msgid "Invoiced Amount"
|
||||||
msgstr "Montant facturé"
|
msgstr "Montant facturé"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model,name:commission_simple.model_account_invoice_report
|
||||||
|
msgid "Invoices Statistics"
|
||||||
|
msgstr "Statistiques des factures"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_is_follower
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_is_follower
|
||||||
msgid "Is Follower"
|
msgid "Is Follower"
|
||||||
@@ -372,11 +477,14 @@ msgid "Journal Item"
|
|||||||
msgstr "Écriture comptable"
|
msgstr "Écriture comptable"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_invoice_report____last_update
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line____last_update
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute____last_update
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute____last_update
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile____last_update
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile____last_update
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment____last_update
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment____last_update
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result____last_update
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result____last_update
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule____last_update
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule____last_update
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_report_commission_simple_report_xlsx____last_update
|
||||||
msgid "Last Modified on"
|
msgid "Last Modified on"
|
||||||
msgstr "Dernière modification le"
|
msgstr "Dernière modification le"
|
||||||
|
|
||||||
@@ -411,7 +519,12 @@ msgstr "Marge"
|
|||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_form
|
||||||
msgid "Match"
|
msgid "Match"
|
||||||
msgstr ""
|
msgstr "Correspondance"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__apply_description
|
||||||
|
msgid "Match Criteria"
|
||||||
|
msgstr "Critères de correspondance"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_rule_id
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__commission_rule_id
|
||||||
@@ -426,7 +539,20 @@ msgstr "Erreur d'envoi du message"
|
|||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_ids
|
||||||
msgid "Messages"
|
msgid "Messages"
|
||||||
|
msgstr "Messages"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Missing Period Start Date."
|
||||||
|
msgstr "Date de début de la période manquante."
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Missing commission periodicity on commission profile '%s'."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
"Périodicité des commissions manquante sur le profil de commission '%s'."
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__my_activity_date_deadline
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__my_activity_date_deadline
|
||||||
@@ -438,11 +564,6 @@ msgstr "Date butoir de l'activité"
|
|||||||
msgid "Name of the Profile"
|
msgid "Name of the Profile"
|
||||||
msgstr "Nom du profil"
|
msgstr "Nom du profil"
|
||||||
|
|
||||||
#. module: commission_simple
|
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__activity_calendar_event_id
|
|
||||||
msgid "Next Activity Calendar Event"
|
|
||||||
msgstr "Prochaine activité du calendrier"
|
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__activity_date_deadline
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__activity_date_deadline
|
||||||
msgid "Next Activity Deadline"
|
msgid "Next Activity Deadline"
|
||||||
@@ -459,7 +580,6 @@ msgid "Next Activity Type"
|
|||||||
msgstr "Type de l'activité suivante"
|
msgstr "Type de l'activité suivante"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
#: code:addons/commission_simple/wizards/commission_compute.py:0
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "No commissions generated."
|
msgid "No commissions generated."
|
||||||
@@ -477,7 +597,7 @@ msgstr "Nombre d'erreurs"
|
|||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_needaction_counter
|
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_needaction_counter
|
||||||
msgid "Number of messages requiring action"
|
msgid "Number of messages which requires an action"
|
||||||
msgstr "Nombre de messages nécessitant une action"
|
msgstr "Nombre de messages nécessitant une action"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
@@ -485,18 +605,39 @@ msgstr "Nombre de messages nécessitant une action"
|
|||||||
msgid "Number of messages with delivery error"
|
msgid "Number of messages with delivery error"
|
||||||
msgstr "Nombre de messages en échec d'envoi"
|
msgstr "Nombre de messages en échec d'envoi"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,help:commission_simple.field_commission_result__message_unread_counter
|
||||||
|
msgid "Number of unread messages"
|
||||||
|
msgstr "Nombre de messages non lus"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__paid
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_profile__trigger_type__paid
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_profile_search
|
||||||
msgid "Paid"
|
msgid "Paid"
|
||||||
msgstr "Payé"
|
msgstr "Payé"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__date_range_id
|
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_range_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_range_id
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
||||||
msgid "Period"
|
msgid "Period"
|
||||||
msgstr "Période"
|
msgstr "Période"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__date_start
|
||||||
|
msgid "Period Start Date"
|
||||||
|
msgstr "Date de début des périodes"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
|
msgid "Price"
|
||||||
|
msgstr "Prix"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Product"
|
||||||
|
msgstr "Produit"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__product_categ_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__product_categ_ids
|
||||||
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_rule__applied_on__3_product_category
|
#: model:ir.model.fields.selection,name:commission_simple.selection__commission_rule__applied_on__3_product_category
|
||||||
@@ -508,6 +649,12 @@ msgstr "Catégories de produits"
|
|||||||
msgid "Product Categories and Customers"
|
msgid "Product Categories and Customers"
|
||||||
msgstr "Catégories de produits et clients"
|
msgstr "Catégories de produits et clients"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/models/commission_rule.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Product Categories:"
|
||||||
|
msgstr "Catégories de produits :"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__product_categ_id
|
#: model:ir.model.fields,field_description:commission_simple.field_account_move_line__product_categ_id
|
||||||
msgid "Product Category"
|
msgid "Product Category"
|
||||||
@@ -524,6 +671,12 @@ msgstr "Produits"
|
|||||||
msgid "Products and Customers"
|
msgid "Products and Customers"
|
||||||
msgstr "Produits et clients"
|
msgstr "Produits et clients"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/models/commission_rule.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Products:"
|
||||||
|
msgstr "Produits :"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__profile_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__profile_id
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__profile_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__profile_id
|
||||||
@@ -531,6 +684,12 @@ msgstr "Produits et clients"
|
|||||||
msgid "Profile"
|
msgid "Profile"
|
||||||
msgstr "Profil"
|
msgstr "Profil"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Quantity"
|
||||||
|
msgstr "Quantité"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_form
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_tree
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_rule_tree
|
||||||
@@ -553,7 +712,6 @@ msgid "Rules"
|
|||||||
msgstr "Règles"
|
msgstr "Règles"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple/models/commission_profile.py:0
|
#: code:addons/commission_simple/models/commission_profile.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__user_id
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__user_id
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
#: model_terms:ir.ui.view,arch_db:commission_simple.commission_result_search
|
||||||
@@ -566,18 +724,24 @@ msgstr "Vendeur"
|
|||||||
msgid "Salesman/Agent"
|
msgid "Salesman/Agent"
|
||||||
msgstr "Vendeur/Agent"
|
msgstr "Vendeur/Agent"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,help:commission_simple.field_account_move_line__product_categ_id
|
||||||
|
msgid "Select category for the current product"
|
||||||
|
msgstr "Sélectionnez la catégorie du produit"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__sequence
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile__sequence
|
||||||
msgid "Sequence"
|
msgid "Sequence"
|
||||||
msgstr "Séquence"
|
msgstr "Séquence"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__date_start
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_rule__date_start
|
||||||
|
#, python-format
|
||||||
msgid "Start Date"
|
msgid "Start Date"
|
||||||
msgstr "Date de début"
|
msgstr "Date de début"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_compute__date_start
|
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_start
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__date_start
|
||||||
msgid "Start date"
|
msgid "Start date"
|
||||||
msgstr "Date de début"
|
msgstr "Date de début"
|
||||||
@@ -613,13 +777,29 @@ msgstr "Déclencheur"
|
|||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__assign_type
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_profile_assignment__assign_type
|
||||||
msgid "Type"
|
msgid "Type"
|
||||||
msgstr ""
|
msgstr "Type"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,help:commission_simple.field_commission_result__activity_exception_decoration
|
#: model:ir.model.fields,help:commission_simple.field_commission_result__activity_exception_decoration
|
||||||
msgid "Type of the exception activity on record."
|
msgid "Type of the exception activity on record."
|
||||||
msgstr "Type de l'activité-alerte sur l'enregistrement."
|
msgstr "Type de l'activité-alerte sur l'enregistrement."
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: code:addons/commission_simple/reports/commission_result_xlsx.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Unit"
|
||||||
|
msgstr "Unité"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_unread
|
||||||
|
msgid "Unread Messages"
|
||||||
|
msgstr "Messages non lus"
|
||||||
|
|
||||||
|
#. module: commission_simple
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__message_unread_counter
|
||||||
|
msgid "Unread Messages Counter"
|
||||||
|
msgstr "Compteur de messages non lus"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__website_message_ids
|
#: model:ir.model.fields,field_description:commission_simple.field_commission_result__website_message_ids
|
||||||
msgid "Website Messages"
|
msgid "Website Messages"
|
||||||
@@ -631,10 +811,9 @@ msgid "Website communication history"
|
|||||||
msgstr "Historique des échanges sur le site Web"
|
msgstr "Historique des échanges sur le site Web"
|
||||||
|
|
||||||
#. module: commission_simple
|
#. module: commission_simple
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple/models/commission_result.py:0
|
#: code:addons/commission_simple/models/commission_result.py:0
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "You cannot delete commission result %s because it is in done state."
|
msgid "You cannot delete commission result %s because it is in done state."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Vous ne pouvez pas supprimer l'état de commission %s parce qu'il est à "
|
"Vous ne pouvez pas supprimer l'état de commission %s parce qu'il est à "
|
||||||
"l'état \"validé\"."
|
"l'état \"terminé\"."
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
from . import commission_profile
|
from . import commission_profile
|
||||||
from . import commission_rule
|
from . import commission_rule
|
||||||
from . import commission_result
|
from . import commission_result
|
||||||
from . import res_company
|
|
||||||
from . import account_move_line
|
from . import account_move_line
|
||||||
|
from . import account_invoice_report
|
||||||
|
|||||||
17
commission_simple/models/account_invoice_report.py
Normal file
17
commission_simple/models/account_invoice_report.py
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
# Copyright 2018-2019 Akretion France (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from odoo import api, fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class AccountInvoiceReport(models.Model):
|
||||||
|
_inherit = 'account.invoice.report'
|
||||||
|
|
||||||
|
commission_amount = fields.Float(readonly=True)
|
||||||
|
|
||||||
|
@api.model
|
||||||
|
def _select(self):
|
||||||
|
select_str = super()._select()
|
||||||
|
select_str += ", line.commission_amount * currency_table.rate AS commission_amount"
|
||||||
|
return select_str
|
||||||
@@ -11,7 +11,7 @@ class AccountMoveLine(models.Model):
|
|||||||
_inherit = 'account.move.line'
|
_inherit = 'account.move.line'
|
||||||
|
|
||||||
commission_result_id = fields.Many2one(
|
commission_result_id = fields.Many2one(
|
||||||
'commission.result', string='Commission Result', check_company=True)
|
'commission.result', string='Commission Result', check_company=True, index=True)
|
||||||
commission_rule_id = fields.Many2one(
|
commission_rule_id = fields.Many2one(
|
||||||
'commission.rule', 'Matched Commission Rule', ondelete='restrict', check_company=True)
|
'commission.rule', 'Matched Commission Rule', ondelete='restrict', check_company=True)
|
||||||
commission_base = fields.Monetary('Commission Base', currency_field='company_currency_id')
|
commission_base = fields.Monetary('Commission Base', currency_field='company_currency_id')
|
||||||
@@ -88,3 +88,18 @@ class AccountMoveLine(models.Model):
|
|||||||
if float_is_zero(lvals['commission_rate'], precision_digits=rate_prec) or self.company_currency_id.is_zero(lvals['commission_base']):
|
if float_is_zero(lvals['commission_rate'], precision_digits=rate_prec) or self.company_currency_id.is_zero(lvals['commission_base']):
|
||||||
return False
|
return False
|
||||||
return lvals
|
return lvals
|
||||||
|
|
||||||
|
def _prepare_commission_xlsx(self):
|
||||||
|
self.ensure_one()
|
||||||
|
vals = {
|
||||||
|
"inv.name": self.move_id.name,
|
||||||
|
"inv.date": self.move_id.invoice_date,
|
||||||
|
"inv.partner": self.move_id.commercial_partner_id.display_name,
|
||||||
|
"product": self.product_id and self.product_id.display_name or self.name,
|
||||||
|
"qty": self.quantity,
|
||||||
|
"uom": self.product_uom_id.name,
|
||||||
|
"commission_base": self.commission_base,
|
||||||
|
"commission_rate": self.commission_rate / 100,
|
||||||
|
"commission_amount": self.commission_amount,
|
||||||
|
}
|
||||||
|
return vals
|
||||||
|
|||||||
@@ -27,6 +27,9 @@ class CommissionProfile(models.Model):
|
|||||||
('paid', 'Paid'),
|
('paid', 'Paid'),
|
||||||
('in_payment', 'In Payment and Paid'),
|
('in_payment', 'In Payment and Paid'),
|
||||||
], default='paid', string='Trigger', required=True)
|
], default='paid', string='Trigger', required=True)
|
||||||
|
date_range_type_id = fields.Many2one(
|
||||||
|
'date.range.type', string='Commission Periodicity', ondelete='restrict',
|
||||||
|
domain="[('company_id', 'in', (False, company_id))]")
|
||||||
|
|
||||||
|
|
||||||
class CommissionProfileAssignment(models.Model):
|
class CommissionProfileAssignment(models.Model):
|
||||||
@@ -76,6 +79,7 @@ class CommissionProfileAssignment(models.Model):
|
|||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
domain = [
|
domain = [
|
||||||
('display_type', '=', False),
|
('display_type', '=', False),
|
||||||
|
('exclude_from_invoice_tab', '=', False),
|
||||||
('move_id.move_type', 'in', ('out_invoice', 'out_refund')),
|
('move_id.move_type', 'in', ('out_invoice', 'out_refund')),
|
||||||
('date', '<=', date_range.date_end),
|
('date', '<=', date_range.date_end),
|
||||||
('company_id', '=', self.company_id.id),
|
('company_id', '=', self.company_id.id),
|
||||||
@@ -100,6 +104,7 @@ class CommissionProfileAssignment(models.Model):
|
|||||||
'profile_id': self.profile_id.id,
|
'profile_id': self.profile_id.id,
|
||||||
'date_range_id': date_range.id,
|
'date_range_id': date_range.id,
|
||||||
'assign_type': self.assign_type,
|
'assign_type': self.assign_type,
|
||||||
|
'assignment_id': self.id,
|
||||||
'company_id': self.company_id.id,
|
'company_id': self.company_id.id,
|
||||||
}
|
}
|
||||||
return vals
|
return vals
|
||||||
|
|||||||
@@ -17,6 +17,8 @@ class CommissionResult(models.Model):
|
|||||||
readonly=True, tracking=True)
|
readonly=True, tracking=True)
|
||||||
profile_id = fields.Many2one(
|
profile_id = fields.Many2one(
|
||||||
'commission.profile', string='Commission Profile', readonly=True, tracking=True)
|
'commission.profile', string='Commission Profile', readonly=True, tracking=True)
|
||||||
|
assignment_id = fields.Many2one(
|
||||||
|
'commission.profile.assignment', string="Commission Profile Assignment", readonly=True)
|
||||||
assign_type = fields.Selection('_assign_type_selection', readonly=True, tracking=True)
|
assign_type = fields.Selection('_assign_type_selection', readonly=True, tracking=True)
|
||||||
company_id = fields.Many2one(
|
company_id = fields.Many2one(
|
||||||
'res.company', string='Company', ondelete='cascade',
|
'res.company', string='Company', ondelete='cascade',
|
||||||
@@ -32,7 +34,10 @@ class CommissionResult(models.Model):
|
|||||||
states={'done': [('readonly', True)]})
|
states={'done': [('readonly', True)]})
|
||||||
amount_total = fields.Monetary(
|
amount_total = fields.Monetary(
|
||||||
string='Commission Total', currency_field='company_currency_id',
|
string='Commission Total', currency_field='company_currency_id',
|
||||||
compute='_compute_amount_total', store=True, tracking=True)
|
compute='_compute_totals', store=True, tracking=True)
|
||||||
|
base_total = fields.Monetary(
|
||||||
|
string="Commission Base Total", currency_field='company_currency_id',
|
||||||
|
compute='_compute_totals', store=True, tracking=True)
|
||||||
state = fields.Selection([
|
state = fields.Selection([
|
||||||
('draft', 'Draft'),
|
('draft', 'Draft'),
|
||||||
('done', 'Done'),
|
('done', 'Done'),
|
||||||
@@ -44,12 +49,13 @@ class CommissionResult(models.Model):
|
|||||||
def _assign_type_selection(self):
|
def _assign_type_selection(self):
|
||||||
return self.env['commission.profile.assignment']._assign_type_selection()
|
return self.env['commission.profile.assignment']._assign_type_selection()
|
||||||
|
|
||||||
@api.depends('line_ids.commission_amount')
|
@api.depends('line_ids.commission_amount', 'line_ids.commission_base')
|
||||||
def _compute_amount_total(self):
|
def _compute_totals(self):
|
||||||
rg_res = self.env['account.move.line'].read_group([('commission_result_id', 'in', self.ids)], ['commission_result_id', 'commission_amount:sum'], ['commission_result_id'])
|
rg_res = self.env['account.move.line'].read_group([('commission_result_id', 'in', self.ids)], ['commission_result_id', 'commission_amount:sum', 'commission_base:sum'], ['commission_result_id'])
|
||||||
mapped_data = dict([(x['commission_result_id'][0], x['commission_amount']) for x in rg_res])
|
mapped_data = dict([(x['commission_result_id'][0], {'amount': x['commission_amount'], 'base': x['commission_base']}) for x in rg_res])
|
||||||
for rec in self:
|
for rec in self:
|
||||||
rec.amount_total = mapped_data.get(rec.id, 0)
|
rec.amount_total = mapped_data.get(rec.id, {}).get('amount')
|
||||||
|
rec.base_total = mapped_data.get(rec.id, {}).get('base')
|
||||||
|
|
||||||
def unlink(self):
|
def unlink(self):
|
||||||
for result in self:
|
for result in self:
|
||||||
@@ -59,7 +65,7 @@ class CommissionResult(models.Model):
|
|||||||
return super().unlink()
|
return super().unlink()
|
||||||
|
|
||||||
def draft2done(self):
|
def draft2done(self):
|
||||||
self.write({'state': 'done'})
|
self.filtered(lambda x: x.state == 'draft').write({'state': 'done'})
|
||||||
|
|
||||||
def backtodraft(self):
|
def backtodraft(self):
|
||||||
self.write({'state': 'draft'})
|
self.write({'state': 'draft'})
|
||||||
@@ -75,3 +81,7 @@ class CommissionResult(models.Model):
|
|||||||
'salesman_period_company_unique',
|
'salesman_period_company_unique',
|
||||||
'unique(company_id, partner_id, date_range_id)',
|
'unique(company_id, partner_id, date_range_id)',
|
||||||
'A commission result already exists for this salesman/agent for the same period.')]
|
'A commission result already exists for this salesman/agent for the same period.')]
|
||||||
|
|
||||||
|
def _prepare_xlsx_lines(self):
|
||||||
|
self.ensure_one()
|
||||||
|
return self.line_ids.sorted(key=lambda x: x.move_id.invoice_date)
|
||||||
|
|||||||
@@ -3,13 +3,13 @@
|
|||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
from odoo import fields, models, api
|
from odoo import fields, models, api, _
|
||||||
|
|
||||||
|
|
||||||
class CommissionRule(models.Model):
|
class CommissionRule(models.Model):
|
||||||
_name = 'commission.rule'
|
_name = 'commission.rule'
|
||||||
_description = 'Commission Rule'
|
_description = 'Commission Rule'
|
||||||
_order = 'profile_id, applied_on'
|
_order = 'profile_id, applied_on, rate desc'
|
||||||
|
|
||||||
partner_ids = fields.Many2many(
|
partner_ids = fields.Many2many(
|
||||||
'res.partner', string='Customers', domain=[('parent_id', '=', False)])
|
'res.partner', string='Customers', domain=[('parent_id', '=', False)])
|
||||||
@@ -34,6 +34,31 @@ class CommissionRule(models.Model):
|
|||||||
('4_global', 'Global')],
|
('4_global', 'Global')],
|
||||||
string='Apply On', default='4_global', required=True)
|
string='Apply On', default='4_global', required=True)
|
||||||
active = fields.Boolean(string='Active', default=True)
|
active = fields.Boolean(string='Active', default=True)
|
||||||
|
apply_description = fields.Html(compute='_compute_apply_description', string="Match Criteria")
|
||||||
|
|
||||||
|
_sql_constraints = [(
|
||||||
|
'rate_positive',
|
||||||
|
'CHECK(rate >= 0)',
|
||||||
|
'Rate must be positive !')]
|
||||||
|
|
||||||
|
def _compute_apply_description(self):
|
||||||
|
customer_label = "<strong>" + _("Customers:") + "</strong>"
|
||||||
|
product_label = "<strong>" + _("Products:") + "</strong>"
|
||||||
|
product_categ_label = "<strong>" + _("Product Categories:") + "</strong>"
|
||||||
|
and_label = "<strong>" + _('AND') + "</strong>"
|
||||||
|
for rule in self:
|
||||||
|
desc = False
|
||||||
|
if rule.applied_on == '0_customer_product':
|
||||||
|
desc = f"{customer_label} {', '.join([part.ref or part.name for part in rule.partner_ids])} {and_label} {product_label} {', '.join([pp.default_code or pp.name for pp in rule.product_ids])}"
|
||||||
|
elif rule.applied_on == '1_customer_product_category':
|
||||||
|
desc = f"{customer_label} {', '.join([part.ref or part.name for part in rule.partner_ids])} {and_label} {product_categ_label} {', '.join([categ.display_name for categ in rule.product_categ_ids])}"
|
||||||
|
elif rule.applied_on == '2_product':
|
||||||
|
desc = f"{product_label} {', '.join([pp.default_code or pp.name for pp in rule.product_ids])}"
|
||||||
|
elif rule.applied_on == '3_product_category':
|
||||||
|
desc = f"{product_categ_label} {', '.join([categ.display_name for categ in rule.product_categ_ids])}"
|
||||||
|
elif rule.applied_on == '4_global':
|
||||||
|
desc = _('Global')
|
||||||
|
rule.apply_description = desc
|
||||||
|
|
||||||
@api.model
|
@api.model
|
||||||
def load_all_rules(self):
|
def load_all_rules(self):
|
||||||
@@ -45,8 +70,3 @@ class CommissionRule(models.Model):
|
|||||||
else:
|
else:
|
||||||
res[rule['profile_id'][0]].append(rule)
|
res[rule['profile_id'][0]].append(rule)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
_sql_constraints = [(
|
|
||||||
'rate_positive',
|
|
||||||
'CHECK(rate >= 0)',
|
|
||||||
'Rate must be positive !')]
|
|
||||||
|
|||||||
@@ -1,13 +0,0 @@
|
|||||||
# Copyright 2019-2024 Akretion France (https://www.akretion.com/)
|
|
||||||
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
|
||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
|
||||||
|
|
||||||
|
|
||||||
from odoo import fields, models
|
|
||||||
|
|
||||||
|
|
||||||
class ResCompany(models.Model):
|
|
||||||
_inherit = 'res.company'
|
|
||||||
|
|
||||||
commission_date_range_type_id = fields.Many2one(
|
|
||||||
'date.range.type', string='Commission Periodicity', ondelete='restrict')
|
|
||||||
1
commission_simple/reports/__init__.py
Normal file
1
commission_simple/reports/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
from . import commission_result_xlsx
|
||||||
112
commission_simple/reports/commission_result_xlsx.py
Normal file
112
commission_simple/reports/commission_result_xlsx.py
Normal file
@@ -0,0 +1,112 @@
|
|||||||
|
# Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from odoo import api, fields, models, tools, _
|
||||||
|
from odoo.exceptions import UserError
|
||||||
|
from datetime import datetime
|
||||||
|
from odoo.tools.misc import format_datetime
|
||||||
|
|
||||||
|
|
||||||
|
class CommissionResultXlsx(models.AbstractModel):
|
||||||
|
_name = "report.commission_simple.report_xlsx"
|
||||||
|
_inherit = "report.report_xlsx.abstract"
|
||||||
|
_description = "Commission Result XLSX"
|
||||||
|
|
||||||
|
def generate_xlsx_report(self, workbook, data, objects):
|
||||||
|
# for some strange reasons, lang is not kept in context
|
||||||
|
self = self.with_context(lang=self.env.user.lang)
|
||||||
|
result = objects[0]
|
||||||
|
sheet = workbook.add_worksheet(result.date_range_id.name)
|
||||||
|
styles = self._prepare_styles(workbook, result.company_id)
|
||||||
|
title = _("Commissions of %(partner)s for period %(period)s", partner=result.partner_id.name, period=result.date_range_id.name)
|
||||||
|
now_str = format_datetime(self.env, datetime.now())
|
||||||
|
i = 0
|
||||||
|
sheet.write(i, 0, title, styles['title'])
|
||||||
|
sheet.write(i, 5, _('Generated from Odoo on %s by %s') % (now_str, self.env.user.name), styles['regular_small'])
|
||||||
|
i += 1
|
||||||
|
sheet.write(i, 0, _('Start Date'), styles['subtitle'])
|
||||||
|
sheet.write(i, 1, result.date_start, styles['subtitle_date'])
|
||||||
|
i += 1
|
||||||
|
sheet.write(i, 0, _('End Date'), styles['subtitle'])
|
||||||
|
sheet.write(i, 1, result.date_end, styles['subtitle_date'])
|
||||||
|
i += 1
|
||||||
|
sheet.write(i, 0, _('Currency'), styles['subtitle'])
|
||||||
|
sheet.write(i, 1, result.company_id.currency_id.name, styles['subtitle'])
|
||||||
|
i += 1
|
||||||
|
sheet.write(i, 0, _('Base Total'), styles['subtitle'])
|
||||||
|
sheet.write(i, 1, result.base_total, styles['subtitle_amount'])
|
||||||
|
i += 1
|
||||||
|
sheet.write(i, 0, _('Amount Total'), styles['subtitle'])
|
||||||
|
sheet.write(i, 1, result.amount_total, styles['subtitle_amount'])
|
||||||
|
i += 3
|
||||||
|
cols = self._prepare_xlsx_cols()
|
||||||
|
coldict = {}
|
||||||
|
pos = 0
|
||||||
|
for key, label, width, style_suffix in cols:
|
||||||
|
coldict[key] = {
|
||||||
|
"label": label,
|
||||||
|
"width": width,
|
||||||
|
"pos": pos,
|
||||||
|
"style": style_suffix and f"regular_{style_suffix}" or "regular",
|
||||||
|
}
|
||||||
|
pos += 1
|
||||||
|
# header
|
||||||
|
for col_key, col_vals in coldict.items():
|
||||||
|
sheet.write(i, col_vals['pos'], col_vals['label'], styles['col_title'])
|
||||||
|
sheet.set_column(col_vals['pos'], col_vals['pos'], col_vals['width'])
|
||||||
|
# table content
|
||||||
|
for line in result._prepare_xlsx_lines():
|
||||||
|
i += 1
|
||||||
|
for col_key, value in line._prepare_commission_xlsx().items():
|
||||||
|
sheet.write(i, coldict[col_key]["pos"], value, styles[coldict[col_key]["style"]])
|
||||||
|
|
||||||
|
def _prepare_xlsx_cols(self):
|
||||||
|
cols = [ # key, label, width, style_suffix
|
||||||
|
("inv.name", _("Invoice"), 14, False),
|
||||||
|
("inv.date", _("Invoice Date"), 11, "date"),
|
||||||
|
("inv.partner", _("Customer"), 50, False),
|
||||||
|
("product", _("Product"), 35, False),
|
||||||
|
("qty", _("Quantity"), 8, "qty"),
|
||||||
|
("uom", _("Unit"), 8, False),
|
||||||
|
("commission_base", _("Commission Base"), 14, "amount"),
|
||||||
|
("commission_rate", _("Commission Rate"), 10, "rate"),
|
||||||
|
("commission_amount", _("Commission Amount"), 14, "amount"),
|
||||||
|
]
|
||||||
|
return cols
|
||||||
|
|
||||||
|
def _prepare_styles(self, workbook, company):
|
||||||
|
col_title_bg_color = '#eeeeee'
|
||||||
|
prec_qty = self.env['decimal.precision'].precision_get('Product Unit of Measure')
|
||||||
|
prec_rate = self.env['decimal.precision'].precision_get('Commission Rate')
|
||||||
|
prec_price = self.env['decimal.precision'].precision_get('Product Price')
|
||||||
|
regular_font_size = 10
|
||||||
|
date_format = "dd/mm/yyyy" # TODO depend on lang
|
||||||
|
num_format_amount = f"# ##0.{'0' * company.currency_id.decimal_places}"
|
||||||
|
num_format_qty = f"# ##0.{'0' * prec_qty}"
|
||||||
|
num_format_rate = f"""0.{'0' * prec_rate} " "%"""
|
||||||
|
num_format_price = f"# ##0.{'0' * prec_price}"
|
||||||
|
styles = {
|
||||||
|
'title': workbook.add_format({
|
||||||
|
'bold': True, 'font_size': regular_font_size + 10,
|
||||||
|
'font_color': '#003b6f'}),
|
||||||
|
'subtitle': workbook.add_format({
|
||||||
|
'bold': True, 'font_size': regular_font_size}),
|
||||||
|
'subtitle_date': workbook.add_format({
|
||||||
|
'bold': True, 'font_size': regular_font_size, 'num_format': date_format}),
|
||||||
|
'subtitle_amount': workbook.add_format({
|
||||||
|
'bold': True, 'font_size': regular_font_size, 'num_format': num_format_amount}),
|
||||||
|
'col_title': workbook.add_format({
|
||||||
|
'bold': True, 'bg_color': col_title_bg_color,
|
||||||
|
'text_wrap': True, 'font_size': regular_font_size,
|
||||||
|
'align': 'center',
|
||||||
|
}),
|
||||||
|
'regular_date': workbook.add_format({'num_format': date_format}),
|
||||||
|
'regular_amount': workbook.add_format({'num_format': num_format_amount}),
|
||||||
|
'regular_rate': workbook.add_format({'num_format': num_format_rate}),
|
||||||
|
'regular_qty': workbook.add_format({'num_format': num_format_qty}),
|
||||||
|
'regular_price': workbook.add_format({'num_format': num_format_price}),
|
||||||
|
'regular': workbook.add_format({}),
|
||||||
|
'regular_small': workbook.add_format({'font_size': regular_font_size - 2}),
|
||||||
|
}
|
||||||
|
return styles
|
||||||
20
commission_simple/reports/report.xml
Normal file
20
commission_simple/reports/report.xml
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
The licence is in the file __manifest__.py
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="commission_result_xlsx_report" model="ir.actions.report">
|
||||||
|
<field name="name">Détails Excel</field>
|
||||||
|
<field name="model">commission.result</field>
|
||||||
|
<field name="report_type">xlsx</field>
|
||||||
|
<field name="report_name">commission_simple.report_xlsx</field>
|
||||||
|
<field name="report_file">commission_simple.report_xlsx</field>
|
||||||
|
<field name="print_report_name">'commission-%s-%s' % (object.date_range_id.name.replace(' ', '_'), object.partner_id.name.replace(' ', '_'))</field>
|
||||||
|
<field name="binding_model_id" ref="model_commission_result" />
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
||||||
@@ -8,4 +8,4 @@ access_commission_rule_audit,Read access on commission.rule for viewer group,mod
|
|||||||
access_commission_result_full,Full access on commission.result to accountant,model_commission_result,account.group_account_user,1,1,1,1
|
access_commission_result_full,Full access on commission.result to accountant,model_commission_result,account.group_account_user,1,1,1,1
|
||||||
access_commission_result_read,Read access on commission.result to invoicing grp,model_commission_result,account.group_account_invoice,1,0,0,0
|
access_commission_result_read,Read access on commission.result to invoicing grp,model_commission_result,account.group_account_invoice,1,0,0,0
|
||||||
access_commission_result_audit,Read access on commission.result to viewer grp,model_commission_result,account.group_account_readonly,1,0,0,0
|
access_commission_result_audit,Read access on commission.result to viewer grp,model_commission_result,account.group_account_readonly,1,0,0,0
|
||||||
access_commission_compute_full,Full access to wizard commission.compute,model_commission_compute,account.group_account_manager,1,1,1,1
|
access_commission_compute_full,Full access to wizard commission.compute to Accountant,model_commission_compute,account.group_account_user,1,1,1,1
|
||||||
|
|||||||
|
@@ -22,6 +22,7 @@
|
|||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="active" invisible="1"/>
|
<field name="active" invisible="1"/>
|
||||||
<field name="trigger_type" widget="radio"/>
|
<field name="trigger_type" widget="radio"/>
|
||||||
|
<field name="date_range_type_id"/>
|
||||||
</group>
|
</group>
|
||||||
<group name="main-right">
|
<group name="main-right">
|
||||||
<field name="company_id" invisible="1"/>
|
<field name="company_id" invisible="1"/>
|
||||||
@@ -55,12 +56,31 @@
|
|||||||
<tree>
|
<tree>
|
||||||
<field name="sequence" widget="handle"/>
|
<field name="sequence" widget="handle"/>
|
||||||
<field name="name" decoration-bf="1"/>
|
<field name="name" decoration-bf="1"/>
|
||||||
<field name="trigger_type" optional="show"/>
|
<field name="trigger_type" optional="show" widget="badge" decoration-info="trigger_type == 'invoice'" decoration-success="trigger_type == 'paid'" decoration-warning="trigger_type == 'in_payment'"/>
|
||||||
|
<field name="date_range_type_id" optional="show"/>
|
||||||
<field name="company_id" groups="base.group_multi_company"/>
|
<field name="company_id" groups="base.group_multi_company"/>
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
|
<record id="commission_profile_search" model="ir.ui.view">
|
||||||
|
<field name="model">commission.profile</field>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<search>
|
||||||
|
<field name="name"/>
|
||||||
|
<filter string="Invoiced" name="invoice" domain="[('trigger_type', '=', 'invoice')]"/>
|
||||||
|
<filter string="Paid" name="paid" domain="[('trigger_type', '=', 'paid')]"/>
|
||||||
|
<filter string="In Payment and Paid" name="in_payment" domain="[('trigger_type', '=', 'in_payment')]"/>
|
||||||
|
<separator/>
|
||||||
|
<filter string="Archived" name="inactive" domain="[('active', '=', False)]"/>
|
||||||
|
<separator/>
|
||||||
|
<group name="groupby">
|
||||||
|
<filter name="date_range_type_groupby" string="Commission Periodicity" context="{'group_by': 'date_range_type_id'}"/>
|
||||||
|
</group>
|
||||||
|
</search>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
<record id="commission_profile_action" model="ir.actions.act_window">
|
<record id="commission_profile_action" model="ir.actions.act_window">
|
||||||
<field name="name">Commission Profiles</field>
|
<field name="name">Commission Profiles</field>
|
||||||
<field name="res_model">commission.profile</field>
|
<field name="res_model">commission.profile</field>
|
||||||
|
|||||||
@@ -15,6 +15,7 @@
|
|||||||
<header>
|
<header>
|
||||||
<button name="draft2done" type="object" states="draft" string="Confirm" class="btn-primary"/>
|
<button name="draft2done" type="object" states="draft" string="Confirm" class="btn-primary"/>
|
||||||
<button name="backtodraft" type="object" states="done" string="Back to Draft" confirm="Are you sure you want to go back to draft?"/>
|
<button name="backtodraft" type="object" states="done" string="Back to Draft" confirm="Are you sure you want to go back to draft?"/>
|
||||||
|
<button name="%(commission_simple.commission_result_xlsx_report)d" type="action" string="Excel Export"/>
|
||||||
<field name="state" widget="statusbar"/>
|
<field name="state" widget="statusbar"/>
|
||||||
</header>
|
</header>
|
||||||
<group name="main">
|
<group name="main">
|
||||||
@@ -23,6 +24,7 @@
|
|||||||
<field name="date_range_id"/>
|
<field name="date_range_id"/>
|
||||||
<field name="date_start"/>
|
<field name="date_start"/>
|
||||||
<field name="date_end"/>
|
<field name="date_end"/>
|
||||||
|
<field name="base_total"/>
|
||||||
<field name="amount_total"/>
|
<field name="amount_total"/>
|
||||||
<field name="company_currency_id" invisible="1"/>
|
<field name="company_currency_id" invisible="1"/>
|
||||||
<field name="company_id" invisible="1"/>
|
<field name="company_id" invisible="1"/>
|
||||||
@@ -34,7 +36,7 @@
|
|||||||
</group>
|
</group>
|
||||||
</group>
|
</group>
|
||||||
<group name="lines" string="Commission Lines">
|
<group name="lines" string="Commission Lines">
|
||||||
<field nolabel="1" name="line_ids" colspan="2">
|
<field nolabel="1" name="line_ids" colspan="2" widget="many2many">
|
||||||
<tree>
|
<tree>
|
||||||
<field name="move_id"/>
|
<field name="move_id"/>
|
||||||
<field name="date" optional="hide"/>
|
<field name="date" optional="hide"/>
|
||||||
@@ -42,8 +44,12 @@
|
|||||||
<field name="product_id"/>
|
<field name="product_id"/>
|
||||||
<field name="product_categ_id" optional="hide"/>
|
<field name="product_categ_id" optional="hide"/>
|
||||||
<field name="name" optional="hide"/>
|
<field name="name" optional="hide"/>
|
||||||
|
<field name="quantity" optional="hide"/>
|
||||||
|
<field name="product_uom_id" optional="hide" groups="uom.group_uom"/>
|
||||||
|
<field name="price_unit" string="Price" optional="hide"/>
|
||||||
|
<field name="discount" string="Disc.%" optional="hide"/>
|
||||||
<field name="price_subtotal" optional="hide" string="Invoiced Amount"/>
|
<field name="price_subtotal" optional="hide" string="Invoiced Amount"/>
|
||||||
<field name="commission_base"/>
|
<field name="commission_base" sum="1"/>
|
||||||
<field name="commission_rate" string="Rate (%)"/>
|
<field name="commission_rate" string="Rate (%)"/>
|
||||||
<field name="commission_amount" sum="1"/>
|
<field name="commission_amount" sum="1"/>
|
||||||
<field name="commission_rule_id" optional="hide"/>
|
<field name="commission_rule_id" optional="hide"/>
|
||||||
@@ -66,6 +72,13 @@
|
|||||||
<field name="model">commission.result</field>
|
<field name="model">commission.result</field>
|
||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<tree decoration-info="state == 'draft'">
|
<tree decoration-info="state == 'draft'">
|
||||||
|
<header>
|
||||||
|
<button
|
||||||
|
name="draft2done"
|
||||||
|
type="object"
|
||||||
|
string="Validate"
|
||||||
|
/>
|
||||||
|
</header>
|
||||||
<field name="date_range_id" optional="show"/>
|
<field name="date_range_id" optional="show"/>
|
||||||
<field name="date_start" optional="hide"/>
|
<field name="date_start" optional="hide"/>
|
||||||
<field name="date_end" optional="hide"/>
|
<field name="date_end" optional="hide"/>
|
||||||
@@ -74,6 +87,7 @@
|
|||||||
<field name="assign_type" optional="hide" widget="badge" decoration-warning="assign_type == 'user'"/>
|
<field name="assign_type" optional="hide" widget="badge" decoration-warning="assign_type == 'user'"/>
|
||||||
<field name="company_currency_id" invisible="1"/>
|
<field name="company_currency_id" invisible="1"/>
|
||||||
<field name="company_id" groups="base.group_multi_company"/>
|
<field name="company_id" groups="base.group_multi_company"/>
|
||||||
|
<field name="base_total" sum="1" optional="hide"/>
|
||||||
<field name="amount_total" sum="1" optional="show"/>
|
<field name="amount_total" sum="1" optional="show"/>
|
||||||
<field name="state" decoration-info="state == 'draft'" decoration-success="state == 'done'" widget="badge"/>
|
<field name="state" decoration-info="state == 'draft'" decoration-success="state == 'done'" widget="badge"/>
|
||||||
</tree>
|
</tree>
|
||||||
|
|||||||
@@ -43,11 +43,12 @@
|
|||||||
<field name="arch" type="xml">
|
<field name="arch" type="xml">
|
||||||
<tree>
|
<tree>
|
||||||
<field name="profile_id" invisible="not context.get('commission_rule_main_view')"/>
|
<field name="profile_id" invisible="not context.get('commission_rule_main_view')"/>
|
||||||
<field name="applied_on"/>
|
<field name="applied_on" widget="badge" decoration-danger="applied_on == '0_customer_product'" decoration-warning="applied_on == '1_customer_product_category'" decoration-info="applied_on == '2_product'" decoration-success="applied_on == '3_product_category'"/>
|
||||||
<field name="date_start"/>
|
<field name="apply_description"/>
|
||||||
<field name="date_end"/>
|
<field name="date_start" optional="show"/>
|
||||||
|
<field name="date_end" optional="show"/>
|
||||||
<field name="rate" string="Rate (%)"/>
|
<field name="rate" string="Rate (%)"/>
|
||||||
<field name="base"/>
|
<field name="base" widget="badge" decoration-success="base == 'invoiced'" decoration-warning="base == 'margin'"/>
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
|
|||||||
@@ -1,2 +1 @@
|
|||||||
from . import commission_compute
|
from . import commission_compute
|
||||||
from . import res_config_settings
|
|
||||||
|
|||||||
@@ -3,8 +3,9 @@
|
|||||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
from odoo import api, fields, models, _
|
from odoo import api, fields, models, _
|
||||||
from dateutil.relativedelta import relativedelta
|
from datetime import datetime, timedelta
|
||||||
from odoo.exceptions import UserError
|
from odoo.exceptions import UserError
|
||||||
|
from odoo.tools.misc import format_date
|
||||||
import logging
|
import logging
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
@@ -13,47 +14,45 @@ class CommissionCompute(models.TransientModel):
|
|||||||
_name = 'commission.compute'
|
_name = 'commission.compute'
|
||||||
_description = 'Compute Commissions'
|
_description = 'Compute Commissions'
|
||||||
|
|
||||||
company_id = fields.Many2one('res.company', required=True, default=lambda self: self.env.company)
|
company_id = fields.Many2one('res.company', required=True)
|
||||||
date_range_type_id = fields.Many2one(related='company_id.commission_date_range_type_id')
|
date_start = fields.Date(string="Period Start Date", required=True)
|
||||||
date_range_id = fields.Many2one(
|
|
||||||
'date.range', required=True, string='Period',
|
|
||||||
compute='_compute_date_range_id', store=True, readonly=False,
|
|
||||||
domain="[('type_id', '=', date_range_type_id)]")
|
|
||||||
date_start = fields.Date(related='date_range_id.date_start')
|
|
||||||
date_end = fields.Date(related='date_range_id.date_end')
|
|
||||||
|
|
||||||
@api.depends('company_id')
|
@api.model
|
||||||
def _compute_date_range_id(self):
|
def default_get(self, fields_list):
|
||||||
for wiz in self:
|
res = super().default_get(fields_list)
|
||||||
date_range_id = False
|
company = self.env.company
|
||||||
company = wiz.company_id
|
last_commission_result = self.env['commission.result'].search([
|
||||||
if company and company.commission_date_range_type_id:
|
('company_id', '=', company.id),
|
||||||
type_id = company.commission_date_range_type_id.id
|
], order='date_start desc', limit=1)
|
||||||
last_commission_result = self.env['commission.result'].search([
|
if last_commission_result:
|
||||||
('company_id', '=', company.id),
|
last_start_date = last_commission_result.date_start
|
||||||
], order='date_end desc', limit=1)
|
commissions_last_start_date = self.env['commission.result'].search([
|
||||||
limit_date = last_commission_result and last_commission_result.date_end or (fields.Date.context_today(self) + relativedelta(months=-2, day=31))
|
('date_start', '=', last_start_date),
|
||||||
date_range = self.env['date.range'].search([
|
('company_id', '=', company.id),
|
||||||
('company_id', 'in', (company.id, False)),
|
], order="date_end asc", limit=1)
|
||||||
('type_id', '=', type_id),
|
min_end_date = commissions_last_start_date.date_end
|
||||||
('date_start', '>', limit_date)
|
date_start = min_end_date + timedelta(1)
|
||||||
], order='date_start', limit=1)
|
else:
|
||||||
date_range_id = date_range and date_range.id or False
|
today = fields.Date.context_today(self)
|
||||||
wiz.date_range_id = date_range_id
|
date_start = datetime(today.year, today.month, 1)
|
||||||
|
|
||||||
|
res.update({
|
||||||
|
'company_id': company.id,
|
||||||
|
'date_start': date_start,
|
||||||
|
})
|
||||||
|
return res
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
|
if not self.date_start:
|
||||||
|
raise UserError(_("Missing Period Start Date."))
|
||||||
creso = self.env['commission.result']
|
creso = self.env['commission.result']
|
||||||
date_range = self.date_range_id
|
existing_commissions = creso.search_read([
|
||||||
existing_commissions = creso.search([
|
('date_start', '=', self.date_start),
|
||||||
('date_range_id', '=', date_range.id),
|
|
||||||
('company_id', '=', self.company_id.id),
|
('company_id', '=', self.company_id.id),
|
||||||
])
|
], ['assignment_id'])
|
||||||
if existing_commissions:
|
exclude_assignment_ids = [x['assignment_id'][0] for x in existing_commissions if x['assignment_id']]
|
||||||
raise UserError(_(
|
com_result_ids = self._core_compute(exclude_assignment_ids)
|
||||||
'Commissions already exist for %(period)s in company %(company)s.',
|
|
||||||
period=date_range.display_name, company=self.company_id.display_name))
|
|
||||||
com_result_ids = self._core_compute()
|
|
||||||
if not com_result_ids:
|
if not com_result_ids:
|
||||||
raise UserError(_('No commissions generated.'))
|
raise UserError(_('No commissions generated.'))
|
||||||
action = self.env['ir.actions.actions']._for_xml_id(
|
action = self.env['ir.actions.actions']._for_xml_id(
|
||||||
@@ -64,12 +63,32 @@ class CommissionCompute(models.TransientModel):
|
|||||||
})
|
})
|
||||||
return action
|
return action
|
||||||
|
|
||||||
def _core_compute(self):
|
def _core_compute(self, exclude_assignment_ids):
|
||||||
rules = self.env['commission.rule'].load_all_rules()
|
rules = self.env['commission.rule'].load_all_rules()
|
||||||
com_result_ids = []
|
com_result_ids = []
|
||||||
assignments = self.env['commission.profile.assignment'].search([('company_id', '=', self.company_id.id)])
|
assignments = self.env['commission.profile.assignment'].search(
|
||||||
|
[('company_id', '=', self.company_id.id), ('id', 'not in', exclude_assignment_ids)])
|
||||||
|
date_range_type2date_range = {}
|
||||||
for assignment in assignments:
|
for assignment in assignments:
|
||||||
com_result = assignment._generate_commission_result(self.date_range_id, rules)
|
profile = assignment.profile_id
|
||||||
|
date_range_type = profile.date_range_type_id
|
||||||
|
if not date_range_type:
|
||||||
|
raise UserError(_("Missing commission periodicity on commission profile '%s'.") % profile.display_name)
|
||||||
|
if date_range_type not in date_range_type2date_range:
|
||||||
|
domain = [
|
||||||
|
('date_start', '=', self.date_start),
|
||||||
|
('type_id', '=', date_range_type.id),
|
||||||
|
]
|
||||||
|
date_range = self.env['date.range'].search(
|
||||||
|
domain + [('company_id', '=', self.company_id.id)], limit=1)
|
||||||
|
if not date_range:
|
||||||
|
date_range = self.env['date.range'].search(
|
||||||
|
domain + [('company_id', '=', False)], limit=1)
|
||||||
|
if not date_range:
|
||||||
|
logger.info('There is no date range with type %s starting on %s. Skipping commission generation for assignment ID %s', date_range_type.name, self.date_start, assignment.id)
|
||||||
|
continue
|
||||||
|
date_range_type2date_range[date_range_type] = date_range
|
||||||
|
com_result = assignment._generate_commission_result(date_range_type2date_range[date_range_type], rules)
|
||||||
if com_result:
|
if com_result:
|
||||||
com_result_ids.append(com_result.id)
|
com_result_ids.append(com_result.id)
|
||||||
else:
|
else:
|
||||||
|
|||||||
@@ -15,10 +15,7 @@
|
|||||||
<group name="main">
|
<group name="main">
|
||||||
<field name="company_id" groups="base.group_multi_company"/>
|
<field name="company_id" groups="base.group_multi_company"/>
|
||||||
<field name="company_id" invisible="1"/>
|
<field name="company_id" invisible="1"/>
|
||||||
<field name="date_range_type_id" invisible="1"/>
|
|
||||||
<field name="date_range_id"/>
|
|
||||||
<field name="date_start"/>
|
<field name="date_start"/>
|
||||||
<field name="date_end"/>
|
|
||||||
</group>
|
</group>
|
||||||
<footer>
|
<footer>
|
||||||
<button name="run" type="object" string="Compute"
|
<button name="run" type="object" string="Compute"
|
||||||
@@ -36,6 +33,6 @@
|
|||||||
<field name="target">new</field>
|
<field name="target">new</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<menuitem id="commission_compute_menu" action="commission_compute_action" parent="commission_root" sequence="15" groups="account.group_account_user"/>
|
<menuitem id="commission_compute_menu" action="commission_compute_action" parent="commission_root" sequence="15"/>
|
||||||
|
|
||||||
</odoo>
|
</odoo>
|
||||||
|
|||||||
@@ -4,20 +4,18 @@
|
|||||||
#
|
#
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: Odoo Server 16.0\n"
|
"Project-Id-Version: Odoo Server 14.0\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2024-11-29 23:32+0000\n"
|
"POT-Creation-Date: 2025-10-17 20:49+0000\n"
|
||||||
"PO-Revision-Date: 2024-11-29 23:32+0000\n"
|
"PO-Revision-Date: 2025-10-17 20:49+0000\n"
|
||||||
"Last-Translator: Alexis de Lattre <alexis.delattre@akretion.com>\n"
|
"Last-Translator: \n"
|
||||||
"Language-Team: \n"
|
"Language-Team: \n"
|
||||||
"Language: fr\n"
|
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"Content-Transfer-Encoding: \n"
|
"Content-Transfer-Encoding: \n"
|
||||||
"Plural-Forms: \n"
|
"Plural-Forms: \n"
|
||||||
|
|
||||||
#. module: commission_simple_agent
|
#. module: commission_simple_agent
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple_agent/models/commission_profile_assignment.py:0
|
#: code:addons/commission_simple_agent/models/commission_profile_assignment.py:0
|
||||||
#: model:ir.model.fields,field_description:commission_simple_agent.field_commission_profile_assignment__agent_id
|
#: model:ir.model.fields,field_description:commission_simple_agent.field_commission_profile_assignment__agent_id
|
||||||
#: model_terms:ir.ui.view,arch_db:commission_simple_agent.commission_result_search
|
#: model_terms:ir.ui.view,arch_db:commission_simple_agent.commission_result_search
|
||||||
@@ -26,7 +24,6 @@ msgid "Agent"
|
|||||||
msgstr "Agent"
|
msgstr "Agent"
|
||||||
|
|
||||||
#. module: commission_simple_agent
|
#. module: commission_simple_agent
|
||||||
#. odoo-python
|
|
||||||
#: code:addons/commission_simple_agent/models/commission_profile_assignment.py:0
|
#: code:addons/commission_simple_agent/models/commission_profile_assignment.py:0
|
||||||
#, python-format
|
#, python-format
|
||||||
msgid "An agent must be selected when the assignment type is 'Agent'."
|
msgid "An agent must be selected when the assignment type is 'Agent'."
|
||||||
@@ -38,6 +35,21 @@ msgstr ""
|
|||||||
msgid "Commission Profile Assignment"
|
msgid "Commission Profile Assignment"
|
||||||
msgstr "Affectation du profil de commission"
|
msgstr "Affectation du profil de commission"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent.field_commission_profile_assignment__display_name
|
||||||
|
msgid "Display Name"
|
||||||
|
msgstr "Nom affiché"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent.field_commission_profile_assignment__id
|
||||||
|
msgid "ID"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#. module: commission_simple_agent
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent.field_commission_profile_assignment____last_update
|
||||||
|
msgid "Last Modified on"
|
||||||
|
msgstr "Dernière modification le"
|
||||||
|
|
||||||
#. module: commission_simple_agent
|
#. module: commission_simple_agent
|
||||||
#: model:ir.model.constraint,message:commission_simple_agent.constraint_commission_profile_assignment_company_agent_uniq
|
#: model:ir.model.constraint,message:commission_simple_agent.constraint_commission_profile_assignment_company_agent_uniq
|
||||||
msgid "This agent already has an assignment in this company."
|
msgid "This agent already has an assignment in this company."
|
||||||
|
|||||||
2
commission_simple_agent_purchase/__init__.py
Normal file
2
commission_simple_agent_purchase/__init__.py
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
from . import models
|
||||||
|
from . import wizards
|
||||||
23
commission_simple_agent_purchase/__manifest__.py
Normal file
23
commission_simple_agent_purchase/__manifest__.py
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
# Copyright 2019-2024 Akretion France (http://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Commission Simple Agent Purchase',
|
||||||
|
'version': '14.0.1.0.0',
|
||||||
|
'category': 'Sales',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Glue module between commission_simple_agent and purchase',
|
||||||
|
'author': 'Akretion',
|
||||||
|
'website': 'https://github.com/akretion/odoo-usability',
|
||||||
|
'depends': [
|
||||||
|
'commission_simple_agent',
|
||||||
|
'purchase',
|
||||||
|
],
|
||||||
|
'data': [
|
||||||
|
'views/commission_result.xml',
|
||||||
|
'views/commission_profile.xml',
|
||||||
|
'wizards/res_config_settings.xml',
|
||||||
|
],
|
||||||
|
'installable': True,
|
||||||
|
}
|
||||||
79
commission_simple_agent_purchase/i18n/fr.po
Normal file
79
commission_simple_agent_purchase/i18n/fr.po
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
# Translation of Odoo Server.
|
||||||
|
# This file contains the translation of the following modules:
|
||||||
|
# * commission_simple_agent_purchase
|
||||||
|
#
|
||||||
|
msgid ""
|
||||||
|
msgstr ""
|
||||||
|
"Project-Id-Version: Odoo Server 16.0\n"
|
||||||
|
"Report-Msgid-Bugs-To: \n"
|
||||||
|
"POT-Creation-Date: 2024-11-29 23:33+0000\n"
|
||||||
|
"PO-Revision-Date: 2024-11-29 23:34+0000\n"
|
||||||
|
"Last-Translator: Alexis de Lattre <alexis.delattre@akretion.com>\n"
|
||||||
|
"Language-Team: \n"
|
||||||
|
"Language: fr\n"
|
||||||
|
"MIME-Version: 1.0\n"
|
||||||
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
|
"Content-Transfer-Encoding: \n"
|
||||||
|
"Plural-Forms: \n"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#. odoo-python
|
||||||
|
#: code:addons/commission_simple_agent_purchase/models/commission_result.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid ""
|
||||||
|
"Cannot delete commission %(commission)s because it is linked to purchase "
|
||||||
|
"order %(po)s. You must delete the purchase order first."
|
||||||
|
msgstr ""
|
||||||
|
"Impossible de supprimer la commission %(commission)s car elle est liée à la "
|
||||||
|
"commande fournisseur %(po)s. Vous devez d'abord supprimer la commande "
|
||||||
|
"fournisseur."
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#. odoo-python
|
||||||
|
#: code:addons/commission_simple_agent_purchase/models/commission_result.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Commission %s"
|
||||||
|
msgstr "Commission %s"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent_purchase.field_res_company__commission_product_id
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent_purchase.field_res_config_settings__commission_product_id
|
||||||
|
msgid "Commission Product"
|
||||||
|
msgstr "Produit de commission"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#: model:ir.model,name:commission_simple_agent_purchase.model_commission_result
|
||||||
|
msgid "Commission Result"
|
||||||
|
msgstr "État des commissions"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#. odoo-python
|
||||||
|
#: code:addons/commission_simple_agent_purchase/models/commission_result.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid "Commission product is not set on company %s."
|
||||||
|
msgstr "Le produit de commission n'est pas défini sur la société %s."
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#: model:ir.model,name:commission_simple_agent_purchase.model_res_company
|
||||||
|
msgid "Companies"
|
||||||
|
msgstr "Sociétés"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#: model:ir.model,name:commission_simple_agent_purchase.model_res_config_settings
|
||||||
|
msgid "Config Settings"
|
||||||
|
msgstr "Configuration"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#: model:ir.model.fields,field_description:commission_simple_agent_purchase.field_commission_result__purchase_id
|
||||||
|
msgid "Purchase Order"
|
||||||
|
msgstr "Commande fournisseur"
|
||||||
|
|
||||||
|
#. module: commission_simple_agent_purchase
|
||||||
|
#. odoo-python
|
||||||
|
#: code:addons/commission_simple_agent_purchase/models/commission_result.py:0
|
||||||
|
#, python-format
|
||||||
|
msgid ""
|
||||||
|
"Purchase Order %s has already been confirmed. You should cancel it first."
|
||||||
|
msgstr ""
|
||||||
|
"La commande fournisseur %s a déjà été confirmée. Vous devez d'abord "
|
||||||
|
"l'annuler."
|
||||||
3
commission_simple_agent_purchase/models/__init__.py
Normal file
3
commission_simple_agent_purchase/models/__init__.py
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
from . import commission_result
|
||||||
|
from . import commission_profile
|
||||||
|
from . import res_company
|
||||||
@@ -0,0 +1,20 @@
|
|||||||
|
# Copyright Akretion France (http://www.akretion.com/)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
|
from odoo import fields, models, api, _
|
||||||
|
from odoo.exceptions import ValidationError
|
||||||
|
|
||||||
|
|
||||||
|
class CommissionProfile(models.Model):
|
||||||
|
_inherit = 'commission.profile'
|
||||||
|
|
||||||
|
commission_product_id = fields.Many2one(
|
||||||
|
'product.product', string='Specific Commission Product', ondelete='restrict',
|
||||||
|
check_company=True,
|
||||||
|
domain=[('type', '=', 'service')],
|
||||||
|
help="If not set, Odoo will use the commission product configured on the accounting "
|
||||||
|
"configuration page."
|
||||||
|
)
|
||||||
|
|
||||||
111
commission_simple_agent_purchase/models/commission_result.py
Normal file
111
commission_simple_agent_purchase/models/commission_result.py
Normal file
@@ -0,0 +1,111 @@
|
|||||||
|
# Copyright Akretion France (https://www.akretion.com/)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from odoo import fields, models, _
|
||||||
|
from odoo.exceptions import UserError
|
||||||
|
from odoo.tools.misc import format_amount, formatLang
|
||||||
|
from markupsafe import Markup
|
||||||
|
|
||||||
|
|
||||||
|
class CommissionResult(models.Model):
|
||||||
|
_inherit = 'commission.result'
|
||||||
|
|
||||||
|
purchase_id = fields.Many2one('purchase.order', string="Purchase Order", tracking=True, readonly=True)
|
||||||
|
|
||||||
|
def draft2done(self):
|
||||||
|
for result in self:
|
||||||
|
if result.assign_type == 'agent':
|
||||||
|
if not result.purchase_id:
|
||||||
|
vals = result._prepare_purchase_order()
|
||||||
|
po = self.env['purchase.order'].create(vals)
|
||||||
|
po.message_post(body=Markup(_("Generated from commission <a href=# data-oe-model=commission.result data-oe-id=%d>%s</a>.") % (result.id, result.display_name)))
|
||||||
|
result.write({'purchase_id': po.id})
|
||||||
|
else:
|
||||||
|
po = self.purchase_id
|
||||||
|
if po.state in ('draft', 'sent', 'cancel'):
|
||||||
|
po.order_line.unlink()
|
||||||
|
po.message_post(body=Markup(_("Purchase order lines re-generated from commission <a href=# data-oe-model=commission.result data-oe-id=%d>%s</a>.") % (result.id, result.display_name)))
|
||||||
|
else:
|
||||||
|
raise UserError(_("Purchase Order %s has already been confirmed. You should cancel it first.") % po.display_name)
|
||||||
|
if po.state == 'cancel':
|
||||||
|
po.button_draft()
|
||||||
|
assert not po.order_line
|
||||||
|
# create lines
|
||||||
|
line_vals = []
|
||||||
|
if not result.company_id.commission_po_config:
|
||||||
|
raise UserError(_(
|
||||||
|
"Purchase order configuration for commission is not set on "
|
||||||
|
"the accounting configuration page of company '%s'.")
|
||||||
|
% result.company_id.display_name)
|
||||||
|
if result.company_id.commission_po_config == 'single_line':
|
||||||
|
line_vals.append(result._prepare_purchase_order_line_single_line(po))
|
||||||
|
else:
|
||||||
|
for move_line in result.line_ids:
|
||||||
|
line_vals.append(result._prepare_purchase_order_line(move_line, po))
|
||||||
|
po_lines = self.env['purchase.order.line'].create(line_vals)
|
||||||
|
po_lines._compute_tax_id()
|
||||||
|
return super().draft2done()
|
||||||
|
|
||||||
|
def _prepare_purchase_order(self):
|
||||||
|
self.ensure_one()
|
||||||
|
fp = self.env['account.fiscal.position'].get_fiscal_position(self.partner_id.id)
|
||||||
|
vals = {
|
||||||
|
'partner_id': self.partner_id.id,
|
||||||
|
'origin': _('Commission %s') % self.date_range_id.display_name,
|
||||||
|
'company_id': self.company_id.id,
|
||||||
|
'currency_id': self.company_id.currency_id.id,
|
||||||
|
'fiscal_position_id': fp and fp.id or False,
|
||||||
|
'payment_term_id': self.partner_id.property_supplier_payment_term_id.id,
|
||||||
|
}
|
||||||
|
return vals
|
||||||
|
|
||||||
|
def _prepare_purchase_order_line(self, move_line, order):
|
||||||
|
self.ensure_one()
|
||||||
|
move = move_line.move_id
|
||||||
|
company_currency = move_line.company_id.currency_id
|
||||||
|
lang = self.partner_id.lang or self.env.lang
|
||||||
|
env = self.with_context(lang=lang).env
|
||||||
|
product = self.profile_id.commission_product_id or self.company_id.commission_product_id
|
||||||
|
if not product:
|
||||||
|
raise UserError(_(
|
||||||
|
"Commission product is not set on profile '%(profile)s' "
|
||||||
|
"nor on company '%(company)s'.",
|
||||||
|
profile=self.profile_id.display_name,
|
||||||
|
company=self.company_id.display_name))
|
||||||
|
vals = {
|
||||||
|
'order_id': order.id,
|
||||||
|
'product_id': product.id,
|
||||||
|
'name': f"""{move.name} {move.commercial_partner_id.name}: {move_line.product_id.display_name} x {formatLang(env, move_line.quantity, dp='Product Unit of Measure')} {move_line.product_uom_id.display_name}\n{_('Base:')} {format_amount(env, move_line.commission_base, company_currency)} - {_('Rate:')} {formatLang(env, move_line.commission_rate, dp='Commission Rate')} %""",
|
||||||
|
'product_qty': 1,
|
||||||
|
'product_uom': product.uom_id.id,
|
||||||
|
'price_unit': move_line.commission_amount,
|
||||||
|
}
|
||||||
|
return vals
|
||||||
|
|
||||||
|
def _prepare_purchase_order_line_single_line(self, order):
|
||||||
|
product = self.profile_id.commission_product_id or self.company_id.commission_product_id
|
||||||
|
if not product:
|
||||||
|
raise UserError(_(
|
||||||
|
"Commission product is not set on profile '%(profile)s' "
|
||||||
|
"nor on company '%(company)s'.",
|
||||||
|
profile=self.profile_id.display_name,
|
||||||
|
company=self.company_id.display_name))
|
||||||
|
vals = {
|
||||||
|
'order_id': order.id,
|
||||||
|
'product_id': product.id,
|
||||||
|
'name': _("Commissions for period %(period)s", period=self.date_range_id.name),
|
||||||
|
'product_qty': 1,
|
||||||
|
'product_uom': product.uom_id.id,
|
||||||
|
'price_unit': self.amount_total,
|
||||||
|
}
|
||||||
|
return vals
|
||||||
|
|
||||||
|
def unlink(self):
|
||||||
|
for result in self:
|
||||||
|
if result.purchase_id:
|
||||||
|
raise UserError(_(
|
||||||
|
"Cannot delete commission %(commission)s because it is linked to "
|
||||||
|
"purchase order %(po)s. You must delete the purchase order first.",
|
||||||
|
commission=result.display_name, po=result.purchase_id.display_name))
|
||||||
|
return super().unlink()
|
||||||
18
commission_simple_agent_purchase/models/res_company.py
Normal file
18
commission_simple_agent_purchase/models/res_company.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# Copyright 2024 Akretion France (https://www.akretion.com/)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
|
from odoo import fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class ResCompany(models.Model):
|
||||||
|
_inherit = 'res.company'
|
||||||
|
|
||||||
|
commission_product_id = fields.Many2one(
|
||||||
|
'product.product', string='Commission Product', ondelete='restrict', check_company=True,
|
||||||
|
domain=[('type', '=', 'service')])
|
||||||
|
commission_po_config = fields.Selection([
|
||||||
|
('single_line', 'Single Line'),
|
||||||
|
('details', 'One line per commission line'),
|
||||||
|
], default='details', string="Purchase Order Configuration")
|
||||||
BIN
commission_simple_agent_purchase/static/description/icon.png
Normal file
BIN
commission_simple_agent_purchase/static/description/icon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 9.2 KiB |
@@ -0,0 +1,22 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2025 Akretion France (https://www.akretion.com)
|
||||||
|
@author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl)
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="commission_profile_form" model="ir.ui.view">
|
||||||
|
<field name="model">commission.profile</field>
|
||||||
|
<field name="inherit_id" ref="commission_simple_agent.commission_profile_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<group name="main-right" position="inside">
|
||||||
|
<field name="commission_product_id"/>
|
||||||
|
</group>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
</odoo>
|
||||||
|
|
||||||
21
commission_simple_agent_purchase/views/commission_result.xml
Normal file
21
commission_simple_agent_purchase/views/commission_result.xml
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2019 Akretion France (http://www.akretion.com)
|
||||||
|
@author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl)
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="commission_result_form" model="ir.ui.view">
|
||||||
|
<field name="model">commission.result</field>
|
||||||
|
<field name="inherit_id" ref="commission_simple.commission_result_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<group name="main-right" position="inside">
|
||||||
|
<field name="purchase_id" attrs="{'invisible': [('assign_type', '!=', 'agent')]}"/>
|
||||||
|
</group>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
</odoo>
|
||||||
1
commission_simple_agent_purchase/wizards/__init__.py
Normal file
1
commission_simple_agent_purchase/wizards/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
from . import res_config_settings
|
||||||
@@ -8,5 +8,6 @@ from odoo import fields, models
|
|||||||
class ResConfigSettings(models.TransientModel):
|
class ResConfigSettings(models.TransientModel):
|
||||||
_inherit = 'res.config.settings'
|
_inherit = 'res.config.settings'
|
||||||
|
|
||||||
commission_date_range_type_id = fields.Many2one(
|
commission_product_id = fields.Many2one(
|
||||||
related='company_id.commission_date_range_type_id', readonly=False)
|
related='company_id.commission_product_id', readonly=False)
|
||||||
|
commission_po_config = fields.Selection(related="company_id.commission_po_config", readonly=False)
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--
|
<!--
|
||||||
Copyright 2019-2025 Akretion France (https://www.akretion.com)
|
Copyright 2019-2024 Akretion France (https://www.akretion.com)
|
||||||
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
-->
|
-->
|
||||||
@@ -19,12 +19,13 @@
|
|||||||
<div class="col-12 col-lg-12 o_setting_box" id="commission_simple-settings">
|
<div class="col-12 col-lg-12 o_setting_box" id="commission_simple-settings">
|
||||||
<div class="o_setting_left_pane" />
|
<div class="o_setting_left_pane" />
|
||||||
<div class="o_setting_right_pane">
|
<div class="o_setting_right_pane">
|
||||||
<div class="row" id="commission_date_range_type_id">
|
<div class="row" id="commission_product_id">
|
||||||
<label
|
<label for="commission_product_id" class="col-md-5" />
|
||||||
for="commission_date_range_type_id"
|
<field name="commission_product_id" context="{'default_type': 'service', 'default_purchase_ok': True, 'default_sale_ok': False, 'default_available_in_pos': False, 'default_purchase_method': 'purchase'}"/>
|
||||||
class="col-md-5"
|
</div>
|
||||||
/>
|
<div class="row" id="commission_po_config">
|
||||||
<field name="commission_date_range_type_id" />
|
<label for="commission_po_config" class="col-md-5" string="Purchase Order"/>
|
||||||
|
<field name="commission_po_config" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -7,7 +7,7 @@ MRP Usability
|
|||||||
!! This file is generated by oca-gen-addon-readme !!
|
!! This file is generated by oca-gen-addon-readme !!
|
||||||
!! changes will be overwritten. !!
|
!! changes will be overwritten. !!
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
!! source digest: sha256:1ed999a373f7a5f44bcdeaa09a9b656603a5ef94249420ad4ba5c5788aa56dad
|
!! source digest: sha256:020a9d9474cfd9d4445a4ea664e6acbfdb6c863d85029a3bad67962b934be139
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
|
|
||||||
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
|
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
'website': 'http://www.akretion.com',
|
'website': 'http://www.akretion.com',
|
||||||
'depends': ['mrp'],
|
'depends': ['mrp'],
|
||||||
'data': [
|
'data': [
|
||||||
|
'security/ir.model.access.csv',
|
||||||
'views/mrp_production.xml',
|
'views/mrp_production.xml',
|
||||||
'views/product_template.xml',
|
'views/product_template.xml',
|
||||||
'views/stock_move_line.xml',
|
'views/stock_move_line.xml',
|
||||||
|
|||||||
3
mrp_usability/security/ir.model.access.csv
Normal file
3
mrp_usability/security/ir.model.access.csv
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
|
mrp.access_uom_category_mrp_manager,Read access on uom.category (inherited in usability module to remove full access),uom.model_uom_category,mrp.group_mrp_manager,1,0,0,0
|
||||||
|
mrp.access_uom_uom_mrp_manager,Read access on uom.uom (inherited in usability module to remove full access),uom.model_uom_uom,mrp.group_mrp_manager,1,0,0,0
|
||||||
|
@@ -367,7 +367,7 @@ ul.auto-toc {
|
|||||||
!! This file is generated by oca-gen-addon-readme !!
|
!! This file is generated by oca-gen-addon-readme !!
|
||||||
!! changes will be overwritten. !!
|
!! changes will be overwritten. !!
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
!! source digest: sha256:1ed999a373f7a5f44bcdeaa09a9b656603a5ef94249420ad4ba5c5788aa56dad
|
!! source digest: sha256:020a9d9474cfd9d4445a4ea664e6acbfdb6c863d85029a3bad67962b934be139
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
|
||||||
<p><a class="reference external image-reference" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external image-reference" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/licence-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/akretion/odoo-usability/tree/14.0/mrp_usability"><img alt="akretion/odoo-usability" src="https://img.shields.io/badge/github-akretion%2Fodoo--usability-lightgray.png?logo=github" /></a></p>
|
<p><a class="reference external image-reference" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external image-reference" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/licence-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/akretion/odoo-usability/tree/14.0/mrp_usability"><img alt="akretion/odoo-usability" src="https://img.shields.io/badge/github-akretion%2Fodoo--usability-lightgray.png?logo=github" /></a></p>
|
||||||
<p>Small usability improvements on MRP:</p>
|
<p>Small usability improvements on MRP:</p>
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ Akretion:
|
|||||||
"website": "http://www.akretion.com",
|
"website": "http://www.akretion.com",
|
||||||
"depends": ["point_of_sale"],
|
"depends": ["point_of_sale"],
|
||||||
"data": [
|
"data": [
|
||||||
|
"security/ir.model.access.csv",
|
||||||
"report/pos.xml",
|
"report/pos.xml",
|
||||||
"views/report_pos_order.xml",
|
"views/report_pos_order.xml",
|
||||||
"views/pos_category.xml",
|
"views/pos_category.xml",
|
||||||
|
|||||||
3
pos_usability/security/ir.model.access.csv
Normal file
3
pos_usability/security/ir.model.access.csv
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
|
point_of_sale.access_uom_uom_manager,Read access on uom.uom (inherited in usability module to remove full access),uom.model_uom_uom,point_of_sale.group_pos_manager,1,0,0,0
|
||||||
|
|
||||||
|
1
purchase_stock_partner_default_picking_type/__init__.py
Normal file
1
purchase_stock_partner_default_picking_type/__init__.py
Normal file
@@ -0,0 +1 @@
|
|||||||
|
from . import models
|
||||||
24
purchase_stock_partner_default_picking_type/__manifest__.py
Normal file
24
purchase_stock_partner_default_picking_type/__manifest__.py
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
# Copyright (C) 2025 Akretion (https://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Purchase Stock Default Picking Type on Partner',
|
||||||
|
'version': '14.0.1.0.0',
|
||||||
|
'category': 'Purchases',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Configure the default picking type for purchase orders on partners',
|
||||||
|
'description': """
|
||||||
|
Purchase Stock Default Picking Type on Partner
|
||||||
|
==============================================
|
||||||
|
|
||||||
|
Allow to configure on partners the default picking type for purchase orders.
|
||||||
|
|
||||||
|
Please contact Alexis de Lattre from Akretion <alexis.delattre@akretion.com> for any help or question about this module.
|
||||||
|
""",
|
||||||
|
'author': 'Akretion',
|
||||||
|
'website': 'https://github.com/akretion/odoo-usability',
|
||||||
|
'depends': ['purchase_stock'],
|
||||||
|
'data': ['views/res_partner.xml'],
|
||||||
|
'installable': True,
|
||||||
|
}
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
from . import res_partner
|
||||||
|
from . import purchase_order
|
||||||
@@ -0,0 +1,23 @@
|
|||||||
|
# Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from odoo import api, fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class PurchaseOrder(models.Model):
|
||||||
|
_inherit = "purchase.order"
|
||||||
|
|
||||||
|
# If I set picking_type_id as computed field with store=True and readonly=False
|
||||||
|
# it doesn't work when creating a PO from the smartbutton of the partner form view
|
||||||
|
# So, for v14, I use a good old onchange !
|
||||||
|
|
||||||
|
@api.onchange("partner_id", "company_id")
|
||||||
|
def onchange_partner_id(self):
|
||||||
|
super(PurchaseOrder, self).onchange_partner_id()
|
||||||
|
if self.partner_id and self.company_id:
|
||||||
|
partner = self.partner_id.commercial_partner_id.with_company(self.company_id.id)
|
||||||
|
if partner.purchase_picking_type_id:
|
||||||
|
self.picking_type_id = partner.purchase_picking_type_id
|
||||||
|
else:
|
||||||
|
self.picking_type_id = self._get_picking_type(self.company_id.id)
|
||||||
@@ -0,0 +1,15 @@
|
|||||||
|
# Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
# @author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
from odoo import fields, models
|
||||||
|
|
||||||
|
|
||||||
|
class ResPartner(models.Model):
|
||||||
|
_inherit = 'res.partner'
|
||||||
|
|
||||||
|
# Used only for manual POs
|
||||||
|
purchase_picking_type_id = fields.Many2one(
|
||||||
|
'stock.picking.type', string="Purchase Picking Type",
|
||||||
|
company_dependent=True,
|
||||||
|
domain="[('code', '=', 'incoming'), ('company_id', '=', current_company_id)]")
|
||||||
Binary file not shown.
|
After Width: | Height: | Size: 9.2 KiB |
@@ -0,0 +1,21 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
<record id="view_partner_property_form" model="ir.ui.view">
|
||||||
|
<field name="model">res.partner</field>
|
||||||
|
<field name="inherit_id" ref="purchase.view_partner_property_form"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<field name="property_purchase_currency_id" position="before">
|
||||||
|
<field name="purchase_picking_type_id" attrs="{'invisible': [('parent_id', '!=', False)]}"/>
|
||||||
|
</field>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
</odoo>
|
||||||
|
|
||||||
@@ -7,7 +7,7 @@ Purchase Usability
|
|||||||
!! This file is generated by oca-gen-addon-readme !!
|
!! This file is generated by oca-gen-addon-readme !!
|
||||||
!! changes will be overwritten. !!
|
!! changes will be overwritten. !!
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
!! source digest: sha256:6f446fb5c348931178ab424cdfb7c3bb89e8c01492867bc79fd1c643e52662e0
|
!! source digest: sha256:23bdae4eb98dd24f1247782ec786337d70802d8c820a88a87395f7f8ead6267b
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
|
|
||||||
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
|
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
|
||||||
|
|||||||
@@ -12,6 +12,7 @@
|
|||||||
'website': 'http://www.akretion.com',
|
'website': 'http://www.akretion.com',
|
||||||
'depends': ['purchase'],
|
'depends': ['purchase'],
|
||||||
'data': [
|
'data': [
|
||||||
|
'security/ir.model.access.csv',
|
||||||
'views/purchase_order.xml',
|
'views/purchase_order.xml',
|
||||||
'views/purchase_report.xml',
|
'views/purchase_report.xml',
|
||||||
'views/account_move.xml',
|
'views/account_move.xml',
|
||||||
|
|||||||
3
purchase_usability/security/ir.model.access.csv
Normal file
3
purchase_usability/security/ir.model.access.csv
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
|
purchase.access_uom_category_purchase_manager,Read access on uom.category (inherited in usability module to remove full access),uom.model_uom_category,purchase.group_purchase_manager,1,0,0,0
|
||||||
|
purchase.access_uom_uom_purchase_manager,Read access on uom.uom (inherited in usability module to remove full access),uom.model_uom_uom,purchase.group_purchase_manager,1,0,0,0
|
||||||
|
@@ -367,7 +367,7 @@ ul.auto-toc {
|
|||||||
!! This file is generated by oca-gen-addon-readme !!
|
!! This file is generated by oca-gen-addon-readme !!
|
||||||
!! changes will be overwritten. !!
|
!! changes will be overwritten. !!
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
||||||
!! source digest: sha256:6f446fb5c348931178ab424cdfb7c3bb89e8c01492867bc79fd1c643e52662e0
|
!! source digest: sha256:23bdae4eb98dd24f1247782ec786337d70802d8c820a88a87395f7f8ead6267b
|
||||||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->
|
||||||
<p><a class="reference external image-reference" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external image-reference" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/licence-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/akretion/odoo-usability/tree/14.0/purchase_usability"><img alt="akretion/odoo-usability" src="https://img.shields.io/badge/github-akretion%2Fodoo--usability-lightgray.png?logo=github" /></a></p>
|
<p><a class="reference external image-reference" href="https://odoo-community.org/page/development-status"><img alt="Beta" src="https://img.shields.io/badge/maturity-Beta-yellow.png" /></a> <a class="reference external image-reference" href="http://www.gnu.org/licenses/agpl-3.0-standalone.html"><img alt="License: AGPL-3" src="https://img.shields.io/badge/licence-AGPL--3-blue.png" /></a> <a class="reference external image-reference" href="https://github.com/akretion/odoo-usability/tree/14.0/purchase_usability"><img alt="akretion/odoo-usability" src="https://img.shields.io/badge/github-akretion%2Fodoo--usability-lightgray.png?logo=github" /></a></p>
|
||||||
<dl class="docutils">
|
<dl class="docutils">
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
access_sale_invoice_discount_all_lines_sale,Full access on sale.invoice.discount.all.lines to Sale user,model_sale_invoice_discount_all_lines,sales_team.group_sale_salesman,1,1,1,1
|
access_sale_invoice_discount_all_lines_sale,Full access on sale.invoice.discount.all.lines to Sale user,model_sale_invoice_discount_all_lines,sales_team.group_sale_salesman,1,1,1,1
|
||||||
access_sale_invoice_discount_all_lines_invoice,Full access on sale.invoice.discount.all.lines to Invoice user,model_sale_invoice_discount_all_lines,account.group_account_invoice,1,1,1,1
|
access_sale_invoice_discount_all_lines_invoice,Full access on sale.invoice.discount.all.lines to Invoice user,model_sale_invoice_discount_all_lines,account.group_account_invoice,1,1,1,1
|
||||||
|
sale.access_uom_category_sale_manager,Read access on uom.category (inherited in usability module to remove full access),uom.model_uom_category,sales_team.group_sale_manager,1,0,0,0
|
||||||
|
sale.access_uom_uom_sale_manager,Read access on uom.uom (inherited in usability module to remove full access),uom.model_uom_uom,sales_team.group_sale_manager,1,0,0,0
|
||||||
|
|||||||
|
@@ -1 +1 @@
|
|||||||
14.0.20250315.0
|
14.0.20251015.0
|
||||||
@@ -25,6 +25,7 @@ setuptools.setup(
|
|||||||
'odoo14-addon-base_usability',
|
'odoo14-addon-base_usability',
|
||||||
'odoo14-addon-commission_simple',
|
'odoo14-addon-commission_simple',
|
||||||
'odoo14-addon-commission_simple_agent',
|
'odoo14-addon-commission_simple_agent',
|
||||||
|
'odoo14-addon-commission_simple_agent_purchase',
|
||||||
'odoo14-addon-crm_usability',
|
'odoo14-addon-crm_usability',
|
||||||
'odoo14-addon-delivery_usability',
|
'odoo14-addon-delivery_usability',
|
||||||
'odoo14-addon-developer_menu',
|
'odoo14-addon-developer_menu',
|
||||||
@@ -57,6 +58,7 @@ setuptools.setup(
|
|||||||
'odoo14-addon-product_usability',
|
'odoo14-addon-product_usability',
|
||||||
'odoo14-addon-project_usability',
|
'odoo14-addon-project_usability',
|
||||||
'odoo14-addon-purchase_product_tree_default',
|
'odoo14-addon-purchase_product_tree_default',
|
||||||
|
'odoo14-addon-purchase_stock_partner_default_picking_type',
|
||||||
'odoo14-addon-purchase_stock_usability',
|
'odoo14-addon-purchase_stock_usability',
|
||||||
'odoo14-addon-purchase_usability',
|
'odoo14-addon-purchase_usability',
|
||||||
'odoo14-addon-sale_agent',
|
'odoo14-addon-sale_agent',
|
||||||
@@ -87,6 +89,7 @@ setuptools.setup(
|
|||||||
'odoo14-addon-stock_reception_usability',
|
'odoo14-addon-stock_reception_usability',
|
||||||
'odoo14-addon-stock_usability',
|
'odoo14-addon-stock_usability',
|
||||||
'odoo14-addon-stock_valuation_xlsx',
|
'odoo14-addon-stock_valuation_xlsx',
|
||||||
|
'odoo14-addon-stock_valuation_xlsx_viewer',
|
||||||
'odoo14-addon-web_tab_title',
|
'odoo14-addon-web_tab_title',
|
||||||
],
|
],
|
||||||
classifiers=[
|
classifiers=[
|
||||||
|
|||||||
@@ -0,0 +1 @@
|
|||||||
|
../../../../commission_simple_agent_purchase
|
||||||
6
setup/commission_simple_agent_purchase/setup.py
Normal file
6
setup/commission_simple_agent_purchase/setup.py
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
import setuptools
|
||||||
|
|
||||||
|
setuptools.setup(
|
||||||
|
setup_requires=['setuptools-odoo'],
|
||||||
|
odoo_addon=True,
|
||||||
|
)
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
../../../../purchase_stock_partner_default_picking_type
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
import setuptools
|
||||||
|
|
||||||
|
setuptools.setup(
|
||||||
|
setup_requires=['setuptools-odoo'],
|
||||||
|
odoo_addon=True,
|
||||||
|
)
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
../../../../stock_valuation_xlsx_viewer
|
||||||
6
setup/stock_valuation_xlsx_viewer/setup.py
Normal file
6
setup/stock_valuation_xlsx_viewer/setup.py
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
import setuptools
|
||||||
|
|
||||||
|
setuptools.setup(
|
||||||
|
setup_requires=['setuptools-odoo'],
|
||||||
|
odoo_addon=True,
|
||||||
|
)
|
||||||
@@ -4,3 +4,5 @@ access_procurement_scheduler_log_user,Read/Create procurement.scheduler.log to S
|
|||||||
access_procurement_scheduler_log_read,Read access on procurement.scheduler.log to Employee,model_procurement_scheduler_log,base.group_user,1,0,0,0
|
access_procurement_scheduler_log_read,Read access on procurement.scheduler.log to Employee,model_procurement_scheduler_log,base.group_user,1,0,0,0
|
||||||
access_stock_warehouse_orderpoint_employee,Read access on stock.warehouse.orderpoint to employee (needed to open product form view with employee-only group),stock.model_stock_warehouse_orderpoint,base.group_user,1,0,0,0
|
access_stock_warehouse_orderpoint_employee,Read access on stock.warehouse.orderpoint to employee (needed to open product form view with employee-only group),stock.model_stock_warehouse_orderpoint,base.group_user,1,0,0,0
|
||||||
stock.access_stock_inventory_line_user,stock.inventory.line user,stock.model_stock_inventory_line,stock.group_stock_user,1,1,1,1
|
stock.access_stock_inventory_line_user,stock.inventory.line user,stock.model_stock_inventory_line,stock.group_stock_user,1,1,1,1
|
||||||
|
stock.access_uom_category_stock_manager,Read access on uom.category (inherited in usability module to remove full access),uom.model_uom_category,stock.group_stock_manager,1,0,0,0
|
||||||
|
stock.access_uom_uom_stock_manager,Read access on uom.uom (inherited in usability module to remove full access),uom.model_uom_uom,stock.group_stock_manager,1,0,0,0
|
||||||
|
|||||||
|
@@ -1,5 +1,5 @@
|
|||||||
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
access_stock_expiry_depreciation_rule_full,Full access on stock.expiry.depreciation.rule to account manager,model_stock_expiry_depreciation_rule,account.group_account_manager,1,1,1,1
|
access_stock_expiry_depreciation_rule_full,Full access on stock.expiry.depreciation.rule to account manager,model_stock_expiry_depreciation_rule,account.group_account_manager,1,1,1,1
|
||||||
access_stock_expiry_depreciation_rule_read,Read access on stock.expiry.depreciation.rule to stock manager,model_stock_expiry_depreciation_rule,stock.group_stock_manager,1,0,0,0
|
access_stock_expiry_depreciation_rule_read,Read access on stock.expiry.depreciation.rule to stock user,model_stock_expiry_depreciation_rule,stock.group_stock_user,1,0,0,0
|
||||||
access_stock_valuation_xlsx,stock.valuation.xlsx wizard,model_stock_valuation_xlsx,stock.group_stock_user,1,1,1,0
|
access_stock_valuation_xlsx,stock.valuation.xlsx wizard,model_stock_valuation_xlsx,stock.group_stock_user,1,1,1,0
|
||||||
access_stock_variation_xlsx,stock.variation.xlsx wizard,model_stock_variation_xlsx,stock.group_stock_user,1,1,1,0
|
access_stock_variation_xlsx,stock.variation.xlsx wizard,model_stock_variation_xlsx,stock.group_stock_user,1,1,1,0
|
||||||
|
|||||||
|
0
stock_valuation_xlsx_viewer/__init__.py
Normal file
0
stock_valuation_xlsx_viewer/__init__.py
Normal file
28
stock_valuation_xlsx_viewer/__manifest__.py
Normal file
28
stock_valuation_xlsx_viewer/__manifest__.py
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
# Copyright 2025 Akretion France (https://www.akretion.com)
|
||||||
|
# @author Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
'name': 'Stock Valuation XLSX Viewer',
|
||||||
|
'version': '14.0.1.0.0',
|
||||||
|
'category': 'Tools',
|
||||||
|
'license': 'AGPL-3',
|
||||||
|
'summary': 'Glue module between stock_viewer and stock_valuation_xlsx',
|
||||||
|
'description': """
|
||||||
|
Stock Valuation XLSX Viewer
|
||||||
|
===========================
|
||||||
|
|
||||||
|
Allows to use the module stock_valuation_xlsx when the user is part of the Stock/Viewer group.
|
||||||
|
|
||||||
|
This module has been written by Alexis de Lattre from Akretion <alexis.delattre@akretion.com>.
|
||||||
|
""",
|
||||||
|
'author': "Akretion",
|
||||||
|
'website': 'https://github.com/akretion/odoo-usability',
|
||||||
|
'depends': ['stock_viewer', 'stock_valuation_xlsx'],
|
||||||
|
'data': [
|
||||||
|
'security/ir.model.access.csv',
|
||||||
|
'views/stock_menu.xml',
|
||||||
|
],
|
||||||
|
'installable': True,
|
||||||
|
}
|
||||||
4
stock_valuation_xlsx_viewer/security/ir.model.access.csv
Normal file
4
stock_valuation_xlsx_viewer/security/ir.model.access.csv
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
|
||||||
|
access_stock_expiry_depreciation_rule_read,Read access on stock.expiry.depreciation.rule to stock user,stock_valuation_xlsx.model_stock_expiry_depreciation_rule,stock_viewer.group_stock_viewer,1,0,0,0
|
||||||
|
access_stock_valuation_xlsx,stock.valuation.xlsx wizard,stock_valuation_xlsx.model_stock_valuation_xlsx,stock_viewer.group_stock_viewer,1,1,1,0
|
||||||
|
access_stock_variation_xlsx,stock.variation.xlsx wizard,stock_valuation_xlsx.model_stock_variation_xlsx,stock_viewer.group_stock_viewer,1,1,1,0
|
||||||
|
BIN
stock_valuation_xlsx_viewer/static/description/icon.png
Normal file
BIN
stock_valuation_xlsx_viewer/static/description/icon.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 9.2 KiB |
16
stock_valuation_xlsx_viewer/views/stock_menu.xml
Normal file
16
stock_valuation_xlsx_viewer/views/stock_menu.xml
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
Copyright 2025 Akretion France (https://www.akretion.com/)
|
||||||
|
@author: Alexis de Lattre <alexis.delattre@akretion.com>
|
||||||
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||||
|
-->
|
||||||
|
|
||||||
|
<odoo>
|
||||||
|
|
||||||
|
|
||||||
|
<record id="stock.menu_warehouse_report" model="ir.ui.menu">
|
||||||
|
<field name="groups_id" eval="[(4, ref('stock_viewer.group_stock_viewer'))]"/>
|
||||||
|
</record>
|
||||||
|
|
||||||
|
|
||||||
|
</odoo>
|
||||||
Reference in New Issue
Block a user