Browse Source

Aug 31: [ADD] Initial commit 'website_in_store_pickup'

pull/254/merge
Cybrosys Technologies 8 months ago
parent
commit
04324356b7
  1. 49
      website_in_store_pickup/README.rst
  2. 22
      website_in_store_pickup/__init__.py
  3. 50
      website_in_store_pickup/__manifest__.py
  4. 21
      website_in_store_pickup/controllers/__init__.py
  5. 104
      website_in_store_pickup/controllers/website_in_store_pickup.py
  6. 7
      website_in_store_pickup/doc/RELEASE_NOTES.md
  7. 22
      website_in_store_pickup/models/__init__.py
  8. 38
      website_in_store_pickup/models/deliver_carrier.py
  9. 30
      website_in_store_pickup/models/stock_warehouse.py
  10. BIN
      website_in_store_pickup/static/description/assets/icons/check.png
  11. BIN
      website_in_store_pickup/static/description/assets/icons/chevron.png
  12. BIN
      website_in_store_pickup/static/description/assets/icons/cogs.png
  13. BIN
      website_in_store_pickup/static/description/assets/icons/consultation.png
  14. BIN
      website_in_store_pickup/static/description/assets/icons/ecom-black.png
  15. BIN
      website_in_store_pickup/static/description/assets/icons/education-black.png
  16. BIN
      website_in_store_pickup/static/description/assets/icons/hotel-black.png
  17. BIN
      website_in_store_pickup/static/description/assets/icons/license.png
  18. BIN
      website_in_store_pickup/static/description/assets/icons/lifebuoy.png
  19. BIN
      website_in_store_pickup/static/description/assets/icons/manufacturing-black.png
  20. BIN
      website_in_store_pickup/static/description/assets/icons/pos-black.png
  21. BIN
      website_in_store_pickup/static/description/assets/icons/puzzle.png
  22. BIN
      website_in_store_pickup/static/description/assets/icons/restaurant-black.png
  23. BIN
      website_in_store_pickup/static/description/assets/icons/service-black.png
  24. BIN
      website_in_store_pickup/static/description/assets/icons/trading-black.png
  25. BIN
      website_in_store_pickup/static/description/assets/icons/training.png
  26. BIN
      website_in_store_pickup/static/description/assets/icons/update.png
  27. BIN
      website_in_store_pickup/static/description/assets/icons/user.png
  28. BIN
      website_in_store_pickup/static/description/assets/icons/wrench.png
  29. BIN
      website_in_store_pickup/static/description/assets/misc/categories.png
  30. BIN
      website_in_store_pickup/static/description/assets/misc/check-box.png
  31. BIN
      website_in_store_pickup/static/description/assets/misc/compass.png
  32. BIN
      website_in_store_pickup/static/description/assets/misc/corporate.png
  33. BIN
      website_in_store_pickup/static/description/assets/misc/customer-support.png
  34. BIN
      website_in_store_pickup/static/description/assets/misc/cybrosys-logo.png
  35. BIN
      website_in_store_pickup/static/description/assets/misc/features.png
  36. BIN
      website_in_store_pickup/static/description/assets/misc/logo.png
  37. BIN
      website_in_store_pickup/static/description/assets/misc/pictures.png
  38. BIN
      website_in_store_pickup/static/description/assets/misc/pie-chart.png
  39. BIN
      website_in_store_pickup/static/description/assets/misc/right-arrow.png
  40. BIN
      website_in_store_pickup/static/description/assets/misc/star.png
  41. BIN
      website_in_store_pickup/static/description/assets/misc/support.png
  42. BIN
      website_in_store_pickup/static/description/assets/misc/whatsapp.png
  43. BIN
      website_in_store_pickup/static/description/assets/modules/1.png
  44. BIN
      website_in_store_pickup/static/description/assets/modules/2.png
  45. BIN
      website_in_store_pickup/static/description/assets/modules/3.png
  46. BIN
      website_in_store_pickup/static/description/assets/modules/4.png
  47. BIN
      website_in_store_pickup/static/description/assets/modules/5.gif
  48. BIN
      website_in_store_pickup/static/description/assets/modules/6.png
  49. BIN
      website_in_store_pickup/static/description/assets/screenshots/hero.gif
  50. BIN
      website_in_store_pickup/static/description/assets/screenshots/store-01.png
  51. BIN
      website_in_store_pickup/static/description/assets/screenshots/store-02.png
  52. BIN
      website_in_store_pickup/static/description/assets/screenshots/store-03.png
  53. BIN
      website_in_store_pickup/static/description/assets/screenshots/store-04.png
  54. BIN
      website_in_store_pickup/static/description/banner.jpg
  55. BIN
      website_in_store_pickup/static/description/icon.png
  56. 582
      website_in_store_pickup/static/description/index.html
  57. 95
      website_in_store_pickup/static/src/js/website_in_store_pickup.js
  58. 22
      website_in_store_pickup/views/delivery_carrier_views.xml
  59. 25
      website_in_store_pickup/views/stock_warehouse_views.xml

49
website_in_store_pickup/README.rst

@ -0,0 +1,49 @@
.. 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
Website In-Store Pickup
=======================
Manage the website in-store pickup easily with this module.
Configuration
-------------
* No additional configurations needed
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
License
-------
Affero General Public License v3.0 (AGPL v3)
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Credits
-------
Developer : (V16) Shafna K,
(V15) Ranjith R,
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
website_in_store_pickup/__init__.py

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

50
website_in_store_pickup/__manifest__.py

@ -0,0 +1,50 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Ranjith R(odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
###############################################################################
{
'name': "Website In-Store Pickup",
'version': '15.0.1.0.0',
'category': 'eCommerce',
'summary': 'To manage the in-store pickups of orders ',
'description': "To facilitate the management of in-store pickups, we have"
"implemented a system to handle customer orders that can "
"be picked up at the physical store location. This system "
"allows customers to place orders online and then select "
"the option to pick up their purchases at the store.",
'author': " Cybrosys Techno Solutions",
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
'depends': ['base', 'delivery', 'stock', 'website_sale_delivery'],
'data': [
'views/stock_warehouse_views.xml',
'views/delivery_carrier_views.xml',
],
'assets': {
'web.assets_frontend': [
'website_in_store_pickup/static/src/js/website_in_store_pickup.js',
],
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False
}

21
website_in_store_pickup/controllers/__init__.py

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

104
website_in_store_pickup/controllers/website_in_store_pickup.py

@ -0,0 +1,104 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Ranjith R(odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
###############################################################################
from odoo import http
from odoo.http import request
from odoo.addons.website_sale_delivery.controllers.main import (
WebsiteSaleDelivery)
from odoo.addons.website_sale.controllers.main import WebsiteSale
class WebsiteInStorePickup(WebsiteSaleDelivery):
""" Inherited Controller to check the carrier and update in corresponding
sale order"""
@http.route(['/shop/check_carrier'], type='json', auth='public',
methods=['POST'], website=True, csrf=False)
def check_carrier(self, **post):
"""To check the carrier details and returns the relevant details
whether the delivery method is store pick or not and returns the
available stores"""
carrier_id = int(post.get('carrier_id'))
carrier = request.env['delivery.carrier'].browse(carrier_id)
store = carrier.store_ids
sale_order_id = http.request.session.get('sale_order_id')
if sale_order_id:
sale_order = http.request.env['sale.order'].sudo().browse(
sale_order_id)
if not carrier.is_store_pick:
sale_order.write({
'partner_invoice_id': sale_order.partner_id.id,
'partner_shipping_id': sale_order.partner_id.id,
})
return {
'is_store_pick': carrier.is_store_pick,
'store_ids': carrier.store_ids.read(),
'store_id': store.read(),
}
@http.route(['/shop/update_address'], type='json', auth='public',
methods=['POST'], website=True, csrf=False)
def update_address(self, **post):
"""To update the address of store address to sale order on choosing
the store for pickup"""
if post.get('store_id'):
store_address = request.env['stock.warehouse'].browse(
int(post['store_id']))
if post['store_id']:
sale_order_id = http.request.session.get('sale_order_id')
if sale_order_id:
sale_order = http.request.env['sale.order'].sudo().browse(
sale_order_id)
sale_order.write({
'partner_invoice_id': store_address.partner_id.id,
'partner_shipping_id': store_address.partner_id.id
})
return {
'store_id': store_address.partner_id.read()
}
return {
'store_id': store_address.partner_id.read()
}
class WebsiteSaleInStorePickup(WebsiteSale):
@http.route('/shop/payment', type='http', auth='public', website=True,
sitemap=False)
def shop_payment(self, **post):
""" Payment step. This page proposes several payment means based on
available payment.acquirer. 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.acquirer website but closed the tab
without paying / canceling
"""
order = request.website.sale_get_order()
redirection = self.checkout_redirection(
order) or self.checkout_check_address(order)
if redirection:
return redirection
render_values = self._get_shop_payment_values(order, **post)
render_values['only_services'] = order and order.only_services or False
if render_values['errors']:
render_values.pop('acquirers', '')
render_values.pop('tokens', '')
return request.render("website_sale.payment", render_values)

7
website_in_store_pickup/doc/RELEASE_NOTES.md

@ -0,0 +1,7 @@
## Module <website_in_store_pickup>
#### 20.07.2024
#### Version 15.0.1.0.0
#### ADD
- Initial Commit for Website In-Store Pickup

22
website_in_store_pickup/models/__init__.py

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

38
website_in_store_pickup/models/deliver_carrier.py

@ -0,0 +1,38 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Ranjith R(odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
###############################################################################
from odoo import fields, models
class DeliveryCarrier(models.Model):
"""Class to add the fields to identify a method as a store picking
delivery method and choose the stores to be available for that particular
delivery method"""
_inherit = 'delivery.carrier'
is_store_pick = fields.Boolean(string='In-Store Pickup',
help="Enable this to identify this as an "
"In-store PickUp delivery method")
store_ids = fields.Many2many('stock.warehouse',
string="Available Stores",
domain="[('is_store', '=', True)]",
help="Choose the stores available for "
"in-store picking and if no stores "
"implies all stores are available")

30
website_in_store_pickup/models/stock_warehouse.py

@ -0,0 +1,30 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Ranjith R(odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
###############################################################################
from odoo import fields, models
class StockWarehouse(models.Model):
"""Class to add a field to identify a warehouse as a store"""
_inherit = 'stock.warehouse'
is_store = fields.Boolean(string='Store',
help="Enable this to identify this Warehouse "
"as a store")

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 95 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 109 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 MiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 57 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 128 KiB

BIN
website_in_store_pickup/static/description/assets/screenshots/store-01.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 109 KiB

BIN
website_in_store_pickup/static/description/assets/screenshots/store-02.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 119 KiB

BIN
website_in_store_pickup/static/description/assets/screenshots/store-03.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 135 KiB

BIN
website_in_store_pickup/static/description/assets/screenshots/store-04.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 304 KiB

BIN
website_in_store_pickup/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 83 KiB

BIN
website_in_store_pickup/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.2 KiB

582
website_in_store_pickup/static/description/index.html

@ -0,0 +1,582 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between"
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42"
style="width: 42px; height: 42px;"/>
<div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
<!-- END OF TITLE BAR -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Website In-Store Pickup
</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
This module is designed to enhance the customer experience by offering an alternative delivery method that allows customers to pick up their purchased items from a physical store location.
</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/hero.gif" class="img-responsive"
style="width: 100%; margin-left: auto; margin-right: auto;"/>
</div>
</div>
</div>
</div>
<!-- NAVIGATION SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/compass.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Explore This Module</h2>
</div>
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;">
<div class="col-sm-12 col-md-6 my-3">
<a href="#overview">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn more about this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#features">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View features of this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#screenshots">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View screenshots for this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
</div>
<!-- END OF NAVIGATION SECTION -->
<!-- OVERVIEW SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pie-chart.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Overview
</h2>
</div>
<div class="row"
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 py-4">
This module is designed to enhance the Customer experience by offering
an alternative Delivery Method that allows Customers to Pick up their
Purchased items from a Physical Store Location.
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Features
</h2>
</div>
<div class="row"
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Provide a new Shipping option during the Checkout
process that allows Customers to choose In-Store Pickup
Delivery Method.</span>
</div>
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Easier Workflow with Simplified Process.</span>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center"
style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Customers might be able to select their preferred
Physical Store Location from which they'll pick up their Order
from the available ones.</span>
</div>
</div>
</div>
<!-- END OF FEATURES SECTION -->
<!-- SCREENSHOTS SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"
id="screenshots">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pictures.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Screenshots
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Set up Inventory Warehouse as Store.
</h3>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Choose the Warehouse in Inventory as Store by enabling the
In-Store option.
</p>
<img src="assets/screenshots/store-01.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Create an In-Store Pickup Delivery Method.
</h3>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Create and Publish the Delivery Method for In-Store Pickup by
enabling the
Store Pickup option.In the Available Stores field, leave
empty to display all Stores in the Website Sale and choose the
desired Stores to restrict other Stores from display in Website.
</p>
<img src="assets/screenshots/store-02.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Select In-Store Pickup Delivery Method.
</h3>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Choose the In-Store Delivery Method and select the Store for
Pickup.The corresponding Store Address will be updated in the
Shipping
Address section.
</p>
<img src="assets/screenshots/store-03.png" class="img-thumbnail">
</div>
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">
Update Delivery Address in Website Orders.
</h3>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
The Store Address will be updated to the Delivery Address and
Invoice Address in the Corresponding Website Order in the
backend.
</p>
<img src="assets/screenshots/store-04.png" class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested Products</h2>
<hr style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/>
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner">
<div class="carousel-item active" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/call_for_price_website/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/1.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/odoo_website_helpdesk_dashboard/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/2.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/product_visibility_website/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/ecommerce_barcode_search/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/4.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/base_accounting_kit/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/5.png">
</div>
</a>
</div>
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/hr_payroll_community/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-top-left-radius:10px; border-top-right-radius:10px"
src="./assets/modules/6.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="left:-25px;width: 35px;color: #000;">
<span class="carousel-control-prev-icon"><i
class="fa fa-chevron-left"
style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1"
data-slide="next"
style="right:-25px;width: 35px;color: #000;">
<span class="carousel-control-next-icon"><i
class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF SUGGESTED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Services</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire Odoo Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure and sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy configuration and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile friendly, awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An all-inclusive hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48"
style="width: 42px; height: 42px;"/>
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help?
Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52"
style="width: 52px; height: 52px;"/>
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
+91 86068 27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31"
style="width:144px; height: 31px; margin-top: 40px;"/>
</div>
</div>
</div>
<!-- END OF SUPPORT -->

95
website_in_store_pickup/static/src/js/website_in_store_pickup.js

@ -0,0 +1,95 @@
/* @odoo-module */
import core from "web.core";
import publicWidget from 'web.public.widget';
import 'website_sale_delivery.checkout';
var QWeb = core.qweb;
var store={}
/**
* Extends the websiteSaleDelivery widget to handle store pickup functionality.
*/
publicWidget.registry.websiteSaleDelivery.include({
/**
* Handles the click event on the store pickup dropdown.
*
* Updates the address display based on the selected store and toggles the
* visibility of UI elements.
*
* @param {Event} ev - The click event.
*/
_onClickDropDown: async function(ev){
var addressTemplate = {};
const selectedStoreId = parseInt(ev.target.value)
var self = this;
const address = await this._rpc({
route: '/shop/update_address',
params: {
store_id: selectedStoreId
},
}).then(result => {
this.$el.find('#store_address_section').remove()
if (result) {
addressTemplate.address = result.store_id[0].contact_address
}
})
},
/**
* Handles the click event on a carrier option.
*
* Performs actions such as checking carrier options, updating UI elements,
* and dynamically rendering store pickup dropdown.
*
* @param {Event} ev - The click event.
*/
_onCarrierClick: function(ev){
var radio = $(ev.currentTarget).find('input[type="radio"]');
const status = this._rpc({
route: '/shop/check_carrier',
params: {
carrier_id: radio.val(),
},
}).then(async data => {
store=data
this.$el.find('#shipping_and_billing').show()
this.$el.find('#store_address_section').remove()
if (this.$el.find('#shipping_and_billing')){
var storeDropdown = this.$el.find('.store-pickup-dropdown');
if (! data.is_store_pick ){
storeDropdown[0].classList.add('d-none')
}
if (data['is_store_pick']){
var templateData = {};
if (data['store_ids'].length === 0) {
templateData.store_all = data['store_id'];
}
else {
templateData.stores = data['store_ids'];
}
var self = this;
if ( storeDropdown.length === 0 ) {
this.el.querySelector('.store-pickup-dropdown').addEventListener('click',this._onClickDropDown.bind(this) )
storeDropdown.on('click', this._onClickDropDown.bind(this))
var stores = data['store_ids'];
var options = "";
stores.forEach(function(store) {
options += "<option value='" + store.id + "'>" + store.name + "</option>";
});
storeDropdown[0].innerHTML = options;
}
else {
var stores = data['store_ids'];
var options = "";
stores.forEach(function(store) {
options += "<option value='" + store.id + "'>" + store.name + "</option>";
});
storeDropdown[0].innerHTML = options;
storeDropdown.on('change', this._onClickDropDown.bind(this))
storeDropdown[0].classList.remove('d-none')
}
}
}
});
this._super(...arguments)
}
})

22
website_in_store_pickup/views/delivery_carrier_views.xml

@ -0,0 +1,22 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- Inherited form view of Delivery Carrier to add the field for
indicating the shipping method is for In-store picking-->
<record id="view_delivery_carrier_form" model="ir.ui.view">
<field name="name">
delivery.carrier.view.form.inherit.website.in.store.pickup
</field>
<field name="model">delivery.carrier</field>
<field name="inherit_id" ref="delivery.view_delivery_carrier_form"/>
<field name="arch" type="xml">
<xpath expr="//group[@name='delivery_details']" position="after">
<group>
<field name="is_store_pick"/>
<field name="store_ids"
widget="many2many_tags" class="oe_inline"
attrs="{'invisible':[('is_store_pick','=',False)]}"/>
</group>
</xpath>
</field>
</record>
</odoo>

25
website_in_store_pickup/views/stock_warehouse_views.xml

@ -0,0 +1,25 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- Inherited form view of stock warehouse to add the field for
checking whether the warehouse is a store-->
<record id="view_warehouse" model="ir.ui.view">
<field name="name">
stock.warehouse.view.form.inherit.website.in.store.pickup
</field>
<field name="model">stock.warehouse</field>
<field name="inherit_id" ref="stock.view_warehouse"/>
<field name="arch" type="xml">
<xpath expr="//field[@name='code']" position="after">
<field name="is_store"/>
</xpath>
</field>
</record>
<template id="payment_delivery_shipping_method_1"
name="Delivery Shipping method"
inherit_id="website_sale_delivery.payment_delivery">
<xpath expr="//div[@id='delivery_method']" position="after">
<select class="store-pickup-dropdown d-none" style="width: 100%;">
</select>
</xpath>
</template>
</odoo>
Loading…
Cancel
Save