Browse Source

Jun 24: [ADD] Initial commit 'website_product_search_snippet'

pull/254/merge
RisvanaCybro 10 months ago
parent
commit
283fce91f5
  1. 48
      website_product_search_snippet/README.rst
  2. 23
      website_product_search_snippet/__init__.py
  3. 64
      website_product_search_snippet/__manifest__.py
  4. 22
      website_product_search_snippet/controllers/__init__.py
  5. 145
      website_product_search_snippet/controllers/website_product_search_snippet.py
  6. 5
      website_product_search_snippet/doc/RELEASE_NOTES.md
  7. 22
      website_product_search_snippet/models/__init__.py
  8. 84
      website_product_search_snippet/models/product_template.py
  9. BIN
      website_product_search_snippet/static/description/assets/icons/check.png
  10. BIN
      website_product_search_snippet/static/description/assets/icons/chevron.png
  11. BIN
      website_product_search_snippet/static/description/assets/icons/cogs.png
  12. BIN
      website_product_search_snippet/static/description/assets/icons/consultation.png
  13. BIN
      website_product_search_snippet/static/description/assets/icons/ecom-black.png
  14. BIN
      website_product_search_snippet/static/description/assets/icons/education-black.png
  15. BIN
      website_product_search_snippet/static/description/assets/icons/hotel-black.png
  16. BIN
      website_product_search_snippet/static/description/assets/icons/license.png
  17. BIN
      website_product_search_snippet/static/description/assets/icons/lifebuoy.png
  18. BIN
      website_product_search_snippet/static/description/assets/icons/manufacturing-black.png
  19. BIN
      website_product_search_snippet/static/description/assets/icons/pos-black.png
  20. BIN
      website_product_search_snippet/static/description/assets/icons/puzzle.png
  21. BIN
      website_product_search_snippet/static/description/assets/icons/restaurant-black.png
  22. BIN
      website_product_search_snippet/static/description/assets/icons/service-black.png
  23. BIN
      website_product_search_snippet/static/description/assets/icons/trading-black.png
  24. BIN
      website_product_search_snippet/static/description/assets/icons/training.png
  25. BIN
      website_product_search_snippet/static/description/assets/icons/update.png
  26. BIN
      website_product_search_snippet/static/description/assets/icons/user.png
  27. BIN
      website_product_search_snippet/static/description/assets/icons/wrench.png
  28. BIN
      website_product_search_snippet/static/description/assets/misc/categories.png
  29. BIN
      website_product_search_snippet/static/description/assets/misc/check-box.png
  30. BIN
      website_product_search_snippet/static/description/assets/misc/compass.png
  31. BIN
      website_product_search_snippet/static/description/assets/misc/corporate.png
  32. BIN
      website_product_search_snippet/static/description/assets/misc/customer-support.png
  33. BIN
      website_product_search_snippet/static/description/assets/misc/cybrosys-logo.png
  34. BIN
      website_product_search_snippet/static/description/assets/misc/features.png
  35. BIN
      website_product_search_snippet/static/description/assets/misc/logo.png
  36. BIN
      website_product_search_snippet/static/description/assets/misc/pictures.png
  37. BIN
      website_product_search_snippet/static/description/assets/misc/pie-chart.png
  38. BIN
      website_product_search_snippet/static/description/assets/misc/right-arrow.png
  39. BIN
      website_product_search_snippet/static/description/assets/misc/star.png
  40. BIN
      website_product_search_snippet/static/description/assets/misc/support.png
  41. BIN
      website_product_search_snippet/static/description/assets/misc/whatsapp.png
  42. BIN
      website_product_search_snippet/static/description/assets/modules/odoo_website_helpdesk.png
  43. BIN
      website_product_search_snippet/static/description/assets/modules/odoo_website_helpdesk_dashboard.png
  44. BIN
      website_product_search_snippet/static/description/assets/modules/product_visibility_website.png
  45. BIN
      website_product_search_snippet/static/description/assets/modules/website_multi_product_return_management.png
  46. BIN
      website_product_search_snippet/static/description/assets/modules/website_product_attachments.png
  47. BIN
      website_product_search_snippet/static/description/assets/modules/website_return_management.png
  48. BIN
      website_product_search_snippet/static/description/assets/screenshots/1.png
  49. BIN
      website_product_search_snippet/static/description/assets/screenshots/2.png
  50. BIN
      website_product_search_snippet/static/description/assets/screenshots/3.png
  51. BIN
      website_product_search_snippet/static/description/assets/screenshots/4.png
  52. BIN
      website_product_search_snippet/static/description/assets/screenshots/5.png
  53. BIN
      website_product_search_snippet/static/description/assets/screenshots/6.png
  54. BIN
      website_product_search_snippet/static/description/assets/screenshots/7.png
  55. BIN
      website_product_search_snippet/static/description/assets/screenshots/8.png
  56. BIN
      website_product_search_snippet/static/description/assets/screenshots/hero.gif
  57. BIN
      website_product_search_snippet/static/description/assets/screenshots/v15-hero.gif
  58. BIN
      website_product_search_snippet/static/description/banner.jpg
  59. BIN
      website_product_search_snippet/static/description/icon.png
  60. 696
      website_product_search_snippet/static/description/index.html
  61. 25
      website_product_search_snippet/static/src/css/website_product_search_snippet.scss
  62. BIN
      website_product_search_snippet/static/src/img/icon.png
  63. 38
      website_product_search_snippet/static/src/js/search_bar.js
  64. 86
      website_product_search_snippet/static/src/js/website_product_search_snippet.js
  65. 59
      website_product_search_snippet/static/src/xml/category_templates.xml
  66. 60
      website_product_search_snippet/static/src/xml/product_templates.xml
  67. 73
      website_product_search_snippet/views/snippets/category_all_result_templates.xml
  68. 213
      website_product_search_snippet/views/snippets/category_details_templates.xml
  69. 136
      website_product_search_snippet/views/snippets/category_selected_product_templates.xml
  70. 73
      website_product_search_snippet/views/snippets/product_all_result_templates.xml
  71. 136
      website_product_search_snippet/views/snippets/product_details_templates.xml
  72. 36
      website_product_search_snippet/views/snippets/product_search_templates.xml
  73. 136
      website_product_search_snippet/views/snippets/product_select_from_category_templates.xml
  74. 12
      website_product_search_snippet/views/snippets/search_snippet_templates.xml
  75. 214
      website_product_search_snippet/views/snippets/selected_category_from_all_category_templates.xml
  76. 136
      website_product_search_snippet/views/snippets/selected_product_from_all_product_templates.xml

48
website_product_search_snippet/README.rst

@ -0,0 +1,48 @@
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
Product Search Snippet
======================
This module helps to search products category and all category wise in website.
Configuration
=============
* No additional configurations needed
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
License
-------
Affero General Public License, Version 3 (AGPL v3).
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Credits
-------
* Developers: (V16) Farhana Jahan PT,
(V15) Aysha Shalin,
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>`__

23
website_product_search_snippet/__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 <http://www.gnu.org/licenses/>.
#
###############################################################################
from . import controllers
from . import models

64
website_product_search_snippet/__manifest__.py

@ -0,0 +1,64 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
{
'name': 'Product Search Snippet',
'version': '15.0.1.0.0',
'summary': """Product Search Snippet for Website allows to easily search
products and filter based on category.""",
'description': """This module enables users to search for products
within a specific category or across all categories using the search
bar on the website snippet and redirect to its details.""",
'category': 'Website',
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': [
'website', 'sale_management'
],
'data': [
'views/snippets/search_snippet_templates.xml',
'views/snippets/product_search_templates.xml',
'views/snippets/product_details_templates.xml',
'views/snippets/selected_product_from_all_product_templates.xml',
'views/snippets/product_all_result_templates.xml',
'views/snippets/category_details_templates.xml',
'views/snippets/category_selected_product_templates.xml',
'views/snippets/selected_category_from_all_category_templates.xml',
'views/snippets/category_all_result_templates.xml',
'views/snippets/product_select_from_category_templates.xml',
],
'assets': {
'web.assets_frontend': [
'website_product_search_snippet/static/src/css/website_product_search_snippet.scss',
'website_product_search_snippet/static/src/js/website_product_search_snippet.js',
'website_product_search_snippet/static/src/js/search_bar.js',
'website_product_search_snippet/static/src/xml/product_templates.xml',
'website_product_search_snippet/static/src/xml/category_templates.xml',
],
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

22
website_product_search_snippet/controllers/__init__.py

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

145
website_product_search_snippet/controllers/website_product_search_snippet.py

@ -0,0 +1,145 @@
# -*- coding: utf-8 -*-
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
###############################################################################
from odoo import http
from odoo.http import request
class WebsiteSnippetPage(http.Controller):
""" Controller for setting routes. Pass all categories and category wise
products as an array to a template"""
@http.route('/category/form', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def category_page(self, **kw):
""" Function for rendering specific category and products of that
category into website """
category = request.env['product.category'].sudo().browse(
int(kw.get('category_id')))
parent = request.env['product.category'].sudo().browse(
int(kw.get('parent_id')))
values = {
'category': category,
'products': request.env['product.template'].search(
[('categ_id', '=', category.id)]),
'products_category': request.env['product.template'].search(
[('category_id', '=', parent.id)])
}
return http.request.render(
'website_product_search_snippet.category_snippet_img', values)
@http.route('/selected/category/result', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def category_all_page(self, **kw):
""" Function for rendering specific category and products of that
category into website """
category = request.env['product.category'].sudo().browse(
int(kw.get('category_id')))
values = {
'category': category,
'products': request.env['product.template'].search(
[('categ_id', '=', category.id)])
}
return http.request.render(
'website_product_search_snippet.all_category_snippet_img', values)
@http.route('/selected/category/from/all_category/result', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def category_from_all_category_page(self, **kw):
""" Function for rendering specific category and products of that
category into website """
category = request.env['product.category'].sudo().browse(
int(kw.get('category_id')))
values = {
'category': category,
'products': request.env['product.template'].search(
[('categ_id', '=', category.id)])
}
return http.request.render(
'website_product_search_snippet.category_from_all_category_snippet_img', values)
@http.route('/product/form', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def product_page(self, **kw):
""" Function for rendering specific product into website """
values = {
'products': request.env['product.template'].sudo().browse(
int(kw.get('product_id')))
}
return http.request.render(
'website_product_search_snippet.products_snippet_img', values)
@http.route('/selected/product/from/category', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def selected_product_page(self, **kw):
""" Function for rendering specific product into website """
values = {
'products': request.env['product.template'].sudo().browse(
int(kw.get('product_id')))
}
return http.request.render(
'website_product_search_snippet.selected_products_from_category_snippet_img',
values)
@http.route('/all/product/selected/product/details', type='http',
auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def product_all_page(self, **kw):
""" Function for rendering specific product into website """
values = {
'products': request.env['product.template'].sudo().browse(
int(kw.get('product_id')))
}
return http.request.render(
'website_product_search_snippet.all_products_snippet_img', values)
@http.route('/select/product/from/category', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def product_category_all_page(self, **kw):
""" Function for rendering specific product into website """
values = {
'products': request.env['product.template'].sudo().browse(
int(kw.get('product_id')))
}
return http.request.render(
'website_product_search_snippet.products_category_snippet_img',
values)
@http.route('/product/form/all/results', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def product_page_result(self):
""" Function for rendering all products into website """
values = {
'products': request.env['product.template'].search([])
}
return http.request.render(
"website_product_search_snippet.product_all_result_template",
values)
@http.route('/category/form/all/results', type='http', auth='public',
website=True, csrf=False, sitemap=False, cache=300)
def category_page_result(self):
""" Function for rendering all categories into website """
values = {'category': request.env['product.category'].search(
[('id', '!=', request.env.ref('product.product_category_all').id),
('id', '!=', request.env.ref('product.product_category_1').id)])}
return http.request.render(
"website_product_search_snippet.category_all_result_template",
values)

5
website_product_search_snippet/doc/RELEASE_NOTES.md

@ -0,0 +1,5 @@
## Module <website_product_search_snippet>
#### 24.05.2024
#### Version 15.0.1.0.0
##### ADD
- Initial commit for Product Search Snippet

22
website_product_search_snippet/models/__init__.py

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

84
website_product_search_snippet/models/product_template.py

@ -0,0 +1,84 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models
class ProductTemplate(models.Model):
""" Inherit product_template model for fetch products and categories to
frontend. """
_inherit = 'product.template'
parent_category_id = fields.Many2one("product.category",
string="Parent Category",
help="Parent Category of product.")
category_boolean = fields.Boolean(default=True,
help="If enabled will be able to search "
"based on Category.")
category_id = fields.Char(string='Parent Category',
compute="_compute_parent_id",
help="Compute the category id of the product.")
@api.depends('category_boolean')
def _compute_parent_id(self):
""" Get the parent category of the product """
self.category_id = self.categ_id.parent_id.id
@api.model
def search_products(self, qry):
""" Search all products in product.template, and pass searched products
into templates. """
products = self.env['product.template'].search([('name', 'ilike', qry)])
return [[product.name, product.id,
product.list_price,
'/web/image/product.template/{}/image_512/'.format(product.id),
product.currency_id.symbol, ]
for product in products]
@api.model
def search_all_categories(self):
""" Search products in all categories """
products = self.env['product.template'].search([])
return [[product.name, product.id,
product.list_price,
'/web/image/product.template/{}/image_512/'.format(product.id),
product.currency_id.symbol, ]
for product in products]
@api.model
def product_all_categories(self):
""" Search all product categories """
categories = self.env['product.category'].search([
('id', '!=', self.env.ref('product.product_category_all').id)])
return [[category.name, category.id, category.parent_id.name,
category.parent_id.id, category.product_count]
for category in categories]
@api.model
def product_category(self, qry):
""" Search all category in product_category, and pass category into
another template. """
category = self.env['product.category'].search(
[('id', '!=', self.env.ref('product.product_category_all').id),
('name', 'ilike', qry)])
return [[category.name, category.id, category.parent_id.name,
category.parent_id.id, category.product_count]
for category in category]

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

BIN
website_product_search_snippet/static/description/assets/modules/odoo_website_helpdesk.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

BIN
website_product_search_snippet/static/description/assets/modules/odoo_website_helpdesk_dashboard.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 47 KiB

BIN
website_product_search_snippet/static/description/assets/modules/product_visibility_website.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 48 KiB

BIN
website_product_search_snippet/static/description/assets/modules/website_multi_product_return_management.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

BIN
website_product_search_snippet/static/description/assets/modules/website_product_attachments.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

BIN
website_product_search_snippet/static/description/assets/modules/website_return_management.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 48 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 146 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/6.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 66 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/7.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 120 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/8.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 216 KiB

BIN
website_product_search_snippet/static/description/assets/screenshots/v15-hero.gif

Binary file not shown.

After

Width:  |  Height:  |  Size: 230 KiB

BIN
website_product_search_snippet/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

BIN
website_product_search_snippet/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.9 KiB

696
website_product_search_snippet/static/description/index.html

@ -0,0 +1,696 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between"
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42"
style="width: 42px; height: 42px;"/>
<div>
<div
style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>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;">
Product Search Snippet</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">
This App Allows to Search Products in Category With the Help of Snippet</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/hero.gif" class="img-responsive"
style="width: 75%; height: auto; position: absolute; margin-left: auto; margin-right: auto; top: 45%; left: 12%; 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;">
See key screenshots of 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 allows users to search for products
either within a particular category or across all categories by
utilizing the search bar on the website snippet.
Subsequently, users can be redirected to view the details of the
chosen product.
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"
id="features">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Features
</h2>
</div>
<div class="row"
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center"
style="margin-top: 40px; margin-bottom: 40px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Community,Enterprise and Odoo.sh Support.</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;">
Search for Products based on specific Categories as well as across All Categories.
</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;">
Filtering can be applied during the search process, either based on a specific Category or across All Categories.
</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;">
Product details can be viewed by clicking on the respective Products.
</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;">
<p style="font-family: 'Montserrat', sans-serif;">Drag the Product
Search Snippet and save it.</p>
<img src="assets/screenshots/1.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">When selecting
"All Categories," the system should be able to display All
Products as users type in the Search Bar, and users should have
the option to choose a specific Product.</p>
<img src="assets/screenshots/2.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">Upon selecting a
Product, the system should direct users to the details of that
Product. Within the product details page, there should be an
option available for users to navigate Back to the previous
page.
</p>
<img src="assets/screenshots/4.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">Upon selecting
"Category", the Search Bar should be filtered according to the
chosen Category. This allows users to narrow down their search,
and they should be able to select a Category from there.
If no products are available in the selected Category, the color
<b>red</b> will be displayed. Additionally, a button labeled
"See All
Category" will be provided to users.</p>
<img src="assets/screenshots/5.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">Get all Product
Categories. Additionally, utilize red and blue colors to
signify the product count within each category.</p>
<img src="assets/screenshots/6.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">Clicking on a
Category should lead users to a dedicated page that displays
Products falling under that specific Category.There also
contains a Search Bar for search products </p>
<img src="assets/screenshots/7.png"
class="img-thumbnail">
</div>
</div>
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<p style="font-family: 'Montserrat', sans-serif;">When there are No
Products Available under the selected Category, the system
should display the following message. </p>
<img src="assets/screenshots/8.png"
class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- RELATED PRODUCTS -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/categories.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Related
Products
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/odoo_website_helpdesk/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/odoo_website_helpdesk.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-radius: 0px;"
src="assets/modules/odoo_website_helpdesk_dashboard.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/website_multi_product_return_management/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/website_multi_product_return_management.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active"
style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/product_visibility_website/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/product_visibility_website.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/website_product_attachments/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/website_product_attachments.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/website_return_management/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/website_return_management.png">
</div>
</a>
</div>
</div>
</div>
<!-- Left and right controls -->
<a class="carousel-control-prev" href="#demo1" data-slide="prev"
style="width:35px; color:#000"> <span
class="carousel-control-prev-icon"><i
class="fa fa-chevron-left"
style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1"
data-slide="next"
style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i
class="fa fa-chevron-right"
style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive"
height="48px" width="48px">
</div>
<h6 class="text-center"
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png"
class="img-responsive mb-3" height="48px"
width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png"
class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center"
style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png"/>
</div>
<h2 class="mt-2"
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">
Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4"
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"
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 -->

25
website_product_search_snippet/static/src/css/website_product_search_snippet.scss

@ -0,0 +1,25 @@
.heading{
color: #fff6f8;
background: #575758;
font-size: 47px;
font-weight: bold;
}
.search_bar{
margin-left: 47px;
border-radius: 15px;
}
.search_container{
background: #9c9a9a
}
#sub_temp{
background: #e9e9f1;
}
#category_template{
background: #e9e9f1;
}
#table_header {
background-color: #bababa;
color: white;
}
#table_row:nth-child(even){background-color: #ededed}
#category_table:nth-child(even){background-color: #c3c3c3}

BIN
website_product_search_snippet/static/src/img/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 14 KiB

38
website_product_search_snippet/static/src/js/search_bar.js

@ -0,0 +1,38 @@
odoo.define('website_product_search_snippet.search', function(require) {
"use strict";
var publicWidget = require('web.public.widget');
var rpc = require('web.rpc');
publicWidget.registry.portalDetails = publicWidget.Widget.extend({
/**
* Retrieve all the data from the table.
*/
selector: '.product_search_bar',
events: {
'keyup .search_product_bar': '_onKeyUp',
},
// Function to start a website.
start: function() {
this._super.apply(this, arguments);
},
// Function to search table datas.
_onKeyUp: function() {
var input, filter, table, tr, td, i, txtValue;
input = this.$el.find("#searchBarInput")[0];
filter = input.value.toUpperCase();
table = this.$el.find("#category_table")
tr = table[0].children.category_table_body.children;
for (i = 0; i < tr.length; i++) {
td = tr[i].children;
for (var j = 0; j < td.length; j++) {
txtValue = td[j].textContent || td[j].innerText;
if (txtValue.toUpperCase().indexOf(filter) > -1) {
tr[i].style.display = "";
break;
} else {
tr[i].style.display = "none";
}
}
}
},
});
});

86
website_product_search_snippet/static/src/js/website_product_search_snippet.js

@ -0,0 +1,86 @@
odoo.define('website_product_search_snippet.dynamic', function(require) {
var PublicWidget = require('web.public.widget');
var rpc = require('web.rpc');
var core = require('web.core');
var Qweb = core.qweb;
const ajax = require('web.ajax');
var Dynamic = PublicWidget.Widget.extend({
selector: '.dynamic_search_snippet',
xmlDependencies: [
"/website_product_search_snippet/static/src/xml/category_templates.xml",
"/website_product_search_snippet/static/src/xml/product_templates.xml",
],
events: {
'click .search_container': '_onClick',
'keyup .search_bar': '_onKeyUp',
'change .category_options': '_filterProducts',
},
// When click on search bar, products/categories will displays.otherwise products/categories will not be displayed
_onClick: function() {
this.$el.find('#searchInput').val("");
},
// Call rpc query to keyup function for display all products under all category filter
_onKeyUp: async function(ev) {
category = this.$el.find(".category_options").find(":selected").text();
var qry = $(ev.currentTarget).val()
if (category === "All Categories") {
await rpc.query({
model: 'product.template',
method: 'search_products',
args: [qry],
}).then(function(result) {
console.log('result', this.$('.qweb_product_id'))
this.$('.qweb_product_id').html("");
this.$('.qweb_product_id').append(Qweb.render('website_product_search_snippet.product_template', {
'result': result
}));
});
}
// Call rpc query to keyup function for display all category under category filter
if (category === "Category") {
await rpc.query({
model: 'product.template',
method: 'product_category',
args: [qry],
}).then(function(result) {
this.$('.qweb_product_id').html("");
this.$('.qweb_product_id').append(Qweb.render('website_product_search_snippet.product_category', {
result
}));
});
}
},
_filterProducts: async function(ev) {
var category = this.$el.find(".category_options").find(":selected").text();
console.log('helloooo', category)
var qry = $(ev.currentTarget).val()
if (category === "All Categories") {
await rpc.query({
model: 'product.template',
method: 'search_all_categories',
args: [],
}).then(function(result) {
console.log('result', this)
this.$('.qweb_product_id').html("");
this.$('.qweb_product_id').append(Qweb.render('website_product_search_snippet.product_template', {
'result': result
}));
});
}
if (category === "Category") {
await rpc.query({
model: 'product.template',
method: 'product_all_categories',
args: [],
}).then(function(result) {
this.$('.qweb_product_id').html("");
this.$('.qweb_product_id').append(Qweb.render('website_product_search_snippet.product_category', {
result
}));
});
}
},
});
PublicWidget.registry.dynamic_search_snippet = Dynamic;
return Dynamic;
});

59
website_product_search_snippet/static/src/xml/category_templates.xml

@ -0,0 +1,59 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!-- When the key is pressed in the search bar the searched category will be shown with its parent category-->
<templates id="template" xml:space="preserve">
<t t-name="website_product_search_snippet.product_category">
<div class="container" id="category_template">
<section>
<form id="category_form">
<div style="height:50px"/>
<center>
<h3>Categories</h3>
</center>
<t t-if="result.length === 0">
<p class="text-center">No results found. Please try another search.</p>
</t>
<div style="height:20px"/>
<table class="table">
<thead id="table_header">
<td><b>Parent Category</b></td>
<td><b>Category</b></td>
</thead>
<tbody id="table_category_body" class="body">
<t t-set="result_limit" t-value="5"/>
<t t-set="counter" t-value="0"/>
<t t-foreach="result" t-as="category">
<t t-if="counter &lt; result_limit">
<tr id="table_row">
<td><t t-esc="category[2]"/></td>
<t t-if="category[4] === 0">
<td><a t-attf-href="/category/form?category_id=#{category[1]}&amp;parent_id=#{category[3]}"
loading="fast" style="color: #de3434;"><t t-esc="category[0]"
/></a></td>
</t>
<t t-else="">
<td><a t-attf-href="/category/form?category_id=#{category[1]}&amp;parent_id=#{category[3]}"
loading="fast"><t t-esc="category[0]"
/></a></td>
</t>
</tr>
</t>
<t t-else="">
<tr id="table_row_hidden" class="d-none">
<td><t t-esc="category[2]"/></td>
<td><a t-attf-href="/category/form?category_id=#{category[1]}"
loading="fast"><t t-esc="category[0]"
/></a></td>
</tr>
</t>
<t t-set="counter" t-value="counter+1"/>
</t>
</tbody>
</table>
<a t-attf-href="/category/form/all/results"
style="margin-left: 38%;">See All Categories</a>
</form>
</section>
<div style="height:20px"/>
</div>
</t>
</templates>

60
website_product_search_snippet/static/src/xml/product_templates.xml

@ -0,0 +1,60 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!--When the key is pressed in the search bar the searched products will be shown with their price and image-->
<templates id="template" xml:space="preserve">
<t t-name="website_product_search_snippet.product_template">
<div class="container" id="sub_temp">
<section cdata-vxml="001">
<form id="product_form" style="background-color: #f3f3f3;">
<div style="height:50px"/>
<center>
<h3 style="margin-left: 0%;">Products</h3>
</center>
<t t-if="result.length === 0">
<p class="text-center">No results found. Please try another search.</p>
</t>
<div style="height:20px"/>
<table class="table">
<thead id="table_header">
<td><b>Image</b></td>
<td><b>Product</b></td>
<td style="padding-left:2%;"><b> </b></td>
<td><b>Price</b></td>
</thead>
<tbody id="table_body" class="body">
<t t-set="result_limit" t-value="5"/>
<t t-set="counter" t-value="0"/>
<t t-foreach="result" t-as="product">
<t t-if="counter &lt; result_limit">
<tr id="table_row">
<td><img t-att-src="product[3]"
style="width:25%;"/></td>
<td><a t-attf-href="/product/form?product_id=#{product[1]}"
loading="fast"><t t-esc="product[0]"
/></a></td>
<td style="padding-left:2%;"><t t-esc="product[4]"/></td>
<td><t t-esc="product[2]"/></td>
</tr>
</t>
<t t-else="">
<tr id="table_row_hidden" class="d-none">
<td><img t-att-src="product[3]"
style="width:25%;"/></td>
<td><a t-attf-href="/product/form?product_id=#{product[1]}"
loading="fast"><t t-esc="product[0]"
/></a></td>
<td style="padding-left:2%;"><t t-esc="product[4]"/></td>
<td><t t-esc="product[2]"/></td>
</tr>
</t>
<t t-set="counter" t-value="counter+1"/>
</t>
</tbody>
</table>
<a t-attf-href="/product/form/all/results"
style="margin-left: 38%;">See All Products</a>
</form>
</section>
<div style="height:20px"/>
</div>
</t>
</templates>

73
website_product_search_snippet/views/snippets/category_all_result_templates.xml

@ -0,0 +1,73 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on 'See All Category' rendering a page the route as
/category/form/all/results,where the categories are displayed -->
<template id="category_all_result_template" name="Category results Snippet">
<t t-call="website.layout">
<section class="row category_result_search_bar" loading="eager">
<div class="container">
<div style="height:20px"/>
<div class="back_button" align="left">
<a t-attf-href="/" name="create"
style="margin-left: 13%;font-weight: bold;">Back
</a>
</div>
<div style="height:20px"/>
<center>
<form align="center" id="search_result"
action="/category/form/all/results">
<div style="height:20px"/>
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">All Categories
</h3>
</center>
<table class="table"
style="width: 66%;margin-left: 17%;">
<thead id="table_header">
<td>
<b>Parent Category</b>
</td>
<td>
<b>Category</b>
</td>
</thead>
<tbody id="table_category_body"
class="body">
<t t-foreach="category" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td>
<t t-esc="product.parent_id.name"/>
</td>
<t t-if="product.product_count">
<td>
<a t-attf-href="/selected/category/from/all_category/result?category_id=#{product.id}"
loading="fast">
<t t-esc="product.name"
/>
</a>
</td>
</t>
<t t-else="">
<td>
<a t-attf-href="/selected/category/from/all_category/result?category_id=#{product.id}"
loading="fast"
style="color: #de3434;">
<t t-esc="product.name"
/>
</a>
</td>
</t>
</tr>
</t>
</tbody>
</table>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

213
website_product_search_snippet/views/snippets/category_details_templates.xml

@ -0,0 +1,213 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on a category directed to products under that
category where the route set as '/category/form' -->
<template id="category_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row product_search_bar" loading="eager">
<div class="container">
<div style="height:20px"/>
<div class="back_button" align="left">
<a t-attf-href="/" name="create"
style="margin-left: 13%;font-weight: bold;">Back
</a>
</div>
<h2>
<center>
<b style="font-size: 50px;">
<t t-esc="category.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<t t-if="category.product_count == 0">
<center>
<form align="center" id="categories"
action="/category/form">
<div style="height:20px"/>
<t t-if="products">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{product.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/selected/product/from/category?product_id=#{product.id}">
<t style="margin-left: -190%;"
t-esc="product.name"/>
</a>
</td>
<td>
<t t-esc="product.currency_id.symbol"/>
<t t-esc="product.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
<t t-else="">
<!--When products are not available get the following message-->
<h4 style="font-size: 307%;">
No products available....!!!!
</h4>
</t>
</form>
</center>
</t>
<t t-else="">
<center>
<form align="center" id="categories"
action="/category/form">
<div style="height:20px"/>
<t t-if="products">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{product.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/selected/product/from/category?product_id=#{product.id}">
<t style="margin-left: -190%;"
t-esc="product.name"/>
</a>
</td>
<td>
<t t-esc="product.currency_id.symbol"/>
<t t-esc="product.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
<t t-else="">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products_category" t-as="prod">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{prod.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/selected/product/from/category?product_id=#{prod.id}">
<t style="margin-left: -190%;"
t-esc="prod.name"/>
</a>
</td>
<td>
<t t-esc="prod.currency_id.symbol"/>
<t t-esc="prod.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
</form>
</center>
</t>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

136
website_product_search_snippet/views/snippets/category_selected_product_templates.xml

@ -0,0 +1,136 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on a product directed to product details
where the page route is set as '/selected/product/from/category' -->
<template id="selected_products_from_category_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row align-items-center">
<div class="container" style="background: e0e0e0;;">
<div style="height:20px"/>
<div class="back_button" align="left">
<a style="margin-left: 31%;" t-attf-href="/category/form?category_id=#{products.categ_id.id}&amp;parent_id=#{products.category_id}"
name="create" loading="fast">Back
</a>
</div>
<center>
<div class="row">
<img class="card-img-top"
t-attf-src='/web/image/product.template/{{products.id}}/image_512/'
alt="Card Image Cap"
style="width: 22%;margin-left: 39%;"
loading="fast"/>
</div>
</center>
<h2>
<center>
<b>
<t t-esc="products.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<center>
<form align="center" id="top_customer"
action="/selected/product/from/category" method="post"
enctype="multipart/form-data"
class="o_mark_required"
data-mark="*"
data-model_name="" data-success-page=""
style="border: 3px solid gray;width: 24%;"
loading="fast">
<div style="height:20px">
</div>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div style="margin-left: 20%;">
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.list_price">
<div align="left">
<span class="s_website_form_label_content">
<b>Price :
<t t-esc="products.currency_id.symbol"/>
<t t-esc="products.list_price"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.categ_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Category :
<t t-esc="products.categ_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.detailed_type">
<div align="left">
<span class="s_website_form_label_content">
<t t-if="products.detailed_type == 'consu'">
<b>Product Type : Consumable</b>
</t>
<t t-if="products.detailed_type == 'service'">
<b>Product Type : Service</b>
</t>
<t t-if="products.detailed_type == 'product'">
<b>Product Type : Storable Product</b>
</t>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.taxes_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Tax :
<t t-esc="products.taxes_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
</div>
<div style="height:20px"/>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

73
website_product_search_snippet/views/snippets/product_all_result_templates.xml

@ -0,0 +1,73 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!--When clicking on a 'See All Products' rendering a page route as
/product/form/all/results,where all products are displayed-->
<template id="product_all_result_template" name="Products results Snippet">
<t t-call="website.layout">
<section class="row category_result_search_bar" loading="eager">
<div class="container">
<div style="height:20px"/>
<div class="back_button" align="left">
<a t-attf-href="/" name="create"
style="margin-left: 13%;font-weight: bold;">Back
</a>
</div>
<div style="height:20px"/>
<center>
<form align="center" id="search_result"
action="/product/form/all/results">
<div style="height:20px"/>
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">All Products
</h3>
</center>
<table class="table"
style="width: 66%;margin-left: 17%;">
<thead id="table_header">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td style="padding-left:2%;">
<b></b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<tbody id="table_category_body"
class="body">
<t t-foreach="products" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td>
<img t-attf-src='/web/image/product.template/{{product.id}}/image_512/'
style="width:25%;"/>
</td>
<td>
<a t-attf-href="/all/product/selected/product/details?product_id=#{product.id}"
loading="fast">
<t t-esc="product.name"/>
</a>
</td>
<td style="padding-left:2%;">
<t t-esc="product.currency_id.symbol"/>
</td>
<td>
<t t-esc="product.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

136
website_product_search_snippet/views/snippets/product_details_templates.xml

@ -0,0 +1,136 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on a product directed to product details
where the page route is set as '/product/form'-->
<template id="products_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row align-items-center">
<div class="container" style="background: e0e0e0;;">
<div style="height:20px"/>
<div class="back_button" align="left">
<a style="margin-left: 31%;" t-attf-href="/"
name="create" loading="fast">Back
</a>
</div>
<center>
<div class="row">
<img class="card-img-top"
t-attf-src='/web/image/product.template/{{products.id}}/image_512/'
alt="Card Image Cap"
style="width: 22%;margin-left: 39%;"
loading="fast"/>
</div>
</center>
<h2>
<center>
<b>
<t t-esc="products.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<center>
<form align="center" id="top_customer"
action="/product/form" method="post"
enctype="multipart/form-data"
class="o_mark_required"
data-mark="*"
data-model_name="" data-success-page=""
style="border: 3px solid gray;width: 24%;"
loading="fast">
<div style="height:20px">
</div>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div style="margin-left: 20%;">
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.list_price">
<div align="left">
<span class="s_website_form_label_content">
<b>Price :
<t t-esc="products.currency_id.symbol"/>
<t t-esc="products.list_price"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.categ_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Category :
<t t-esc="products.categ_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.detailed_type">
<div align="left">
<span class="s_website_form_label_content">
<t t-if="products.detailed_type == 'consu'">
<b>Product Type : Consumable</b>
</t>
<t t-if="products.detailed_type == 'service'">
<b>Product Type : Service</b>
</t>
<t t-if="products.detailed_type == 'product'">
<b>Product Type : Storable Product</b>
</t>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.taxes_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Tax :
<t t-esc="products.taxes_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
</div>
<div style="height:20px"/>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

36
website_product_search_snippet/views/snippets/product_search_templates.xml

@ -0,0 +1,36 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- Add a template for a search bar view where the user can filter by
category or all categories using search bar -->
<template id="search_snippet" name="Search Product">
<section class="container dynamic_search_snippet"
style="border: 0px solid white; width:49%;">
<div class="qweb_product">
<div class="row">
<div style="height:10px"/>
<div class="search_bar_container" style="width:100%;">
<h1 class="heading" align="center">Product Search</h1>
<div class="search_container">
<div style="height:35px"/>
<div style="margin-left:18%;">
<select name="category_options"
class="category_options"
id="category_options"
style="height: 30px; width: 25%; border-radius: 25px;">
<option id="all_category" value="volvo">All Categories</option>
<option id="category" value="saab">Category</option>
</select>
<input type="text" class="search_bar"
placeholder="Search..." id="searchInput"
style="margin-bottom:10px;height:30px;width: 45%;"/>
</div>
<div style="height:22px"/>
<div class="qweb_product_id" loading="fast"/>
</div>
</div>
</div>
</div>
</section>
<div style="height:20px"/>
</template>
</odoo>

136
website_product_search_snippet/views/snippets/product_select_from_category_templates.xml

@ -0,0 +1,136 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on a product directed to product details
where the page route is set as '/select/product/from/category'-->
<template id="products_category_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row align-items-center">
<div class="container" style="background: e0e0e0;;">
<div style="height:20px"/>
<div class="back_button" align="left">
<a style="margin-left: 31%;" t-attf-href="/selected/category/from/all_category/result?category_id=#{products.categ_id.id}&amp;parent_id=#{products.category_id}"
name="create" loading="fast">Back
</a>
</div>
<center>
<div class="row">
<img class="card-img-top"
t-attf-src='/web/image/product.template/{{products.id}}/image_512/'
alt="Card Image Cap"
style="width: 22%;margin-left: 39%;"
loading="fast"/>
</div>
</center>
<h2>
<center>
<b>
<t t-esc="products.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<center>
<form align="center" id="top_customer"
action="/select/product/from/category" method="post"
enctype="multipart/form-data"
class="o_mark_required"
data-mark="*"
data-model_name="" data-success-page=""
style="border: 3px solid gray;width: 24%;"
loading="fast">
<div style="height:20px">
</div>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div style="margin-left: 20%;">
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.list_price">
<div align="left">
<span class="s_website_form_label_content">
<b>Price :
<t t-esc="products.currency_id.symbol"/>
<t t-esc="products.list_price"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.categ_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Category :
<t t-esc="products.categ_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.detailed_type">
<div align="left">
<span class="s_website_form_label_content">
<t t-if="products.detailed_type == 'consu'">
<b>Product Type : Consumable</b>
</t>
<t t-if="products.detailed_type == 'service'">
<b>Product Type : Service</b>
</t>
<t t-if="products.detailed_type == 'product'">
<b>Product Type : Storable Product</b>
</t>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.taxes_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Tax :
<t t-esc="products.taxes_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
</div>
<div style="height:20px"/>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

12
website_product_search_snippet/views/snippets/search_snippet_templates.xml

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!--Add a website snippet-->
<template id="external_snippets" inherit_id="website.snippets"
priority="8">
<xpath expr="//div[@id='snippet_effect']//t[@t-snippet][last()]"
position="after">
<t t-snippet="website_product_search_snippet.search_snippet"
t-thumbnail="/website_product_search_snippet/static/src/img/icon.png"/>
</xpath>
</template>
</odoo>

214
website_product_search_snippet/views/snippets/selected_category_from_all_category_templates.xml

@ -0,0 +1,214 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!--When clicking on a category directed to products under that
category where the route set as '/selected/category/from/all_category/result'-->
<template id="category_from_all_category_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row product_search_bar" loading="eager">
<div class="container">
<div style="height:20px"/>
<div class="back_button" align="left">
<a t-attf-href="/category/form/all/results" name="create"
style="margin-left: 13%;font-weight: bold;">Back
</a>
</div>
<h2>
<center>
<b style="font-size: 50px;">
<t t-esc="category.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<t t-if="category.product_count == 0">
<center>
<form align="center" id="categories"
action="/selected/category/from/all_category/result">
<div style="height:20px"/>
<t t-if="products">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{product.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/select/product/from/category?product_id=#{product.id}">
<t style="margin-left: -190%;"
t-esc="product.name"/>t style="margin-left: -190%;"
t-esc="product.name"/>
</a>
</td>
<td>
<t t-esc="product.currency_id.symbol"/>
<t t-esc="product.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
<t t-else="">
<!--When products are not available get the following message-->
<h4 style="font-size: 307%;">
No products available....!!!!
</h4>
</t>
</form>
</center>
</t>
<t t-else="">
<center>
<form align="center" id="categories"
action="/selected/category/from/all_category/result">
<div style="height:20px"/>
<t t-if="products">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products" t-as="product">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{product.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/select/product/from/category?product_id=#{product.id}">
<t style="margin-left: -190%;"
t-esc="product.name"/>
</a>
</td>
<td>
<t t-esc="product.currency_id.symbol"/>
<t t-esc="product.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
<t t-else="">
<!--When the products are available for the
category then shows all products-->
<div style="height:20px"/>
<center>
<h3 style="font-size: 26px;">Products</h3>
</center>
<div>
<input type="text"
class="search_product_bar"
placeholder="Search..."
id="searchBarInput"
style="margin-left:64%%; width:16%;"/>
</div>
<table class="category_table"
id="category_table"
style="margin-left: 13%;width: 77%;border-bottom: 1px solid #ddd;background: #bababa;">
<thead style="background: #7b7b7b;">
<td>
<b>Image</b>
</td>
<td>
<b>Product</b>
</td>
<td>
<b>Price</b>
</td>
</thead>
<div style="height:20px"/>
<tbody id="category_table_body"
class="body">
<t t-foreach="products_category" t-as="prod">
<tr style="nth-child(even){background-color: #f2f2f2}"
id="category_table">
<td style="width: 19%;">
<img t-attf-src="/web/image/product.template/{{prod.id}}/image_512/"
style="width: 71%;"/>
</td>
<td>
<a t-attf-href="/select/product/from/category?product_id=#{prod.id}">
<t style="margin-left: -190%;"
t-esc="prod.name"/>
</a>
</td>
<td>
<t t-esc="prod.currency_id.symbol"/>
<t t-esc="prod.list_price"/>
</td>
</tr>
</t>
</tbody>
</table>
</t>
</form>
</center>
</t>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>

136
website_product_search_snippet/views/snippets/selected_product_from_all_product_templates.xml

@ -0,0 +1,136 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<!-- When clicking on a product directed to product details
where the page route is set as '/all/product/selected/product/details'-->
<template id="all_products_snippet_img" name="Products Snippet">
<t t-call="website.layout">
<section class="row align-items-center">
<div class="container" style="background: e0e0e0;;">
<div style="height:20px"/>
<div class="back_button" align="left">
<a style="margin-left: 31%;" t-attf-href="/product/form/all/results"
name="create" loading="fast">Back
</a>
</div>
<center>
<div class="row">
<img class="card-img-top"
t-attf-src='/web/image/product.template/{{products.id}}/image_512/'
alt="Card Image Cap"
style="width: 22%;margin-left: 39%;"
loading="fast"/>
</div>
</center>
<h2>
<center>
<b>
<t t-esc="products.name"/>
</b>
<br/>
</center>
</h2>
<div style="height:20px"/>
<center>
<form align="center" id="top_customer"
action="/all/product/selected/product/details" method="post"
enctype="multipart/form-data"
class="o_mark_required"
data-mark="*"
data-model_name="" data-success-page=""
style="border: 3px solid gray;width: 24%;"
loading="fast">
<div style="height:20px">
</div>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div style="margin-left: 20%;">
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.list_price">
<div align="left">
<span class="s_website_form_label_content">
<b>Price :
<t t-esc="products.currency_id.symbol"/>
<t t-esc="products.list_price"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.categ_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Category :
<t t-esc="products.categ_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.detailed_type">
<div align="left">
<span class="s_website_form_label_content">
<t t-if="products.detailed_type == 'consu'">
<b>Product Type : Consumable</b>
</t>
<t t-if="products.detailed_type == 'service'">
<b>Product Type : Service</b>
</t>
<t t-if="products.detailed_type == 'product'">
<b>Product Type : Storable Product</b>
</t>
</span>
</div>
</t>
</div>
</div>
</div>
<div style="height:20px"/>
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="s_website_form_rows row s_col_no_bgcolor">
<div class="form-group col-12 s_website_form_field s_website_form_required"
data-type="char" data-name="Field">
<div class="row s_col_no_resize s_col_no_bgcolor">
<t t-if="products.taxes_id">
<div align="left">
<span class="s_website_form_label_content">
<b>Tax :
<t t-esc="products.taxes_id.name"/>
</b>
</span>
</div>
</t>
</div>
</div>
</div>
</div>
<div style="height:20px"/>
</form>
</center>
</div>
</section>
<div style="height:20px"/>
</t>
</template>
</odoo>
Loading…
Cancel
Save