Browse Source

Aug 14: [ADD] Initital Commits 'one_page_checkout'

pull/331/head
Cybrosys Technologies 9 months ago
parent
commit
7fb622f45a
  1. 46
      one_page_checkout/README.rst
  2. 22
      one_page_checkout/__init__.py
  3. 61
      one_page_checkout/__manifest__.py
  4. 23
      one_page_checkout/controllers/__init__.py
  5. 56
      one_page_checkout/controllers/website_form.py
  6. 137
      one_page_checkout/controllers/website_sale.py
  7. 7
      one_page_checkout/doc/RELEASE_NOTES.md
  8. BIN
      one_page_checkout/static/description/assets/icons/capture (1).png
  9. BIN
      one_page_checkout/static/description/assets/icons/check.png
  10. BIN
      one_page_checkout/static/description/assets/icons/chevron.png
  11. BIN
      one_page_checkout/static/description/assets/icons/cogs.png
  12. BIN
      one_page_checkout/static/description/assets/icons/consultation.png
  13. BIN
      one_page_checkout/static/description/assets/icons/ecom-black.png
  14. BIN
      one_page_checkout/static/description/assets/icons/education-black.png
  15. BIN
      one_page_checkout/static/description/assets/icons/hotel-black.png
  16. BIN
      one_page_checkout/static/description/assets/icons/img.png
  17. BIN
      one_page_checkout/static/description/assets/icons/license.png
  18. BIN
      one_page_checkout/static/description/assets/icons/lifebuoy.png
  19. BIN
      one_page_checkout/static/description/assets/icons/manufacturing-black.png
  20. BIN
      one_page_checkout/static/description/assets/icons/photo-capture.png
  21. BIN
      one_page_checkout/static/description/assets/icons/pos-black.png
  22. BIN
      one_page_checkout/static/description/assets/icons/puzzle.png
  23. BIN
      one_page_checkout/static/description/assets/icons/restaurant-black.png
  24. BIN
      one_page_checkout/static/description/assets/icons/service-black.png
  25. BIN
      one_page_checkout/static/description/assets/icons/trading-black.png
  26. BIN
      one_page_checkout/static/description/assets/icons/training.png
  27. BIN
      one_page_checkout/static/description/assets/icons/update.png
  28. BIN
      one_page_checkout/static/description/assets/icons/user.png
  29. BIN
      one_page_checkout/static/description/assets/icons/wrench.png
  30. BIN
      one_page_checkout/static/description/assets/misc/Cybrosys R.png
  31. BIN
      one_page_checkout/static/description/assets/misc/categories.png
  32. BIN
      one_page_checkout/static/description/assets/misc/check-box.png
  33. BIN
      one_page_checkout/static/description/assets/misc/compass.png
  34. BIN
      one_page_checkout/static/description/assets/misc/corporate.png
  35. BIN
      one_page_checkout/static/description/assets/misc/customer-support.png
  36. BIN
      one_page_checkout/static/description/assets/misc/cybrosys-logo.png
  37. 33
      one_page_checkout/static/description/assets/misc/email.svg
  38. BIN
      one_page_checkout/static/description/assets/misc/features.png
  39. BIN
      one_page_checkout/static/description/assets/misc/logo.png
  40. 3
      one_page_checkout/static/description/assets/misc/phone.svg
  41. BIN
      one_page_checkout/static/description/assets/misc/pictures.png
  42. BIN
      one_page_checkout/static/description/assets/misc/pie-chart.png
  43. BIN
      one_page_checkout/static/description/assets/misc/right-arrow.png
  44. 9
      one_page_checkout/static/description/assets/misc/star (1) 2.svg
  45. BIN
      one_page_checkout/static/description/assets/misc/star.png
  46. 9
      one_page_checkout/static/description/assets/misc/support (1) 1.svg
  47. 6
      one_page_checkout/static/description/assets/misc/support-email.svg
  48. BIN
      one_page_checkout/static/description/assets/misc/support.png
  49. 17
      one_page_checkout/static/description/assets/misc/tick-mark.svg
  50. 9
      one_page_checkout/static/description/assets/misc/whatsapp 1.svg
  51. BIN
      one_page_checkout/static/description/assets/misc/whatsapp.png
  52. 33
      one_page_checkout/static/description/assets/misc/whatsapp.svg
  53. BIN
      one_page_checkout/static/description/assets/modules/1.gif
  54. BIN
      one_page_checkout/static/description/assets/modules/1.png
  55. BIN
      one_page_checkout/static/description/assets/modules/2.png
  56. BIN
      one_page_checkout/static/description/assets/modules/3.png
  57. BIN
      one_page_checkout/static/description/assets/modules/4.jpg
  58. BIN
      one_page_checkout/static/description/assets/modules/5.jpg
  59. BIN
      one_page_checkout/static/description/assets/modules/6.png
  60. BIN
      one_page_checkout/static/description/assets/modules/l2.png
  61. BIN
      one_page_checkout/static/description/assets/modules/l3.png
  62. BIN
      one_page_checkout/static/description/assets/modules/l4.png
  63. BIN
      one_page_checkout/static/description/assets/modules/l5.png
  64. BIN
      one_page_checkout/static/description/assets/modules/l6.png
  65. BIN
      one_page_checkout/static/description/assets/screenshots/hero.gif
  66. BIN
      one_page_checkout/static/description/assets/screenshots/image1.png
  67. BIN
      one_page_checkout/static/description/assets/screenshots/image2.png
  68. BIN
      one_page_checkout/static/description/assets/screenshots/image3.png
  69. BIN
      one_page_checkout/static/description/banner.jpg
  70. BIN
      one_page_checkout/static/description/icon.png
  71. 655
      one_page_checkout/static/description/index.html
  72. 38
      one_page_checkout/static/src/css/style.css
  73. 24
      one_page_checkout/static/src/js/checkout_form.js
  74. 16
      one_page_checkout/static/src/js/payment_demo.js
  75. 215
      one_page_checkout/static/src/js/website_sale.js
  76. 148
      one_page_checkout/static/src/js/website_sale_delivery.js
  77. 93
      one_page_checkout/views/address_column_templates.xml
  78. 262
      one_page_checkout/views/address_form_templates.xml
  79. 74
      one_page_checkout/views/extra_info_templates.xml
  80. 77
      one_page_checkout/views/payment_templates.xml
  81. 66
      one_page_checkout/views/website_sale_templates.xml

46
one_page_checkout/README.rst

@ -0,0 +1,46 @@
.. 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
One Page Checkout
=================
* Condensed ecommerce checkout into a single page.
Configuration
=============
* No additional configurations needed
License
-------
AFFERO GENERAL PUBLIC LICENSE, Version 3 (AGPL v3).
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer: (V17) Afra K, 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
one_page_checkout/__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 <https://www.gnu.org/licenses/>.
#
#############################################################################
from . import controllers

61
one_page_checkout/__manifest__.py

@ -0,0 +1,61 @@
# -*- 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 <https://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': 'One Page Checkout',
'version': '17.0.1.0.0',
'category': 'eCommerce',
'summary': """
Simplifies ecommerce checkout by condensing it into a single,
user-friendly page.
""",
'description': """
Condenses the entire ecommerce checkout process into a single,
user-friendly page, simplifying the steps and enhancing the user
experience.
""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
'images': ['static/description/banner.jpg'],
'depends': ['base', 'website', 'website_sale', 'payment_demo'],
'data': [
'views/address_column_templates.xml',
'views/address_form_templates.xml',
'views/extra_info_templates.xml',
'views/payment_templates.xml',
'views/website_sale_templates.xml',
],
'assets': {
'web.assets_frontend': [
'one_page_checkout/static/src/css/style.css',
'one_page_checkout/static/src/js/website_sale.js',
'one_page_checkout/static/src/js/checkout_form.js',
'one_page_checkout/static/src/js/website_sale_delivery.js',
'one_page_checkout/static/src/js/payment_demo.js'
],
},
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

23
one_page_checkout/controllers/__init__.py

@ -0,0 +1,23 @@
# -*- 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 <https://www.gnu.org/licenses/>.
#
#############################################################################
from . import website_form
from . import website_sale

56
one_page_checkout/controllers/website_form.py

@ -0,0 +1,56 @@
# -*- 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 <https://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import http
from odoo.http import request
from odoo.addons.website.controllers.form import WebsiteForm
class WebsiteSaleForm(WebsiteForm):
"""
Class representing a form for ecommerce checkout.
Inherits:
WebsiteForm: The base class for website forms, providing common
functionalities.
Usage:
1. Create an instance of `WebsiteSaleForm` and customize it as needed.
2. Use the instance to handle the checking out in your shop.
"""
@http.route('/website/form/shop.sale.order', type='http', auth="public",
methods=['POST'], website=True)
def website_form_saleorder(self, **kwargs):
"""
This function is called when the user submits the checkout form for a
sales order on the website. It first calls the parent method `website_
form_sale_order` to handle the submission of the form and create the
sales order. Then, it retrieves the created sales order from the
website session and stores its ID in the user's session. Finally,
it redirects the user to the payment status page.
:param kwargs: Optional keyword arguments.
:return: A redirect to the payment status page.
"""
super(WebsiteSaleForm, self).website_form_saleorder(**kwargs)
order = request.website.sale_get_order()
if request.session.get('sale_last_order_id') is None and order:
request.session['sale_last_order_id'] = order.id
return request.redirect('/payment/status')

137
one_page_checkout/controllers/website_sale.py

@ -0,0 +1,137 @@
# -*- 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 <https://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import http
from odoo.http import request
from odoo.addons.website_sale.controllers.main import WebsiteSale
class WebsiteSaleEcom(WebsiteSale):
"""
Customized version of the website sale controller for e-commerce.
This class is a subclass of `WebsiteSale` and provides additional
customizations and overrides specific to e-commerce functionality on the
website. It extends the base functionality of `WebsiteSale` to cater to the
specific needs of an e-commerce website.
Inherits:
WebsiteSale: The base class for the website sale controller.
Usage:
1. Create an instance of `WebsiteSaleEcom` and customize it as needed.
2. Use the instance to handle e-commerce functionality on your website.
"""
def _get_address_values(self, **post):
"""
This method overrides the default `address()` method of the
`WebsiteSale` class to get additional context values related to the
customer's address.
:param post: A dictionary containing the form data submitted by the
user.
:type post: dict
:return: A dictionary containing the updated q-context values related
to the customer's address.
:rtype: dict
"""
return super(WebsiteSaleEcom, self).address(**post).qcontext
@http.route(['/shop/address'], type='http', methods=['GET', 'POST'],
auth="public", website=True, sitemap=False)
def address(self, **kw):
"""
Renders the checkout address page for the current website sale order.
If the request is a POST, updates the current order's delivery and
invoice addresses with the provided data.
If the current user is authenticated and the order's partner matches
the authenticated user's partner, redirects to the payment page.
:return: An HTTP response with the rendered checkout address page or a
redirection to the login or payment page.
:rtype: werkzeug.wrappers.Response
"""
res = super(WebsiteSaleEcom, self).address(**kw)
order = res.qcontext.get('website_sale_order')
if order:
user = request.website.user_id.sudo()
if order.partner_id.id == user.partner_id.id:
return request.redirect('/shop/payment')
else:
return res
return res
@http.route(['/shop/extra_info'], type='http', auth="public", website=True,
sitemap=False)
def extra_info(self):
"""
Overwrites the existing extra_info function.
Redirects the current request to the checkout payment page.
:return: An HTTP response redirecting to the checkout payment page.
:rtype: werkzeug.wrappers.Response
"""
return request.redirect('/shop/payment')
@http.route('/shop/payment', type='http', auth='public', website=True,
sitemap=False)
def shop_payment(self, **post):
"""
Overwrites the existing shop_payment function.
Removed the redirection if there is no address for user.
This page proposes several payment means based on available
payment.provider. State at this point :
- a draft sales order with lines; otherwise, clean context / session
and back to the shop
- no transaction in context / session, or only a draft one, if the
customer did go to a payment.provider webshop_paymentsite but
closed the tab without paying / canceling
"""
post.update({'partner_id': -1})
order = request.website.sale_get_order()
render_values = self._get_shop_payment_values(order, **post)
render_values['only_services'] = order and order.only_services or False
address_values = self._get_address_values(**post)
# Included /address values to the /payment and its template
render_values.update({
'account_on_checkout': address_values.get('account_on_checkout'),
'country_states': address_values.get('country_states', []),
'is_public_user': address_values.get('is_public_user'),
'only_services': address_values.get('only_services'),
'countries': address_values.get('countries', []),
'country': address_values.get('country', []),
'checkout': address_values.get('checkout'),
'error': address_values.get('error'),
'mode': address_values.get('mode'),
'deliveries': order._get_delivery_methods().sudo(),
'delivery_action_id': request.env.ref(
'delivery.action_delivery_carrier_form'
).id,
'sale_order_id': order.id
})
if render_values['errors']:
render_values.pop('providers', '')
render_values.pop('tokens', '')
request.session['sale_last_order_id'] = order.id
return request.render("website_sale.payment", render_values)

7
one_page_checkout/doc/RELEASE_NOTES.md

@ -0,0 +1,7 @@
## Module <one_page_checkout>
#### 10.07.2024
#### Version 17.0.1.0.0
#### ADD
- Initial Commit for One Page Checkout

BIN
one_page_checkout/static/description/assets/icons/capture (1).png

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

BIN
one_page_checkout/static/description/assets/icons/img.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

BIN
one_page_checkout/static/description/assets/icons/photo-capture.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
one_page_checkout/static/description/assets/misc/Cybrosys R.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

BIN
one_page_checkout/static/description/assets/misc/categories.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

33
one_page_checkout/static/description/assets/misc/email.svg

@ -0,0 +1,33 @@
<svg width="80" height="81" viewBox="0 0 80 81" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="3116889_design_email_material_communication_mail_icon 1" clip-path="url(#clip0_81_366)">
<g id="layer1">
<path id="rect3851" d="M74.6067 0.730957H5.5424C2.75742 0.730957 0.499756 3.01685 0.499756 5.83664V75.7642C0.499756 78.584 2.75742 80.8699 5.5424 80.8699H74.6067C77.3916 80.8699 79.6493 78.584 79.6493 75.7642V5.83664C79.6493 3.01685 77.3916 0.730957 74.6067 0.730957Z" fill="#DB534B"/>
<g id="Clip path group">
<mask id="mask0_81_366" style="mask-type:luminance" maskUnits="userSpaceOnUse" x="1" y="5" width="78" height="76">
<g id="clipPath4206">
<path id="rect4208" d="M73.6244 5.2915H6.62595C3.92428 5.2915 1.73413 7.4473 1.73413 10.1066V76.0546C1.73413 78.7139 3.92428 80.8697 6.62595 80.8697H73.6244C76.3261 80.8697 78.5162 78.7139 78.5162 76.0546V10.1066C78.5162 7.4473 76.3261 5.2915 73.6244 5.2915Z" fill="white"/>
</g>
</mask>
<g mask="url(#mask0_81_366)">
<g id="g4145" opacity="0.489612">
<g id="g4147">
<path id="path4149" d="M65.8115 41.5171C65.8115 54.9863 54.4292 65.9053 40.3884 65.9053L198.828 221.861C212.869 221.861 224.251 210.942 224.251 197.472L65.8115 41.5171Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4151" d="M40.3884 65.9051C33.2495 65.9051 26.7979 63.0825 22.1802 58.5371L180.62 214.492C185.237 219.038 191.689 221.86 198.828 221.86L40.3884 65.9051Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4153" d="M22.1802 58.5373C17.7157 54.1428 14.9653 48.1381 14.9653 41.5171L173.405 197.472C173.405 204.093 176.155 210.098 180.62 214.493L22.1802 58.5373Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4155" d="M14.9653 41.5171C14.9653 28.0479 26.3476 17.1289 40.3884 17.1289L198.828 173.084C184.787 173.084 173.405 184.003 173.405 197.472L14.9653 41.5171Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4157" d="M40.3884 17.1289C47.5273 17.1289 53.9789 19.9516 58.5966 24.4969L217.036 180.452C212.418 175.907 205.967 173.084 198.828 173.084L40.3884 17.1289Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4159" d="M58.5964 24.4971C63.0609 28.8916 65.8113 34.8963 65.8113 41.5173L224.251 197.473C224.251 190.852 221.5 184.847 217.036 180.452L58.5964 24.4971Z" fill="black" fill-opacity="0.0588235"/>
</g>
<path id="path4111" d="M65.8114 41.5171C65.8114 54.9863 54.4291 65.9053 40.3884 65.9053C26.3476 65.9053 14.9653 54.9863 14.9653 41.5171C14.9653 28.0479 26.3476 17.1289 40.3884 17.1289C54.4291 17.1289 65.8114 28.0479 65.8114 41.5171Z" fill="black" fill-opacity="0.0588235"/>
</g>
</g>
</g>
<path id="path3864" d="M17.506 17.5386H62.9018C64.4068 17.5386 65.8501 18.1439 66.9143 19.2214C67.9784 20.2988 68.5763 21.7602 68.5763 23.284V57.7564C68.5763 58.5109 68.4295 59.258 68.1443 59.9551C67.8592 60.6521 67.4412 61.2855 66.9143 61.819C66.3873 62.3525 65.7618 62.7757 65.0733 63.0645C64.3849 63.3532 63.647 63.5018 62.9018 63.5018H17.506C14.3567 63.5018 11.8315 60.9164 11.8315 57.7564V23.284C11.8315 20.0953 14.3567 17.5386 17.506 17.5386ZM40.2039 37.6475L62.9018 23.284H17.506L40.2039 37.6475ZM17.506 57.7564H62.9018V30.0923L40.2039 44.4271L17.506 30.0923V57.7564Z" fill="white"/>
</g>
</g>
<defs>
<clipPath id="clip0_81_366">
<rect width="80" height="81" fill="white"/>
</clipPath>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 3.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

3
one_page_checkout/static/description/assets/misc/phone.svg

@ -0,0 +1,3 @@
<svg width="36" height="44" viewBox="0 0 36 44" fill="none" xmlns="http://www.w3.org/2000/svg">
<path id="Vector" d="M7.25 19.3903C10.13 26.0689 14.76 31.5322 20.43 34.9305L24.83 29.7268C25.38 29.0778 26.17 28.889 26.86 29.1486C29.1 30.0218 31.51 30.4938 34 30.4938C35.11 30.4938 36 31.544 36 32.8537V41.1135C36 42.4233 35.11 43.4734 34 43.4734C15.22 43.4734 0 25.5143 0 3.35456C0 2.0448 0.9 0.994629 2 0.994629H9C10.11 0.994629 11 2.0448 11 3.35456C11 6.29268 11.4 9.1364 12.14 11.7795C12.36 12.5937 12.2 13.5259 11.65 14.1749L7.25 19.3903Z" fill="white"/>
</svg>

After

Width:  |  Height:  |  Size: 565 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

9
one_page_checkout/static/description/assets/misc/star (1) 2.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 26 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

9
one_page_checkout/static/description/assets/misc/support (1) 1.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 43 KiB

6
one_page_checkout/static/description/assets/misc/support-email.svg

@ -0,0 +1,6 @@
<svg width="49" height="37" viewBox="0 0 49 37" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="Group">
<path id="Vector" d="M2.23798 3.59132C3.53363 4.39742 21.5313 15.9748 22.2027 16.3917C22.8741 16.8087 23.5573 17.0032 24.6173 17.0032C25.6774 17.0032 26.3606 16.8087 27.0319 16.3917C27.7033 15.9748 45.701 4.39742 46.9967 3.59132C47.4796 3.29945 48.2923 2.77131 48.469 2.17368C48.7753 1.11741 48.4455 0.714355 47.138 0.714355H24.6173H2.09664C0.789214 0.714355 0.459412 1.13131 0.765656 2.17368C0.942335 2.78521 1.75506 3.29945 2.23798 3.59132Z" fill="white"/>
<path id="Vector_2" d="M48.0214 4.21664C47.0555 4.80037 38.3865 12.0831 32.6503 16.4611L42.3323 29.3171C42.5679 29.5951 42.6739 29.9286 42.5443 30.0954C42.403 30.2483 42.0967 30.1649 41.8494 29.9008L30.2357 18.3374C28.4807 19.6716 27.2439 20.5889 27.0319 20.7279C26.1249 21.2699 25.4889 21.3394 24.6173 21.3394C23.7457 21.3394 23.1096 21.2699 22.2027 20.7279C21.9789 20.5889 20.7539 19.6716 18.9989 18.3374L7.38519 29.9008C7.14961 30.1788 6.83159 30.2622 6.69025 30.0954C6.54891 29.9425 6.65491 29.5951 6.89048 29.3171L16.5607 16.4611C10.8245 12.0831 2.06126 4.80037 1.09541 4.21664C0.0588929 3.59121 0 4.32783 0 4.89766C0 5.46749 0 33.3893 0 33.3893C0 34.6819 1.61367 36.2941 2.76797 36.2941H24.6173H46.4666C47.6209 36.2941 48.999 34.668 48.999 33.3893C48.999 33.3893 48.999 5.4536 48.999 4.89766C48.999 4.31393 49.0697 3.59121 48.0214 4.21664Z" fill="white"/>
</g>
</svg>

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

17
one_page_checkout/static/description/assets/misc/tick-mark.svg

@ -0,0 +1,17 @@
<svg width="52" height="52" viewBox="0 0 52 52" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="52" height="52" fill="#F5F5F5"/>
<g clip-path="url(#clip0_0_1)">
<rect width="1440" height="7504" transform="translate(-107 -1660)" fill="white"/>
<rect x="-45" y="-203" width="1305" height="937" rx="19" fill="#FFF5FC"/>
<rect width="52" height="52" fill="url(#pattern0)"/>
</g>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_0_1" transform="scale(0.00387597)"/>
</pattern>
<clipPath id="clip0_0_1">
<rect width="1440" height="7504" fill="white" transform="translate(-107 -1660)"/>
</clipPath>
<image id="image0_0_1" width="258" height="258" xlink:href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQIAAAECCAYAAAAVT9lQAAAACXBIWXMAAAsTAAALEwEAmpwYAAAJJ0lEQVR4nO3dYZXjNhQGUDEohEAohEAohEAYCIawEAxhIQRCIQTCQmhX202bTWcmcWzpSda953y/J9JYL5EsyykBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD1/f49f37PXwXztVprgMXeUtkCkDNXaw2wyOF7zql8EXir1SBgmTw4v6XyReBUq0HA835L/8zVSxeAXGSOldoELPBHqvMrIP+N3yu1CXhS/hXwJZUvAIoANKrGbcFr8t/5rU6zgGfVWhBUBKBBtRYEFQFoVJ4KXJIiAMOqsUNQEYBG1Z4K/PXz7ykC0IjaU4GcuUrLgKecUt0CoAhAQ/JP8jwgFQEY1CHV2yCkCECDaj0rcJ8/azQOeGxK9QvAtQi4OwDBIm4NKgLQkJoPDCkC0KCo9QBFABpRe6uwIgANidofcM23pAhAqDwAo9YDrkXAyUIQKA/AqPUARQAacEqxRSBHEYBAkYuC15yKtxL40JwUARhWXhQ8p/gi4DVkEOSQYu8MXDOXbijwvug7A4oABIvcLnwbuwYhyCnFFwBFAALVet/go+RfI4fCbQXekefi0QXgWgRsGILKWrk9eM0fZZsL3It+cOg+p7LNBe5Fnib0XuayzQXutbJHQBGAIK0VAbcJobI8B2+pCDhhCCrLRSB64N8XAbcJoaLWikCO24RQ0ZTiB/19PFIMFc0pftDfZy7aYuAXLRYBLyeFilosApfkDgFU02IRcIcAKmnt4aHbuEMAFbT28NBtpoLtBn5quQh8Ldhu4KeWi4BnCKCClouAo8aggpaLQM6xXNOBrPUiYPswFNZ6EZjLNR3IWi8CFgehsNaLgMVBKKz1IpBj5yAU1EMRmIq1HuiiCNg5CAX1UAQuyeIgFNNDEfBYMRTUQxHIOZXqAKDd8wRuMxdrPdDkyUL3ceYgFNRDEbBpCArqoQjk2DQEhfRSBKZSHQCj+5LiB/gzOZfqABjdKcUP8GfibcVQSC9FIOdYqA9gaD0VgalQH8DQ8rdr9OB+NudCfQBDy/vy83w7eoA/E+sCUEBPRSDnWKYbYFz5m7WnIjCV6QYYVy9PEl5zLtMNMK7eioB1ASggf7tGD+4lOZbpBhjXnOIH9pJ8KdMNMK5enh+4xvkCsLFTih/YS+J8AdhYb0Ugx/kCsKG8YSh6UC/NXKQnaFb+h+d5oJ+AZfS2azDHy0oHk4vA9Z+fL9ZT7MfZnTyYLil+YC+N9xEM5LYI3Ca/osq3wXq9bRi65q1EZ9Cmj4rANflb7Bj26fYhF9ToQb003lM4kEdF4DZT0Gfs3ZI+biW2EA/klQvUQuIy+ad19KB+JccSnUF71nxLWUh8Tu6j6AH9SmwhHsSaInAbC4kf6/E2YY4txIPYqghcc0l+Rt47pD6LgFeXD2LrInCbqWI7WtbrbcIctwoHULIIXGMhsb9zBa5xq3AANYrANSMvJNbs563/Z9Z6di7q4hxtITEXv+gB/Wo8Vbhz0d9QlzTGQmJuY/RgfjVuFe5cdBG4zVS4rZF6vU2Yc0lj/WobTktF4Jo9LiT2fIcgx63CnWv14tzbQuI5xffpq5kK9AeNaf3n6h4WEucU34+vxu7BgZxS/AX3WS6p34XE1vv2sziAdEA9PAM/FWt9Gbl4RffZmtg9OKBejsbqZSExf8aWp1yPct6+S+hFLyfmtr6Q2PsdArsH6epwjFYXEucU3zdrYvcgP/SwXnDNJbW1kNhTIX0vHijiX72sF9xmKtITy+SCFN0Pa2JKwP/0eFFHLiTmv9vz4mDOcfNeYRemFH9xLk3EQmLvi4M5HijiU+cUf5G+kpoLiXOlNpXKJZkS8EC+QHr9yZsv8OP2XfKL3hcHc0r3ETuRL5Toi3VNpu275Ife+yXHlIBF8gUTfdGuydYLiT3/UrrtE1MCFut9QWzLhcTe+yLHGQO85JD6/xbMWbuQ2Puvo5xpRfvhx/bT6It4i1zSa4tke2i/MwbYxJziL+atMi1o9yHt4xeRKQGb2MMGmts8s5C4lzZPD9oJi/TyyPKzebSQODfwGdfGlIAi9rCZ5j7vLSTuYV0gx5SAYnp6ZPnZXNJ/C4mHtI91gend/x5sZA8baz4bPHtYFzAloIpjir/Y5eOYElDNlOIvePl/ps/+aVDCHn5G7ymmBIQ4pP2uF/QYUwLCnFL8ABBTAhowp/iBMHIuyePFNKDHU5D3lOPjfxHUsbctyL3EiUM0Z0rxA2OkXJIpAY06p/gBMkqOT/5PoLpDckuxRkwJaN5ent5rNV5VRjf2cM5fq/H2YrqxlxN+Wou3F9MdtxS3jSkB3drjqUZROS3se2jKOcUPot5zXtzr0JhDcktxTb6lbV/fBmHcUnw90wv9Dc2aU/yg6i0OG2F3PKW4PA4bYZfcUnw+04t9DF3IF3j0IGs9l2TPAAOw6/DzHF/vWujHIbml+FHmFf0K3Tml+EHXWmwjZkh7fJfimpzWdSf0ac/vUlya88q+hK4dU/wgjI5txJAcZDKt70Lo38gHmdhGDDdG3XV43KLzYE/yT+TogVkzTiOGD5xT/ACtEXsG4BOHNMYtRacRwwN7P+vwvF1Xwb7tedfhYcN+gl3b667DactOghHs7azDy7bdA+OYU/wA3irHjfsGhrGXsw7nrTsGRpO/SaMH8prYMwAb6fnBpLcC/QFD6nWK4KEi2FiPDyZ5NwEUMKX4wf1sPFQEBfVwdoEFQiishynCqVjrgX+1PEU4F2w3cKfVKcKhZKOBX7U4RZiKthh4V0tThEuyQAhhWpkiOHUIArUwRTgXbyXwUPQU4VC+icAzoqYIU43GAc+JmCJckgVCaE7tKYIFQmhUrSnCuVaDgOVqTREOtRoEvKb0FGGq1xRgjVJTBAuE0JFSU4RTzUYA6209RbBACB3a+tBTZxBCp45pmyLgDELo3Nr3IjiDEHZg7RTBAiHsxKtvV/aSEtiZr2l5ITiGfFKgmDxFyPP9Z4vAHPMxgdLyS0mfXSA8BH1GoIK8MehRIZjCPh1QxaPtx5e4jwbUlL/xPyoEDhyBQXy0t+Ac+aGA+t7bW+B5AhjQ7d4CzxPAoPItwm/J8wQwvLxw+Bb9IQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA4DV/A/Mf3+pWEmbtAAAAAElFTkSuQmCC"/>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.0 KiB

9
one_page_checkout/static/description/assets/misc/whatsapp 1.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 38 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

33
one_page_checkout/static/description/assets/misc/whatsapp.svg

@ -0,0 +1,33 @@
<svg width="80" height="80" viewBox="0 0 80 80" fill="none" xmlns="http://www.w3.org/2000/svg">
<g id="3116884_whatsapp_square_chat_design_message_icon 1" clip-path="url(#clip0_81_382)">
<g id="layer1">
<path id="rect3851" d="M74.6066 0.72168H5.5424C2.75742 0.72168 0.499756 2.97935 0.499756 5.76433V74.8286C0.499756 77.6135 2.75742 79.8712 5.5424 79.8712H74.6066C77.3916 79.8712 79.6492 77.6135 79.6492 74.8286V5.76433C79.6492 2.97935 77.3916 0.72168 74.6066 0.72168Z" fill="#39BB59"/>
<g id="Clip path group">
<mask id="mask0_81_382" style="mask-type:luminance" maskUnits="userSpaceOnUse" x="6" y="9" width="75" height="72">
<g id="clipPath4206">
<path id="rect4208" d="M75.7716 9.01709H11.1629C8.55758 9.01709 6.44556 11.0471 6.44556 13.5512V75.6502C6.44556 78.1543 8.55758 80.1843 11.1629 80.1843H75.7716C78.3769 80.1843 80.4889 78.1543 80.4889 75.6502V13.5512C80.4889 11.0471 78.3769 9.01709 75.7716 9.01709Z" fill="white"/>
</g>
</mask>
<g mask="url(#mask0_81_382)">
<g id="g4145" opacity="0.489612">
<g id="g4147">
<path id="path4149" d="M68.2374 43.1284C68.2374 55.8115 57.2611 66.0932 43.7212 66.0932L196.51 212.946C210.049 212.946 221.026 202.665 221.026 189.982L68.2374 43.1284Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4151" d="M43.7211 66.0932C36.8369 66.0932 30.6154 63.4353 26.1624 59.1553L178.951 206.008C183.404 210.289 189.625 212.946 196.51 212.946L43.7211 66.0932Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4153" d="M26.1623 59.1553C21.8571 55.0173 19.2048 49.363 19.2048 43.1284L171.993 189.982C171.993 196.216 174.645 201.87 178.951 206.008L26.1623 59.1553Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4155" d="M19.2048 43.1284C19.2048 30.4453 30.1811 20.1636 43.7211 20.1636L196.509 167.017C182.969 167.017 171.993 177.299 171.993 189.982L19.2048 43.1284Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4157" d="M43.7212 20.1636C50.6054 20.1636 56.8269 22.8215 61.2799 27.1015L214.068 173.955C209.615 169.675 203.394 167.017 196.51 167.017L43.7212 20.1636Z" fill="black" fill-opacity="0.0588235"/>
<path id="path4159" d="M61.2798 27.1016C65.585 31.2396 68.2373 36.8939 68.2373 43.1284L221.026 189.982C221.026 183.747 218.373 178.093 214.068 173.955L61.2798 27.1016Z" fill="black" fill-opacity="0.0588235"/>
</g>
<path id="path4111" d="M68.2373 43.1284C68.2373 55.8115 57.261 66.0932 43.7211 66.0932C30.1811 66.0932 19.2048 55.8115 19.2048 43.1284C19.2048 30.4453 30.1811 20.1636 43.7211 20.1636C57.261 20.1636 68.2373 30.4453 68.2373 43.1284Z" fill="black" fill-opacity="0.0588235"/>
</g>
</g>
</g>
<path id="path4074" d="M51.3896 43.6875C51.9673 43.9879 52.337 44.1497 52.4526 44.3808C52.5912 44.635 52.545 45.7904 51.9673 47.1076C51.5051 48.4017 49.1018 49.6496 48.0388 49.6958C46.9758 49.7421 46.9527 50.5277 41.1985 48.0089C35.4444 45.49 31.9781 39.3431 31.7008 38.9502C31.4235 38.5574 29.4823 35.7612 29.5748 32.9188C29.6903 30.0995 31.1693 28.7592 31.7701 28.2046C32.3247 27.6037 32.9487 27.5344 33.3415 27.6037H34.4276C34.7743 27.6037 35.2596 27.4651 35.6986 28.6437L37.2931 32.965C37.4318 33.2654 37.5242 33.6121 37.3163 33.9818L36.6923 34.9293L35.7911 35.8998C35.5138 36.1771 35.1902 36.4776 35.5138 37.0553C35.7911 37.6561 36.9465 39.5741 38.5641 41.1687C40.667 43.2022 42.5158 43.8724 43.0704 44.1728C43.625 44.4963 43.9716 44.4501 44.3182 44.0804L46.1901 41.9081C46.6291 41.3304 46.9989 41.4691 47.5304 41.6539L51.3896 43.6875ZM40.4128 16.0493C46.5417 16.0493 52.4195 18.484 56.7533 22.8178C61.0871 27.1515 63.5217 33.0293 63.5217 39.1582C63.5217 45.287 61.0871 51.1649 56.7533 55.4986C52.4195 59.8324 46.5417 62.2671 40.4128 62.2671C35.8604 62.2671 31.6315 60.9498 28.0496 58.6852L17.304 62.2671L20.8858 51.5214C18.6212 47.9396 17.304 43.7106 17.304 39.1582C17.304 33.0293 19.7386 27.1515 24.0724 22.8178C28.4061 18.484 34.284 16.0493 40.4128 16.0493ZM40.4128 20.6711C35.5098 20.6711 30.8075 22.6188 27.3405 26.0858C23.8735 29.5528 21.9257 34.2551 21.9257 39.1582C21.9257 43.1329 23.1736 46.8072 25.2996 49.8114L23.0812 56.4898L29.7596 54.2714C32.7638 56.3974 36.4381 57.6453 40.4128 57.6453C45.3159 57.6453 50.0182 55.6975 53.4852 52.2305C56.9522 48.7635 58.9 44.0613 58.9 39.1582C58.9 34.2551 56.9522 29.5528 53.4852 26.0858C50.0182 22.6188 45.3159 20.6711 40.4128 20.6711Z" fill="white"/>
</g>
</g>
<defs>
<clipPath id="clip0_81_382">
<rect width="80" height="80" fill="white"/>
</clipPath>
</defs>
</svg>

After

Width:  |  Height:  |  Size: 4.3 KiB

BIN
one_page_checkout/static/description/assets/modules/1.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 912 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 228 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 81 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

BIN
one_page_checkout/static/description/assets/modules/l2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

BIN
one_page_checkout/static/description/assets/modules/l3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

BIN
one_page_checkout/static/description/assets/modules/l4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

BIN
one_page_checkout/static/description/assets/modules/l5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 88 KiB

BIN
one_page_checkout/static/description/assets/modules/l6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 237 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 108 KiB

BIN
one_page_checkout/static/description/assets/screenshots/image1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
one_page_checkout/static/description/assets/screenshots/image2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

BIN
one_page_checkout/static/description/assets/screenshots/image3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

BIN
one_page_checkout/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

BIN
one_page_checkout/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

655
one_page_checkout/static/description/index.html

@ -0,0 +1,655 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Odoo App 3 Index</title>
<!-- Bootstrap CSS -->
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css"
integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm"
crossorigin="anonymous">
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap"
rel="stylesheet">
</head>
<body>
<section>
<div class="container"
style="font-family: 'Inter', sans-serif !important;background-color: #fff !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between flex-wrap align-items-sm-center"
style="border-bottom:1px solid rgba(0, 0, 0, 0.22)">
<div class="my-3">
<img src="assets/misc/Cybrosys R.png"
style="width:auto !important; height:40px !important">
</div>
<div class="my-3 d-flex align-items-center">
<div class="text-center"
style="background-color:#017E84 !important;font-size: 0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;">
Community
</div>
<div class="text-center"
style="background-color:#875A7B !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important;min-width: 120px !important;">
Enterprise
</div>
<div class="text-center"
style="background-color:#7C7BAD !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;">
Odoo.sh
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 text-center d-flex align-items-center flex-column"
style="margin: 80px 0px !important;">
<h1 style="font-size: 2.8rem;font-weight: 700; color:
#1A202C;">
One Page Checkout</h1>
<p class="my-3 mb-4"
style="max-width: 80%; font-weight: 400 !important; line-height: 32px; color: #718096;">
This Module simplifies ecommerce checkout by condensing it into a single, user-friendly page.
</p>
<div style="width: 80%; margin-top: 3rem;">
<img src="assets/screenshots/hero.gif"
class="img-responsive" width="100%" height="auto">
</div>
</div>
</div>
<div class="container mt-5 mb-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#714b67 !important">
Key Highlights
</p>
</div>
<div class="row py-4">
<div class="col-md-6 col-sm-12 p-3">
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px;
background: #FFF;
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); ">
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67;
display: flex; justify-content: center; align-items: center;
margin-right: 10px; flex-shrink: 0;">
<i class="fa-solid fa-star "
style="color: #fff;font-size:14px;"></i>
</div>
<div>
<p style="color: #1A202C;font-weight: 600;
font-size: 1.2rem; margin-bottom: 2px;">
Simplifies the ecommerce checkout process into single step. </p>
</div>
</div>
</div>
<div class="col-md-6 col-sm-12 p-3">
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px;
background: #FFF;
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); ">
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67;
display: flex; justify-content: center; align-items: center;
margin-right: 10px; flex-shrink: 0;">
<i class="fa-solid fa-star "
style="color: #fff;font-size:14px;"></i>
</div>
<div>
<p style="color: #1A202C;font-weight: 600;
font-size: 1.2rem; margin-bottom: 2px;">
Create a new address and select existing address.</p>
</div>
</div>
</div>
</div>
</div>
<div class="container rounded">
<ul class="nav nav-tabs d-flex"
style="width: fit-content;margin: 0 auto;gap: 1rem;">
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
class="active show" data-toggle="tab" href="#tab1"
style="color: #fff;font-weight: 500; background-color: #714B67; text-decoration: none;">
<i class="fa-regular fa-image pr-2"
style="color: #fff;"></i>
Screenshots</a></li>
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
data-toggle="tab" href="#tab2"
style="color: #fff;font-weight: 500; text-decoration: none;"><i
class="fa-solid fa-star pr-2"
style="color: #fff;"></i>Features</a></li>
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
data-toggle="tab" href="#tab3"
style="color: #fff;font-weight: 500; text-decoration: none; background-color: #714B67;"><i
class="fa-solid fa-book-open pr-2"
style="color: #fff;"></i>Released Notes</a></li>
</ul>
<div class="tab-content"
style="background-color: rgba(121, 113, 119, 0.04);">
<div id="tab1" class="tab-pane fade in active show">
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/image1.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Checking out with Login User.</h4>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/image2.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Checking out with Public User.</h4>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/image3.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Form validation for Public User.</h4>
</div>
</div>
</div>
</div>
<div id="tab2" class="tab-pane fade">
<div class="col-mg-12" style="padding: 1rem 4rem;">
<ul style="list-style: none; padding: 1rem 0;font-weight: 500;">
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Support in Community, Enterprise & Odoo.sh.
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Select any delivery method.
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Create a new address and select existing address.
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Apply your promo-codes.
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Inline validation for public users.
</li>
</ul>
</div>
</div>
<div id="tab3" class="tab-pane fade">
<div class="col-mg-12 active" style="padding: 1rem 4rem;">
<div class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="d-flex mb-3"
style="font-size: 0.8rem; font-weight: 500;"><span>Version
17.0.1.0.0</span><span
class="px-2">|</span><span
style="color: #714B67;font-weight: 600;">Released on:25th Jan 2024</span>
</div>
<p class="m-0"
style=" color:#718096!important; font-size:1rem !important;line-height: 28px;">
Initial commit for One Page Checkout </p>
</div>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Related Products</p>
</div>
</div>
<div id="myCarousel" class="carousel slide py-3" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<div class="row p-4">
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/base_accounting_kit/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/1.gif" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Odoo 17 Full Accounting Kit</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/invoice_format_editor/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/2.png" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Invoice Format Editor</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/inventory_barcode_scanning/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/3.png" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Barcode scanning in Inventory</p>
</div>
</a>
</div>
</div>
</div>
</div>
<div class="carousel-item">
<div class="row p-4">
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/whatsapp_redirect/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/4.jpg" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Send Whatsapp Message</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/base_account_budget/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px;">
<img src="assets/modules/5.jpg" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Budget Management</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/product_barcode/" style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px;">
<img src="assets/modules/6.png" alt="" width="100%" height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">Product Barcode Generator</p>
</div>
</a>
</div>
</div>
</div>
</div>
</div>
<a class="carousel-control-prev" href="#myCarousel" 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="#myCarousel" 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 class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Our Services</p>
</div>
</div>
<div class="container my-5">
<div class="row py-3">
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#13EA36 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/cogs.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Customization</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#DBC711; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/wrench.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Implementation</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#FF6B6B ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/lifebuoy.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Support</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#FFA801 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/user.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Hire
Odoo Developer</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#54A0FF; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/puzzle.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Integration</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#6D7680 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/update.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Migration</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#786FA6 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/consultation.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Consultancy</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#F8A5C2 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/training.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Implementation</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#E6BE26; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/license.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Licensing Consultancy</p>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Our Industries</p>
</div>
</div>
<div class="container">
<div class="row my-5 py-4">
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100 "
style="border-right: 1px solid rgb(209, 209, 209); border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; box-shadow: 6px 0 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/trading-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Trading</p>
<p>Easily procure and sell your products</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgb(209, 209, 209); padding: 30px;">
<img src="assets/icons/pos-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">POS</p>
<p>Easy configuration and convivial experience</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgba(0, 0, 0, 0.2); padding: 30px; box-shadow: 0 5px 10px rgba(228, 227, 227, 0.373)">
<img src="assets/icons/education-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Education</p>
<p>A platform for educational management</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; ">
<img src="assets/icons/manufacturing-black.png"
width="42px" height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Manufacturing</p>
<p>Plan, track and schedule your operations</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;">
<img src="assets/icons/ecom-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">E-commerce &
Website</p>
<p>Mobile friendly, awe-inspiring product pages</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;box-shadow: 0 -5px 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/service-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Service
Management</p>
<p>Keep track of services and invoice</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px; ">
<img src="assets/icons/restaurant-black.png"
width="42px" height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Restaurant</p>
<p>Run your bar or restaurant methodically</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style=" padding: 30px;box-shadow: -5px 0 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/hotel-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Hotel
Management</p>
<p>An all-inclusive hotel management application</p>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Support</p>
</div>
</div>
<div class="container my-5">
<div class="row" style="background-color: #FFFAFE;">
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center"
style="border-right: 1px solid #D9D9D9;">
<div style="padding: 30px;">
<div class="d-flex align-items-center">
<img src="assets/misc/support (1) 1.svg" alt=""
width="60px" style="margin-right: 12px;">
<div style="padding: 0px 8px;">
<span
style="color: #714B67;font-size: 24px;font-weight: 600;padding-bottom: 1rem;">Need
Help?</span>
<p class="m-0" style="color:#718096;">Got
questions or need help? Get in touch.</p>
<div style="font-weight: 400;"><span><img
src="assets/misc/support-email.svg"
alt=""
width="18px"
style="filter: invert(1);margin-right: 0.8rem;"></span>odoo@cybrosys.com
</div>
</div>
</div>
</div>
</div>
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center">
<div style="padding: 30px;">
<div class="d-flex align-items-center">
<img src="assets/misc/whatsapp 1.svg" alt=""
width="60px" style="margin-right: 12px;">
<div>
<span style="color: #714B67;font-size: 24px;font-weight: 600;">WhatsApp</span>
<p class="m-0" style="color:#718096;">Say hi to
us on WhatsApp!</p>
<div style="font-weight: 400; font-size: 16px;"><span><img
src="assets/misc/phone.svg"
alt="" width="14px"
style="filter: invert(1); margin-right: 0.8rem;"></span>+91
99456767686
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</section>
<!-- Optional JavaScript -->
<!-- jQuery first, then Popper.js, then Bootstrap JS -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script>
</body>
</html>

38
one_page_checkout/static/src/css/style.css

@ -0,0 +1,38 @@
/* Column Responsive CSS for including three templates in a single page */
.single_pg_checkout_layout{
width:90%;
max-width:1400px;
margin: 0 auto;
}
.single_pg_checkout_layout .column {
float: left;
width: 33.33%;
}
.block-ui{
pointer-events:none;
opacity:0.5;
}
/* Clear floats after the columns */
.single_pg_checkout_layout:after {
content: "";
display: table;
clear: both;
}
@media screen and (max-width: 1000px) {
.single_pg_checkout_layout .column {
width: 80%;
margin: 15px auto;
}
}
@media screen and (max-width: 750px) {
.single_pg_checkout_layout .column {
width: 90%;
margin: 15px auto;
}
}
@media screen and (max-width: 500px) {
.single_pg_checkout_layout .column {
width: 97%;
margin: 15px auto;
}
}

24
one_page_checkout/static/src/js/checkout_form.js

@ -0,0 +1,24 @@
/** @odoo-module **/
import { _t } from '@web/core/l10n/translation';
import { Component } from '@odoo/owl';
import PaymentForm from '@payment/js/payment_form';
PaymentForm.include({
events: Object.assign({}, PaymentForm.prototype.events || {}, {
'click button[name="o_payment_submit_button"]': '_onClickPayment',
}),
init: function () {
this._super(...arguments);
},
/**
* OnePagePaymentForm widget. Enhances the payment form by adding a click
* event listener that submits the extra_info_form along with the payment form.
*
* @extends paymentFormMixin
*/
_onClickPayment: async function (ev) {
this.$el('#extra_info_form').submit()
},
});

16
one_page_checkout/static/src/js/payment_demo.js

@ -0,0 +1,16 @@
/** @odoo-module **/
import publicWidget from "@web/legacy/js/public/public_widget";
import { jsonrpc } from "@web/core/network/rpc_service";
publicWidget.registry.determine_checkout = publicWidget.Widget.extend({
selector: '#wrap',
init() {
this._super(...arguments);
this.rpc = this.bindService("rpc");
},
willStart: function () {
var self = this;
this.$el.find('#o_demo_express_checkout_container_6').css('display', 'none')
return this._super(...arguments);
},
});

215
one_page_checkout/static/src/js/website_sale.js

@ -0,0 +1,215 @@
/** @odoo-module **/
import wSaleUtils from "@website_sale/js/website_sale_utils";
import VariantMixin from "@website_sale/js/sale_variant_mixin";
import publicWidget from '@web/legacy/js/public/public_widget';
import { cartHandlerMixin } from '@website_sale/js/website_sale_utils';
import { WebsiteSale } from '@website_sale/js/website_sale';
import { _t } from "@web/core/l10n/translation";
publicWidget.registry.OnePageCheckoutWebsiteSale = publicWidget.Widget.extend(
VariantMixin, cartHandlerMixin, {
selector: '.single_pg_checkout_layout',
events: Object.assign({}, VariantMixin.events || {}, {
'click .a-submit': '_onClickSubmit',
'click .show_coupon': '_onClickShowCoupon',
'change select[name="country_id"]': '_onChangeCountry',
'click span[title="Details"]': '_onCartDetailClick',
}),
/**
* Initializes the widget.
* Sets the `isWebsite` property to `true`.
*/
init: function () {
this._super.apply(this, arguments);
this.isWebsite = true;
this.rpc = this.bindService("rpc");
},
/**
* Starts the widget.
* Calls the super method and returns the resulting promise.
* @returns {Promise} A promise representing the start of the widget.
*/
start() {
const def = this._super(...arguments);
return def;
},
/**
* Destroys the widget.
* Calls the super method and performs any necessary cleanup.
*/
destroy() {
this._super.apply(this, arguments);
this._cleanupZoom();
},
/**
* Changes the country and updates the corresponding fields
based on the selected country.
*/
_changeCountry: function () {
var self = this
if (!this.$el.find("#country_id").val()) {
return;
}
return this.rpc("/shop/country_infos/" + $("#country_id").val(), {
mode: this.$el.find("#country_id").attr('mode'),
}).then(function (data) {
// placeholder phone_code
self.$el.find("input[name='phone']").attr('placeholder', data.phone_code !== 0 ? '+'+ data.phone_code : '');
// populate states and display
var selectStates = self.$el.find("select[name='state_id']");
// dont reload state at first loading (done in qweb)
if (selectStates.data('init')===0 || selectStates.find('option').length===1) {
if (data.states.length || data.state_required) {
selectStates.html('');
data.states.forEach((x) => {
var opt = self.$el.find('<option>').text(x[1])
.attr('value', x[0])
.attr('data-code', x[2]);
selectStates.append(opt);
});
selectStates.parent('div').show();
} else {
selectStates.val('').parent('div').hide();
}
selectStates.data('init', 0);
} else {
selectStates.data('init', 0);
}
// manage fields order / visibility
if (data.fields) {
if (data.fields.indexOf("zip") > data.fields.indexOf("city")){
self.$el.find(".div_zip").before(self.$el.find(".div_city"));
} else {
self.$el.find(".div_zip").after(self.$el.find(".div_city"));
}
var all_fields = ["street", "zip", "city", "country_name"]; // "state_code"];
all_fields.forEach((field) => {
self.$el.find(".checkout_autoformat .div_" + field.split('_')[0]).toggle(data.fields.indexOf(field)>=0);
});
}
if (self.$el.find("label[for='zip']").length) {
self.$el.find("label[for='zip']").toggleClass('label-optional', !data.zip_required);
self.$el.find("label[for='zip']").get(0).toggleAttribute('required', !!data.zip_required);
}
if (self.$el.find("label[for='zip']").length) {
self.$el.find("label[for='state_id']").toggleClass('label-optional', !data.state_required);
self.$el.find("label[for='state_id']").get(0).toggleAttribute('required', !!data.state_required);
}
});
},
/**
* Handles the click event on submit buttons and performs the necessary actions.
* @param {Event} ev - The click event.
* @param {boolean} forceSubmit - Determines whether to force the submission
even if certain conditions are not met.
*/
_onClickSubmit: function (ev, forceSubmit) {
if (this.$(ev.currentTarget).is('#products_grid .a-submit') && !forceSubmit) {
return;
}
var $aSubmit = this.$(ev.currentTarget);
if (!ev.isDefaultPrevented() && !$aSubmit.is(".disabled")) {
ev.preventDefault();
$aSubmit.closest('form').submit();
}
if ($aSubmit.hasClass('a-submit-loading')) {
var loading = '<span class="fa fa-cog fa-spin"/>';
var fa_span = $aSubmit.find('span[class*="fa"]');
if (fa_span.length) {
fa_span.replaceWith(loading);
} else {
$aSubmit.append(loading);
}
}
},
/**
* Handles the click event to show the coupon form by hiding the
"show coupon" button and displaying the coupon form.
* @param {Event} ev - The click event.
*/
_onClickShowCoupon: function (ev) {
this.$el.find(".show_coupon").hide();
this.$el.find('.coupon_form').removeClass('d-none');
},
/**
* Handles the change event on the country field and triggers the country
change functionality.
* If the checkout_autoformat element is not present, the function does
nothing.
* This function internally calls the _changeCountry function.
* @param {Event} ev - The change event.
*/
_onChangeCountry: function (ev) {
if (!this.$('.checkout_autoformat').length) {
return;
}
this._changeCountry();
},
/**
* Handles the click event on the cart detail element.
* Toggles the chevron icon and shows/hides the summary div accordingly.
* @param {Event} ev - The click event.
*/
_onCartDetailClick: function(ev) {
var $elem = this.$(ev.currentTarget);
if ($elem.hasClass('fa-chevron-down')) {
$elem.removeClass('fa-chevron-down');
$elem.addClass('fa-chevron-up');
} else {
$elem.removeClass('fa-chevron-up');
$elem.addClass('fa-chevron-down');
}
var $summary_div = this.$el.find('.toggle_summary_div');
$summary_div.toggleClass('d-none');
}
});
/**
* This widget is used for the one-page checkout cart functionality.
* It adds events to change shipping and edit address.
*/
publicWidget.registry.OnePageCheckoutWebsiteSaleCart = publicWidget.Widget.extend({
selector: '.single_pg_checkout_layout .oe_cart',
events: {
'click .js_change_shipping': '_onClickChangeShipping',
'click .js_edit_address': '_onClickEditAddress',
},
/**
* Handles the click event on the "Change Shipping" element.
* Updates the shipping options by toggling visibility and applying CSS classes.
* Performs a POST request to update the selected shipping option via AJAX.
* @param {Event} ev - The click event.
*/
_onClickChangeShipping: function (ev) {
var $old = this.$el.find('.all_shipping').find('.card.border.border-primary');
$old.find('.btn-ship').toggle();
$old.addClass('js_change_shipping');
$old.removeClass('border border-primary');
var $new = this.$(ev.currentTarget).parent('div.one_kanban').find('.card');
$new.find('.btn-ship').toggle();
$new.removeClass('js_change_shipping');
$new.addClass('border border-primary');
var $form = this.$(ev.currentTarget).parent('div.one_kanban').find('form.d-none');
this.$.post($form.attr('action'), $form.serialize()+'&xhr=1');
},
/**
* Handles the click event on the "Edit Address" element.
* Prevents the default action of the click event.
* Updates the action attribute of the corresponding form and submits it.
* @param {Event} ev - The click event.
*/
_onClickEditAddress: function (ev) {
ev.preventDefault();
this.$(ev.currentTarget).closest('div.one_kanban').find('form.d-none').attr('action', '/shop/address').submit();
}
});
return {
OnePageCheckoutWebsiteSale: publicWidget.registry.OnePageCheckoutWebsiteSale,
OnePageCheckoutWebsiteSaleCart: publicWidget.registry.OnePageCheckoutWebsiteSaleCart,
};

148
one_page_checkout/static/src/js/website_sale_delivery.js

@ -0,0 +1,148 @@
/** @odoo-module **/
import publicWidget from "@web/legacy/js/public/public_widget";
import { _t } from "@web/core/l10n/translation";
import { renderToElement } from "@web/core/utils/render";
import { KeepLast } from "@web/core/utils/concurrency";
import { Component } from "@odoo/owl";
import '@website_sale/js/website_sale_delivery';
publicWidget.registry.websiteSaleDelivery.include({
_getCurrentLocation: async function () {
const data = await this.rpc("/shop/access_point/get");
const carriers = this.$el.find('.o_delivery_carrier_select')
for (let carrier of carriers) {
const deliveryType = this.$el.find('input[type="radio"]').attr("delivery_type");
const deliveryName = this.$el.find('.o_delivery_carrier_select label').text();
const showLoc = this.$el.find(".o_show_pickup_locations");
if (!showLoc) {
continue;
}
const orderLoc = this.$el.find(".o_order_location");
if (data[deliveryType + '_access_point'] && data.delivery_name == deliveryName) {
this.$el.find(".o_order_location_name").text = data.name
this.$el.find(".o_order_location_address").text = data[deliveryType + '_access_point']
orderLoc.parent().removeClass('new-parent-class');
showLoc.addClass("d-none");
break;
} else {
orderLoc.parent().addClass("d-none");
showLoc.removeClass("d-none");
}
}
},
/**
* @private
* @param {jQuery} $carrierInput
*/
_showLoading: function (carrierInput) {
const priceTag = this.$el.find('.o_wsale_delivery_badge_price')
while (priceTag.firstChild) {
priceTag.removeChild(priceTag.lastChild);
}
const loadingCircle = priceTag.append(document.createElement('span'));
loadingCircle.addClass("fa", "fa-circle-o-notch", "fa-spin");
},
/**
* Update the total cost according to the selected shipping method
* @private
* @param {float} amount : The new total amount of to be paid
*/
_getCarrierRateShipment: async function(carrierInput) {
const result = await this.rpc('/shop/carrier_rate_shipment', {
'carrier_id': carrierInput.value,
});
},
_handleCarrierUpdateResult: async function (carrierInput) {
//---updating carrier input function
const result = await this.rpc('/shop/update_carrier', {
'carrier_id': carrierInput.value,
})
this.result = result;
result.status = true
this._handleCarrierUpdateResultBadge(result);
if (carrierInput.checked) {
var amountDelivery = this.$el.find('#order_delivery .monetary_field');
var amountUntaxed = this.$el.find('#order_total_untaxed .monetary_field');
var amountTax = this.$el.find('#order_total_taxes .monetary_field');
var amountTotal = this.$el.find('#order_total .monetary_field, #amount_total_summary.monetary_field');
if(amountDelivery){
amountDelivery.html = result.new_amount_delivery;
}
if(amountUntaxed){
amountUntaxed.html = result.new_amount_untaxed;
}
if(amountTax){
amountTax.html = result.new_amount_tax;
}
amountTotal.each(function() {
this.html = result.new_amount_total;
});
if (result.new_amount_total_raw !== undefined) {
this._updateShippingCost(result.new_amount_total_raw);
// reload page only when amount_total switches between zero and not zero
const hasPaymentMethod = this.$el.find(
"div[name='o_website_sale_free_cart']"
) === null;
const shouldDisplayPaymentMethod = result.new_amount_total_raw !== 0;
}
this._updateShippingCost(result.new_amount_delivery);
}
this._enableButton(result.status);
let currentId = result.carrier_id
const showLocations = this.$el.find(".o_show_pickup_locations");
for (const showLoc of showLocations) {
const currentCarrierId = showLoc.closest("li").find("input")[0].value;
if (currentCarrierId == currentId) {
this._specificDropperDisplay(showLoc);
break;
}
}
},
_onCarrierClick: async function (ev) {
//----on carrier click
const radio = this.$el.find('.o_delivery_carrier_select')[0].firstElementChild
if (radio.checked && !this._shouldDisplayPickupLocations(ev) && !this.forceClickCarrier) {
return;
}
this.forceClickCarrier = false;
this._disablePayButton();
this._showLoading(radio);
radio.checked = true;
await this._onClickShowLocations(ev);
await this._handleCarrierUpdateResult(radio);
this._disablePayButtonNoPickupPoint(ev);
},
/**
* Handles the result of the carrier update and updates the relevant elements on the order summary.
* Updates the carrier badge, delivery amount, untaxed amount, tax amount, total amount, and shipping cost (if applicable).
* @param {Object} result - The result of the carrier update.
*/
_enableButton(status){
//----enabling payment button
var PayButton = this.$el.find('[name="o_payment_submit_button"]');
PayButton.removeAttr('disabled');
},
/**
* Handles the change event on the address selection element.
* Determines whether to show the available shipping countries for billing or all countries.
* Updates the visibility and disabled state of the country and state selection elements accordingly.
* @param {Event} ev - The change event.
*/
_onSetAddress: function (ev) {
var value = $(ev.currentTarget).val();
var $providerFree = this.$el.find('select[name="country_id"]:not(.o_provider_restricted), select[name="state_id"]:not(.o_provider_restricted)');
var $providerRestricted = this.$el.find('select[name="country_id"].o_provider_restricted, select[name="state_id"].o_provider_restricted');
if (value === 0) {
// Ship to the same address: only show shipping countries available for billing
$providerFree.hide().attr('disabled', true);
$providerRestricted.show().attr('disabled', false).change();
} else {
// Create a new address: show all countries available for billing
$providerFree.show().attr('disabled', false).change();
$providerRestricted.hide().attr('disabled', true);
}
},
});

93
one_page_checkout/views/address_column_templates.xml

@ -0,0 +1,93 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template for the address column -->
<template id="address_column" name="Address Column">
<div class="col-12 col-xl order-xl-1 oe_cart">
<div class="row"
t-if="not only_services and not is_public_user">
<div class="col-lg-12">
<h3 class="o_page_header mt8">
Billing Address
</h3>
</div>
<!-- Call the address_kanban template for the billing address -->
<div class="col-lg-12 one_kanban">
<t t-call="website_sale.address_kanban">
<t t-set='contact'
t-value="order.partner_id"/>
<t t-set='selected' t-value="1"/>
<t t-set='readonly' t-value="1"/>
<t t-set='allow_edit' t-value="1"/>
</t>
</div>
</div>
<!-- Display the shipping address header if the user is not a
public user and has permission to access the delivery/invoice address group -->
<t t-if="not only_services and not is_public_user"
groups="account.group_delivery_invoice_address">
<div class="row">
<div class="col-lg-12">
<h3 class="o_page_header mt16 mb4">
Shipping Address
</h3>
</div>
</div>
<div class="col-lg-12 one_kanban">
<t t-call="website_sale.address_kanban">
<t t-set='contact'
t-value="order.partner_shipping_id"/>
<t t-set='selected' t-value="1"/>
<t t-set='readonly' t-value="1"/>
<t t-set='allow_edit' t-value="1"/>
</t>
</div>
<div class="row all_shipping">
<div class="col-lg-12">
<div class="row mt8">
<!-- Display a button to add a new shipping address -->
<div class="col-md-12 col-lg-12 one_kanban">
<form action="/shop/address"
method="post"
class=''>
<input type="hidden"
name="csrf_token"
t-att-value="request.csrf_token()"
t-nocache="The csrf token must always be up to date."/>
<a role="button"
href="#"
class='a-submit btn btn-secondary mb-2 btn-block'>
<i class="fa fa-plus-square"/>
<span>
Add an address
</span>
</a>
</form>
</div>
<!-- Loop over each shipping address and call
the address_kanban template for each address -->
<t t-foreach="shippings"
t-as="ship">
<div class="col-md-12 col-lg-6 one_kanban mb-2">
<t t-call="website_sale.address_kanban">
<t t-set='contact'
t-value="ship"/>
<t t-set='selected'
t-value="order.partner_shipping_id==ship"/>
<t t-set='readonly'
t-value="bool(len(shippings)==1)"/>
<t t-set='edit_billing'
t-value="bool(ship==order.partner_id)"/>
<t t-set="allow_edit"
t-value="not order.partner_id or (ship.id in order.partner_id.child_ids.ids)"/>
</t>
</div>
</t>
</div>
</div>
</div>
</t>
<!-- Call the one_page_checkout.address_form template -->
<t t-call="one_page_checkout.address_form"/>
</div>
</template>
</odoo>

262
one_page_checkout/views/address_form_templates.xml

@ -0,0 +1,262 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template for the address form -->
<template id="address_form" name="Address Form">
<div class="row">
<!-- Form for public users to enter their payment information -->
<form t-if="is_public_user"
action="/shop/payment" method="post"
class="checkout_autoformat">
<div class="row">
<t t-set="error_message" t-value="error.get('error_message', False)"/>
<t t-if="error_message">
<h5 class="text-danger" t-esc="error_message[0]"/>
</t>
<div t-attf-class="mb-3 col-lg-12 div_name">
<label class="col-form-label"
for="name">Name
</label>
<input type="text" name="name"
t-attf-class="form-control #{'is-invalid' if error.get('name', '') != '' else 'valid'}"
t-att-value="'name' in checkout and checkout['name']"/>
</div>
<div class="w-100"/>
<div t-attf-class="mb-3 col-lg-6"
id="div_email">
<label t-attf-class="col-form-label #{mode[1] == 'shipping' and 'label-optional' or ''}"
for="email">Email
</label>
<input type="email"
name="email"
t-attf-class="form-control #{'is-invalid' if error.get('email', '') != '' else 'valid'}"
t-att-value="'email' in checkout and checkout['email']"/>
</div>
<div t-attf-class="mb-3 col-lg-6"
id="div_phone">
<label class="col-form-label"
for="phone">Phone
</label>
<input type="tel" name="phone"
t-attf-class="form-control #{'is-invalid' if error.get('name', '') != '' else 'valid'}"
t-att-value="'phone' in checkout and checkout['phone']"/>
</div>
<!-- Input fields for company name and VAT number if in B2B mode -->
<t t-if="website._display_partner_b2b_fields()">
<div class="w-100"/>
<t t-set='vat_warning'
t-value="'vat' in checkout and checkout['vat'] and not can_edit_vat"/>
<t t-if="mode == ('new', 'billing') or (mode == ('edit', 'billing') and (can_edit_vat or 'vat' in checkout and checkout['vat']))">
<div t-attf-class="mb-3 col-lg-6 mb-0">
<label class="col-form-label fw-normal label-optional"
for="company_name">
Company Name
</label>
<input type="text"
name="company_name"
t-attf-class="form-control"
t-att-value="'commercial_company_name' in checkout and checkout['commercial_company_name'] or 'company_name' in checkout and checkout['company_name']"
t-att-readonly="'1' if vat_warning else None"/>
<small t-if="vat_warning"
class="form-text text-muted d-block d-lg-none">
Changing company
name is not allowed
once document(s)
have been issued
for your account.
Please contact us
directly for this
operation.
</small>
</div>
<div t-attf-class="mb-3 col-lg-6 div_vat mb-0">
<label class="col-form-label fw-normal label-optional"
for="vat">TIN /
VAT
</label>
<input type="text"
name="vat"
t-attf-class="form-control"
t-att-value="'vat' in checkout and checkout['vat']"
t-att-readonly="'1' if vat_warning else None"/>
<small t-if="vat_warning"
class="form-text text-muted d-block d-lg-none">
Changing VAT number
is not allowed once
document(s) have
been issued for
your account.
Please contact us
directly for this
operation.
</small>
</div>
<div t-if="vat_warning"
class="col-12 d-none d-lg-block mb-1">
<small class="form-text text-muted">
Changing company
name or VAT number
is not allowed once
document(s) have
been issued for
your account.
Please contact us
directly for this
operation.
</small>
</div>
</t>
</t>
<div class="w-100"/>
<div t-attf-class="mb-3 col-lg-12 div_street">
<label class="col-form-label"
for="street">Street
<span class="d-none d-md-inline">
and Number
</span>
</label>
<input type="text"
name="street"
t-attf-class="form-control #{'is-invalid' if error.get('street', '') != '' else 'valid'}"
t-att-value="'street' in checkout and checkout['street']"/>
</div>
<div t-attf-class="mb-3 col-lg-12 div_street2">
<label class="col-form-label label-optional"
for="street2">Street 2
</label>
<input type="text"
name="street2"
t-attf-class="form-control"
t-att-value="'street2' in checkout and checkout['street2']"/>
</div>
<div class="w-100"/>
<t t-set='zip_city'
t-value='country and [x for x in country.get_address_fields() if x in ["zip", "city"]] or ["city", "zip"]'/>
<t t-if="'zip' in zip_city and zip_city.index('zip') &lt; zip_city.index('city')">
<div t-attf-class="mb-3 col-md-4 div_zip">
<label class="col-form-label label-optional"
for="zip">Zip Code
</label>
<input type="text"
name="zip"
t-attf-class="form-control"
t-att-value="'zip' in checkout and checkout['zip']"/>
</div>
</t>
<div t-attf-class="mb-3 col-md-8 div_city">
<label class="col-form-label"
for="city">City
</label>
<input type="text" name="city"
t-attf-class="form-control #{'is-invalid' if error.get('city', '') != '' else 'valid'}"
t-att-value="'city' in checkout and checkout['city']"/>
</div>
<t t-if="'zip' in zip_city and zip_city.index('zip') &gt; zip_city.index('city')">
<div t-attf-class="mb-3 col-md-4 div_zip">
<label class="col-form-label label-optional"
for="zip">Zip Code
</label>
<input type="text"
name="zip"
t-attf-class="form-control"
t-att-value="'zip' in checkout and checkout['zip']"/>
</div>
</t>
<div class="w-100"/>
<div t-attf-class="mb-3 and 'o_has_error' or ''} col-lg-6 div_country">
<label class="col-form-label"
for="country_id">Country
</label>
<select id="country_id"
name="country_id"
t-attf-class="form-select"
t-att-mode="mode[1]">
<option value="">
Country...
</option>
<t t-foreach="countries"
t-as="c">
<option t-att-value="c.id"
t-att-selected="c.id == (country and country.id or -1)">
<t t-esc="c.name"/>
</option>
</t>
</select>
</div>
<div t-attf-class="mb-3 col-lg-6 div_state"
t-att-style="(not country or not country.state_ids) and 'display: none'">
<label class="col-form-label" for="state_id">
State / Province
</label>
<select name="state_id" t-attf-class="form-select"
data-init="1">
<option value="">
State / Province...
</option>
<t t-foreach="country_states" t-as="s">
<option t-att-value="s.id"
t-att-selected="s.id == ('state_id' in checkout and country and checkout['state_id'] != '' and int(checkout['state_id']))">
<t t-esc="s.name"/>
</option>
</t>
</select>
</div>
<div class="w-100"/>
<!-- Checkbox to choose whether to ship to the same address as billing -->
<t t-if="mode == ('new', 'billing') and not only_services">
<div class="col-lg-12">
<div class="checkbox">
<label>
<input type="checkbox"
id='shipping_use_same'
class="mr8"
name='use_same'
value="1"
checked='checked'/>
Ship to the same
address
<span class='ship_to_other text-muted'
style="display: none">
&amp;nbsp;(
<i>Your
shipping
address
will be
requested
later)
</i>
</span>
</label>
</div>
</div>
</t>
</div>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"
t-nocache="The csrf token must always be up to date."/>
<input type="hidden" name="submitted"
value="1"/>
<input type="hidden" name="partner_id"
t-att-value="partner_id or '0'"/>
<input type="hidden" name="callback"
t-att-value="callback"/>
<input type="hidden"
name="field_required"
t-att-value="'phone,name'"/>
<!-- Navigation -->
<div class="d-flex justify-content-between">
<a role="button"
t-att-href="mode == ('new', 'billing') and '/shop/cart' or '/shop/checkout'"
class="btn btn-secondary mb32">
<i class="fa fa-chevron-left"/>
<span>Back</span>
</a>
<a role="submit " href="#"
class="btn btn-primary mb32 a-submit a-submit-disable a-submit-loading">
<span>Confirm</span>
<i class="fa fa-chevron-right"/>
</a>
</div>
</form>
</div>
</template>
</odoo>

74
one_page_checkout/views/extra_info_templates.xml

@ -0,0 +1,74 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template for the extra info -->
<template id="extra_info" name="Extra Info">
<form action="/website/form/shop.sale.order" method="post"
id="extra_info_form"
enctype="multipart/form-data"
t-attf-class="o_mark_required s_website_form_no_recaptcha #{'block-ui' if website_sale_order.partner_id.active == False else ''}"
data-mark="*" data-force_action="shop.sale.order"
data-model_name="sale.order" data-success-mode="redirect"
data-success-page="/payment/status" hide-change-model="true">
<!-- Create a hidden input field with name "csrf_token" and
value from request.csrf_token() -->
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<!-- Create a form field for a text input with name "client_order_ref" -->
<div class="mb-0 py-2 col-12 s_website_form_field"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<label class="col-form-label col-sm-auto s_website_form_label"
style="width: 200px" for="sale1">
<span class="s_website_form_label_content">
Your Reference
</span>
</label>
<!-- Create a text input field with id "sale1" and
class "form-control s_website_form_input" -->
<div class="col-sm">
<input id="sale1" type="text"
class="form-control s_website_form_input"
name="client_order_ref"/>
</div>
</div>
</div>
<div class="mb-0 py-2 col-12 s_website_form_field s_website_form_custom"
data-type="text" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<label class="col-form-label col-sm-auto s_website_form_label"
style="width: 200px" for="sale2">
<span class="s_website_form_label_content">Give
us your feedback
</span>
</label>
<!-- Create a textarea input field with id "sale2"
and class "form-control s_website_form_input" -->
<div class="col-sm">
<textarea id="sale2"
class="form-control s_website_form_input"
name="Give us your feedback"/>
</div>
</div>
</div>
<!-- Create a form field for a binary input with name "a_document" -->
<div class="mb-0 py-2 col-12 s_website_form_field s_website_form_custom"
data-type="binary" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<label class="col-form-label col-sm-auto s_website_form_label"
style="width: 200px" for="sale3">
<span class="s_website_form_label_content">
Upload a document
</span>
</label>
<div class="col-sm">
<input id="sale3" type="file"
class="form-control s_website_form_input"
name="a_document"/>
</div>
</div>
</div>
</div>
</form>
</template>
</odoo>

77
one_page_checkout/views/payment_templates.xml

@ -0,0 +1,77 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- Template for the payment -->
<template id="payment" name="Payment">
<!--- Section for selecting the delivery method, which is
only shown if there is more than one delivery option available. -->
<div t-if="deliveries" id="delivery_carrier">
<t t-set="delivery_nb" t-value="len(deliveries)"/>
<h3 class="mb24">Choose a
delivery method
</h3>
<div
class="card border-0" id="delivery_method">
<ul class="list-group">
<t t-foreach="deliveries" t-as="delivery">
<li class="list-group-item o_delivery_carrier_select">
<t t-call="website_sale.payment_delivery_methods"/>
</li>
</t>
</ul>
</div>
</div>
<!-- Section for selecting the payment method, which is shown
if there is a total amount to be paid. -->
<div class="col-12 col-xl order-xl-1 oe_cart">
<div class="oe_structure clearfix mt-3"
id="oe_structure_website_sale_payment_1"/>
<t t-if="website_sale_order.amount_total">
<div t-if="payment_methods_sudo or tokens_sudo"
id="payment_method"
class="mt-4">
<t t-call="payment.form"/>
</div>
<!-- If there are payment providers available, the user is
presented with the option to choose a payment method.
Otherwise, a message is displayed saying that no suitable
payment option could be found. -->
<div t-else="" class="alert alert-warning">
<strong>No suitable payment option could be
found.
</strong>
<br/>
If you believe that it is an error, please
contact the website administrator.
</div>
</t>
<div t-if="not providers" class="mt-2">
<a role="button" class="btn-link"
groups="base.group_system"
t-attf-href="/web#action=#{payment_action_id}">
<i class="fa fa-arrow-right"/>
Add payment providers
</a>
</div>
<div class="js_payment mt-3"
t-if="not website_sale_order.amount_total"
id="payment_method"
name="o_website_sale_free_cart">
<form target="_self"
action="/shop/payment/validate"
method="post">
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"
t-nocache="The csrf token must always be up to date."/>
<!-- If there is no amount to be paid (i.e., the cart is free),
a confirmation button is displayed instead of the payment methods section. -->
<t t-call="website_sale.payment_footer">
<t t-set="submit_button_label">Confirm
Order
</t>
</t>
</form>
</div>
</div>
</template>
</odoo>

66
one_page_checkout/views/website_sale_templates.xml

@ -0,0 +1,66 @@
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- This template inherits from the website_sale.payment template and
is used for the one-page checkout payment step. -->
<template id="one_page_checkout_payment" inherit_id="website_sale.payment">
<xpath expr="//t[@t-call='website_sale.checkout_layout']" position="replace">
<t t-call="website_sale.checkout_layout">
<div class="single_pg_checkout_layout">
<div class='col-auto'>
<!-- This sets the step to 20 if the partner is inactive,
or 40 if the partner is active. -->
<t t-if="website_sale_order.partner_id.active == False">
<t t-set="step" t-value="20"/>
</t>
<t t-else="">
<t t-set="step" t-value="40"/>
</t>
</div>
<div class='col-12'>
<div class="col-12">
<!-- This calls the payment template for the right column.
If the partner is inactive, it adds the "block-ui" class to the column. -->
<div t-attf-class="column #{'block-ui' if website_sale_order.partner_id.active == False else ''}">
<t t-call="one_page_checkout.payment"/>
<!-- This calls the cart_summary and extra_info templates for the left column. -->
<div class="row">
<t t-call="one_page_checkout.extra_info"/>
</div>
</div>
<div class="row">
<!-- This calls the address column template for the middle column. -->
<div class="col-12">
<t t-call="one_page_checkout.address_column"/>
</div>
</div>
</div>
<!-- This displays any errors that occur during checkout. -->
<div class="col-12" t-if="errors">
<t t-foreach="errors" t-as="error">
<div class="alert alert-danger" t-if="error" role="alert">
<h4>
<t t-esc="error[0]"/>
</h4>
<t t-esc="error[1]"/>
</div>
</t>
</div>
</div>
</div>
</t>
</xpath>
</template>
<!-- This template inherits from the website_sale.cart template and is
used for the one-page checkout cart feature. -->
<template id="one_page_checkout_checkout"
inherit_id="website_sale.checkout">
<!-- This XPath expression finds the "redirect_url" element and
replaces it with a new value. -->
<xpath expr="//t[@t-set='redirect']" position="replace">
<!-- This sets the "redirect_url" variable to the new URL for
the one-page checkout. -->
<t t-set="redirect" t-value="'/shop/checkout?express=1'"/>
</xpath>
</template>
</odoo>
Loading…
Cancel
Save