From e28ae72d57e5f393aa5a5af27078cc1b3c8e4124 Mon Sep 17 00:00:00 2001 From: "Pedro M. Baeza" Date: Thu, 14 Mar 2019 11:41:26 +0100 Subject: [PATCH 01/16] [ADD] website_event_questions_by_ticket: Conditional Events Questions This module allows to set that an event question is only asked for certain tickets. If the question is general, then having one of the allowed tickets will serve for showing it. If the question is specific to each attendee, then the evaluation will be done for each of the tickets. Configuration ============= 1. Go to *Events > Events* 2. Create or select one event. 3. On the "Questions" page, create a new question or edit an existing one. 4. Fill the field "Limited to tickets" for restricting the question to that ticket. Leave it blank for making it available for all tickets. Usage ===== 1. Go to the website. 2. Go to "Events" section and select one of them. 3. Select ticket quantity and click on "Register". 4. On the popup dialog, the questions linked to that ticket and those without restrictions will be shown. Known issues / Roadmap ====================== * Add tests (tour) to the module. --- website_event_questions_by_ticket/README.rst | 104 ++++ website_event_questions_by_ticket/__init__.py | 3 + .../__manifest__.py | 22 + .../models/__init__.py | 3 + .../models/event_event.py | 33 ++ .../readme/CONFIGURE.rst | 5 + .../readme/CONTRIBUTORS.rst | 3 + .../readme/DESCRIPTION.rst | 6 + .../readme/ROADMAP.rst | 1 + .../readme/USAGE.rst | 6 + .../static/description/icon.png | Bin 0 -> 9455 bytes .../static/description/index.html | 455 ++++++++++++++++++ .../views/event_event_views.xml | 32 ++ .../views/event_templates.xml | 21 + 14 files changed, 694 insertions(+) create mode 100644 website_event_questions_by_ticket/README.rst create mode 100644 website_event_questions_by_ticket/__init__.py create mode 100644 website_event_questions_by_ticket/__manifest__.py create mode 100644 website_event_questions_by_ticket/models/__init__.py create mode 100644 website_event_questions_by_ticket/models/event_event.py create mode 100644 website_event_questions_by_ticket/readme/CONFIGURE.rst create mode 100644 website_event_questions_by_ticket/readme/CONTRIBUTORS.rst create mode 100644 website_event_questions_by_ticket/readme/DESCRIPTION.rst create mode 100644 website_event_questions_by_ticket/readme/ROADMAP.rst create mode 100644 website_event_questions_by_ticket/readme/USAGE.rst create mode 100644 website_event_questions_by_ticket/static/description/icon.png create mode 100644 website_event_questions_by_ticket/static/description/index.html create mode 100644 website_event_questions_by_ticket/views/event_event_views.xml create mode 100644 website_event_questions_by_ticket/views/event_templates.xml diff --git a/website_event_questions_by_ticket/README.rst b/website_event_questions_by_ticket/README.rst new file mode 100644 index 000000000..16ed6b8b2 --- /dev/null +++ b/website_event_questions_by_ticket/README.rst @@ -0,0 +1,104 @@ +============================ +Conditional Events Questions +============================ + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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-LGPL--3-blue.png + :target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html + :alt: License: LGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fevent-lightgray.png?logo=github + :target: https://github.com/OCA/event/tree/11.0/website_event_questions_by_ticket + :alt: OCA/event +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/event-11-0/event-11-0-website_event_questions_by_ticket + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/199/11.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module allows to set that an event question is only asked for certain +tickets. + +If the question is general, then having one of the allowed tickets will serve +for showing it. If the question is specific to each attendee, then the +evaluation will be done for each of the tickets. + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +#. Go to *Events > Events* +#. Create or select one event. +#. On the "Questions" page, create a new question or edit an existing one. +#. Fill the field "Limited to tickets" for restricting the question to that + ticket. Leave it blank for making it available for all tickets. + +Usage +===== + + +#. Go to the website. +#. Go to "Events" section and select one of them. +#. Select ticket quantity and click on "Register". +#. On the popup dialog, the questions linked to that ticket and those without + restrictions will be shown. + +Known issues / Roadmap +====================== + +* Add tests (tour) to the module. + +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 smashing it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +~~~~~~~ + +* Tecnativa + +Contributors +~~~~~~~~~~~~ + +* `Tecnativa `_: + + * Pedro M. Baeza + +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/event `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/website_event_questions_by_ticket/__init__.py b/website_event_questions_by_ticket/__init__.py new file mode 100644 index 000000000..7d768b54b --- /dev/null +++ b/website_event_questions_by_ticket/__init__.py @@ -0,0 +1,3 @@ +# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). + +from . import models diff --git a/website_event_questions_by_ticket/__manifest__.py b/website_event_questions_by_ticket/__manifest__.py new file mode 100644 index 000000000..37aadee79 --- /dev/null +++ b/website_event_questions_by_ticket/__manifest__.py @@ -0,0 +1,22 @@ +# Copyright 2019 Tecnativa - Pedro M. Baeza +# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). + +{ + "name": "Conditional Events Questions", + "summary": "Events Questions conditional to the chosen ticket", + "version": "11.0.1.0.0", + "category": "Website", + "website": "https://github.com/OCA/event", + "author": "Tecnativa, " + "Odoo Community Association (OCA)", + "license": "LGPL-3", + "installable": True, + "depends": [ + "website_event_sale", + "website_event_questions", + ], + "data": [ + "views/event_event_views.xml", + "views/event_templates.xml", + ], +} diff --git a/website_event_questions_by_ticket/models/__init__.py b/website_event_questions_by_ticket/models/__init__.py new file mode 100644 index 000000000..444d27961 --- /dev/null +++ b/website_event_questions_by_ticket/models/__init__.py @@ -0,0 +1,3 @@ +# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). + +from . import event_event diff --git a/website_event_questions_by_ticket/models/event_event.py b/website_event_questions_by_ticket/models/event_event.py new file mode 100644 index 000000000..f3f8ad478 --- /dev/null +++ b/website_event_questions_by_ticket/models/event_event.py @@ -0,0 +1,33 @@ +# Copyright 2019 Tecnativa - Pedro M. Baeza +# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). + +from odoo import fields, models + + +class EventEvent(models.Model): + _inherit = 'event.event' + + def _get_specific_questions(self, ticket_id): + self.ensure_one() + return self.specific_question_ids.filtered(lambda x: ( + not x.restricted_ticket_ids or + ticket_id in x.restricted_ticket_ids.ids + )) + + def _get_general_questions(self, ticket_ids): + self.ensure_one() + return self.general_question_ids.filtered(lambda x: ( + not x.restricted_ticket_ids or + (set(ticket_ids) & set(x.restricted_ticket_ids.ids)) + )) + + +class EventQuestion(models.Model): + _inherit = 'event.question' + + restricted_ticket_ids = fields.Many2many( + comodel_name="event.event.ticket", + string="Limited to tickets", + domain="[('event_id', '=', parent.id)]", + ondelete="restrict", + ) diff --git a/website_event_questions_by_ticket/readme/CONFIGURE.rst b/website_event_questions_by_ticket/readme/CONFIGURE.rst new file mode 100644 index 000000000..926c7afe0 --- /dev/null +++ b/website_event_questions_by_ticket/readme/CONFIGURE.rst @@ -0,0 +1,5 @@ +#. Go to *Events > Events* +#. Create or select one event. +#. On the "Questions" page, create a new question or edit an existing one. +#. Fill the field "Limited to tickets" for restricting the question to that + ticket. Leave it blank for making it available for all tickets. diff --git a/website_event_questions_by_ticket/readme/CONTRIBUTORS.rst b/website_event_questions_by_ticket/readme/CONTRIBUTORS.rst new file mode 100644 index 000000000..2d4d7a884 --- /dev/null +++ b/website_event_questions_by_ticket/readme/CONTRIBUTORS.rst @@ -0,0 +1,3 @@ +* `Tecnativa `_: + + * Pedro M. Baeza diff --git a/website_event_questions_by_ticket/readme/DESCRIPTION.rst b/website_event_questions_by_ticket/readme/DESCRIPTION.rst new file mode 100644 index 000000000..592216245 --- /dev/null +++ b/website_event_questions_by_ticket/readme/DESCRIPTION.rst @@ -0,0 +1,6 @@ +This module allows to set that an event question is only asked for certain +tickets. + +If the question is general, then having one of the allowed tickets will serve +for showing it. If the question is specific to each attendee, then the +evaluation will be done for each of the tickets. diff --git a/website_event_questions_by_ticket/readme/ROADMAP.rst b/website_event_questions_by_ticket/readme/ROADMAP.rst new file mode 100644 index 000000000..351e76b9e --- /dev/null +++ b/website_event_questions_by_ticket/readme/ROADMAP.rst @@ -0,0 +1 @@ +* Add tests (tour) to the module. diff --git a/website_event_questions_by_ticket/readme/USAGE.rst b/website_event_questions_by_ticket/readme/USAGE.rst new file mode 100644 index 000000000..64f4e7a33 --- /dev/null +++ b/website_event_questions_by_ticket/readme/USAGE.rst @@ -0,0 +1,6 @@ + +#. Go to the website. +#. Go to "Events" section and select one of them. +#. Select ticket quantity and click on "Register". +#. On the popup dialog, the questions linked to that ticket and those without + restrictions will be shown. diff --git a/website_event_questions_by_ticket/static/description/icon.png b/website_event_questions_by_ticket/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..3a0328b516c4980e8e44cdb63fd945757ddd132d GIT binary patch literal 9455 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 z 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 Xviia!U7SGha1wx#SCgwmn*{w2TRX*I literal 0 HcmV?d00001 diff --git a/website_event_questions_by_ticket/static/description/index.html b/website_event_questions_by_ticket/static/description/index.html new file mode 100644 index 000000000..57a99e2a6 --- /dev/null +++ b/website_event_questions_by_ticket/static/description/index.html @@ -0,0 +1,455 @@ + + + + + + +Conditional Events Questions + + + +
+

Conditional Events Questions

+ + +

Beta License: LGPL-3 OCA/event Translate me on Weblate Try me on Runbot

+

This module allows to set that an event question is only asked for certain +tickets.

+

If the question is general, then having one of the allowed tickets will serve +for showing it. If the question is specific to each attendee, then the +evaluation will be done for each of the tickets.

+

Table of contents

+ +
+

Configuration

+
    +
  1. Go to Events > Events
  2. +
  3. Create or select one event.
  4. +
  5. On the “Questions” page, create a new question or edit an existing one.
  6. +
  7. Fill the field “Limited to tickets” for restricting the question to that +ticket. Leave it blank for making it available for all tickets.
  8. +
+
+
+

Usage

+
    +
  1. Go to the website.
  2. +
  3. Go to “Events” section and select one of them.
  4. +
  5. Select ticket quantity and click on “Register”.
  6. +
  7. On the popup dialog, the questions linked to that ticket and those without +restrictions will be shown.
  8. +
+
+
+

Known issues / Roadmap

+
    +
  • Add tests (tour) to the module.
  • +
+
+
+

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 smashing it by providing a detailed and welcomed +feedback.

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • Tecnativa
  • +
+
+
+

Contributors

+ +
+
+

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/event project on GitHub.

+

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

+
+
+
+ + diff --git a/website_event_questions_by_ticket/views/event_event_views.xml b/website_event_questions_by_ticket/views/event_event_views.xml new file mode 100644 index 000000000..b3eda1de6 --- /dev/null +++ b/website_event_questions_by_ticket/views/event_event_views.xml @@ -0,0 +1,32 @@ + + + + + + event.question + + + + + + + + + + + + event.event + + + + + + + + + diff --git a/website_event_questions_by_ticket/views/event_templates.xml b/website_event_questions_by_ticket/views/event_templates.xml new file mode 100644 index 000000000..1eb2323ae --- /dev/null +++ b/website_event_questions_by_ticket/views/event_templates.xml @@ -0,0 +1,21 @@ + + + + + + + From 9dc3342b3a54da1acfd45c5bcc9f1dcbed1e0fc9 Mon Sep 17 00:00:00 2001 From: Diogo Alves Date: Fri, 28 Jun 2019 15:47:35 +0100 Subject: [PATCH 02/16] [MIG] website_event_questions_by_ticket: Migrate to 12.0 --- website_event_questions_by_ticket/__manifest__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/website_event_questions_by_ticket/__manifest__.py b/website_event_questions_by_ticket/__manifest__.py index 37aadee79..4b12aa1e9 100644 --- a/website_event_questions_by_ticket/__manifest__.py +++ b/website_event_questions_by_ticket/__manifest__.py @@ -4,7 +4,7 @@ { "name": "Conditional Events Questions", "summary": "Events Questions conditional to the chosen ticket", - "version": "11.0.1.0.0", + "version": "12.0.1.0.0", "category": "Website", "website": "https://github.com/OCA/event", "author": "Tecnativa, " From 8fd2e575bb19581ff184e01ea80f8386c07c82e8 Mon Sep 17 00:00:00 2001 From: Ioan Galan Date: Wed, 21 Oct 2020 13:28:31 +0200 Subject: [PATCH 03/16] [IMP] website_event_questions_by_ticket: black, isort, prettier --- .../__manifest__.py | 13 ++----- .../models/event_event.py | 23 ++++++------ .../views/event_event_views.xml | 22 +++++++----- .../views/event_templates.xml | 36 +++++++++++++------ 4 files changed, 56 insertions(+), 38 deletions(-) diff --git a/website_event_questions_by_ticket/__manifest__.py b/website_event_questions_by_ticket/__manifest__.py index 4b12aa1e9..105140b18 100644 --- a/website_event_questions_by_ticket/__manifest__.py +++ b/website_event_questions_by_ticket/__manifest__.py @@ -7,16 +7,9 @@ "version": "12.0.1.0.0", "category": "Website", "website": "https://github.com/OCA/event", - "author": "Tecnativa, " - "Odoo Community Association (OCA)", + "author": "Tecnativa, " "Odoo Community Association (OCA)", "license": "LGPL-3", "installable": True, - "depends": [ - "website_event_sale", - "website_event_questions", - ], - "data": [ - "views/event_event_views.xml", - "views/event_templates.xml", - ], + "depends": ["website_event_sale", "website_event_questions",], + "data": ["views/event_event_views.xml", "views/event_templates.xml",], } diff --git a/website_event_questions_by_ticket/models/event_event.py b/website_event_questions_by_ticket/models/event_event.py index f3f8ad478..8b7ac1c1f 100644 --- a/website_event_questions_by_ticket/models/event_event.py +++ b/website_event_questions_by_ticket/models/event_event.py @@ -5,25 +5,28 @@ class EventEvent(models.Model): - _inherit = 'event.event' + _inherit = "event.event" def _get_specific_questions(self, ticket_id): self.ensure_one() - return self.specific_question_ids.filtered(lambda x: ( - not x.restricted_ticket_ids or - ticket_id in x.restricted_ticket_ids.ids - )) + return self.specific_question_ids.filtered( + lambda x: ( + not x.restricted_ticket_ids or ticket_id in x.restricted_ticket_ids.ids + ) + ) def _get_general_questions(self, ticket_ids): self.ensure_one() - return self.general_question_ids.filtered(lambda x: ( - not x.restricted_ticket_ids or - (set(ticket_ids) & set(x.restricted_ticket_ids.ids)) - )) + return self.general_question_ids.filtered( + lambda x: ( + not x.restricted_ticket_ids + or (set(ticket_ids) & set(x.restricted_ticket_ids.ids)) + ) + ) class EventQuestion(models.Model): - _inherit = 'event.question' + _inherit = "event.question" restricted_ticket_ids = fields.Many2many( comodel_name="event.event.ticket", diff --git a/website_event_questions_by_ticket/views/event_event_views.xml b/website_event_questions_by_ticket/views/event_event_views.xml index b3eda1de6..e1eed65dd 100644 --- a/website_event_questions_by_ticket/views/event_event_views.xml +++ b/website_event_questions_by_ticket/views/event_event_views.xml @@ -1,11 +1,13 @@ - + - event.question - + @@ -18,15 +20,19 @@ - event.event - + - - + + - diff --git a/website_event_questions_by_ticket/views/event_templates.xml b/website_event_questions_by_ticket/views/event_templates.xml index 1eb2323ae..016bed0b2 100644 --- a/website_event_questions_by_ticket/views/event_templates.xml +++ b/website_event_questions_by_ticket/views/event_templates.xml @@ -1,21 +1,37 @@ - + - -