diff --git a/web_action_conditionable/README.rst b/web_action_conditionable/README.rst new file mode 100644 index 000000000..bfdab2e99 --- /dev/null +++ b/web_action_conditionable/README.rst @@ -0,0 +1,113 @@ +======================== +web_action_conditionable +======================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:4bc330cf2cd18ff1c39c729eeae66a68dde8f3252b6825de70919e0f45dcc9fc + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fweb-lightgray.png?logo=github + :target: https://github.com/OCA/web/tree/18.0/web_action_conditionable + :alt: OCA/web +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/web-18-0/web-18-0-web_action_conditionable + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/web&target_branch=18.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +Add support for conditions on create and delete actions on One2Many +fields. + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +Odoo by default support: + +:: + + + +with this module you can: + +:: + + + +It works in any tree view, so you can use it in One2many. + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* Cristian Salamea + +Contributors +------------ + +- Cristian Salamea + +- André Paramés (https://www.acsone.eu/) + +- Alexandre Díaz + +- Sudhir Arya + +- Jasper Jumelet + +- `Trobz `__: + + - Nguyễn Minh Chiến + - Tran Thanh Trai + +Other credits +------------- + +The migration of this module from 15.0 to 17.0 was financially supported +by Camptocamp + +Maintainers +----------- + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +This module is part of the `OCA/web `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/web_action_conditionable/__init__.py b/web_action_conditionable/__init__.py new file mode 100644 index 000000000..e69de29bb diff --git a/web_action_conditionable/__manifest__.py b/web_action_conditionable/__manifest__.py new file mode 100644 index 000000000..7ae1abff4 --- /dev/null +++ b/web_action_conditionable/__manifest__.py @@ -0,0 +1,16 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +{ + "name": "web_action_conditionable", + "version": "18.0.1.0.0", + "depends": ["base", "web"], + "data": [], + "author": "Cristian Salamea,Odoo Community Association (OCA)", + "website": "https://github.com/OCA/web", + "license": "AGPL-3", + "assets": { + "web.assets_backend": [ + "web_action_conditionable/static/src/components/*", + ], + }, + "installable": True, +} diff --git a/web_action_conditionable/i18n/es.po b/web_action_conditionable/i18n/es.po new file mode 100644 index 000000000..e69de29bb diff --git a/web_action_conditionable/i18n/hr.po b/web_action_conditionable/i18n/hr.po new file mode 100644 index 000000000..e69de29bb diff --git a/web_action_conditionable/i18n/it.po b/web_action_conditionable/i18n/it.po new file mode 100644 index 000000000..73388557f --- /dev/null +++ b/web_action_conditionable/i18n/it.po @@ -0,0 +1,14 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: Automatically generated\n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" diff --git a/web_action_conditionable/i18n/web_action_conditionable.pot b/web_action_conditionable/i18n/web_action_conditionable.pot new file mode 100644 index 000000000..78d58d53f --- /dev/null +++ b/web_action_conditionable/i18n/web_action_conditionable.pot @@ -0,0 +1,13 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" diff --git a/web_action_conditionable/i18n/zh_CN.po b/web_action_conditionable/i18n/zh_CN.po new file mode 100644 index 000000000..e69de29bb diff --git a/web_action_conditionable/pyproject.toml b/web_action_conditionable/pyproject.toml new file mode 100644 index 000000000..4231d0ccc --- /dev/null +++ b/web_action_conditionable/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/web_action_conditionable/readme/CONTRIBUTORS.md b/web_action_conditionable/readme/CONTRIBUTORS.md new file mode 100644 index 000000000..5361a82e9 --- /dev/null +++ b/web_action_conditionable/readme/CONTRIBUTORS.md @@ -0,0 +1,13 @@ +- Cristian Salamea \<\> + +- André Paramés \<\> () + +- Alexandre Díaz \<\> + +- Sudhir Arya \<\> + +- Jasper Jumelet \<\> + +- [Trobz](https://trobz.com): + - Nguyễn Minh Chiến \<\> + - Tran Thanh Trai \<\> diff --git a/web_action_conditionable/readme/CREDITS.md b/web_action_conditionable/readme/CREDITS.md new file mode 100644 index 000000000..42d9c02ed --- /dev/null +++ b/web_action_conditionable/readme/CREDITS.md @@ -0,0 +1,2 @@ +The migration of this module from 15.0 to 17.0 was financially supported +by Camptocamp diff --git a/web_action_conditionable/readme/DESCRIPTION.md b/web_action_conditionable/readme/DESCRIPTION.md new file mode 100644 index 000000000..f2447e0a1 --- /dev/null +++ b/web_action_conditionable/readme/DESCRIPTION.md @@ -0,0 +1,2 @@ +Add support for conditions on create and delete actions on One2Many +fields. diff --git a/web_action_conditionable/readme/USAGE.md b/web_action_conditionable/readme/USAGE.md new file mode 100644 index 000000000..141711299 --- /dev/null +++ b/web_action_conditionable/readme/USAGE.md @@ -0,0 +1,9 @@ +Odoo by default support: + + + +with this module you can: + + + +It works in any tree view, so you can use it in One2many. diff --git a/web_action_conditionable/static/description/icon.png b/web_action_conditionable/static/description/icon.png new file mode 100644 index 000000000..3a0328b51 Binary files /dev/null and b/web_action_conditionable/static/description/icon.png differ diff --git a/web_action_conditionable/static/description/index.html b/web_action_conditionable/static/description/index.html new file mode 100644 index 000000000..44bfcdf05 --- /dev/null +++ b/web_action_conditionable/static/description/index.html @@ -0,0 +1,452 @@ + + + + + +web_action_conditionable + + + +
+

web_action_conditionable

+ + +

Beta License: AGPL-3 OCA/web Translate me on Weblate Try me on Runboat

+

Add support for conditions on create and delete actions on One2Many +fields.

+

Table of contents

+ +
+

Usage

+

Odoo by default support:

+
+<tree delete="false" create="false">
+
+

with this module you can:

+
+<tree delete="state=='draft'" create="state!='sent'">
+
+

It works in any tree view, so you can use it in One2many.

+
+
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Authors

+
    +
  • Cristian Salamea
  • +
+
+
+

Contributors

+ +
+
+

Other credits

+

The migration of this module from 15.0 to 17.0 was financially supported +by Camptocamp

+
+
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

This module is part of the OCA/web project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/web_action_conditionable/static/src/components/field_one2many.esm.js b/web_action_conditionable/static/src/components/field_one2many.esm.js new file mode 100644 index 000000000..a4065fc17 --- /dev/null +++ b/web_action_conditionable/static/src/components/field_one2many.esm.js @@ -0,0 +1,41 @@ +/** @odoo-module **/ +/* global console */ +import {X2ManyField} from "@web/views/fields/x2many/x2many_field"; +import {evaluateExpr} from "@web/core/py_js/py"; +import {patch} from "@web/core/utils/patch"; + +patch(X2ManyField.prototype, { + get rendererProps() { + this.updateActiveActions(); + return super.rendererProps; + }, + updateActiveActions() { + if ( + this.props.viewMode === "list" && + this.activeActions.type === "one2many" && + !this.props.readonly + ) { + const self = this; + const archInfo = this.activeField.views[this.props.viewMode]; + const xmlDoc = archInfo.xmlDoc; + ["create", "delete"].forEach(function (item) { + if (item in self.activeActions && xmlDoc.hasAttribute(item)) { + const expr = xmlDoc.getAttribute(item); + try { + self.activeActions[item] = evaluateExpr( + expr, + self.props.record.data + ); + } catch (error) { + console.warn( + "[web_action_conditionable] unrecognized expr '" + + expr + + "', ignoring" + ); + console.warn(error); + } + } + }); + } + }, +});