Browse Source

Dec 07 : [ADD] Initial Commit 'event_ticket_qr_scanner'

pull/295/head
RisvanaCybro 1 year ago
parent
commit
598be45e0c
  1. 48
      event_ticket_qr_scanner/README.rst
  2. 22
      event_ticket_qr_scanner/__init__.py
  3. 56
      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. 69
      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/manufacturing-black.png
  18. BIN
      event_ticket_qr_scanner/static/description/assets/icons/pos-black.png
  19. BIN
      event_ticket_qr_scanner/static/description/assets/icons/puzzle.png
  20. BIN
      event_ticket_qr_scanner/static/description/assets/icons/restaurant-black.png
  21. BIN
      event_ticket_qr_scanner/static/description/assets/icons/service-black.png
  22. BIN
      event_ticket_qr_scanner/static/description/assets/icons/trading-black.png
  23. BIN
      event_ticket_qr_scanner/static/description/assets/icons/training.png
  24. BIN
      event_ticket_qr_scanner/static/description/assets/icons/update.png
  25. BIN
      event_ticket_qr_scanner/static/description/assets/icons/user.png
  26. BIN
      event_ticket_qr_scanner/static/description/assets/icons/wrench.png
  27. BIN
      event_ticket_qr_scanner/static/description/assets/misc/categories.png
  28. BIN
      event_ticket_qr_scanner/static/description/assets/misc/check-box.png
  29. BIN
      event_ticket_qr_scanner/static/description/assets/misc/compass.png
  30. BIN
      event_ticket_qr_scanner/static/description/assets/misc/corporate.png
  31. BIN
      event_ticket_qr_scanner/static/description/assets/misc/customer-support.png
  32. BIN
      event_ticket_qr_scanner/static/description/assets/misc/cybrosys-logo.png
  33. BIN
      event_ticket_qr_scanner/static/description/assets/misc/features.png
  34. BIN
      event_ticket_qr_scanner/static/description/assets/misc/logo.png
  35. BIN
      event_ticket_qr_scanner/static/description/assets/misc/pictures.png
  36. BIN
      event_ticket_qr_scanner/static/description/assets/misc/pie-chart.png
  37. BIN
      event_ticket_qr_scanner/static/description/assets/misc/right-arrow.png
  38. BIN
      event_ticket_qr_scanner/static/description/assets/misc/star.png
  39. BIN
      event_ticket_qr_scanner/static/description/assets/misc/support.png
  40. BIN
      event_ticket_qr_scanner/static/description/assets/misc/whatsapp.png
  41. BIN
      event_ticket_qr_scanner/static/description/assets/modules/1.png
  42. BIN
      event_ticket_qr_scanner/static/description/assets/modules/2.png
  43. BIN
      event_ticket_qr_scanner/static/description/assets/modules/3.jpg
  44. BIN
      event_ticket_qr_scanner/static/description/assets/modules/4.png
  45. BIN
      event_ticket_qr_scanner/static/description/assets/modules/5.gif
  46. BIN
      event_ticket_qr_scanner/static/description/assets/modules/6.png
  47. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot1.png
  48. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot10.png
  49. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot11.png
  50. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot2.png
  51. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot3.png
  52. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot4.png
  53. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot5.png
  54. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot6.png
  55. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot7.png
  56. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot8.png
  57. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/Screenshot9.png
  58. BIN
      event_ticket_qr_scanner/static/description/assets/screenshots/hero.gif
  59. BIN
      event_ticket_qr_scanner/static/description/banner.jpg
  60. BIN
      event_ticket_qr_scanner/static/description/icon.png
  61. 682
      event_ticket_qr_scanner/static/description/index.html
  62. 11
      event_ticket_qr_scanner/static/src/css/event_ticket_scan.css
  63. 92
      event_ticket_qr_scanner/static/src/js/event_ticket_scan.js
  64. 1
      event_ticket_qr_scanner/static/src/js/html5-qrcode.js
  65. 19
      event_ticket_qr_scanner/static/src/xml/event_ticket_scan_template.xml
  66. 19
      event_ticket_qr_scanner/views/event_event_ticket.xml
  67. 28
      event_ticket_qr_scanner/views/event_event_views.xml
  68. 16
      event_ticket_qr_scanner/views/event_template.xml

48
event_ticket_qr_scanner/README.rst

@ -0,0 +1,48 @@
.. 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: (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) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Anagha S (odoo@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

56
event_ticket_qr_scanner/__manifest__.py

@ -0,0 +1,56 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Anagha S (odoo@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': '16.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_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',
'event_ticket_qr_scanner/static/src/xml/'
'event_ticket_scan_template.xml',
],
},
'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>
#### 06.11.2023
#### Version 16.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) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Anagha S (odoo@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

69
event_ticket_qr_scanner/models/event_event_ticket.py

@ -0,0 +1,69 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Anagha S (odoo@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/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/misc/categories.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/check-box.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/compass.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/corporate.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/customer-support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/cybrosys-logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/features.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/pictures.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/pie-chart.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/right-arrow.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

BIN
event_ticket_qr_scanner/static/description/assets/misc/star.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/support.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

BIN
event_ticket_qr_scanner/static/description/assets/misc/whatsapp.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 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/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/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 214 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 148 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 181 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 216 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 714 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 150 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 221 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 219 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 194 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 191 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 391 KiB

BIN
event_ticket_qr_scanner/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

BIN
event_ticket_qr_scanner/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

682
event_ticket_qr_scanner/static/description/index.html

@ -0,0 +1,682 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between"
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42"
style="width: 42px; height: 42px;"/>
<div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Event Ticket QR Code Scanner</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
Scan and Manage QR Codes for Event Tickets.
</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/hero.gif" class="img-responsive"
style="width: 100%; margin-left: auto; margin-right: auto;"/>
</div>
</div>
</div>
</div>
<!-- NAVIGATION SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/compass.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Explore This
Module</h2>
</div>
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;">
<div class="col-sm-12 col-md-6 my-3">
<a href="#overview">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn
more about this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#features">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
features of this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#screenshots">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View
screenshots for this
module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
</div>
<!-- END OF NAVIGATION SECTION -->
<!-- OVERVIEW SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pie-chart.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Overview
</h2>
</div>
<div class="row"
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 py-4">
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.
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Features
</h2>
</div>
<div class="row"
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center"
style="margin-top: 40px; margin-bottom: 40px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Generate QR code for event ticket.</span>
</div>
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Sent Ticket contain QR code to Attendee by Mail on Confirming Registration for the Event.</span>
</div>
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Scan Qr Code for Tickets.</span>
</div>
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Invalid Ticket Handling.</span>
</div>
</div>
</div>
<!-- END OF FEATURES SECTION -->
<!-- SCREENSHOTS SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"
id="screenshots">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pictures.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Screenshots
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Create new Event and Tickets.
</h3>
<img src="assets/screenshots/Screenshot1.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Qr Code will be generated for the Tickets.
</h3>
<img src="assets/screenshots/Screenshot2.png"
class="img-thumbnail">
</div>
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Go to Website for the Event. Select the ticket and register.
</h3>
<div style="display: block; margin: 30px auto;">
<img src="assets/screenshots/Screenshot3.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
In the Confirmation page of the event registration, you can see
the Qr code for the Ticket.
</h3>
<img src="assets/screenshots/Screenshot4.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
An email with the Ticket QR code will be sent to the attendee on
confirming the registration.Or can Print directly from the
Attendee form.
</h3>
<img src="assets/screenshots/Screenshot5.png"
class="img-thumbnail">
<img src="assets/screenshots/Screenshot6.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Click 'Scan Tickets' from the Event form.
</h3>
<img src="assets/screenshots/Screenshot7.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Click 'Scan' to scan the ticket QR code.
</h3>
<img src="assets/screenshots/Screenshot8.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
If the ticket QR code is Valid, select the attendee who
registered for the event with that ticket.Click
'MARK AS ATTENDING' to mark the attendee as attended the Event.
</h3>
<img src="assets/screenshots/Screenshot9.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Attendee is marked as attended the event.
</h3>
<img src="assets/screenshots/Screenshot10.png"
class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
If the ticket is not valid, An error message will be shown.
</h3>
<img src="assets/screenshots/Screenshot11.png"
class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- RELATED PRODUCTS -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/categories.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Related
Products
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/fb_messenger/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/4.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/16.0/project_task_timer/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
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/16.0/website_portal_events/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active"
style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/project_dashboard_odoo/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
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/16.0/voice_note_in_chatter/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/5.gif">
</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/16.0/task_overdue_email_odoo/#"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="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="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 RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<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>
</div>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; 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: 0px; 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: 0px; 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: 0px; 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: 0px; 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: 0px; 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: 0px; 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: 0px; 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>
</div>
<!-- END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48"
style="width: 42px; height: 42px;"/>
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help?
Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52"
style="width: 52px; height: 52px;"/>
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
+91 86068
27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31"
style="width:144px; height: 31px; margin-top: 40px;"/>
</div>
</div>
</div>
<!-- END OF SUPPORT -->

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;
}

92
event_ticket_qr_scanner/static/src/js/event_ticket_scan.js

@ -0,0 +1,92 @@
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: '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','=','open']];
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);
});

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="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