Browse Source

May 30: [ADD] Initial Commit 'event_ticket_qr_scanner'

pull/254/merge
RisvanaCybro 11 months ago
parent
commit
f9985d0454
  1. 50
      event_ticket_qr_scanner/README.rst
  2. 22
      event_ticket_qr_scanner/__init__.py
  3. 57
      event_ticket_qr_scanner/__manifest__.py
  4. 6
      event_ticket_qr_scanner/doc/RELEASE_NOTES.md
  5. 22
      event_ticket_qr_scanner/models/__init__.py
  6. 68
      event_ticket_qr_scanner/models/event_event_ticket.py
  7. 14
      event_ticket_qr_scanner/report/event_event_templates.xml
  8. BIN
      event_ticket_qr_scanner/static/description/assets/icons/check.png
  9. BIN
      event_ticket_qr_scanner/static/description/assets/icons/chevron.png
  10. BIN
      event_ticket_qr_scanner/static/description/assets/icons/cogs.png
  11. BIN
      event_ticket_qr_scanner/static/description/assets/icons/consultation.png
  12. BIN
      event_ticket_qr_scanner/static/description/assets/icons/ecom-black.png
  13. BIN
      event_ticket_qr_scanner/static/description/assets/icons/education-black.png
  14. BIN
      event_ticket_qr_scanner/static/description/assets/icons/hotel-black.png
  15. BIN
      event_ticket_qr_scanner/static/description/assets/icons/license.png
  16. BIN
      event_ticket_qr_scanner/static/description/assets/icons/lifebuoy.png
  17. BIN
      event_ticket_qr_scanner/static/description/assets/icons/logo.png
  18. BIN
      event_ticket_qr_scanner/static/description/assets/icons/manufacturing-black.png
  19. BIN
      event_ticket_qr_scanner/static/description/assets/icons/pos-black.png
  20. BIN
      event_ticket_qr_scanner/static/description/assets/icons/puzzle.png
  21. BIN
      event_ticket_qr_scanner/static/description/assets/icons/restaurant-black.png
  22. BIN
      event_ticket_qr_scanner/static/description/assets/icons/service-black.png
  23. BIN
      event_ticket_qr_scanner/static/description/assets/icons/trading-black.png
  24. BIN
      event_ticket_qr_scanner/static/description/assets/icons/training.png
  25. BIN
      event_ticket_qr_scanner/static/description/assets/icons/update.png
  26. BIN
      event_ticket_qr_scanner/static/description/assets/icons/user.png
  27. BIN
      event_ticket_qr_scanner/static/description/assets/icons/wrench.png
  28. BIN
      event_ticket_qr_scanner/static/description/assets/modules/1.png
  29. BIN
      event_ticket_qr_scanner/static/description/assets/modules/2.png
  30. BIN
      event_ticket_qr_scanner/static/description/assets/modules/3.jpg
  31. BIN
      event_ticket_qr_scanner/static/description/assets/modules/3.png
  32. BIN
      event_ticket_qr_scanner/static/description/assets/modules/4.jpg
  33. BIN
      event_ticket_qr_scanner/static/description/assets/modules/4.png
  34. BIN
      event_ticket_qr_scanner/static/description/assets/modules/5.gif
  35. BIN
      event_ticket_qr_scanner/static/description/assets/modules/5.jpg
  36. BIN
      event_ticket_qr_scanner/static/description/assets/modules/6.jpg
  37. BIN
      event_ticket_qr_scanner/static/description/assets/modules/6.png
  38. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_1.png
  39. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_10.png
  40. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_11.png
  41. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_2.png
  42. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_3.png
  43. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_4.png
  44. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_5.png
  45. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_6.png
  46. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_7.png
  47. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_8.png
  48. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_9.png
  49. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/hero.gif
  50. BIN
      event_ticket_qr_scanner/static/description/banner.jpg
  51. BIN
      event_ticket_qr_scanner/static/description/icon.png
  52. 637
      event_ticket_qr_scanner/static/description/index.html
  53. 11
      event_ticket_qr_scanner/static/src/css/event_ticket_scan.css
  54. 93
      event_ticket_qr_scanner/static/src/js/event_ticket_scan.js
  55. 1
      event_ticket_qr_scanner/static/src/js/html5-qrcode.js
  56. 19
      event_ticket_qr_scanner/static/src/xml/event_ticket_scan_template.xml
  57. 19
      event_ticket_qr_scanner/views/event_event_ticket.xml
  58. 28
      event_ticket_qr_scanner/views/event_event_views.xml
  59. 16
      event_ticket_qr_scanner/views/event_template.xml

50
event_ticket_qr_scanner/README.rst

@ -0,0 +1,50 @@
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
Event Ticket QR Code Scanner
============================
This module helps to create QR codes for event tickets,
scan them, and manage invalid tickets.
Configuration
=============
* Install qrcode package.
License
-------
Affero General Public License v3.0 (AGPL v3)
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer: (V15) Mufeeda Shirin ,
(V16) Anagha S,
* Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if
your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

22
event_ticket_qr_scanner/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
from . import models

57
event_ticket_qr_scanner/__manifest__.py

@ -0,0 +1,57 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
{
'name': 'Event Ticket QR Code Scanner',
'version': '15.0.1.0.0',
'category': 'Marketing',
'summary': 'QR Code Scanner for Event Ticket',
'description': """This module helps to create QR codes for event tickets,
scan them, and manage invalid tickets.""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['website_event', 'sale_management'],
'data': ['views/event_event_ticket.xml',
'views/event_event_views.xml',
'views/event_template.xml',
'report/event_event_templates.xml',
],
'assets': {
'web.assets_qweb': [
'event_ticket_qr_scanner/static/src/xml/event_ticket_scan_template.xml',
],
'web.assets_backend': [
'event_ticket_qr_scanner/static/src/js/event_ticket_scan.js',
'event_ticket_qr_scanner/static/src/js/html5-qrcode.js',
'event_ticket_qr_scanner/static/src/css/event_ticket_scan.css',
],
},
'external_dependencies': {
'python': ['qrcode']
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'application': False,
'auto_install': False,
}

6
event_ticket_qr_scanner/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <event_ticket_qr_scanner>
#### 22.05.2024
#### Version 17.0.1.0.0
#### ADD
- Initial commit for Event Ticket QR Code Scanner

22
event_ticket_qr_scanner/models/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
from . import event_event_ticket

68
event_ticket_qr_scanner/models/event_event_ticket.py

@ -0,0 +1,68 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
import base64
from io import BytesIO
from odoo import api, fields, models
try:
import qrcode
except ImportError:
qrcode = None
class EventEventTicket(models.Model):
"""This class extends the 'event.event.ticket' model to include
the generation of QR codes for event tickets."""
_inherit = 'event.event.ticket'
ticket_qr_code_image = fields.Binary(string='QRcode', attachment=False,
help='QR code for Event Tickets.',
readonly=True)
@api.model
def create(self, vals):
"""Generate qrcode when create new product."""
res = super(EventEventTicket, self).create(vals)
ean = self.generate_ticket_qr(res.id)
res.ticket_qr_code_image = ean
return res
def generate_ticket_qr(self, val_id):
"""Action to generate QR code for Tickets.
:param int val_id: id of the event.
:return: event ticket qrcode image."""
data = self.browse(val_id)
if qrcode and base64:
code = qrcode.QRCode(
version=1,
error_correction=qrcode.constants.ERROR_CORRECT_L,
box_size=3, border=4)
code.add_data(f"Event: {data.event_id.name},")
code.add_data(f"code: {data.event_id.id},")
code.add_data(f"Ticket: {val_id},")
code.add_data(f"Price: {data.price}")
code.make(fit=True)
img = code.make_image()
temp = BytesIO()
img.save(temp, format="PNG")
qr_image = base64.b64encode(temp.getvalue())
return qr_image

14
event_ticket_qr_scanner/report/event_event_templates.xml

@ -0,0 +1,14 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- QR Code On Full page ticket -->
<template id="event_report_template_full_page_ticket_inherited"
inherit_id="event.event_report_template_full_page_ticket">
<xpath expr="//div[hasclass('o_event_full_page_ticket_side_info')]"
position="inside">
<t t-if="attendee">
<img style="height: 100px; width: 100px;"
t-attf-src="data:image/png;base64,{{attendee.event_ticket_id.ticket_qr_code_image}}"/>
</t>
</xpath>
</template>
</odoo>

BIN
event_ticket_qr_scanner/static/description/assets/icons/check.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/chevron.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/cogs.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/consultation.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/ecom-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/education-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/hotel-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/license.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/lifebuoy.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/manufacturing-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/pos-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/puzzle.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/restaurant-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/service-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/trading-black.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/training.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/update.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
event_ticket_qr_scanner/static/description/assets/icons/user.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

BIN
event_ticket_qr_scanner/static/description/assets/icons/wrench.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/3.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 93 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 58 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/4.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 81 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/5.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 678 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/5.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 81 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/6.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

BIN
event_ticket_qr_scanner/static/description/assets/modules/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_10.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 124 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_11.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 78 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 228 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 161 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 120 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 132 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_7.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 94 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_8.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/event_qr_9.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

BIN
event_ticket_qr_scanner/static/description/assets/screenshots/hero.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 330 KiB

BIN
event_ticket_qr_scanner/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
event_ticket_qr_scanner/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.5 KiB

637
event_ticket_qr_scanner/static/description/index.html

@ -0,0 +1,637 @@
<div class="container" style="padding: 1rem !important; margin-bottom: 1rem !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between"
style="border-bottom: 1px solid #d5d5d5;">
<div class="my-3">
<img src="./assets/icons/logo.png" style="width: auto !important; height: 40px !important;">
</div>
<div class="my-3 d-flex align-items-center">
<div
style="background-color: #7C7BAD !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="background-color: #017E84 !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
</div>
</div>
<div class="container" style="padding: 0rem 1.5rem 4rem !important">
<div class="row" style="height: 900px !important;">
<div class="col-sm-12 col-md-12 col-lg-12"
style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;">
<h1
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important; font-size: 3.5rem !important; text-align: center !important;">
Event Ticket QR Code Scanner</h1>
<p
style="font-family: 'Montserrat', sans-serif !important; font-weight: 300 !important; color: #FFFFFF !important; font-size: 1.4rem !important; text-align: center !important;">
Scan and Manage QR Codes for Event Tickets.
</p>
<img src="./assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto"/>
</div>
</div>
<div class="row">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-compass mr-2"></i>Explore this module
</h2>
</div>
<div class="col-md-6">
<a href="#overview" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Overview</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
Learn more about this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#features" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Features</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
View features of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#screenshots" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Screenshots</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
See key screenshots of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
</div>
<div class="row" id="overview">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-pie-chart mr-2"></i>Overview
</h2>
</div>
<div class="col-mg-12 pl-3">
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;">
This module generates QR codes for event tickets, allows an option to scan these codes, and makes it
easier to handle tickets that may be found invalid. Essentially, it simplifies the handling of event
tickets, ensuring a more seamless and effective experience for both organisers and attendees.
</p>
</div>
</div>
<div class="row" id="features">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-star mr-2"></i>Features
</h2>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Generate QR code for event ticket.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Sent Ticket contain QR code to Attendee by Mail on Confirming Registration for the Event.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Scan Qr Code for Tickets.</h4>
</div>
</div>
</div>
<div class="row" id="screenshots">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-image mr-2"></i>Screenshots
</h2>
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Create new Event and Tickets.</h4>
<img src="assets/screenshots/event_qr_1.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Register the events from website</h4>
<img src="assets/screenshots/event_qr_2.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Confirm the Registration by providing the attendee details. </h4>
<img src="assets/screenshots/event_qr_3.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
We can download the tickets directly after Registration</h4>
<img src="assets/screenshots/event_qr_4.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
</h4>Print the Tickets from Attendee Form
<img src="assets/screenshots/event_qr_5.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
</h4>
<img src="assets/screenshots/event_qr_6.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Click 'Scan Tickets' from the Event form.
</h4>
<img src="assets/screenshots/event_qr_7.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Click 'Scan' to scan the ticket QR code.
</h4>
<img src="assets/screenshots/event_qr_8.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Select the Attendee</h4>
<img src="assets/screenshots/event_qr_9.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Marked as Attending</h4>
<img src="assets/screenshots/event_qr_10.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
<div class="col-lg-12 my-3">
<h4 class="mt-3"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
Shows if no attendee found</h4>
<img src="assets/screenshots/event_qr_11.png" class="img-responsive img-thumbnail border"
width="100%" height="auto"/>
</div>
</div>
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested Products</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner">
<div class="carousel-item active" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/website_repeat_sale/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/delivery_date_ecommerce/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/product_brand_ecommerce/#"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/website_decimal_quantity/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/4.jpg">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/call_for_price_website/#" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/5.jpg">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/website_cart_clear/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/6.jpg">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="left:-25px;width: 35px;color: #000;"> <span class="carousel-control-prev-icon"><i
class="fa fa-chevron-left" style="font-size:24px"></i></span> </a> <a
class="carousel-control-next" href="#demo1" data-slide="next"
style="right:-25px;width: 35px;color: #000;">
<span class="carousel-control-next-icon"><i class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF SUGGESTED PRODUCTS -->
<!-- OUR SERVICES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Services</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</section>
<!-- END OF END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Industries</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/education-black.png" class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px"
width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;">
<img src="./assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5
style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</section>
<!-- END OF END OF OUR INDUSTRIES -->
<!-- FOOTER -->
<!-- Footer Section -->
<section class="container" style="margin: 5rem auto 2rem;">
<div class="row" style="max-width:1540px;">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Need Help?</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
</div>
</div>
<!-- Contact Cards -->
<div class="row d-flex justify-content-center align-items-center"
style="max-width:1540px; margin: 0 auto 2rem auto;">
<div class="col-lg-12" style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; ">
<div class="row mt-4">
<div class="col-lg-6">
<a href="mailto:odoo@cybrosys.com" target="_blank" class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #4d4d4d; color: #FFF; border-radius: 4px;"><i
class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a>
</div>
<div class="col-lg-6">
<a href="https://api.whatsapp.com/send?phone=918606827707" target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #25D366; color: #FFF; border-radius: 4px;"><i
class="fa fa-whatsapp mr-2"></i>WhatsApp</a>
</div>
</div>
</div>
</div>
<!-- End of Contact Cards -->
</section>
<!-- Footer -->
<section class="oe_container" style="padding: 2rem 3rem 1rem;">
<div class="row" style="max-width:1540px; margin: 0 auto; margin-right: 3rem; ">
<!-- Logo -->
<div class="col-lg-12 d-flex justify-content-center align-items-center" style="margin-top: 3rem;">
<img src="https://www.cybrosys.com/images/logo.png" width="200px" height="auto"/>
</div>
<!-- End of Logo -->
<div class="col-lg-12">
<hr
style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;">
<!-- End of Footer Section -->
</div>
</div>
</section>
<!-- END OF FOOTER -->
</div>

11
event_ticket_qr_scanner/static/src/css/event_ticket_scan.css

@ -0,0 +1,11 @@
#html5-qrcode-button-camera-stop{
color: #FFFFFF;
background-color: #71639e;
border-color: #71639e;
}
#select_attendee_id{
width: 215px;
height: 35px;
padding: 5px 35px 5px 27px;
font-size: 18px; border: 2px solid #ccc; margin: 0 auto;
}

93
event_ticket_qr_scanner/static/src/js/event_ticket_scan.js

@ -0,0 +1,93 @@
odoo.define('event_ticket_qr_scanner.scan_ticket_qrcode', function (require){
"Use strict";
var core = require('web.core');
var rpc = require('web.rpc');
var AbstractAction = require('web.AbstractAction');
var QrcodeScanner = AbstractAction.extend({
/*
Open Qr Code scanner Window
*/
contentTemplate: 'event_ticket_qr_scanner.QrCodeScanner',
events: {
'click #barcode-scanner': 'load_qr',
'click #mark_as_attending': 'markAsAttending'
},
load_qr: function (ev) {
this.$('#result').html("")
var self = this;
const scanner = new Html5QrcodeScanner('reader', {
qrbox: {
width: 250,
height: 250,
}, // Sets dimensions of scanning box (set relative to reader element width)
fps: 20, // Frames per second to attempt a scan
});
scanner.render(success, error);
// Starts scanner
function success(data) {
const keyValuePairs = data.split(',');
const result = {};
for (const pair of keyValuePairs) {
const [key, value] = pair.split(':');
const trimmedKey = key.trim();
const trimmedValue = value.trim();
result[trimmedKey] = trimmedValue;
}
if (result.hasOwnProperty('Event')){
this.$('#result').html(`
<div style="text-align: center;" id='success_message'>
<h2>Success!</h2>
<p>Event : ${result['Event']}</p>
</div>`);
scanner.clear();
self.$('#reader').css('display', 'none');
var domain = [['event_ticket_id','=',parseInt(result['Ticket'])],
['event_id','=',parseInt(result['code'])], ['state','in',['open','draft']]];
var fields = ['name','partner_id'];
rpc.query({
model: 'event.registration',
method: 'search_read',
args: [domain,fields],
}).then(function(vals){
if (vals.length === 0) {
this.$("#success_message").append(`<p style="color:red;">No Attendee Found!!</p>`);
}
else{
this.$('#success_message').append(`<label style="display: inline-flex;" for="select_attendee_id">
Select Attendee : <select name="select_attendee_id" id="select_attendee_id" class="attendee_selection"
style="">
</select></label><br/><br/><button id="mark_as_attending" icon="fa fa-check" class="btn btn-primary">
Mark as Attending</button>`)
for (let i = 0; i < vals.length; i++) {
var htmlToAppend = "<option id='option' value="+vals[i]['id']+">"+vals[i]['name']+"</option>";
this.$("#select_attendee_id").append(htmlToAppend);
};
}
});
}
else{
this.$('#result').html(`<h2 style="color:red;">Invalid!</h2>`)
scanner.clear();
this.$el.find('#reader').css('display', 'none');
}
}
function error(err) {
console.warn(err);// Prints any errors to the console
}
},
// Mark Selected attendees as attended the event
markAsAttending(ev){
var self = this;
var attendee_id = this.$el.find('#select_attendee_id').val()
rpc.query({
model: 'event.registration',
method: 'action_set_done',
args: [parseInt(attendee_id)],
}).then(function(){
location.reload();
});
},
});
core.action_registry.add('js_function', QrcodeScanner);
return QrcodeScanner;
});

1
event_ticket_qr_scanner/static/src/js/html5-qrcode.js

File diff suppressed because one or more lines are too long

19
event_ticket_qr_scanner/static/src/xml/event_ticket_scan_template.xml

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="utf-8" ?>
<templates id="template" xml:space="preserve">
<!-- Qr Code Scanner -->
<t t-name="event_ticket_qr_scanner.QrCodeScanner">
<t t-set="_activeClasses">border-primary</t>
<div>
<label t-attf-class="btn btn-{{navClass}} o_wsale_apply_barcode"
title="Barcode" for="o_wsale_apply_barcode"
id="barcode-scanner">
<i class="fa fa-qrcode"/>SCAN
</label>
<div id="reader" style="width: 600px;
margin-left: 182px;">
</div>
<div id="result" style="text-align: center; font-size: 1.5rem;">
</div>
</div>
</t>
</templates>

19
event_ticket_qr_scanner/views/event_event_ticket.xml

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- Qr code image on event ticket form view -->
<record id="event_event_ticket_view_tree_from_event" model="ir.ui.view">
<field name="name">
event.event.ticket.view.tree.inherit.event.ticket.qr.scanner
</field>
<field name="model">event.event.ticket</field>
<field name="inherit_id"
ref="event.event_event_ticket_view_tree_from_event"/>
<field name="arch" type="xml">
<field name="description" position="after">
<field name="ticket_qr_code_image" widget="image"
class="oe_avatar"
options='{"zoom": true, "preview_image": "avatar_128","size": [30, 40]}'/>
</field>
</field>
</record>
</odoo>

28
event_ticket_qr_scanner/views/event_event_views.xml

@ -0,0 +1,28 @@
<?xml version="1.0" encoding="UTF-8"?>
<odoo>
<!-- Open Scanner-->
<record id="scan_ticket_qrcode" model="ir.actions.client">
<field name="name">Scan Ticket Qr Code</field>
<field name="tag">js_function</field>
<field name="target">new</field>
</record>
<!-- New Button on Event form to scan Ticket QR code-->
<record id="view_event_form" model="ir.ui.view">
<field name="name">
event.event.view.form.inherit.event.ticket.qr.scanner
</field>
<field name="model">event.event</field>
<field name="inherit_id" ref="event.view_event_form"/>
<field name="priority" eval="20"/>
<field name="arch" type="xml">
<header position="inside">
<button type="action"
name="%(event_ticket_qr_scanner.scan_ticket_qrcode)d"
string="Scan Tickets" icon="fa-qrcode"
class="btn btn-primary scan_tickets"
attrs="{'invisible': [('seats_expected', '=', 0)]}"/>
<field name="seats_expected" invisible="1"/>
</header>
</field>
</record>
</odoo>

16
event_ticket_qr_scanner/views/event_template.xml

@ -0,0 +1,16 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Add a QR Code on Event registration -->
<template id="registration_complete"
inherit_id="website_event.registration_complete">
<xpath expr="//div[hasclass('o_wereg_confirmed_attendees')]/div/div"
position="inside">
<t t-if="attendee.event_ticket_id">
<div id="qr_code_image">
<img style="height: 100px; width: 100px;"
t-attf-src="data:image/png;base64,{{attendee.event_ticket_id.ticket_qr_code_image}}"/>
</div>
</t>
</xpath>
</template>
</odoo>
Loading…
Cancel
Save