@ -0,0 +1,47 @@ |
|||
.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg |
|||
:target: https://www.gnu.org/licenses/agpl-3.0-standalone.html |
|||
:alt: License: AGPL-3 |
|||
|
|||
Website Call For Price |
|||
======================= |
|||
This module helps hide specific products prices from the shop and using 'Call for Price' button customer can sent their details, the user will follow up the details and get the product price. |
|||
|
|||
Configuration |
|||
============= |
|||
* No additional configuration required |
|||
|
|||
Company |
|||
------- |
|||
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__ |
|||
|
|||
License |
|||
------- |
|||
General Public License, Version 3 (LGPL v3). |
|||
(https://www.gnu.org/licenses/agpl-3.0-standalone.html) |
|||
|
|||
Credits |
|||
------- |
|||
Developer:(V14) Mruthul Raj, 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>`__ |
@ -0,0 +1,22 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Mruthul Raj (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from . import models |
@ -0,0 +1,54 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Mruthul Raj (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
{ |
|||
'name': 'Website Call For Price', |
|||
'version': '14.0.1.0.0', |
|||
'category': 'Website', |
|||
'summary': """Helps to hide price of specified product from shop""", |
|||
'description': "The module aims to help website owners conceal the prices " |
|||
"of certain products from their online store. Instead of " |
|||
"displaying the price and an Add to Cart button, the module " |
|||
"replaces it with a customizable call-for-price message or " |
|||
"button. Customers interested in these products can use the " |
|||
"form that appears upon clicking the button to request more " |
|||
"information about the price, and they will receive a call " |
|||
"back from the store to discuss the pricing details", |
|||
'author': 'Cybrosys Techno Solutions', |
|||
'company': 'Cybrosys Techno Solutions', |
|||
'maintainer': 'Cybrosys Techno Solutions', |
|||
'website': 'https://www.cybrosys.com', |
|||
'depends': ['website_sale_wishlist', 'website_sale_comparison'], |
|||
'data': ['security/ir.model.access.csv', |
|||
'views/shop_hide_call_price_templates.xml', |
|||
'views/shop_grid_templates.xml', |
|||
'views/wishlist_hide_price_templates.xml', |
|||
'views/hide_price_templates.xml', |
|||
'views/compare_templates.xml', |
|||
'views/call_for_price_views.xml', |
|||
'views/product_template_views.xml', |
|||
'views/assets.xml'], |
|||
'images': ['static/description/banner.jpg'], |
|||
'license': 'AGPL-3', |
|||
'installable': True, |
|||
'auto_install': False, |
|||
'application': False, |
|||
} |
@ -0,0 +1,6 @@ |
|||
## Module <call_for_price_website> |
|||
|
|||
#### 22.11.2023 |
|||
#### Version 14.0.1.0.0 |
|||
#### ADD |
|||
- Initial Commit for Website Call For Price |
@ -0,0 +1,23 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Mruthul Raj (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from . import call_price |
|||
from . import product_template |
@ -0,0 +1,56 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Mruthul Raj (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class CallPrice(models.Model): |
|||
"""Creating a model to record all the request the get from website.""" |
|||
_name = 'call.price' |
|||
_description = 'Call for Price' |
|||
_rec_name = 'product_id' |
|||
|
|||
first_name = fields.Char(string="First Name", help="First Name of user") |
|||
last_name = fields.Char(string="Last Name", help="Last Name of user") |
|||
product_id = fields.Many2one('product.product', string="Product", |
|||
help="In which product they are requesting " |
|||
"price") |
|||
email = fields.Char(string="Email", help="Users email for contact") |
|||
phone = fields.Char(string="Contact No.", help="Users contact number for " |
|||
"contacting") |
|||
quantity = fields.Integer(string="Quantity", |
|||
help="How much quantity of product price " |
|||
"they want know") |
|||
message = fields.Char(string="Message", |
|||
help="If any messages for referring") |
|||
state = fields.Selection([('draft', 'Draft'), ('done', 'Done'), |
|||
('cancel', 'Cancel')], |
|||
default="draft", help="Call for price requests " |
|||
"stage") |
|||
|
|||
def action_done(self): |
|||
"""The price of the requested product will be updated for them, |
|||
form state is done""" |
|||
self.write({'state': 'done'}) |
|||
|
|||
def action_cancel(self): |
|||
"""Cancel the form or change the state to cancel""" |
|||
self.write({'state': 'cancel'}) |
@ -0,0 +1,33 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################### |
|||
# |
|||
# Cybrosys Technologies Pvt. Ltd. |
|||
# |
|||
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) |
|||
# Author: Mruthul Raj (odoo@cybrosys.com) |
|||
# |
|||
# You can modify it under the terms of the GNU AFFERO |
|||
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. |
|||
# |
|||
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE |
|||
# (AGPL v3) along with this program. |
|||
# If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################### |
|||
from odoo import fields, models |
|||
|
|||
|
|||
class ProductTemplate(models.Model): |
|||
"""Inheriting product variants model for adding a field that will hide |
|||
price from website""" |
|||
_inherit = 'product.template' |
|||
|
|||
price_call = fields.Boolean(string="Call for Price", |
|||
help="This will hide the price and cart button " |
|||
"from shop and customer can request by " |
|||
"calling for price") |
|
After Width: | Height: | Size: 3.6 KiB |
After Width: | Height: | Size: 310 B |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 576 B |
After Width: | Height: | Size: 733 B |
After Width: | Height: | Size: 911 B |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 673 B |
After Width: | Height: | Size: 878 B |
After Width: | Height: | Size: 653 B |
After Width: | Height: | Size: 905 B |
After Width: | Height: | Size: 839 B |
After Width: | Height: | Size: 427 B |
After Width: | Height: | Size: 627 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 988 B |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 1.9 KiB |
After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 2.1 KiB |
After Width: | Height: | Size: 4.4 KiB |
After Width: | Height: | Size: 589 B |
After Width: | Height: | Size: 3.4 KiB |
After Width: | Height: | Size: 1.7 KiB |
After Width: | Height: | Size: 2.3 KiB |
After Width: | Height: | Size: 967 B |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 3.8 KiB |
After Width: | Height: | Size: 5.0 KiB |
After Width: | Height: | Size: 60 KiB |
After Width: | Height: | Size: 47 KiB |
After Width: | Height: | Size: 53 KiB |
After Width: | Height: | Size: 49 KiB |
After Width: | Height: | Size: 46 KiB |
After Width: | Height: | Size: 48 KiB |
After Width: | Height: | Size: 135 KiB |
After Width: | Height: | Size: 387 KiB |
After Width: | Height: | Size: 211 KiB |
After Width: | Height: | Size: 199 KiB |
After Width: | Height: | Size: 175 KiB |
After Width: | Height: | Size: 178 KiB |
After Width: | Height: | Size: 148 KiB |
After Width: | Height: | Size: 122 KiB |
After Width: | Height: | Size: 494 KiB |
After Width: | Height: | Size: 35 KiB |
After Width: | Height: | Size: 11 KiB |
@ -0,0 +1,647 @@ |
|||
<div style="background-color: #714B67; min-height: 600px; width: 100%; padding: 15px; position: relative;"> |
|||
<!-- TITLE BAR --> |
|||
<div |
|||
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;"> |
|||
<img src="assets/misc/cybrosys-logo.png" width="42" height="42" |
|||
style="width: 42px; height: 42px;"/> |
|||
<div> |
|||
<div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" |
|||
class="mr-2"> |
|||
<i class="fa fa-check mr-1"></i>Community |
|||
</div> |
|||
<div style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" |
|||
class="mr-2"> |
|||
<i class="fa fa-check mr-1"></i>Enterprise |
|||
</div> |
|||
<div style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" |
|||
class="mr-2"> |
|||
<i class="fa fa-check mr-1"></i>Odoo.sh |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF TITLE BAR --> |
|||
<!-- APP HERO --> |
|||
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;"> |
|||
Website Call For Price</h1> |
|||
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;"> |
|||
Get A Call Back For Specific Products Price</p> |
|||
<!-- END OF APP HERO --> |
|||
<img src="assets/screenshots/hero.gif" |
|||
style="width: 75%; height: auto; position: absolute; margin-left: auto; margin-right: auto; top: 45%; left: 12%; right: auto;"/> |
|||
</div> |
|||
<!-- NAVIGATION SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/compass.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Explore This |
|||
Module</h2> |
|||
</div> |
|||
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;"> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#overview"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn |
|||
more about this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#features"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View |
|||
features of this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-sm-12 col-md-6 my-3"> |
|||
<a href="#screenshots"> |
|||
<div class="d-flex justify-content-between align-items-center" |
|||
style="background-color: #f5f5f5; padding: 30px; width: 100%;"> |
|||
<div> |
|||
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span> |
|||
<span |
|||
style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View |
|||
screenshots for this |
|||
module</span> |
|||
</div> |
|||
<img src="assets/misc/right-arrow.png" width="36" height="36"/> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<!-- END OF NAVIGATION SECTION --> |
|||
<!-- OVERVIEW SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/pie-chart.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Overview |
|||
</h2> |
|||
</div> |
|||
<div class="row" |
|||
style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> |
|||
<div class="col-sm-12 py-4"> |
|||
In some cases, we have to hide the price of a product. These items might |
|||
be free, out of stock, or available for |
|||
any other reason. This module allows you to hide the price and add to |
|||
cart button for specific products; the |
|||
call for price option will send a price request to the merchant. |
|||
</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;">Hide specific product price.</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;">Hide Add to Cart button.</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;">Adds a button for price requests from merchants.</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;">Track all requests from the backend.</span> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- SCREENSHOTS SECTION --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;" |
|||
id="screenshots"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/pictures.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Screenshots |
|||
</h2> |
|||
</div> |
|||
<div class="row"> |
|||
<div class="col-sm-12"> |
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Enable Call for Price |
|||
from the Product Sales tab</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
Go to Products -> Sales -> |
|||
Enable Call for Price. After enabling this, the price and add to |
|||
cart button will hide from the website. </p> |
|||
<img src="assets/screenshots/Screenshot1.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Hide product price from a list of products</h3> |
|||
<img src="assets/screenshots/Screenshot2.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Wishlist page</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
Hide the price and add to cart button from wishlist page.</p> |
|||
<img src="assets/screenshots/Screenshot3.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Product Compare Page</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
If the user needs to compare the products, then they need to |
|||
request the price.</p> |
|||
<img src="assets/screenshots/Screenshot4.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Call For Price Button</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
Hides the price and add to cart button from product item and |
|||
adds button for price request, on clicking a popup will |
|||
open.</p> |
|||
<img src="assets/screenshots/Screenshot5.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Call For Price Request</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
Users need to enter these details in order to get the price of |
|||
the |
|||
product. The request will be sent to the merchant by clicking |
|||
Send |
|||
button.</p> |
|||
<img src="assets/screenshots/Screenshot6.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
Request Send</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
After sending the request, a success message will show there, |
|||
and |
|||
the merchant can access the request from backend.</p> |
|||
<img src="assets/screenshots/Screenshot7.png" class="img-thumbnail"> |
|||
</div> |
|||
|
|||
<div style="display: block; margin: 30px auto;"> |
|||
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;"> |
|||
The Backend View</h3> |
|||
<p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> |
|||
Initially, a draft request is created; after merchant |
|||
verification, the sales team contacts the customer.</p> |
|||
<img src="assets/screenshots/Screenshot8.png" class="img-thumbnail"> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF SCREENSHOTS SECTION --> |
|||
<!-- SUGGESTED PRODUCTS --> |
|||
<div class="row"> |
|||
<div class="col-lg-12 d-flex flex-column justify-content-center" |
|||
style="text-align: center; padding: 2.5rem 1rem !important;"> |
|||
<h2 style="color: #212529 !important;">Suggested Products</h2> |
|||
<hr |
|||
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/> |
|||
|
|||
<div id="demo1" class="row carousel slide" data-ride="carousel"> |
|||
<!-- The slideshow --> |
|||
<div class="carousel-inner"> |
|||
<div class="carousel-item active" style="min-height:0px"> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/odoo_website_helpdesk/#" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/1.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/odoo_website_helpdesk_dashboard/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/2.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/user_password_strength/#" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/3.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
<div class="carousel-item" style="min-height:0px"> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/website_return_management/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/4.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/website_multi_product_return_management/" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/5.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" |
|||
style="float:left"> |
|||
<a href="https://apps.odoo.com/apps/modules/14.0/index_and_follow/#" |
|||
target="_blank"> |
|||
<div style="border-radius:10px"> |
|||
<img class="img img-responsive center-block" |
|||
style="border-top-left-radius:10px; border-top-right-radius:10px" |
|||
src="./assets/modules/6.png"> |
|||
</div> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- Left and right controls --> |
|||
<a class="carousel-control-prev" href="#demo1" data-slide="prev" |
|||
style="left:-25px;width: 35px;color: #000;"> <span |
|||
class="carousel-control-prev-icon"><i |
|||
class="fa fa-chevron-left" |
|||
style="font-size:24px"></i></span> </a> <a |
|||
class="carousel-control-next" href="#demo1" |
|||
data-slide="next" |
|||
style="right:-25px;width: 35px;color: #000;"> |
|||
<span class="carousel-control-next-icon"><i |
|||
class="fa fa-chevron-right" |
|||
style="font-size:24px"></i></span> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<!-- END OF SUGGESTED PRODUCTS --> |
|||
<!-- OUR SERVICES --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/star.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Our Services |
|||
</h2> |
|||
</div> |
|||
<div class="container my-5"> |
|||
<div class="row"> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/cogs.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Customization</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/wrench.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Implementation</h6> |
|||
</div> |
|||
|
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/lifebuoy.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Support</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/user.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Hire |
|||
Odoo |
|||
Developer</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/puzzle.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Integration</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/update.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Migration</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/consultation.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Consultancy</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/training.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Implementation</h6> |
|||
</div> |
|||
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> |
|||
<div class="d-flex justify-content-center align-items-center mx-3 my-3" |
|||
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;"> |
|||
<img src="assets/icons/license.png" class="img-responsive" |
|||
height="48px" width="48px"> |
|||
</div> |
|||
<h6 class="text-center" |
|||
style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> |
|||
Odoo |
|||
Licensing Consultancy</h6> |
|||
</div> |
|||
</div> |
|||
|
|||
</div> |
|||
<!-- END OF OUR SERVICES --> |
|||
<!-- OUR INDUSTRIES --> |
|||
<div class="d-flex align-items-center" |
|||
style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> |
|||
<div class="d-flex justify-content-center align-items-center mr-2" |
|||
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> |
|||
<img src="assets/misc/corporate.png"/> |
|||
</div> |
|||
<h2 class="mt-2" |
|||
style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> |
|||
Our |
|||
Industries |
|||
</h2> |
|||
</div> |
|||
<div class="container my-5"> |
|||
<div class="row"> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/trading-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Trading |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Easily procure |
|||
and |
|||
sell your products</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/pos-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
POS |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Easy |
|||
configuration |
|||
and convivial experience</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/education-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Education |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
A platform for |
|||
educational management</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/manufacturing-black.png" |
|||
class="img-responsive mb-3" height="48px" |
|||
width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
Manufacturing |
|||
</h5> |
|||
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> |
|||
Plan, track and |
|||
schedule your operations</p> |
|||
</div> |
|||
</div> |
|||
<div class="col-lg-3"> |
|||
<div class="my-4 d-flex flex-column justify-content-center" |
|||
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> |
|||
<img src="assets/icons/ecom-black.png" |
|||
class="img-responsive mb-3" height="48px" width="48px"> |
|||
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> |
|||
E-commerce & 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 --> |
@ -0,0 +1,136 @@ |
|||
/** |
|||
* This file is used to give a success alert after requesting a call for price. |
|||
*/ |
|||
odoo.define('call_for_price_website.website_call_for_price', function(require) { |
|||
"use strict"; |
|||
const rpc = require('web.rpc'); |
|||
var Dialog = require('web.Dialog'); |
|||
var publicWidget = require('web.public.widget'); |
|||
publicWidget.registry.CallForPrice = publicWidget.Widget.extend({ |
|||
selector: '.oe_website_sale', |
|||
events: { |
|||
'click #send_btn': 'callforprice', |
|||
'click #button_call_for_price': 'modalshow', |
|||
'click #call_modal_close': 'modalhide' |
|||
}, |
|||
callforprice:async function() { |
|||
var self = this; |
|||
let product_product_id; |
|||
var first = self.$el.find('#first_name').val(); |
|||
var last = self.$el.find('#last_name').val(); |
|||
var product_id = self.$el.find('#product_id').val(); |
|||
var phone = self.$el.find('#phone').val(); |
|||
var email = self.$el.find('#email').val(); |
|||
var message = self.$el.find('#message').val(); |
|||
var qty = self.$el.find('#quantity').val(); |
|||
/** |
|||
* Validate email address format using a regular expression. |
|||
* email - The email address to validate. |
|||
* returns - True if the email is valid, false otherwise. |
|||
*/ |
|||
function validateEmail(email) { |
|||
// Email validation regex pattern
|
|||
var emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/; |
|||
return emailPattern.test(email); |
|||
} |
|||
/** |
|||
* Validate phone number format using a regular expression. |
|||
* phone - The phone number to validate. |
|||
* returns - True if the phone number is valid, false otherwise. |
|||
*/ |
|||
function validatePhoneNumber(phone) { |
|||
// Phone number validation regex pattern (without alphabets)
|
|||
var phonePattern = /^[^A-Za-z]*$/ |
|||
return phonePattern.test(phone); |
|||
} |
|||
if (first && phone) { |
|||
if (!$.isNumeric(qty)) { |
|||
var modal = new Dialog(null, { |
|||
title: "Warning", |
|||
$content: $('<div>').text("Quantity should be a numeric value."), |
|||
buttons: [{ |
|||
text: "Close", |
|||
close: true |
|||
}], |
|||
}); |
|||
modal.open(); |
|||
return; |
|||
} |
|||
if (!validateEmail(email)) { |
|||
var modal = new Dialog(null, { |
|||
title: "Warning", |
|||
$content: $('<div>').text("Please enter a valid email address."), |
|||
buttons: [{ |
|||
text: "Close", |
|||
close: true |
|||
}], |
|||
}); |
|||
modal.open(); |
|||
return; |
|||
} |
|||
if (!validatePhoneNumber(phone)) { |
|||
var modal = new Dialog(null, { |
|||
title: "Warning", |
|||
$content: $('<div>').text("Please enter a valid phone number."), |
|||
buttons: [{ |
|||
text: "Close", |
|||
close: true |
|||
}], |
|||
}); |
|||
modal.open(); |
|||
return; |
|||
} |
|||
await rpc.query({ |
|||
model:'product.product', |
|||
method:'search_read', |
|||
args:[[['product_tmpl_id','=',parseInt(product_id)],['combination_indices','=',this.attrValue]]] |
|||
}).then(function(product){ |
|||
product_product_id=product[0].id |
|||
}) |
|||
let vals_list = { |
|||
'product_id': product_product_id, |
|||
'first_name': first, |
|||
'last_name': last, |
|||
'phone': phone, |
|||
'email': email, |
|||
'quantity': qty, |
|||
'message': message |
|||
} |
|||
rpc.query({ |
|||
model: "call.price", |
|||
method: "create", |
|||
args: [vals_list] |
|||
}).then(function(result) { |
|||
self.$el.find('#alert_message')[0].style.display = "block" |
|||
self.$el.find('#call_for_price')[0].style.display = 'none'; |
|||
}); |
|||
} else { |
|||
var modal = new Dialog(null, { |
|||
title: "Warning", |
|||
$content: $('<div>').text("Please enter the required information."), |
|||
buttons: [{ |
|||
text: "Close", |
|||
close: true |
|||
}], |
|||
}); |
|||
modal.open(); |
|||
} |
|||
}, |
|||
modalshow: function() { |
|||
const url = window.location.href; |
|||
const urlParts = url.split('#'); |
|||
if (urlParts.length > 1) { |
|||
const parameterParts = urlParts[1].split('='); |
|||
if (parameterParts.length === 2 && parameterParts[0] === 'attr') { |
|||
const attrValue = parameterParts[1]; |
|||
this.attrValue = attrValue; |
|||
} |
|||
} |
|||
this.$el.find('#call_for_price')[0].style.display = 'block'; |
|||
}, |
|||
modalhide: function() { |
|||
this.$el.find('#call_for_price')[0].style.display = 'none'; |
|||
} |
|||
}); |
|||
return publicWidget.registry.CallForPrice; |
|||
}); |
@ -0,0 +1,9 @@ |
|||
<?xml version="1.0" encoding="utf-8" ?> |
|||
<odoo> |
|||
<!-- Extend the 'assets_frontend' template --> |
|||
<template id="assets_frontend" inherit_id="web.assets_frontend"> |
|||
<xpath expr="." position="inside"> |
|||
<script type="text/javascript" src='/call_for_price_website/static/src/js/website_call_for_price.js' /> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |
@ -0,0 +1,59 @@ |
|||
<?xml version="1.0" encoding="utf-8" ?> |
|||
<odoo> |
|||
<!-- This record for creating tree view for call for price requests--> |
|||
<record id="call_price_view_tree" model="ir.ui.view"> |
|||
<field name="name">call.price.view.tree</field> |
|||
<field name="model">call.price</field> |
|||
<field name="arch" type="xml"> |
|||
<tree> |
|||
<field name="product_id"/> |
|||
<field name="first_name"/> |
|||
<field name="last_name"/> |
|||
<field name="email"/> |
|||
<field name="state"/> |
|||
</tree> |
|||
</field> |
|||
</record> |
|||
<!-- This record for creating form view for call for price requests--> |
|||
<record id="call_price_view_form" model="ir.ui.view"> |
|||
<field name="name">call.price.view.form</field> |
|||
<field name="model">call.price</field> |
|||
<field name="arch" type="xml"> |
|||
<form> |
|||
<header> |
|||
<button name="action_done" class="oe_highlight" |
|||
states="draft" string="Done" type="object"/> |
|||
<button name="action_cancel" string="Cancel" type="object"/> |
|||
<field name="state" widget="statusbar" |
|||
statusbar_visible="draft,done,cancel"/> |
|||
</header> |
|||
<sheet> |
|||
<group> |
|||
<group> |
|||
<field name="product_id"/> |
|||
<field name="first_name"/> |
|||
<field name="email" widget="email"/> |
|||
<field name="message"/> |
|||
</group> |
|||
<group> |
|||
<field name="quantity"/> |
|||
<field name="last_name"/> |
|||
<field name="phone" widget="phone"/> |
|||
</group> |
|||
</group> |
|||
</sheet> |
|||
</form> |
|||
</field> |
|||
</record> |
|||
<!-- This record for creating menu action for call for price menu--> |
|||
<record id="call_price_action" model="ir.actions.act_window"> |
|||
<field name="name">Call For Price</field> |
|||
<field name="res_model">call.price</field> |
|||
<field name="view_mode">tree,form</field> |
|||
</record> |
|||
<!-- Menu for call for price--> |
|||
<menuitem id="call_price_menu" name="Call For Price" |
|||
parent="website_sale.menu_orders" |
|||
groups="sales_team.group_sale_salesman" |
|||
action="call_price_action"/> |
|||
</odoo> |
@ -0,0 +1,49 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- This template used to hide the price form the comparison page--> |
|||
<template id="compare_hide_price" |
|||
inherit_id="website_sale_comparison.product_compare"> |
|||
<xpath expr="//div[hasclass('product_summary')]" |
|||
position="replace"> |
|||
<t t-if="product.price_call"> |
|||
<a class="o_product_comparison_table" |
|||
t-att-href="product.website_url"> |
|||
<span t-esc="combination_info['display_name']"/> |
|||
<br/> |
|||
</a> |
|||
</t> |
|||
<t t-else=""> |
|||
<div class='product_summary'> |
|||
<a class="o_product_comparison_table" |
|||
t-att-href="product.website_url"> |
|||
<span t-esc="combination_info['display_name']"/> |
|||
<br/> |
|||
</a> |
|||
|
|||
<span> |
|||
<strong>Price:</strong> |
|||
<del t-attf-class="text-danger mr8 {{'' if combination_info['has_discounted_price'] else 'd-none'}}" |
|||
style="white-space: nowrap;" |
|||
t-esc="combination_info['list_price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
<span t-esc="combination_info['price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
</span> |
|||
|
|||
<form action="/shop/cart/update" method="post" |
|||
class="text-center"> |
|||
<input type="hidden" name="csrf_token" |
|||
t-att-value="request.csrf_token()"/> |
|||
<input name="product_id" t-att-value="product.id" |
|||
type="hidden"/> |
|||
<a role="button" |
|||
class="btn btn-primary btn-block a-submit" href="#"> |
|||
<i class="fa fa-shopping-cart"/>&nbsp;Add to |
|||
Cart |
|||
</a> |
|||
</form> |
|||
</div> |
|||
</t> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |
@ -0,0 +1,35 @@ |
|||
<?xml version="1.0" encoding="utf-8" ?> |
|||
<odoo> |
|||
<!-- This template used to hide price from product comparison tool page--> |
|||
<template id="compare_hide_price_product" |
|||
inherit_id="website_sale_comparison.product_product"> |
|||
<xpath expr="//div[hasclass('pl-2')]" position="replace"> |
|||
<t t-if="product.price_call"> |
|||
<div class="col-8 pl-2"> |
|||
<h6> |
|||
<a t-att-href="product.website_url"> |
|||
<t t-esc="combination_info['display_name']"/> |
|||
</a> |
|||
<br/> |
|||
</h6> |
|||
</div> |
|||
</t> |
|||
<t t-else=""> |
|||
<div class="col-8 pl-2"> |
|||
<h6> |
|||
<a t-att-href="product.website_url"> |
|||
<t t-esc="combination_info['display_name']"/> |
|||
</a> |
|||
<br/> |
|||
<del t-attf-class="text-danger mr8 {{'' if combination_info['has_discounted_price'] else 'd-none'}}" |
|||
style="white-space: nowrap;" |
|||
t-esc="combination_info['list_price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
<span t-esc="combination_info['price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
</h6> |
|||
</div> |
|||
</t> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |
@ -0,0 +1,14 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!--This file is used to add a field on product variants for hiding price--> |
|||
<record id="product_template_only_form_view" model="ir.ui.view"> |
|||
<field name="name">product.template.view.form.inherit.call.for.price.website</field> |
|||
<field name="model">product.template</field> |
|||
<field name="inherit_id" ref="product.product_template_only_form_view"/> |
|||
<field name="arch" type="xml"> |
|||
<xpath expr="//field[@name='accessory_product_ids']" position="after"> |
|||
<field name="price_call"/> |
|||
</xpath> |
|||
</field> |
|||
</record> |
|||
</odoo> |
@ -0,0 +1,26 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- This template is used for hiding price from shop grid and list view--> |
|||
<template id="shop_hide_price" inherit_id="website_sale.products_item"> |
|||
<xpath expr="//div[hasclass('product_price')]" position="replace"> |
|||
<t t-if="product.price_call"> |
|||
</t> |
|||
<t t-else=""> |
|||
<div class="product_price mb-1" itemprop="offers" |
|||
itemscope="itemscope" itemtype="http://schema.org/Offer"> |
|||
<span class="h5" t-if="combination_info['price']" |
|||
t-esc="combination_info['price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
<del t-attf-class="text-danger ml-1 h6 {{'' if combination_info['has_discounted_price'] else 'd-none'}}" |
|||
style="white-space: nowrap;" |
|||
t-esc="combination_info['list_price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.currency_id}"/> |
|||
<span itemprop="price" style="display:none;" |
|||
t-esc="combination_info['price']"/> |
|||
<span itemprop="priceCurrency" style="display:none;" |
|||
t-esc="website.currency_id.name"/> |
|||
</div> |
|||
</t> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |
@ -0,0 +1,177 @@ |
|||
<?xml version="1.0" encoding="UTF-8" ?> |
|||
<odoo> |
|||
<!-- This template is used for hiding product price and add to cart button |
|||
from each product and show button for requesting price--> |
|||
<template id="shop_product_hide_price" inherit_id="website_sale.product"> |
|||
<xpath expr="//div[hasclass('js_main_product')]" position="replace"> |
|||
<t t-if="product.price_call"> |
|||
<div class="alert alert-success" id="alert_message" |
|||
style="display:none"> |
|||
Thank you for information, we will get back to you asap. |
|||
</div> |
|||
<div class="js_product js_main_product"> |
|||
<t t-placeholder="select"> |
|||
<input type="hidden" class="product_id" |
|||
name="product_id" |
|||
t-att-value="product_variant.id"/> |
|||
<input type="hidden" class="product_template_id" |
|||
name="product_template_id" |
|||
t-att-value="product.id"/> |
|||
<t t-if="combination" t-call="sale.variants"> |
|||
<t t-set="ul_class" t-value="'flex-column'"/> |
|||
<t t-set="parent_combination" t-value="None"/> |
|||
</t> |
|||
<t t-else=""> |
|||
<ul class="d-none js_add_cart_variants" |
|||
t-att-data-attribute_exclusions="{'exclusions: []'}"/> |
|||
</t> |
|||
</t> |
|||
<p t-if="True" |
|||
class="css_not_available_msg alert alert-warning">This |
|||
combination does not exist. |
|||
</p> |
|||
<a role="button" class="btn btn-primary" |
|||
href="#call_for_price" |
|||
data-bs-toggle="modal" |
|||
id="button_call_for_price"> |
|||
Call for Price |
|||
</a> |
|||
<div id="product_option_block"/> |
|||
</div> |
|||
</t> |
|||
<t t-else=""> |
|||
<div class="js_product js_main_product mb-3"> |
|||
<div> |
|||
<t t-call="website_sale.product_price"/> |
|||
<small class="ml-1 text-muted o_base_unit_price_wrapper d-none" |
|||
groups="website_sale.group_show_uom_price"> |
|||
<t t-call='website_sale.base_unit_price'/> |
|||
</small> |
|||
</div> |
|||
<t t-placeholder="select"> |
|||
<input type="hidden" class="product_id" |
|||
name="product_id" |
|||
t-att-value="product_variant.id"/> |
|||
<input type="hidden" class="product_template_id" |
|||
name="product_template_id" |
|||
t-att-value="product.id"/> |
|||
<input t-if="product.public_categ_ids.ids" type="hidden" |
|||
class="product_category_id" |
|||
name="product_category_id" |
|||
t-att-value="product.public_categ_ids.ids[0]"/> |
|||
<t t-if="combination" t-call="sale.variants"> |
|||
<t t-set="ul_class" t-valuef="flex-column"/> |
|||
<t t-set="parent_combination" t-value="None"/> |
|||
</t> |
|||
<t t-else=""> |
|||
<ul class="d-none js_add_cart_variants" |
|||
t-att-data-attribute_exclusions="{'exclusions: []'}"/> |
|||
</t> |
|||
</t> |
|||
<p t-if="True" |
|||
class="css_not_available_msg alert alert-warning">This |
|||
combination does not exist. |
|||
</p> |
|||
<div id="add_to_cart_wrap" class="d-inline"> |
|||
<a data-animation-selector=".o_wsale_product_images" |
|||
role="button" id="add_to_cart" |
|||
class="btn btn-primary btn-lg js_check_product a-submit my-1 mr-1 px-5 font-weight-bold flex-grow-1" |
|||
href="#"><i class="fa fa-shopping-cart mr-2"/>ADD TO |
|||
CART |
|||
</a> |
|||
<div id="product_option_block" |
|||
class="d-inline-block align-middle"/> |
|||
</div> |
|||
</div> |
|||
</t> |
|||
</xpath> |
|||
<xpath expr="//div[@id='product_details']" position="before"> |
|||
<div id="call_for_price" class="modal"> |
|||
<div class="modal-dialog modal-content" style="height:60%"> |
|||
<div class="page"> |
|||
<h3 class="text-center">Call For Price</h3> |
|||
</div> |
|||
<input type="hidden" name="product_id" id="product_id" |
|||
t-att-value="product.id"/> |
|||
<hr/> |
|||
<center> |
|||
<table style="width:500px"> |
|||
<tr style="height:60px"> |
|||
<td style="width:100px"> |
|||
<label for="first_name" |
|||
class="control-label">First Name: |
|||
</label> |
|||
</td> |
|||
<td> |
|||
<input type="text" class="form-control" |
|||
name="first_name" |
|||
id="first_name" |
|||
required="required"/> |
|||
</td> |
|||
</tr> |
|||
<tr style="height:60px"> |
|||
<td> |
|||
<label for="last_name" |
|||
class="control-label">Last Name: |
|||
</label> |
|||
</td> |
|||
<td> |
|||
<input type="text" class="form-control" |
|||
name="last_name" |
|||
id="last_name"/> |
|||
</td> |
|||
</tr> |
|||
<tr style="height:60px"> |
|||
<td> |
|||
<label for="email">Email</label> |
|||
</td> |
|||
<td> |
|||
<input type="text" class="form-control" |
|||
name="email" |
|||
id="email"/> |
|||
</td> |
|||
</tr> |
|||
<tr style="height:60px"> |
|||
<td> |
|||
<label for="phone">Contact No.</label> |
|||
</td> |
|||
<td> |
|||
<input type="text" class="form-control" |
|||
id="phone" name="phone"/> |
|||
</td> |
|||
</tr> |
|||
<tr style="height:60px"> |
|||
<td> |
|||
<label>Quantity</label> |
|||
</td> |
|||
<td> |
|||
<input type="number" class="form-control" |
|||
name="quantity" id="quantity"/> |
|||
</td> |
|||
</tr> |
|||
<tr style="height:60px"> |
|||
<td> |
|||
<label>Message</label> |
|||
</td> |
|||
<td> |
|||
<input type="text" class="form-control" |
|||
name="message" id="message"/> |
|||
</td> |
|||
</tr> |
|||
</table> |
|||
<hr/> |
|||
<button id="send_btn" type="confirm" |
|||
class="btn btn-primary"> |
|||
Send |
|||
</button> |
|||
<button id="call_modal_close" type="button" |
|||
class="btn btn-outline-secondary" |
|||
data-bs-dismiss="modal"> |
|||
Close |
|||
</button> |
|||
</center> |
|||
</div> |
|||
</div> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |
@ -0,0 +1,115 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<odoo> |
|||
<!-- This template used to hide price from wishlist page--> |
|||
<template id="wishlist_hide_price" |
|||
inherit_id="website_sale_wishlist.product_wishlist"> |
|||
<xpath expr="//t[@t-foreach='wishes']" position="replace"> |
|||
<t t-foreach="wishes" t-as="wish"> |
|||
<t t-if="wish.product_id.price_call"> |
|||
<tr t-att-data-wish-id='wish.id' |
|||
t-att-data-product-id='wish.product_id.id'> |
|||
<td class='td-img'> |
|||
<a t-att-href="wish.product_id.website_url"> |
|||
<img t-attf-src="/web/image/product.product/#{wish.product_id.id}/image_128" |
|||
class="img img-fluid" style="margin:auto;" |
|||
alt="Product image"/> |
|||
</a> |
|||
</td> |
|||
<td class='text-left'> |
|||
<strong> |
|||
<a t-att-href="wish.product_id.website_url"> |
|||
<t t-esc="wish.product_id.display_name"/> |
|||
</a> |
|||
</strong> |
|||
<small class='d-none d-md-block'> |
|||
<p t-field="wish.product_id.description_sale" |
|||
class="text-muted"/> |
|||
</small> |
|||
<button type="button" |
|||
class="btn btn-link o_wish_rm no-decoration"> |
|||
<small> |
|||
<i class='fa fa-trash-o'/> |
|||
Remove |
|||
</small> |
|||
</button> |
|||
</td> |
|||
<td> |
|||
<t t-set="combination_info" |
|||
t-value="wish.product_id._get_combination_info_variant()"/> |
|||
</td> |
|||
<td class='text-center td-wish-btn'> |
|||
<input name="product_id" |
|||
t-att-value="wish.product_id.id" |
|||
type="hidden"/> |
|||
<button type="button" role="button" |
|||
class="btn btn-secondary btn-block o_wish_add mb4"> |
|||
Add |
|||
<span class='d-none d-md-inline'>to Cart</span> |
|||
</button> |
|||
</td> |
|||
</tr> |
|||
</t> |
|||
<t t-else=""> |
|||
<tr t-att-data-wish-id='wish.id' |
|||
t-att-data-product-id='wish.product_id.id'> |
|||
<td class='td-img'> |
|||
<a t-att-href="wish.product_id.website_url"> |
|||
<img t-attf-src="/web/image/product.product/#{wish.product_id.id}/image_128" |
|||
class="img img-fluid" style="margin:auto;" |
|||
alt="Product image"/> |
|||
</a> |
|||
</td> |
|||
<td class='text-left'> |
|||
<strong> |
|||
<a t-att-href="wish.product_id.website_url"> |
|||
<t t-esc="wish.product_id.display_name"/> |
|||
</a> |
|||
</strong> |
|||
<small class='d-none d-md-block'> |
|||
<p t-field="wish.product_id.description_sale" |
|||
class="text-muted"/> |
|||
</small> |
|||
<button type="button" |
|||
class="btn btn-link o_wish_rm no-decoration"> |
|||
<small> |
|||
<i class='fa fa-trash-o'/> |
|||
Remove |
|||
</small> |
|||
</button> |
|||
</td> |
|||
<td> |
|||
<t t-set="combination_info" |
|||
t-value="wish.product_id._get_combination_info_variant()"/> |
|||
<t t-esc="combination_info['price']" |
|||
t-options="{'widget': 'monetary', 'display_currency': website.pricelist_id.currency_id}"/> |
|||
</td> |
|||
<td class='text-center td-wish-btn'> |
|||
<input name="product_id" |
|||
t-att-value="wish.product_id.id" |
|||
type="hidden"/> |
|||
<button type="button" role="button" |
|||
class="btn btn-secondary btn-block o_wish_add mb4"> |
|||
Add |
|||
<span class='d-none d-md-inline'>to Cart</span> |
|||
</button> |
|||
</td> |
|||
</tr> |
|||
</t> |
|||
</t> |
|||
</xpath> |
|||
<xpath expr="//td[hasclass('td-wish-btn')]" position="replace"> |
|||
<t t-if="wish.product_id.price_call"/> |
|||
<t t-else=""> |
|||
<td class='text-center td-wish-btn align-middle'> |
|||
<input name="product_id" t-att-value="wish.product_id.id" |
|||
type="hidden"/> |
|||
<button type="button" role="button" |
|||
class="btn btn-secondary btn-block o_wish_add mb4"> |
|||
Add |
|||
<span class='d-none d-md-inline'>to Cart</span> |
|||
</button> |
|||
</td> |
|||
</t> |
|||
</xpath> |
|||
</template> |
|||
</odoo> |