Browse Source

Sep 30: [ADD] Initial Commit 'website_customer_contact'

pull/309/merge
Risvana Cybro 2 weeks ago
parent
commit
14007d367d
  1. 48
      website_customer_contact/README.rst
  2. 22
      website_customer_contact/__init__.py
  3. 51
      website_customer_contact/__manifest__.py
  4. 24
      website_customer_contact/controllers/__init__.py
  5. 74
      website_customer_contact/controllers/contact_request.py
  6. 36
      website_customer_contact/controllers/portal.py
  7. 51
      website_customer_contact/controllers/website_customer_contact.py
  8. 7
      website_customer_contact/doc/RELEASE_NOTES.md
  9. BIN
      website_customer_contact/static/description/assets/icons/capture (1).png
  10. BIN
      website_customer_contact/static/description/assets/icons/check.png
  11. BIN
      website_customer_contact/static/description/assets/icons/chevron.png
  12. BIN
      website_customer_contact/static/description/assets/icons/cogs.png
  13. BIN
      website_customer_contact/static/description/assets/icons/consultation.png
  14. BIN
      website_customer_contact/static/description/assets/icons/ecom-black.png
  15. BIN
      website_customer_contact/static/description/assets/icons/education-black.png
  16. BIN
      website_customer_contact/static/description/assets/icons/hotel-black.png
  17. BIN
      website_customer_contact/static/description/assets/icons/img.png
  18. BIN
      website_customer_contact/static/description/assets/icons/license.png
  19. BIN
      website_customer_contact/static/description/assets/icons/lifebuoy.png
  20. BIN
      website_customer_contact/static/description/assets/icons/manufacturing-black.png
  21. BIN
      website_customer_contact/static/description/assets/icons/photo-capture.png
  22. BIN
      website_customer_contact/static/description/assets/icons/pos-black.png
  23. BIN
      website_customer_contact/static/description/assets/icons/puzzle.png
  24. BIN
      website_customer_contact/static/description/assets/icons/restaurant-black.png
  25. BIN
      website_customer_contact/static/description/assets/icons/service-black.png
  26. BIN
      website_customer_contact/static/description/assets/icons/trading-black.png
  27. BIN
      website_customer_contact/static/description/assets/icons/training.png
  28. BIN
      website_customer_contact/static/description/assets/icons/update.png
  29. BIN
      website_customer_contact/static/description/assets/icons/user.png
  30. BIN
      website_customer_contact/static/description/assets/icons/wrench.png
  31. BIN
      website_customer_contact/static/description/assets/misc/Cybrosys R.png
  32. 33
      website_customer_contact/static/description/assets/misc/email.svg
  33. 3
      website_customer_contact/static/description/assets/misc/phone.svg
  34. 9
      website_customer_contact/static/description/assets/misc/star (1) 2.svg
  35. 9
      website_customer_contact/static/description/assets/misc/support (1) 1.svg
  36. 6
      website_customer_contact/static/description/assets/misc/support-email.svg
  37. 17
      website_customer_contact/static/description/assets/misc/tick-mark.svg
  38. 9
      website_customer_contact/static/description/assets/misc/whatsapp 1.svg
  39. 33
      website_customer_contact/static/description/assets/misc/whatsapp.svg
  40. BIN
      website_customer_contact/static/description/assets/modules/accounting_report_excel.png
  41. BIN
      website_customer_contact/static/description/assets/modules/customer_followup.png
  42. BIN
      website_customer_contact/static/description/assets/modules/fedex.png
  43. BIN
      website_customer_contact/static/description/assets/modules/multiple_product_rfq.png
  44. BIN
      website_customer_contact/static/description/assets/modules/pos_order_types.png
  45. BIN
      website_customer_contact/static/description/assets/modules/project_gantt_view.png
  46. BIN
      website_customer_contact/static/description/assets/screenshots/1.png
  47. BIN
      website_customer_contact/static/description/assets/screenshots/2.png
  48. BIN
      website_customer_contact/static/description/assets/screenshots/3.png
  49. BIN
      website_customer_contact/static/description/assets/screenshots/4.png
  50. BIN
      website_customer_contact/static/description/assets/screenshots/5.png
  51. BIN
      website_customer_contact/static/description/assets/screenshots/6.png
  52. BIN
      website_customer_contact/static/description/assets/screenshots/7.png
  53. BIN
      website_customer_contact/static/description/assets/screenshots/hero.gif
  54. BIN
      website_customer_contact/static/description/banner.jpg
  55. BIN
      website_customer_contact/static/description/icon.png
  56. 713
      website_customer_contact/static/description/index.html
  57. 107
      website_customer_contact/static/src/css/website_customer_contact.css
  58. 1
      website_customer_contact/static/src/img/contacts.svg
  59. 36
      website_customer_contact/static/src/js/customer_contact_edit_form.js
  60. 77
      website_customer_contact/static/src/js/customer_contact_form.js
  61. 325
      website_customer_contact/views/portal_templates.xml
  62. 198
      website_customer_contact/views/website_templates.xml

48
website_customer_contact/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
Website Customer Contact
=========================
This module helps you to create contact and addresses from website.
Configuration
=============
* No additional configuration is needed.
License
-------
Affero General Public License v3.0 (AGPL v3)
(https://www.gnu.org/licenses/agpl-3.0-standalone.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developers: (V16) Rahul Rajeev, Jumana Jabin MP,
(V17) Anzil K A
Contact: odoo@cybrosys.com
Contacts
--------
* Mail Contact : odoo@cybrosys.com
* Website : https://cybrosys.com
Bug Tracker
-----------
Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported.
Maintainer
==========
.. image:: https://cybrosys.com/images/logo.png
:target: https://cybrosys.com
This module is maintained by Cybrosys Technologies.
For support and more information, please visit `Our Website <https://cybrosys.com/>`__
Further information
===================
HTML Description: `<static/description/index.html>`__

22
website_customer_contact/__init__.py

@ -0,0 +1,22 @@
# -- coding: utf-8 --
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
###############################################################################
from . import controllers

51
website_customer_contact/__manifest__.py

@ -0,0 +1,51 @@
# -- coding: utf-8 --
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Technologies (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 <https://www.gnu.org/licenses/>.
#
###############################################################################
{
'name': "Website Customer Contact",
'version': '17.0.1.0.0',
'category': 'Website',
'summary': """This module helps you to create contact and addresses
from website.""",
'description': """This module helps you to create contact and addresses
from website. You can create,view and edit contacts and addresses.""",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'depends': ['website'],
'data': [
'views/portal_templates.xml',
'views/website_templates.xml',
],
'assets': {
'web.assets_frontend': [
'website_customer_contact/static/src/css/website_customer_contact.css',
'website_customer_contact/static/src/js/customer_contact_edit_form.js',
'website_customer_contact/static/src/js/customer_contact_form.js',
],
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

24
website_customer_contact/controllers/__init__.py

@ -0,0 +1,24 @@
# -- coding: utf-8 --
###############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
###############################################################################
from . import contact_request
from . import portal
from . import website_customer_contact

74
website_customer_contact/controllers/contact_request.py

@ -0,0 +1,74 @@
# -- coding: utf-8 --
##############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
##############################################################################
from odoo import http
from odoo.http import request
class WebsiteCustomerContact(http.Controller):
""""Class to create a form to website"""
@http.route('/contact_request_form', type="http", website=True,
auth='public')
def contact_request_form(self):
"""Render the contact request form template and pass values
to the website."""
return http.request.render(
"website_customer_contact.website_customer_contact_request_form",
{
'contact_title': request.env['res.partner.title']
.sudo().search([]),
'country_id': request.env['res.country'].sudo().search([]),
'state_id': request.env['res.country.state'].sudo().search([]),
})
@http.route('/contact_request_form/submit', type="http", website=True,
auth='public', methods=["POST"], csrf=False)
def contact_request_form_completed(self, **kw):
"""Handle the completion of the contact request form and create
a new partner."""
kw['parent_id'] = request.env.user.partner_id.id
kw['website_id'] = request.website.id
if kw:
request.env['res.partner'].sudo().create(kw)
return request.redirect('/contact_request_form/success')
@http.route('/contact_request_form/success', type="http", website=True, auth='public')
def contact_request_form_success(self):
"""Render the success page after creating contact."""
return request.render("website_customer_contact.website_customer_contact_request_form_completed")
@http.route('/contact_request_form/write', type="http", website=True,
auth='public')
def contact_request_form_edit(self, **kw):
"""Handle editing of a contact request form and update the
corresponding partner record."""
if kw['id']:
current_contact = request.env['res.partner'].sudo().browse(
int(kw['id']))
# To write new values
current_contact.write(kw)
customer_contact = request.env['res.partner'].sudo().search(
[('parent_id', '=', request.env.user.partner_id.id)])
return request.render(
"website_customer_contact.website_customer_contact", {
'customer_contact_portal': customer_contact,
'page_name': 'customer_contact'})

36
website_customer_contact/controllers/portal.py

@ -0,0 +1,36 @@
# -- coding: utf-8 --
##############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
###############################################################################
from odoo.addons.portal.controllers import portal
from odoo.http import request
class CustomerPortal(portal.CustomerPortal):
""""Class to create a portal to website"""
def _prepare_home_portal_values(self, counters):
""""Function to super and pass value to portal"""
values = super()._prepare_home_portal_values(counters)
if 'contact_count' in counters:
values['contact_count'] = request.env['res.partner'] \
.sudo().search_count(
[('parent_id', '=', request.env.user.partner_id.id)])
return values

51
website_customer_contact/controllers/website_customer_contact.py

@ -0,0 +1,51 @@
# -- coding: utf-8 --
##############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys (<https://www.cybrosys.com>)
#
# This program is free software: you can modify
# it under the terms of the GNU Affero General Public License (AGPL) as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# 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 for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
##############################################################################
from odoo import http
from odoo.http import request
class CustomerContacts(http.Controller):
""""Class to create a route to website"""
@http.route(['/my/contacts'], type='http', auth='public', website=True)
def view_customer(self):
"""Render the customer contact template and pass values to the
website."""
customer_contact = request.env['res.partner'].sudo().search(
[('parent_id', '=', request.env.user.partner_id.id)])
return request.render(
'website_customer_contact.website_customer_contact',
{'customer_contact_portal': customer_contact,
'page_name': 'customer_contact'})
@http.route(['/my/contacts/<int:contact>'], type='http', auth='public',
website=True)
def view_customer_details(self, contact):
"""Render the customer contact details template and pass values to
the website."""
customer_contact = request.env['res.partner'].sudo().search(
[('parent_id', '=', request.env.user.partner_id.id),
('id', '=', contact)])
return request.render(
'website_customer_contact.website_customer_contact_detail',
{'customer_contact_portal': customer_contact,
'page_name': 'customer_contact_details'})

7
website_customer_contact/doc/RELEASE_NOTES.md

@ -0,0 +1,7 @@
## Module <website_customer_contact>
#### 11.08.2025
#### Version 17.0.1.0.0
##### ADD
- Initial Commit for Website Customer Contact

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

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

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

After

Width:  |  Height:  |  Size: 3.2 KiB

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

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

After

Width:  |  Height:  |  Size: 565 B

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

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 26 KiB

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

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 43 KiB

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

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

After

Width:  |  Height:  |  Size: 1.4 KiB

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

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

After

Width:  |  Height:  |  Size: 4.0 KiB

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

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 38 KiB

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

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

After

Width:  |  Height:  |  Size: 4.3 KiB

BIN
website_customer_contact/static/description/assets/modules/accounting_report_excel.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 126 KiB

BIN
website_customer_contact/static/description/assets/modules/customer_followup.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

BIN
website_customer_contact/static/description/assets/modules/fedex.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 131 KiB

BIN
website_customer_contact/static/description/assets/modules/multiple_product_rfq.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 65 KiB

BIN
website_customer_contact/static/description/assets/modules/pos_order_types.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 116 KiB

BIN
website_customer_contact/static/description/assets/modules/project_gantt_view.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 121 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 40 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 36 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 75 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 27 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 268 KiB

BIN
website_customer_contact/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

BIN
website_customer_contact/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.6 KiB

713
website_customer_contact/static/description/index.html

@ -0,0 +1,713 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Web Pay Customer Contact</title>
<!-- Bootstrap CSS -->
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/npm/bootstrap@4.0.0/dist/css/bootstrap.min.css"
integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm"
crossorigin="anonymous">
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.1/css/all.min.css">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap"
rel="stylesheet">
</head>
<body>
<section>
<div class="container"
style="font-family: 'Inter', sans-serif !important;background-color: #fff !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between flex-wrap align-items-sm-center"
style="border-bottom:1px solid rgba(0, 0, 0, 0.22)">
<div class="my-3">
<img src="assets/misc/Cybrosys R.png"
style="width:auto !important; height:40px !important">
</div>
<div class="my-3 d-flex align-items-center">
<div class="text-center"
style="background-color:#017E84 !important;font-size: 0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;">
Community
</div>
<div class="text-center"
style="background-color:#875A7B !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important;min-width: 120px !important;">
Enterprise
</div>
<div class="text-center"
style="background-color:#7C7BAD !important; color:#fff !important;font-size: 0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width: 120px !important;">
Odoo.sh
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 text-center d-flex align-items-center flex-column"
style="margin: 80px 0px !important;">
<h1 style="font-size: 2.8rem;font-weight: 700; color:
#1A202C;">
Web Pay Customer Contact</h1>
<p class="my-3 mb-4"
style="max-width: 80%; font-weight: 400 !important; line-height: 32px; color: #718096;">
This Module Helps to Create Contact and Addresses from Website.
</p>
<div style="width: 80%; margin-top: 3rem;">
<img src="assets/screenshots/hero.gif"
class="img-responsive" width="100%" height="auto">
</div>
</div>
</div>
<div class="container mt-5 mb-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#714b67 !important">
Key Highlights
</p>
</div>
<div class="row py-4">
<div class="col-md-6 col-sm-12 p-3">
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px;
background: #FFF;
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); ">
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67;
display: flex; justify-content: center; align-items: center;
margin-right: 10px; flex-shrink: 0;">
<i class="fa-solid fa-star "
style="color: #fff;font-size:14px;"></i>
</div>
<div>
<p style="color: #1A202C;font-weight: 600;
font-size: 1.2rem; margin-bottom: 2px;">
Add Contacts & Addresses on your account.</p>
</div>
</div>
</div>
<div class="col-md-6 col-sm-12 p-3">
<div class="d-flex h-100" style="padding: 30px;border-radius: 12px;
background: #FFF;
box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.25); ">
<div style="width: 36px; height: 36px; border-radius: 50%; background: #714B67;
display: flex; justify-content: center; align-items: center;
margin-right: 10px; flex-shrink: 0;">
<i class="fa-solid fa-star "
style="color: #fff;font-size:14px;"></i>
</div>
<div>
<p style="color: #1A202C;font-weight: 600;
font-size: 1.2rem; margin-bottom: 2px;">
Create and Edit Contacts & Addresses.</p>
</div>
</div>
</div>
</div>
</div>
<div class="container rounded">
<ul class="nav nav-tabs d-flex"
style="width: fit-content;margin: 0 auto;gap: 1rem;">
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
class="active show" data-toggle="tab" href="#tab1"
style="color: #fff;font-weight: 500; background-color: #714B67; text-decoration: none;">
<i class="fa-regular fa-image pr-2"
style="color: #fff;"></i>
Screenshots</a></li>
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
data-toggle="tab" href="#tab2"
style="color: #fff;font-weight: 500; text-decoration: none;"><i
class="fa-solid fa-star pr-2"
style="color: #fff;"></i>Features</a></li>
<li class="col text-center py-2 text-nowrap "
style="color: #fff; background-color: #714B67;border-radius: 6px 6px 0px 0px;">
<a
data-toggle="tab" href="#tab3"
style="color: #fff;font-weight: 500; text-decoration: none; background-color: #714B67;"><i
class="fa-solid fa-book-open pr-2"
style="color: #fff;"></i>Released Notes</a></li>
</ul>
<div class="tab-content"
style="background-color: rgba(121, 113, 119, 0.04);">
<div id="tab1" class="tab-pane fade in active show">
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/1.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Contact Request</h4>
<p class="m-0" style="color:#718096">
Navigate to Website > User > Contact Request.
</p>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/2.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Contact Request Form</h4>
<p class="m-0" style="color:#718096">
In the form view enter the contact details and choose
the type of contact type from the "Type" field.
A contact will be created once the form is submitted.
</p>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/3.png"
class="img-responsive" width="100%"
height="auto">
<img src="assets/screenshots/4.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Contacts Menu</h4>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/5.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/6.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Contact Details</h4>
</div>
</div>
</div>
<div class="col-lg-12 py-2"
style="padding: 1rem 4rem !important;">
<div
style="border: 1px solid #d8d6d6; border-radius: 4px; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="row justify-content-center p-3 w-100 m-0">
<img src="assets/screenshots/7.png"
class="img-responsive" width="100%"
height="auto">
</div>
<div class="px-3">
<h4 class="mt-2"
style=" font-weight:600 !important; color:#282F33 !important; font-size:1.3rem !important">
Edit Contact</h4>
</div>
</div>
</div>
</div>
<div id="tab2" class="tab-pane fade">
<div class="col-mg-12" style="padding: 1rem 4rem;">
<ul style="list-style: none; padding: 1rem 0;font-weight: 500;">
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>
Add Contacts & Addresses on your account
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>
Create and Edit Contacts & Addresses.
</li>
<li class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; margin-bottom: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<span style="margin-right: 12px;"><img
src="assets/misc/star (1) 2.svg"
alt=""
width="16px"></span>Available in
both Community & Enterprise.
</li>
</ul>
</div>
</div>
<div id="tab3" class="tab-pane fade">
<div class="col-mg-12 active" style="padding: 1rem 4rem;">
<div class="py-3"
style="font-weight: 500;background-color: #fff; border-radius: 4px; padding: 1rem; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);">
<div class="d-flex mb-3"
style="font-size: 0.8rem; font-weight: 500;"><span>Version
17.0.1.0.0</span><span
class="px-2">|</span><span
style="color: #714B67;font-weight: 600;">Released on:08th May 2025</span>
</div>
<p class="m-0"
style=" color:#718096!important; font-size:1rem !important;line-height: 28px;">
Initial commit for Website Customer Contact</p>
</div>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Related Products</p>
</div>
</div>
<div id="myCarousel" class="carousel slide py-3" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<div class="row p-4">
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/account_reports_xlsx/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/accounting_report_excel.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
Accounting Report Excel</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/customer_followup_community/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/customer_followup.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
Customer Followup</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/fedex_odoo_connector/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/fedex.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
Fedex Odoo Connector</p>
</div>
</a>
</div>
</div>
</div>
</div>
<div class="carousel-item">
<div class="row p-4">
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/product_to_rfq_pro/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px; ">
<img src="assets/modules/multiple_product_rfq.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
Add Multiple Products To RFQ Pro</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/custom_gantt_view/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px;">
<img src="assets/modules/project_gantt_view.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
Project Gantt View</p>
</div>
</a>
</div>
</div>
<div class="col">
<div class="p-3">
<a href="https://apps.odoo.com/apps/modules/17.0/pos_order_types/"
style="color: #000; text-decoration: none;">
<div style="border:1px solid #CBCBCB !important;border-radius: 4px;">
<div style="width: 300px;">
<img src="assets/modules/pos_order_types.png"
alt="" width="100%"
height="auto">
</div>
<p class="text-center pt-2 text-black font-weight-bold">
POS Order Types</p>
</div>
</a>
</div>
</div>
</div>
</div>
</div>
<a class="carousel-control-prev" href="#myCarousel"
data-slide="prev" style="width: 35px; color: #000;">
<span class="carousel-control-prev-icon">
<i class="fa fa-chevron-left"
style="font-size: 24px;"></i>
</span>
</a>
<a class="carousel-control-next" href="#myCarousel"
data-slide="next" style="width: 35px; color: #000;">
<span class="carousel-control-next-icon">
<i class="fa fa-chevron-right"
style="font-size: 24px;"></i>
</span>
</a>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Our Services</p>
</div>
</div>
<div class="container my-5">
<div class="row py-3">
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#13EA36 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/cogs.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Customization</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#DBC711; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/wrench.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Implementation</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#FF6B6B ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/lifebuoy.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Support</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#FFA801 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/user.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Hire
Odoo Developer</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative; border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#54A0FF; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/puzzle.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Integration</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#6D7680 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/update.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Migration</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#786FA6 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/consultation.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Consultancy</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#F8A5C2 ; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/training.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Implementation</p>
</div>
</div>
<div class="col-md-4 col-sm-6 px-4 py-4">
<div
style="background-color: #fff; padding: 25px; text-align: center; box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px, rgba(0, 0, 0, 0.06) 0px 1px 2px 0px; position: relative;border-radius: 4px;">
<div style="position: absolute; top: 0%; left: 50%; transform: translate(-50%, -50%);">
<div style="background-color:#E6BE26; border-radius: 50%; padding: 15px; width: 68px;
height: 68px; display: inline-block; box-shadow:0px 4px 4px rgba(0, 0, 0, 0.25);">
<img src="assets/icons/license.png"
alt="service-icon" width="38px"
height="auto">
</div>
</div>
<p style="margin-top: 20px; font-weight: bold;">Odoo
Licensing Consultancy</p>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-4">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Our Industries</p>
</div>
</div>
<div class="container">
<div class="row my-5 py-4">
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100 "
style="border-right: 1px solid rgb(209, 209, 209); border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; box-shadow: 6px 0 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/trading-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Trading</p>
<p>Easily procure and sell your products</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgb(209, 209, 209); padding: 30px;">
<img src="assets/icons/pos-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">POS</p>
<p>Easy configuration and convivial experience</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209);border-bottom: 1px solid rgba(0, 0, 0, 0.2); padding: 30px; box-shadow: 0 5px 10px rgba(228, 227, 227, 0.373)">
<img src="assets/icons/education-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Education</p>
<p>A platform for educational management</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-bottom: 1px solid rgb(209, 209, 209); padding: 30px; ">
<img src="assets/icons/manufacturing-black.png"
width="42px" height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Manufacturing</p>
<p>Plan, track and schedule your operations</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;">
<img src="assets/icons/ecom-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">E-commerce &
Website</p>
<p>Mobile friendly, awe-inspiring product pages</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px;box-shadow: 0 -5px 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/service-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Service
Management</p>
<p>Keep track of services and invoice</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style="border-right: 1px solid rgb(209, 209, 209); padding: 30px; ">
<img src="assets/icons/restaurant-black.png"
width="42px" height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">
Restaurant</p>
<p>Run your bar or restaurant methodically</p>
</div>
</div>
<div class="col-md-3 col-sm-6 p-0">
<div class="d-flex flex-column h-100"
style=" padding: 30px;box-shadow: -5px 0 10px rgba(228, 227, 227, 0.373);">
<img src="assets/icons/hotel-black.png" width="42px"
height="auto" alt="">
<p style="color: #714B67;font-weight: 600; margin-top: 10px;
font-size: 1.2rem; margin-bottom: 2px;">Hotel
Management</p>
<p>An all-inclusive hotel management application</p>
</div>
</div>
</div>
</div>
<div class="container mt-5">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center mt-5">
<p class="m-0"
style="font-weight: 600; font-size: 24px; color:#000 !important">
Support</p>
</div>
</div>
<div class="container my-5">
<div class="row" style="background-color: #FFFAFE;">
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center"
style="border-right: 1px solid #D9D9D9;">
<div style="padding: 30px;">
<div class="d-flex align-items-center">
<img src="assets/misc/support (1) 1.svg" alt=""
width="60px" style="margin-right: 12px;">
<div style="padding: 0px 8px;">
<span
style="color: #714B67;font-size: 24px;font-weight: 600;padding-bottom: 1rem;">Need
Help?</span>
<p class="m-0" style="color:#718096;">Got
questions or need help? Get in touch.</p>
<div style="font-weight: 400;"><span><img
src="assets/misc/support-email.svg"
alt=""
width="18px"
style="filter: invert(1);margin-right: 0.8rem;"></span>odoo@cybrosys.com
</div>
</div>
</div>
</div>
</div>
<div class="col-md-6 pb-4 d-flex align-items-center justify-content-center">
<div style="padding: 30px;">
<div class="d-flex align-items-center">
<img src="assets/misc/whatsapp 1.svg" alt=""
width="60px" style="margin-right: 12px;">
<div>
<span style="color: #714B67;font-size: 24px;font-weight: 600;">WhatsApp</span>
<p class="m-0" style="color:#718096;">Say hi to
us on WhatsApp!</p>
<div style="font-weight: 400; font-size: 16px;"><span><img
src="assets/misc/phone.svg"
alt="" width="14px"
style="filter: invert(1); margin-right: 0.8rem;"></span>+91
99456767686
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</section>
<!-- Optional JavaScript -->
<!-- jQuery first, then Popper.js, then Bootstrap JS -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script>
</body>
</html>

107
website_customer_contact/static/src/css/website_customer_contact.css

@ -0,0 +1,107 @@
a#myModal{
margin-top: -56px;
margin-left: 1137px;
}
@media screen and (max-width: 1600px) {
.modal.show .modal-dialog{
max-height:56% !important;
}
}
@media screen and (max-width: 991px) {
.modal.show .modal-dialog{
max-height:56% !important;
}
}
@media screen and (max-width: 768px) {
.form-field .col-md-3
text-align:left !important;
}
.form-field .o_website_form_input{
width:96% !important;
}
.modal-body{
background-color:#fff;
}
.modal.show .modal-dialog{
max-height:75% !important;
}
.contact_form{
width:100% !important;
}
}
@media screen and (max-width: 500px) {
a#myModal{
margin-top: -47px;
margin-left: 182px;
}
.modal-dialog.modal-content{
min-height: 440px !important;
max-width: 100% !important;
}
.contact_form form label{
width:48% !important;
}
.contact_form form .form-control {
width: 100% !important;
}
}
.btn-add-contact{
background: none;
border: none;
}
.btn-add-contact a{
color: white !important;
padding: 0px 36px !important;
height: 36px !important;
display: flex;
align-items: center;
outline: none !important;
border-radius: 9px;
box-shadow: none;
background-color: #35979c;
}
.o_popup_btn_close{
color: #FFFFFF;
background-color: #35979c;
border-color: #35979c;
font-size:1rem !important;
margin-left:9px;
}
.o_popup_btn_close:hover{
color:#fff !important;
background-color:#2d8084;
}
a#myModal{
position: absolute;
right: 17px;
top: 12px;
margin:0px !important;
}
.contact_form{
margin: auto;
width: 750px;
}
.contact_form .form-group{
margin-bottom:16px;
}
.contact_form form label {
font-weight: 700;
float: left;
width: 17%;
}
.contact_form form .form-control {
width:83%;
}
.contact-success{
width: 369px;
margin: auto;
margin-top: 14%;
font-size:18px;
border-radius:43px;
}
.contact-success span{
padding-right:7px;
font-size:22px;
}

1
website_customer_contact/static/src/img/contacts.svg

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50" width="50px" height="50px"><path d="M 24.875 3.3125 C 20.183594 3.417969 17.214844 5.316406 15.9375 8.25 C 14.722656 11.042969 14.976563 14.5625 15.84375 18.21875 C 15.378906 18.765625 14.996094 19.535156 15.09375 20.6875 L 15.09375 20.75 C 15.261719 21.96875 15.628906 22.828125 16.09375 23.4375 C 16.316406 23.726563 16.632813 23.742188 16.90625 23.90625 C 17.148438 25.269531 17.691406 26.570313 18.3125 27.59375 C 18.34375 27.742188 18.40625 27.878906 18.5 28 C 18.5 28 18.601563 28.128906 18.625 28.15625 C 18.9375 28.625 19.09375 29.277344 19.09375 30 C 19.09375 30.769531 19.082031 31.484375 19 32.28125 C 18.699219 33.039063 17.949219 33.644531 16.75 34.25 C 15.496094 34.882813 13.855469 35.464844 12.1875 36.1875 C 10.519531 36.910156 8.828125 37.777344 7.46875 39.15625 C 6.109375 40.535156 5.136719 42.445313 5 44.9375 L 4.9375 46 L 45.0625 46 L 45 44.9375 C 44.863281 42.445313 43.914063 40.539063 42.5625 39.15625 C 41.210938 37.773438 39.511719 36.910156 37.84375 36.1875 C 36.175781 35.464844 34.523438 34.886719 33.25 34.25 C 32.015625 33.632813 31.242188 33.003906 30.90625 32.21875 C 30.828125 31.273438 30.8125 30.527344 30.8125 29.6875 C 30.8125 29.152344 30.996094 28.667969 31.3125 28.1875 C 31.320313 28.175781 31.335938 28.167969 31.34375 28.15625 C 31.347656 28.148438 31.40625 28.09375 31.40625 28.09375 C 31.53125 27.964844 31.617188 27.800781 31.65625 27.625 C 32.261719 26.585938 32.765625 25.265625 33 23.9375 C 33.3125 23.773438 33.664063 23.753906 33.90625 23.4375 C 34.386719 22.808594 34.667969 21.914063 34.78125 20.6875 C 34.871094 19.628906 34.566406 18.859375 34.09375 18.28125 C 34.613281 16.679688 35.230469 14.117188 35.03125 11.5 C 34.921875 10.0625 34.542969 8.628906 33.6875 7.4375 C 32.914063 6.359375 31.664063 5.621094 30.09375 5.28125 C 29.035156 3.867188 27.113281 3.3125 24.90625 3.3125 Z M 24.90625 5.3125 C 24.917969 5.3125 24.925781 5.3125 24.9375 5.3125 C 26.933594 5.320313 28.210938 5.882813 28.625 6.59375 L 28.875 7.03125 L 29.375 7.09375 C 30.75 7.285156 31.503906 7.816406 32.0625 8.59375 C 32.621094 9.371094 32.941406 10.457031 33.03125 11.65625 C 33.214844 14.058594 32.519531 16.875 32.0625 18.15625 L 31.75 19 L 32.53125 19.40625 C 32.523438 19.433594 32.851563 19.765625 32.8125 20.5 C 32.8125 20.515625 32.8125 20.515625 32.8125 20.53125 C 32.71875 21.472656 32.476563 22.003906 32.3125 22.21875 C 32.144531 22.4375 32.058594 22.40625 32.09375 22.40625 L 31.21875 22.40625 L 31.09375 23.28125 C 30.921875 24.578125 30.261719 26.210938 29.6875 27.03125 L 29.65625 27.03125 C 29.597656 27.117188 29.554688 27.21875 29.5 27.3125 C 29.238281 27.617188 28.84375 28.019531 28.28125 28.5 C 27.347656 29.296875 26.109375 30 25 30 C 23.898438 30 22.648438 29.261719 21.6875 28.4375 C 20.855469 27.722656 20.359375 27.109375 20.21875 26.9375 C 20.214844 26.929688 20.222656 26.914063 20.21875 26.90625 C 19.628906 26.054688 18.953125 24.5625 18.78125 23.28125 L 18.6875 22.40625 L 17.875 22.40625 C 17.839844 22.390625 17.746094 22.339844 17.65625 22.21875 C 17.480469 21.988281 17.230469 21.449219 17.09375 20.53125 C 17.09375 20.511719 17.09375 20.519531 17.09375 20.5 C 17.089844 20.484375 17.097656 20.484375 17.09375 20.46875 C 17.078125 19.710938 17.546875 19.289063 17.46875 19.34375 L 18.03125 18.9375 L 17.875 18.25 C 16.953125 14.605469 16.808594 11.304688 17.78125 9.0625 C 18.753906 6.828125 20.722656 5.414063 24.90625 5.3125 Z M 21.09375 30.53125 C 22.148438 31.308594 23.46875 32 25 32 C 26.5 32 27.785156 31.34375 28.8125 30.59375 C 28.816406 31.203125 28.835938 31.828125 28.90625 32.59375 L 28.90625 32.71875 L 28.96875 32.84375 C 29.144531 33.304688 29.394531 33.695313 29.6875 34.0625 C 29.675781 34.101563 29.664063 34.144531 29.65625 34.1875 C 29.65625 34.1875 29.417969 34.84375 28.71875 35.5625 C 28.019531 36.28125 26.933594 37 25 37 C 23.074219 37 21.949219 36.25 21.21875 35.5 C 20.488281 34.75 20.25 34.0625 20.25 34.0625 C 20.539063 33.6875 20.777344 33.285156 20.9375 32.8125 L 21 32.625 C 21.085938 31.867188 21.09375 31.183594 21.09375 30.53125 Z M 31.25 35.4375 C 31.601563 35.664063 31.964844 35.875 32.34375 36.0625 C 33.804688 36.789063 35.460938 37.351563 37.03125 38.03125 C 38.601563 38.710938 40.066406 39.480469 41.125 40.5625 C 41.96875 41.425781 42.476563 42.574219 42.75 44 L 7.25 44 C 7.523438 42.574219 8.027344 41.425781 8.875 40.5625 C 9.9375 39.480469 11.429688 38.710938 13 38.03125 C 14.570313 37.351563 16.210938 36.792969 17.65625 36.0625 C 18.015625 35.878906 18.382813 35.6875 18.71875 35.46875 C 18.941406 35.871094 19.285156 36.394531 19.78125 36.90625 C 20.800781 37.957031 22.527344 39 25 39 C 27.464844 39 29.15625 37.96875 30.15625 36.9375 C 30.703125 36.375 31.035156 35.851563 31.25 35.4375 Z"/></svg>

After

Width:  |  Height:  |  Size: 4.7 KiB

36
website_customer_contact/static/src/js/customer_contact_edit_form.js

@ -0,0 +1,36 @@
/** @odoo-module */
import dom from '@web/legacy/js/core/dom';
import publicWidget from '@web/legacy/js/public/public_widget';
import { Dialog } from "@web/core/dialog/dialog";
import { AlertDialog } from "@web/core/confirmation_dialog/confirmation_dialog";
import { _t } from "@web/core/l10n/translation";
// * Odoo customer contact form widget.
// *
// * This widget handles the behavior of the customer contact edit form on the website. It listens to specific events and
// * performs corresponding actions when triggered.
// */
publicWidget.registry.WebsiteCustomerContactEdit = publicWidget.Widget.extend({
selector: '.customer_contact_edit_form',
events: {
'click #form_submit': 'validateNumber',
},
// /**
// * Validate the input value of the #phone,#mobile fields to ensure it contains
// only valid numbers.
// *
// * @param {Event} ev - The "input" event object.
// */
validateNumber: function (ev) {
const mobile_no = this.$('#mobile');
const phone_no = this.$('#phone');
if ((!/^\d+$/.test(mobile_no.val())) || (!/^\d+$/.test(phone_no.val()))) {
ev.preventDefault()
this.call('dialog', 'add', AlertDialog, {
title: _t("Warning!"),
body: _t("Enter Valid Phone Number and Mobile Number"),
});
}
return;
},
});

77
website_customer_contact/static/src/js/customer_contact_form.js

@ -0,0 +1,77 @@
/** @odoo-module */
import dom from '@web/legacy/js/core/dom';
import publicWidget from '@web/legacy/js/public/public_widget';
import { Dialog } from "@web/core/dialog/dialog";
import { AlertDialog } from "@web/core/confirmation_dialog/confirmation_dialog";
import { _t } from "@web/core/l10n/translation";
// * Odoo customer contact form widget.
// *
// * This widget handles the behavior of the customer contact request form
// on the website. It listens to specific events and
// * performs corresponding actions when triggered.
// */
publicWidget.registry.WebsiteCustomerContactRequest = publicWidget.Widget.extend({
selector: '.customer_contact_form',
events: {
'click #contact_request_form_submit ': 'validateNumber',
"change .select_box_test": "_onChangeType",
"change .country_select": "_onChangeCountry",
},
// /**
// * Validate the input value of the #phone,#mobile fields to ensure it
// contains only valid numbers.
// *
// * @param {Event} ev - The "input" event object.
// */
validateNumber: function (ev) {
const mobile_no = this.$('#mobile_number');
const phone_no = this.$('#phone_number');
if ((!/^\d+$/.test(mobile_no.val())) || (!/^\d+$/.test(phone_no.val()))) {
ev.preventDefault()
this.call('dialog', 'add', AlertDialog, {
title: _t("Warning!"),
body: _t("Enter Valid Phone Number and Mobile Number"),
});
}
return;
},
// Onchange of customer type, fields to fill varies
_onChangeType: function (ev) {
let select = this.$(ev.currentTarget);
let selectedValue = select.val();
if (selectedValue === "contact") {
this.$el.find(".job_position").show();
this.$el.find(".contact_title").show();
this.$el.find(".street").hide();
this.$el.find(".street2").hide();
this.$el.find(".city").hide();
this.$el.find(".zip").hide();
this.$el.find(".state_id").hide();
this.$el.find(".country_id").hide();
} else {
this.$el.find(".job_position").hide();
this.$el.find(".contact_title").hide();
this.$el.find(".street").show();
this.$el.find(".street2").show();
this.$el.find(".city").show();
this.$el.find(".zip").show();
this.$el.find(".state_id").show();
this.$el.find(".country_id").show();
}
},
// Onchange of country, only states of that particular country will be shown
_onChangeCountry: function (ev) {
let selected_country =
this.$el.find(".country_select")[0].selectedOptions[0].innerText;
let state = this.$el.find(".state_select_option");
for (let i = 0; i < state.length; i++) {
state[i].style["display"] = "";
if (state[i].dataset["id"] != selected_country) {
state[i].style["display"] = "none";
}
}
},
});

325
website_customer_contact/views/portal_templates.xml

@ -0,0 +1,325 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<template id="website_customer_contact_detail"
name="Customer Contact Detail">
<!-- This is a code snippet for a website customer contact detail page written in-->
<!-- The Odoo framework's templating language (XML-based). The page displays customer -->
<!-- Contact details and allows the customer to edit their contact information using a form.-->
<t t-call="portal.portal_layout">
<t t-set="breadcrumbs_searchbar" t-value="True"/>
<t t-call="portal.portal_searchbar">
<t t-set="title">Customer Contact</t>
</t>
<!-- Intro-->
<div class="pb-2 pt-3 card-header bg-white"
style="position:relative;">
<h2 class="my-0">
Contact Details
</h2>
<a role="button"
class="btn btn-secondary flex-grow-1 mb-1 createButton"
data-bs-toggle="modal"
id="myModal" data-bs-target="#contactpopup" href="#">
<t>Edit</t>
</a>
</div>
<!-- Information-->
<div id="information">
<div class="pb-2 pt-3 card-header bg-white">
<div class="row">
<div class="mb-3 col-6">
<strong>Name</strong>
<span t-field="customer_contact_portal.name"/>
</div>
<div class="mb-3 col-6">
<strong>Email</strong>
<span t-field="customer_contact_portal.email"/>
</div>
</div>
<div class="row">
<div class="mb-3 col-6">
<t t-if="customer_contact_portal.type=='contact'">
<strong>Title</strong>
<span t-field="customer_contact_portal.title"/>
</t>
<t t-else="">
<strong>Address</strong>
<span t-field="customer_contact_portal.street"/>
</t>
</div>
<div class="mb-3 col-6">
<strong>Phone</strong>
<span t-field="customer_contact_portal.phone"/>
</div>
</div>
<div class="row">
<div class="mb-3 col-6">
<t t-if="customer_contact_portal.type=='contact'">
<strong>Job Position</strong>
<span t-field="customer_contact_portal.function"/>
</t>
<t t-else="">
<strong>Address2</strong>
<span t-field="customer_contact_portal.street2"/>
</t>
</div>
<div class="mb-3 col-6">
<strong>Mobile</strong>
<span t-field="customer_contact_portal.mobile"/>
</div>
</div>
<div class="row">
<t t-if="customer_contact_portal.type!='contact'">
<div class="mb-3 col-2">
<strong>City</strong>
<span t-field="customer_contact_portal.city"/>
</div>
<div class="mb-3 col-2">
<strong>ZIP</strong>
<span t-field="customer_contact_portal.zip"/>
</div>
<div class="mb-3 col-2">
<strong>State</strong>
<span t-field="customer_contact_portal.state_id"/>
</div>
</t>
<div class="mb-3 col-6">
<strong>Notes</strong>
<span t-field="customer_contact_portal.comment"/>
</div>
</div>
<div class="row">
<div class="mb-3 col-6">
<t t-if="customer_contact_portal.type!='contact'">
<strong>Country</strong>
<span t-field="customer_contact_portal.country_id"/>
</t>
</div>
</div>
</div>
</div>
<form action="/contact_request_form/write" method="post"
enctype="multipart/form-data">
<input type="hidden" name="csrf_token"
t-att-value="request.csrf_token()"/>
<div class="customer_contact_edit_form">
<div id="contactpopup" class="modal fade">
<div class="modal-dialog modal-content"
style="border:solid 2px white; min-height:200px;max-width:800px;margin-top:10px;max-height:46%;">
<div class="modal-body" id="pop_html">
<br/>
<div style="margin-top:-40px" class="mb-4">
<h2 style="text-align:center; font-size 18px; font-weight:bold"
class="o_default_snippet_text">
Edit Contact
</h2>
</div>
<div class="form-group row form-field"
style="display:none;">
<div class="col-lg-3 col-md-4">
<label class="col-form-label"
for="dealer_contact">Id *
</label>
</div>
<div class="col-lg-7 col-md-8">
<input id="id1" type="text"
required="True"
class="form-control o_website_form_input"
name="id"
t-att-value="customer_contact_portal.id"/>
</div>
</div>
<div class="form-group row form-field mb-3"
style="justify-content:center;">
<div class="col-lg-3 col-md-3"
style="text-align:right;">
<label class="col-form-label"
for="id1">
Name
</label>
</div>
<div class="col-lg-9 col-md-9">
<input id="id1" type="text"
required="True"
class="form-control w-75 o_website_form_input"
name="name"
t-att-value="customer_contact_portal.name"/>
</div>
</div>
<div class="form-group row form-field mb-3"
style="justify-content:center;">
<div class="col-lg-3 col-md-3"
style="text-align:right;">
<label class="col-form-label"
for="mobile">
Mobile
</label>
</div>
<div class="col-lg-9 col-md-9">
<input id="mobile" type="text"
class="form-control w-75 o_website_form_input"
name="mobile"
t-att-value="customer_contact_portal.mobile"/>
</div>
</div>
<div class="form-group row mb-3 form-field"
style="justify-content:center;">
<div class="col-lg-3 col-md-3"
style="text-align:right;">
<label class="col-form-label"
for="email">
Email
</label>
</div>
<div class="col-lg-9 col-md-9">
<input id="email" type="email"
class="form-control w-75 o_website_form_input"
name="email"
t-att-value="customer_contact_portal.email"/>
</div>
</div>
<div class="form-group row mb-3 form-field"
style="justify-content:center;">
<div class="col-lg-3 col-md-3"
style="text-align:right;">
<label class="col-form-label"
for="phone">
Phone
</label>
</div>
<div class="col-lg-9 col-md-9">
<input id="phone" type="text"
class="form-control w-75 o_website_form_input"
name="phone"
t-att-value="customer_contact_portal.phone"/>
</div>
</div>
<div class="form-group row form-field">
<div style="margin-top: 16px; display:flex; align-items:center; justify-content:center;"
class="mt-4">
<button type="submit"
id="form_submit"
class="btn btn-primary btn-md o_website_form_send">
Save
</button>
<a href="#"
class="btn o_popup_btn_close o_not_editable o_default_snippet_text pull-right"
data-bs-dismiss="modal"
style="font-size:30px">Cancel
</a>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
</t>
</template>
<template id="website_customer_contact" name="Customer Contact">
<!-- This template creates a page for displaying customer contact information -->
<!-- in a table format. It also includes an option to add new contacts.-->
<t t-call="portal.portal_layout">
<t t-set="breadcrumbs_searchbar" t-value="True"/>
<t t-call="portal.portal_searchbar">
<t t-set="title">Customer Contact</t>
</t>
<t t-if="customer_contact_portal" t-call="portal.portal_table">
<thead>
<tr class="active">
<th class="text-center">Name</th>
<th class="text-center">Type</th>
<th class="text-center">Email</th>
<th class="text-center">Phone</th>
</tr>
</thead>
<t t-foreach="customer_contact_portal" t-as="contact">
<tr>
<td class="text-center">
<a t-attf-href="/my/contacts/#{contact.id}">
<span t-field="contact.name"/>
</a>
</td>
<td class="text-center">
<span t-field="contact.type"/>
</td>
<td class="text-center">
<span t-field="contact.email"/>
</td>
<td class="text-center">
<span t-field="contact.phone"/>
</td>
</tr>
</t>
</t>
<p t-else="">There are currently no contacts under your account.
</p>
<div style="padding:0 45% 0 45%">
<button class="btn-primary btn-add-contact"
style="margin-top: 16px;">
<a href="/contact_request_form"
style="color: white !important;">Add
</a>
</button>
</div>
</t>
</template>
<template id="website_customer_contact_portal_menu" name="Portal Menu"
inherit_id="portal.portal_breadcrumbs"
priority="60">
<!-- The "Portal Menu" template provides breadcrumb navigation for the customer contact portal,
Showing the current page and allowing users to navigate to previous pages. It includes
special cases for the "customer_contact" and "customer_contact_details"-->
<xpath expr="//ol[hasclass('o_portal_submenu')]" position="inside">
<li t-if="page_name=='customer_contact'"
class="breadcrumb-item active">
<span>Customer Contacts
</span>
</li>
<li t-if="page_name=='customer_contact_details'"
class="breadcrumb-item active">
<a t-attf-href="/my/contacts"
arialabel="Customer Contact Details"
title="Customer Contact Details">
<span>Customer Contacts</span>
</a>
<span>/
<em t-out="customer_contact_portal.name"/>
</span>
</li>
</xpath>
</template>
<!-- The "portal_my_home_contacts" template adds a
"Contacts" section to the customer portal homepage. It allows customers to
view and manage their contacts -->
<template id="portal_my_home_contacts"
name="Portal Contacts" inherit_id="portal.portal_my_home"
customize_show="True" priority="30">
<xpath expr="//div[hasclass('o_portal_docs')]" position="before">
<t t-set="portal_client_category_enable" t-value="True"/>
</xpath>
<div id="portal_client_category" position="inside">
<t t-call="portal.portal_docs_entry">
<t t-set="icon"
t-value="'/website_customer_contact/static/src/img/contacts.svg'"/>
<t t-set="title">Contacts</t>
<t t-set="url" t-value="'/my/contacts'"/>
<t t-set="text">View contacts</t>
<t t-set="placeholder_count" t-value="'contact_count'"/>
</t>
</div>
</template>
<template id="website_customer_contact_request"
name="Link to frontend portal" inherit_id="portal.user_dropdown">
<!-- The "website_customer_contact_request" template adds a link to the frontend portal
allowing customers to make a contact request, and inherits from the "portal.user_dropdown" template.-->
<xpath expr="//*[@id='o_logout_divider']" position="before">
<a href="/contact_request_form" role="menuitem"
class="dropdown-item ps-3">
<i class="fa fa-fw fa-id-card-o me-1 small text-muted"/>
Contact Request
</a>
</xpath>
</template>
</odoo>

198
website_customer_contact/views/website_templates.xml

@ -0,0 +1,198 @@
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<template id="website_customer_contact_request_form"
name="Contact Request Form">
<!-- This appears to be a website contact form written in HTML and a templating language.
The form includes various input fields for the user to enter information, such as
their name, job position, email, and phone number, as well as drop-down menus
for selecting the type of contact and the country. It also has a notes section for
the user to add any additional comments.-->
<t t-call="website.layout">
<div id="wrap" class="customer_contact_form">
<div class="oe_structure">
<div class="container">
<div class="contact_form mt-4">
<form class="w-100 float-left" action="/contact_request_form/submit"
method="post">
<div class="form-group type">
<label for="type" name='type'
class="control-label">Type
</label>
<select name="type"
t-attf-class="form-control select_box_test"
required="">
<option value="contact">Contact
</option>
<option value="invoice">Invoice
Address
</option>
<option value="delivery">Delivery
Address
</option>
<option value="other">Other Address
</option>
</select>
</div>
<div class="form-group contact_name">
<label for="contact_name"
class="control-label">Name*
</label>
<input id="contact_name" type="text"
class="form-control" name="name"
required=""
placeholder="Name"/>
</div>
<div class="form-group job_position">
<label for="job_position"
class="control-label">Job Position
</label>
<input id="job_position" type="text"
class="form-control" name="function"
placeholder="Job Position"/>
</div>
<div class="form-group street"
style="display: none;">
<label for="street" class="control-label">
Address
</label>
<input id="street" type="text"
class="form-control" name="street"
placeholder="Address"/>
</div>
<div class="form-group street2"
style="display: none;">
<label for="street2" class="control-label">
Address2
</label>
<input id="street2" type="text"
class="form-control" name="street2"
placeholder="Address2"/>
</div>
<div class="form-group city"
style="display: none;">
<label for="city" class="control-label">
City
</label>
<input id="city" type="text"
class="form-control" name="city"
placeholder="City"/>
</div>
<div class="form-group zip"
style="display: none;">
<label for="zip" class="control-label">ZIP
</label>
<input id="zip" type="number"
class="form-control" name="zip"
placeholder="ZIP"/>
</div>
<div class="form-group state_id"
style="display: none;">
<label for="state_id"
class="control-label">
State
</label>
<select id="state_id" name="state_id"
class="form-control link-style state_select">
<option value=""/>
<t t-foreach="state_id" t-as="state">
<option t-esc="state.name"
t-att-data-id="state.country_id.name"
class="state_select_option"
t-att-value="state.id"/>
</t>
</select>
</div>
<div class="form-group country_id"
style="display: none;">
<label for="country_id"
class="control-label">Country
</label>
<select id="country_id" name="country_id"
class="form-control link-style country_select">
<option value=""/>
<t t-foreach="country_id"
t-as="country">
<option t-esc="country.name"
t-att-value="country.id"/>
</t>
</select>
</div>
<div class="form-group contact_title">
<label for="contact_title"
class="control-label">Title
</label>
<select id="contact_title" name="title"
class="form-control link-style">
<option value=""/>
<t t-foreach="contact_title"
t-as="title">
<option t-esc="title.name"
t-att-value="title.id"/>
</t>
</select>
</div>
<div class="form-group email">
<label for="email" class="control-label">
Email*
</label>
<input id="email" type="email"
class="form-control" name="email"
required=""
placeholder="Email"/>
</div>
<div class="form-group phone_number">
<label for="phone_number"
class="control-label">Phone*
</label>
<input id="phone_number" type="char"
class="form-control" name="phone"
required=""
placeholder="Phone"/>
</div>
<div class="form-group mobile_number">
<label for="mobile_number"
class="control-label">Mobile
</label>
<input id="mobile_number" type="char"
class="form-control" name="mobile"
placeholder="Mobile"/>
</div>
<div class="form-group notes">
<label for="notes" class="control-label">
Notes
</label>
<input id="notes" type="text"
class="form-control" name="comment"
placeholder="Notes"/>
</div>
<div class="clearfix oe_login_buttons" style="padding:0 45% 0 45%;
margin-top: 10px; margin-bottom: 10px;">
<button id="contact_request_form_submit"
class="btn btn-primary pull-left" type="submit">
SUBMIT
</button>
</div>
</form>
</div>
</div>
</div>
</div>
</t>
</template>
<template id="website_customer_contact_request_form_completed">
<!--This template load a success page on success creation of contact or address-->
<t t-call="website.layout">
<div class="container">
<div class="row">
<div class="col-lg-12" style="text-align:center;">
<div class="alert alert-success contact-success"
role="status">
<span class="fa fa-check-circle"/>
Contact Created Successfully
</div>
</div>
</div>
</div>
</t>
</template>
</odoo>
Loading…
Cancel
Save