From 1e48c0a54d47b1f8fea4373a83a479e9f897d895 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=BB=8E=E4=BC=9F=E6=9D=B0?= <674416404@qq.com> Date: Tue, 3 Sep 2019 11:36:40 +0000 Subject: [PATCH] [IMP] move some notions from agreement_legal to agreement we move the is_template field definition and the agreement.type model from the agreement_legal module to the agreement module. The fields are not displayed by default, unless the feature is enabled through a technical feature group, this is configurable in the agreement_sale module (because agreement in itself has no UI, and agreement_legal enables the feature by default) --- agreement/__manifest__.py | 1 + agreement/i18n/zh_CN.po | 157 ++++++++++++++++++++++ agreement/models/__init__.py | 1 + agreement/models/agreement.py | 14 +- agreement/models/agreement_type.py | 12 ++ agreement/readme/CONTRIBUTORS.rst | 1 + agreement/readme/DESCRIPTION.rst | 6 + agreement/security/agreement_security.xml | 9 ++ agreement/views/agreement.xml | 6 +- agreement/views/agreement_type.xml | 54 ++++++++ 10 files changed, 259 insertions(+), 2 deletions(-) create mode 100644 agreement/i18n/zh_CN.po create mode 100644 agreement/models/agreement_type.py create mode 100644 agreement/views/agreement_type.xml diff --git a/agreement/__manifest__.py b/agreement/__manifest__.py index 96638f92b..f340688fc 100644 --- a/agreement/__manifest__.py +++ b/agreement/__manifest__.py @@ -16,6 +16,7 @@ 'security/ir.model.access.csv', 'security/agreement_security.xml', 'views/agreement.xml', + 'views/agreement_type.xml', ], 'demo': ['demo/demo.xml'], 'development_status': 'Beta', diff --git a/agreement/i18n/zh_CN.po b/agreement/i18n/zh_CN.po new file mode 100644 index 000000000..1e76dc1d3 --- /dev/null +++ b/agreement/i18n/zh_CN.po @@ -0,0 +1,157 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * agreement +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2019-09-04 18:23+0000\n" +"Last-Translator: 黎伟杰 <674416404@qq.com>\n" +"Language-Team: none\n" +"Language: zh_CN\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" +"X-Generator: Weblate 3.8\n" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__active +msgid "Active" +msgstr "有效" + +#. module: agreement +#: model:ir.model,name:agreement.model_agreement +#: model_terms:ir.ui.view,arch_db:agreement.agreement_form +msgid "Agreement" +msgstr "协议" + +#. module: agreement +#: model:ir.actions.act_window,name:agreement.agreement_action +#: model:ir.ui.menu,name:agreement.agreement_menu +#: model_terms:ir.ui.view,arch_db:agreement.agreement_tree +msgid "Agreements" +msgstr "协议" + +#. module: agreement +#: model_terms:ir.ui.view,arch_db:agreement.agreement_search +msgid "Archived" +msgstr "已归档" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__company_id +msgid "Company" +msgstr "公司" + +#. module: agreement +#: model_terms:ir.ui.view,arch_db:agreement.agreement_form +msgid "Configuration" +msgstr "配置" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__create_uid +msgid "Created by" +msgstr "创建者" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__create_date +msgid "Created on" +msgstr "创建时间" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__display_name +msgid "Display Name" +msgstr "显示名称" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__end_date +msgid "End Date" +msgstr "结束日期" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__id +msgid "ID" +msgstr "ID" + +#. module: agreement +#: model:ir.model.fields,help:agreement.field_agreement__code +msgid "ID used for internal contract tracking." +msgstr "用于内部合同跟踪的ID。" + +#. module: agreement +#: model:ir.model.fields,help:agreement.field_agreement__active +msgid "If unchecked, it will allow you to hide the agreement without removing it." +msgstr "如果不选中,它将允许您隐藏协议而不删除它。" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement____last_update +msgid "Last Modified on" +msgstr "最后修改时间" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__write_uid +msgid "Last Updated by" +msgstr "最后更新者" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__write_date +msgid "Last Updated on" +msgstr "最后更新时间" + +#. module: agreement +#: model_terms:ir.ui.view,arch_db:agreement.agreement_search +msgid "Name or Number" +msgstr "姓名或号码" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__partner_id +#: model_terms:ir.ui.view,arch_db:agreement.agreement_search +msgid "Partner" +msgstr "业务伙伴" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__code +msgid "Reference" +msgstr "参考" + +#. module: agreement +#: model_terms:ir.ui.view,arch_db:agreement.agreement_search +msgid "Search Agreements" +msgstr "搜索协议" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__signature_date +#: model_terms:ir.ui.view,arch_db:agreement.agreement_search +msgid "Signature Date" +msgstr "签名日期" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__start_date +msgid "Start Date" +msgstr "开始日期" + +#. module: agreement +#: model:ir.model.fields,help:agreement.field_agreement__partner_id +msgid "The customer or vendor this agreement is related to." +msgstr "与本协议相关的客户或供应商。" + +#. module: agreement +#: sql_constraint:agreement:0 +msgid "This agreement code already exists for this partner!" +msgstr "此合作伙伴的协议代码已存在!" + +#. module: agreement +#: model:ir.model.fields,field_description:agreement.field_agreement__name +msgid "Title" +msgstr "标题" + +#. module: agreement +#: model:ir.model.fields,help:agreement.field_agreement__end_date +msgid "When the agreement ends." +msgstr "协议结束时。" + +#. module: agreement +#: model:ir.model.fields,help:agreement.field_agreement__start_date +msgid "When the agreement starts." +msgstr "协议开始时。" diff --git a/agreement/models/__init__.py b/agreement/models/__init__.py index 51f4021fd..8fc631aa1 100644 --- a/agreement/models/__init__.py +++ b/agreement/models/__init__.py @@ -1 +1,2 @@ from . import agreement +from . import agreement_type diff --git a/agreement/models/agreement.py b/agreement/models/agreement.py index b09b4dbc5..68bb8e171 100644 --- a/agreement/models/agreement.py +++ b/agreement/models/agreement.py @@ -12,11 +12,23 @@ class Agreement(models.Model): code = fields.Char(required=True, copy=False) name = fields.Char(required=True) partner_id = fields.Many2one( - 'res.partner', string='Partner', ondelete='restrict', required=True, + 'res.partner', string='Partner', ondelete='restrict', domain=[('parent_id', '=', False)]) company_id = fields.Many2one( 'res.company', string='Company', default=lambda self: self.env['res.company']._company_default_get()) + is_template = fields.Boolean( + string="Is a Template?", + default=False, + copy=False, + help="Set if the agreement is a template. " + "Template agreements don't require a partner." + ) + agreement_type_id = fields.Many2one( + 'agreement.type', + string="Agreement Type", + help="Select the type of agreement", + ) active = fields.Boolean(default=True) signature_date = fields.Date() start_date = fields.Date() diff --git a/agreement/models/agreement_type.py b/agreement/models/agreement_type.py new file mode 100644 index 000000000..a35a64826 --- /dev/null +++ b/agreement/models/agreement_type.py @@ -0,0 +1,12 @@ +# Copyright (C) 2018 - TODAY, Pavlov Media +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class AgreementType(models.Model): + _name = "agreement.type" + _description = "Agreement Types" + + name = fields.Char(string="Name", required=True) + active = fields.Boolean(default=True) diff --git a/agreement/readme/CONTRIBUTORS.rst b/agreement/readme/CONTRIBUTORS.rst index bc3bbf22d..05342b331 100644 --- a/agreement/readme/CONTRIBUTORS.rst +++ b/agreement/readme/CONTRIBUTORS.rst @@ -1,2 +1,3 @@ * Alexis de Lattre * Yves Goldberg +* Alexandre Fayolle diff --git a/agreement/readme/DESCRIPTION.rst b/agreement/readme/DESCRIPTION.rst index c58e0465c..24b6ee5a8 100644 --- a/agreement/readme/DESCRIPTION.rst +++ b/agreement/readme/DESCRIPTION.rst @@ -6,3 +6,9 @@ This module adds an *Agreement* object with the following properties: * signature date. * start date. * end date. + +Optionally, you can also enable using: +* agreement types +* a flag to set an agreement as a template agreement + +(Install agreement_sale to get the configuration settings for these). diff --git a/agreement/security/agreement_security.xml b/agreement/security/agreement_security.xml index d645ef6d6..9784e6b7a 100644 --- a/agreement/security/agreement_security.xml +++ b/agreement/security/agreement_security.xml @@ -13,5 +13,14 @@ ['|', ('company_id', '=', False), ('company_id', 'child_of', [user.company_id.id])] + + Use agreement type + + + + + Use agreement template + + diff --git a/agreement/views/agreement.xml b/agreement/views/agreement.xml index 15f284ce0..8754247cb 100644 --- a/agreement/views/agreement.xml +++ b/agreement/views/agreement.xml @@ -21,7 +21,11 @@ - + + + diff --git a/agreement/views/agreement_type.xml b/agreement/views/agreement_type.xml new file mode 100644 index 000000000..1ca06a478 --- /dev/null +++ b/agreement/views/agreement_type.xml @@ -0,0 +1,54 @@ + + + + + Agreement Type List + agreement.type + + + + + + + + + + Agreement Type Form + agreement.type + +
+
+ +
+ +
+
+
+
+
+
+ + + agreement.type.search + agreement.type + + + + + + + + + + + Agreement Types + agreement.type + tree,form + +