Browse Source

May 08 : [ADD] Initial Commit 'whatsapp_chat_layout'

dependabot/npm_and_yarn/odoo_website_helpdesk/static/src/cdn/minimist-1.2.8
Sayooj 2 years ago
parent
commit
62573d5db7
  1. 44
      whatsapp_chat_layout/README.rst
  2. 22
      whatsapp_chat_layout/__init__.py
  3. 57
      whatsapp_chat_layout/__manifest__.py
  4. 6
      whatsapp_chat_layout/doc/RELEASE_NOTES.md
  5. 24
      whatsapp_chat_layout/models/__init__.py
  6. 30
      whatsapp_chat_layout/models/res_company.py
  7. 50
      whatsapp_chat_layout/models/res_config_settings.py
  8. 32
      whatsapp_chat_layout/models/res_users.py
  9. BIN
      whatsapp_chat_layout/static/description/assets/icons/check.png
  10. BIN
      whatsapp_chat_layout/static/description/assets/icons/chevron.png
  11. BIN
      whatsapp_chat_layout/static/description/assets/icons/cogs.png
  12. BIN
      whatsapp_chat_layout/static/description/assets/icons/consultation.png
  13. BIN
      whatsapp_chat_layout/static/description/assets/icons/ecom-black.png
  14. BIN
      whatsapp_chat_layout/static/description/assets/icons/education-black.png
  15. BIN
      whatsapp_chat_layout/static/description/assets/icons/hotel-black.png
  16. BIN
      whatsapp_chat_layout/static/description/assets/icons/license.png
  17. BIN
      whatsapp_chat_layout/static/description/assets/icons/lifebuoy.png
  18. BIN
      whatsapp_chat_layout/static/description/assets/icons/manufacturing-black.png
  19. BIN
      whatsapp_chat_layout/static/description/assets/icons/pos-black.png
  20. BIN
      whatsapp_chat_layout/static/description/assets/icons/puzzle.png
  21. BIN
      whatsapp_chat_layout/static/description/assets/icons/restaurant-black.png
  22. BIN
      whatsapp_chat_layout/static/description/assets/icons/service-black.png
  23. BIN
      whatsapp_chat_layout/static/description/assets/icons/trading-black.png
  24. BIN
      whatsapp_chat_layout/static/description/assets/icons/training.png
  25. BIN
      whatsapp_chat_layout/static/description/assets/icons/update.png
  26. BIN
      whatsapp_chat_layout/static/description/assets/icons/user.png
  27. BIN
      whatsapp_chat_layout/static/description/assets/icons/wrench.png
  28. BIN
      whatsapp_chat_layout/static/description/assets/misc/categories.png
  29. BIN
      whatsapp_chat_layout/static/description/assets/misc/check-box.png
  30. BIN
      whatsapp_chat_layout/static/description/assets/misc/compass.png
  31. BIN
      whatsapp_chat_layout/static/description/assets/misc/corporate.png
  32. BIN
      whatsapp_chat_layout/static/description/assets/misc/customer-support.png
  33. BIN
      whatsapp_chat_layout/static/description/assets/misc/cybrosys-logo.png
  34. BIN
      whatsapp_chat_layout/static/description/assets/misc/features.png
  35. BIN
      whatsapp_chat_layout/static/description/assets/misc/logo.png
  36. BIN
      whatsapp_chat_layout/static/description/assets/misc/pictures.png
  37. BIN
      whatsapp_chat_layout/static/description/assets/misc/pie-chart.png
  38. BIN
      whatsapp_chat_layout/static/description/assets/misc/right-arrow.png
  39. BIN
      whatsapp_chat_layout/static/description/assets/misc/star.png
  40. BIN
      whatsapp_chat_layout/static/description/assets/misc/support.png
  41. BIN
      whatsapp_chat_layout/static/description/assets/misc/whatsapp.png
  42. BIN
      whatsapp_chat_layout/static/description/assets/modules/1.png
  43. BIN
      whatsapp_chat_layout/static/description/assets/modules/2.png
  44. BIN
      whatsapp_chat_layout/static/description/assets/modules/3.png
  45. BIN
      whatsapp_chat_layout/static/description/assets/modules/4.png
  46. BIN
      whatsapp_chat_layout/static/description/assets/modules/5.png
  47. BIN
      whatsapp_chat_layout/static/description/assets/modules/6.png
  48. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/1.png
  49. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/10.png
  50. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/11.png
  51. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/12.png
  52. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/2.png
  53. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/3.png
  54. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/4.png
  55. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/5.png
  56. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/6.png
  57. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/7.png
  58. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/8.png
  59. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/9.png
  60. BIN
      whatsapp_chat_layout/static/description/assets/screenshots/hero.gif
  61. BIN
      whatsapp_chat_layout/static/description/banner.png
  62. BIN
      whatsapp_chat_layout/static/description/icon.png
  63. 573
      whatsapp_chat_layout/static/description/index.html
  64. 4
      whatsapp_chat_layout/static/src/css/color.css
  65. 50
      whatsapp_chat_layout/static/src/css/discuss.css
  66. 49
      whatsapp_chat_layout/static/src/css/thread.css
  67. 30
      whatsapp_chat_layout/static/src/js/discuss_container.js
  68. 38
      whatsapp_chat_layout/static/src/js/discuss_sidebar.js
  69. 106
      whatsapp_chat_layout/static/src/xml/composer.xml
  70. 51
      whatsapp_chat_layout/static/src/xml/discuss_sidebar.xml
  71. 38
      whatsapp_chat_layout/static/src/xml/discuss_sidebar_category.xml
  72. 33
      whatsapp_chat_layout/static/src/xml/discuss_sidebar_mailbox.xml
  73. 37
      whatsapp_chat_layout/views/res_config_settings.xml

44
whatsapp_chat_layout/README.rst

@ -0,0 +1,44 @@
.. image:: https://img.shields.io/badge/licence-LGPL--3-blue.svg
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
:alt: License: LGPL-3
Whatsapp Chat Layout in Odoo Discuss
==================
* Whatsapp Chat Layout in Odoo Discuss module for Odoo 16.
Installation
============
- www.odoo.com/documentation/16.0/setup/install.html
- Install our custom addon
License
-------
General Public License, Version 3 (LGPL v3).
(https://www.odoo.com/documentation/user/16.0/legal/licenses/licenses.html)
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
* Developer:
(V16) Afra M P @cybrosys
Contacts
--------
* Mail Contact : odoo@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
==========
This module is maintained by Cybrosys Technologies.
For support and more information, please visit https://www.cybrosys.com
Further information
===================
HTML Description: `<static/description/index.html>`__

22
whatsapp_chat_layout/__init__.py

@ -0,0 +1,22 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import models

57
whatsapp_chat_layout/__manifest__.py

@ -0,0 +1,57 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
{
'name': 'Whatsapp Chat Layout in Odoo Discuss',
'version': '16.0.1.0.0',
'summary': 'Redesigned the discuss module into whatsapp chat layout',
'description': 'Odoo discuss with whatsapp view',
'category': 'Discuss',
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': "https://www.cybrosys.com",
'license': 'LGPL-3',
'depends': ['base', 'mail', 'base_setup'],
'data': [
'views/res_config_settings.xml'
],
'assets': {
'web.assets_backend': [
'whatsapp_chat_layout/static/src/css/discuss.css',
'whatsapp_chat_layout/static/src/css/thread.css',
'whatsapp_chat_layout/static/src/css/color.css',
'whatsapp_chat_layout/static/src/js/discuss_sidebar.js',
'whatsapp_chat_layout/static/src/js/discuss_container.js',
'whatsapp_chat_layout/static/src/xml/discuss_sidebar.xml',
'whatsapp_chat_layout/static/src/xml/discuss_sidebar_category.xml',
'whatsapp_chat_layout/static/src/xml/discuss_sidebar_mailbox.xml',
'whatsapp_chat_layout/static/src/xml/composer.xml'
],
},
'images': [
'static/description/icon.png',
'static/description/banner.png'
],
'installable': True,
'auto_install': False,
'application': False,
}

6
whatsapp_chat_layout/doc/RELEASE_NOTES.md

@ -0,0 +1,6 @@
## Module <whatsapp_chat_layout>
#### 22.03.2023
#### Version 16.0.1.0.0
#### ADD
- Initial commit for Whatsapp Chat Layout in Odoo Discuss

24
whatsapp_chat_layout/models/__init__.py

@ -0,0 +1,24 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from . import res_users
from . import res_config_settings
from . import res_company

30
whatsapp_chat_layout/models/res_company.py

@ -0,0 +1,30 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ResCompany(models.Model):
"""Inherit the model res_company to store the image"""
_inherit = 'res.company'
background_image = fields.Binary(string="Background Image", attachment=True,
help='Provide background image')

50
whatsapp_chat_layout/models/res_config_settings.py

@ -0,0 +1,50 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import fields, models
class ResConfigSettings(models.TransientModel):
"""Inherit the model res_config_settings to add fields"""
_inherit = 'res.config.settings'
background_color = fields.Char(string='Background Color',
config_parameter='base_setup.background_color',
default='#FFFFFF',
help='Select discuss background color')
layout_color = fields.Char(string='Layout Color',
config_parameter='base_setup.layout_color',
default='#3a8180',
help='select discuss layout color')
chat_background = fields.Binary(string="Background Image",
related='company_id.background_image',
readonly=False,
help='Add background image for discuss')
def get_color(self):
"""Function to return values into js"""
colors = {'background_color': self.env[
'ir.config_parameter'].sudo().get_param(
'base_setup.background_color'), 'layout_color': self.env[
'ir.config_parameter'].sudo().get_param(
'base_setup.layout_color'),
'background_image': self.env.user.company_id.background_image}
return colors

32
whatsapp_chat_layout/models/res_users.py

@ -0,0 +1,32 @@
# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Afra MP (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, models
class ResUsers(models.Model):
"""Inherit the model res_users to add a function to call rpc query in js"""
_inherit = 'res.users'
@api.model
def get_user_image(self):
"""function to get current user image and return in js"""
return self.env.user.partner_id.image_1920

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 589 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 967 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 88 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 81 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 79 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 92 KiB

BIN
whatsapp_chat_layout/static/description/assets/modules/5.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 82 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 119 KiB

BIN
whatsapp_chat_layout/static/description/assets/screenshots/10.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 192 KiB

BIN
whatsapp_chat_layout/static/description/assets/screenshots/11.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 664 KiB

BIN
whatsapp_chat_layout/static/description/assets/screenshots/12.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 527 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 131 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 122 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 204 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 135 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 211 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 160 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 91 KiB

BIN
whatsapp_chat_layout/static/description/assets/screenshots/9.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 128 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 489 KiB

BIN
whatsapp_chat_layout/static/description/banner.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 86 KiB

BIN
whatsapp_chat_layout/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

573
whatsapp_chat_layout/static/description/index.html

@ -0,0 +1,573 @@
<div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;">
<!-- TITLE BAR -->
<div class="d-flex align-items-center justify-content-between"
style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;">
<img src="assets/misc/cybrosys-logo.png" width="42" height="42" style="width: 42px; height: 42px;"/>
<div>
<div
style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"
class="mr-2">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="color: #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 -->
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12">
<!-- APP HERO -->
<h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;">
Whatsapp Chat Layout in Odoo Discuss</h1>
<p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">Detailed Whatsapp Chat Layout in Odoo Discuss View.</p>
<!-- END OF APP HERO -->
<img src="assets/screenshots/hero.gif" class="img-responsive"
style="width: 100%; margin-left: auto; margin-right: auto;"/>
</div>
</div>
</div>
</div>
<!-- NAVIGATION SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/compass.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Explore This
Module</h2>
</div>
<div class="row my-4" style="font-family: 'Montserrat', sans-serif;">
<div class="col-sm-12 col-md-6 my-3">
<a href="#overview">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">Learn more about this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#features">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View features of this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
<div class="col-sm-12 col-md-6 my-3">
<a href="#screenshots">
<div class="d-flex justify-content-between align-items-center"
style="background-color: #f5f5f5; padding: 30px; width: 100%;">
<div>
<span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span>
<span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33; display: block;">View screenshots for this module</span>
</div>
<img src="assets/misc/right-arrow.png" width="36" height="36"/>
</div>
</a>
</div>
</div>
<!-- END OF NAVIGATION SECTION -->
<!-- OVERVIEW SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pie-chart.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Overview
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 py-4">
Whatsapp Chat Layout in Odoo Discuss module Redesigned the discuss module into whatsapp chat layout.User can change the
background color and layout color of the discuss module. And also set background image.
</div>
</div>
<!-- END OF OVERVIEW SECTION -->
<!-- FEATURES SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/features.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Features
</h2>
</div>
<div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;">
<div class="col-sm-12 col-md-6">
<div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px">
<img src="assets/misc/check-box.png" class="mr-2"/>
<span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Dynamically change background and Layout color.</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;">Dynamically change background image.</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;">Current user chat view in left side.</span>
</div>
<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;">Easy to Use and Manage.</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;">
Available in Odoo 16.0 Community and Enterprise.</span>
</div>
</div>
</div>
<!-- END OF FEATURES SECTION -->
<!-- SCREENSHOTS SECTION -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="screenshots">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/pictures.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Screenshots
</h2>
</div>
<div class="row">
<div class="col-sm-12">
<div style="display: block; margin: 30px auto;">
<h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Rearranged the sidebar and the Chatter.
</h3>
<img src="assets/screenshots/1.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;">Click Mail icon to view the inbox,starred and history messages.
</h3>
<img src="assets/screenshots/2.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;">Click Chat icon to view the Direct messages.
</h3>
<img src="assets/screenshots/3.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;">Click Channel icon to view the Channels.
</h3>
<img src="assets/screenshots/4.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;">Click Start a meeting icon to start a group video call.
</h3>
<img src="assets/screenshots/5.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;">Current user chat view in left side.
</h3>
<img src="assets/screenshots/6.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;">
Change background color and layout color in configuration settings.
</h3>
<img src="assets/screenshots/7.png" class="img-thumbnail">
<img src="assets/screenshots/8.png" class="img-thumbnail">
<img src="assets/screenshots/9.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;">
Change background image in configuration settings.
</h3>
<img src="assets/screenshots/10.png" class="img-thumbnail">
<img src="assets/screenshots/11.png" class="img-thumbnail">
<img src="assets/screenshots/12.png" class="img-thumbnail">
</div>
</div>
</div>
<!-- END OF SCREENSHOTS SECTION -->
<!-- RELATED PRODUCTS -->
<div class="row">
<div class="col-sm-12 col-md-12-col-lg-2">
<h2 style="font-weight: bold; color: #3D3D4E;">Related Modules</h2>
<p style="color: #777783;">Explore our related modules</p>
<hr />
</div>
<div class="col-sm-12">
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner" style="padding: 30px;">
<div class="carousel-item" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/whatsapp_redirect/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" 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/16.0/hr_payroll_community/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" 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/16.0/crm_dashboard/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" src="assets/modules/3.png">
</div>
</a>
</div>
</div>
<div class="carousel-item active" style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/16.0/export_stockinfo_xls/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" 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/16.0/sale_discount_total/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" 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/16.0/fleet_rental/" target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block" style="border-radius: 0px;" 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="width:35px; color:#000"> <span
class="carousel-control-prev-icon"><i class="fa fa-chevron-left" style="font-size:24px"></i></span>
</a> <a class="carousel-control-next" href="#demo1" data-slide="next" style="width:35px; color:#000">
<span class="carousel-control-next-icon"><i class="fa fa-chevron-right" style="font-size:24px"></i></span>
</a>
</div>
</div>
</div>
<!-- END OF RELATED PRODUCTS -->
<!-- OUR SERVICES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/star.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our Services
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Customization</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Support</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Hire
Odoo
Developer</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #54a0ff !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Integration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Migration</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Consultancy</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Implementation</h6>
</div>
<div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4">
<div class="d-flex justify-content-center align-items-center mx-3 my-3"
style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;">
<img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px">
</div>
<h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;">
Odoo
Licensing Consultancy</h6>
</div>
</div>
</div>
<!-- END OF END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/corporate.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our
Industries
</h2>
</div>
<div class="container my-5">
<div class="row">
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Trading
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easily procure
and
sell your products</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
POS
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Easy
configuration
and convivial experience</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/education-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Education
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
A platform for
educational management</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Manufacturing
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Plan, track and
schedule your operations</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
E-commerce &amp; Website
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Mobile
friendly,
awe-inspiring product pages</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Service Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Keep track of
services and invoice</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Restaurant
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
Run your bar or
restaurant methodically</p>
</div>
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;">
<img src="assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px">
<h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;">
Hotel Management
</h5>
<p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;">
An
all-inclusive
hotel management application</p>
</div>
</div>
</div>
</div>
<!-- END OF END OF OUR INDUSTRIES -->
<!-- SUPPORT -->
<div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;">
<div class="d-flex justify-content-center align-items-center mr-2"
style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;">
<img src="assets/misc/customer-support.png"/>
</div>
<h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Support
</h2>
</div>
<div class="container mt-5">
<div class="row">
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/support.png" height="48" width="48" style="width: 42px; height: 42px;"/>
</div>
<div>
<h4>Need Help?</h4>
<p style="line-height: 100%;">Got questions or need help? Get in touch.</p>
<a href="mailto:odoo@cybrosys.com">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">
odoo@cybrosys.com</p>
</a>
</div>
</div>
</div>
<div class="col-sm-12 col-md-6">
<div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;">
<div class="mr-4 d-flex justify-content-center align-items-center"
style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;">
<img src="assets/misc/whatsapp.png" height="52" width="52" style="width: 52px; height: 52px;"/>
</div>
<div>
<h4>WhatsApp</h4>
<p style="line-height: 100%;">Say hi to us on WhatsApp!</p>
<a href="https://api.whatsapp.com/send?phone=918606827707">
<p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">+91 86068
27707</p>
</a>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-sm-12 my-5 d-flex justify-content-center align-items-center">
<img src="assets/misc/logo.png" width="144" height="31"
style="width:144px; height: 31px; margin-top: 40px;"/>
</div>
</div>
</div>
<!-- END OF SUPPORT -->

4
whatsapp_chat_layout/static/src/css/color.css

@ -0,0 +1,4 @@
:root{
--background-color: #ffffff;
--layout-color: #3a8180;
}

50
whatsapp_chat_layout/static/src/css/discuss.css

@ -0,0 +1,50 @@
.o_DiscussSidebar.o_Discuss_sidebar.flex-shrink-0.h-100.pt-3.border-end.bg-light {
width: 400px;
}
.o_DiscussSidebar_startAMeetingButton {
font-size: 24px;
width: 55px;
height: 65px;
background-color: #eeedee!important;
color: #979797;
border-color: #eeedee;
margin-left: 10px;
padding-top: 18px;
}
.header {
margin-left: 200px;
}
.text-700 {
color: gray!important;
}
.o_DiscussSidebarCategory_header.d-flex.align-items-center.my-1 {
height: 74px;
background-color: var(--layout-color) !important;
}
button.o_DiscussSidebarCategory_title{
color: white!important;
}
i.o_DiscussSidebarCategory_command.o_DiscussSidebarCategory_commandAdd.fa.fa-plus.btn.p-0.text-start.text-700.opacity-100-hover.opacity-75.ms-1 {
color: white!important;
}
i.o_DiscussSidebarCategory_command.o_DiscussSidebarCategory_commandView.fa.fa-cog.btn.p-0.text-start.text-700.opacity-100-hover.opacity-75 {
color: white!important;
}
.o_DiscussSidebar.o_Discuss_sidebar.flex-shrink-0 {
background-color: #FFFFFF!important;
}
.o_ThreadIcon.d-flex.justify-content-center.flex-shrink-0.o_DiscussSidebarMailbox_item.ms-4.me-2 {
border-radius: 50%;
font-size: 34px;
padding-right: 15px;
color: var(--layout-color) !important;
}
.o_DiscussSidebarMailbox_item.o_DiscussSidebarMailbox_name.me-2.text-truncate {
color: black;
font-size: 17px;
}

49
whatsapp_chat_layout/static/src/css/thread.css

@ -0,0 +1,49 @@
.o_ThreadViewTopbar.d-flex.flex-shrink-0.w-100.px-3.bg-100.border-bottom {
height: 66px;
background-color: #eeedee!important;
}
.o_MessageList.bg-view.d-flex.flex-column.overflow-auto.o_ThreadView_messageList.flex-grow-1.o-empty.align-items-center.justify-content-center {
background-color: var(--background-color) !important;
background-image: var(--background-image) !important;
background-repeat:no-repeat;
background-size:cover;
}
.o_MessageList.bg-view.d-flex.flex-column.overflow-auto.o_ThreadView_messageList.flex-grow-1.pb-4{
background-color: var(--background-color) !important;
background-image: var(--background-image) !important;
background-repeat:no-repeat;
background-size:cover;
}
.o_Composer.o-has-current-partner-avatar.pe-3.ps-1.o-has-footer{
background-color: #eeedee!important;
height: 85px;
padding-top: 15px!important;
}
button.o_Composer_toolButton{
font-size: 25px;
background-color: #eeedee;
}
.o_Composer_toolButtons.d-flex.py-1.border-top.bg-view.o-composer-has-current-partner-avatar.o-composer-is-compact.border-bottom {
height: 50px;
background-color: #eeedee!important;
}
button.o_Composer_actionButton.o_Composer_button.o_Composer_buttonSend.fa.fa-paper-plane.o-last.o-composer-is-compact.border-start-0.o-has-current-partner-avatar.rounded-0.rounded-end-3 {
background-color: var(--layout-color) !important;
color: white;
}
.o_Message.position-relative.py-1.o-discussion.o-currentAuthor.mt-1.px-3.o_MessageList_item.o_MessageList_message {
display: flex;
flex-direction: row-reverse;
justify-content: end;
}
.o_Message.position-relative.py-1.o-discussion.o-squashed.pt-1.o-currentAuthor.px-3.o_MessageList_item.o_MessageList_message {
display: flex;
flex-direction: row-reverse;
justify-content: end;
}
.text-break {
word-break: inherit!important;
}

30
whatsapp_chat_layout/static/src/js/discuss_container.js

@ -0,0 +1,30 @@
/** @odoo-module */
/**
* This file is used to hide the set color to discuss model.
*/
import { DiscussContainer} from '@mail/components/discuss_container/discuss_container';
import { patch} from "@web/core/utils/patch";
var rpc = require('web.rpc');
const {onWillStart} = owl;
patch(DiscussContainer.prototype, 'discuss_container// model: "mail",ord-patch', {
setup() {
this._super();
onWillStart(async () => {
await rpc.query({ //Call rpc to get color value.
model: "res.config.settings",
method: "get_color",
args: [0],
}).then(function(result) {
if (result.background_color !== false){
document.documentElement.style.setProperty("--background-color",result.background_color);
}//set discuss background color
if (result.layout_color !== false){
document.documentElement.style.setProperty("--layout-color",result.layout_color);
}// set discuss layout color
if (result.background_image !== false){
document.documentElement.style.setProperty("--background-image",'url(data:image/png;base64,'+result.background_image+')');
}// set discuss background image
});
});
}
});

38
whatsapp_chat_layout/static/src/js/discuss_sidebar.js

@ -0,0 +1,38 @@
/** @odoo-module **/
import { patch } from "@web/core/utils/patch";
import { DiscussSidebar } from "@mail/components/discuss_sidebar/discuss_sidebar";
const { onMounted, useRef } = owl;
var rpc = require('web.rpc');
patch(DiscussSidebar.prototype, 'discuss_sidebar// model: "res.users",ord-patch', {
setup() {
this._super.apply();
this.root = useRef("root")
onMounted(this.sidebar)
},
sidebar(){
var self = this
rpc.query({//Call rpc to get current user image.
model: "res.users",
method: "get_user_image",
}).then(function(result) {
let image = document.createElement('div')
image.innerHTML = '<img class="o_Composer_currentPartner rounded-circle o_object_fit_cover"style="margin-top: 21px;margin-left: 10px;width: 45px;height: 45px;"src="data:image/png;base64,' + result + '">'
self.root.el.querySelector('#img').appendChild(image);
});
},
_onClickMail(ev) {// Click function of mail button
this.root.el.querySelector('.mail').classList.remove("d-none");
this.root.el.querySelector('.channel').classList.add("d-none");
this.root.el.querySelector('.chat').classList.add("d-none");
},
_onClickChat(ev) {// Click function of chat button
this.root.el.querySelector('.chat').classList.remove("d-none");
this.root.el.querySelector('.mail').classList.add("d-none");
this.root.el.querySelector('.channel').classList.add("d-none");
},
_onClickChannel(ev) {// Click function of channel button
this.root.el.querySelector('.channel').classList.remove("d-none");
this.root.el.querySelector('.mail').classList.add("d-none");
this.root.el.querySelector('.chat').classList.add("d-none");
},
});

106
whatsapp_chat_layout/static/src/xml/composer.xml

@ -0,0 +1,106 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--Rearranged the Composer and Composer.actionButtons templates-->
<templates id="template" xml:space="preserve">
<t name="mail.ComposerAdvanced"
t-inherit="mail.Composer"
t-inherit-mode="extension"
owl="1">
<xpath expr="//div[hasclass('o_Composer_coreMain')]" position="replace">
<div
class="o_Composer_coreMain d-flex flex-nowrap align-items-start flex-grow-1"
t-att-class="{
'o-composer-is-compact': composerView.isCompact,
'flex-column border rounded-3 bg-view': !composerView.isCompact,
}"
>
<div class="o_Composer_toolButtons d-flex py-1 border-top bg-view"
t-att-class="{
'o-composer-has-current-partner-avatar': composerView.hasCurrentPartnerAvatar,
'o-composer-is-compact border-bottom': composerView.isCompact,
'flex-row flex-grow-1 justify-content-between': !composerView.isCompact,
}">
<div class="o_Composer_primaryToolButtons d-flex align-items-center"
t-att-class="{ 'o-composer-is-compact px-2': composerView.isCompact, 'flex-column': composerView.messageViewInEditing and composerView.messageViewInEditing.isInChatWindow }">
<button class="o_Composer_button o_Composer_buttonEmojis o_Composer_toolButton btn btn-light border-0 rounded-pill"
t-att-class="{
'o-open bg-200': composerView.emojisPopoverView,
'o-isDeviceSmall': messaging.device.isSmall,
}"
t-attf-class="{{ composerView.messageViewInEditing ? 'my-1' : 'mx-1' }}"
t-att-aria-expanded="composerView.emojisPopoverView ? 'true' : 'false'"
t-on-keydown="composerView.onKeydownButtonEmojis"
t-on-click="composerView.onClickButtonEmojis"
t-ref="buttonEmojis"
>
<i class="fa fa-smile-o overflow-visible" role="img" aria-label="Emojis"/>
</button>
<button class="o_Composer_button o_Composer_buttonAttachment o_Composer_toolButton btn btn-light fa fa-paperclip border-0 rounded-pill"
t-att-class="{ 'o-isDeviceSmall': messaging.device.isSmall }"
t-attf-class="{{ composerView.messageViewInEditing ? 'my-1' : 'mx-1' }}"
title="Add attachment" aria-label="Add attachment" type="button"
t-on-click="composerView.onClickAddAttachment"/>
</div>
<t t-if="composerView.isExpandable">
<div class="o_Composer_secondaryToolButtons">
<button class="o_Composer_button o_Composer_buttonFullComposer o_Composer_toolButton btn btn-light fa fa-expand mx-1 border-0 rounded-pill bg-view"
t-att-class="{ 'o-isDeviceSmall': messaging.device.isSmall }"
title="Full composer" aria-label="Full composer" type="button"
t-on-click="composerView.onClickFullComposer"/>
</div>
</t>
</div>
<ComposerTextInput
className="'o_Composer_textInput flex-grow-1 align-self-stretch'"
classNameObj="{
'o-composer-is-compact': composerView.isCompact,
'rounded-3': !composerView.isCompact,
'o_Composer_textInput-mobile': messaging.device.isSmall,
'o-has-current-partner-avatar': composerView.hasCurrentPartnerAvatar,
'rounded-start-3': composerView.isCompact and composerView.hasCurrentPartnerAvatar,
}"
record="composerView"
t-key="composerView.localId"
/>
<div class="o_Composer_buttons d-flex align-items-stretch align-self-stretch flex-shrink-0"
t-att-class="{ 'o-composer-is-compact': composerView.isCompact, 'h-auto w-100 px-3': !composerView.isCompact, 'o-isDeviceSmall': messaging.device.isSmall, 'o-messaging-in-editing': composerView and composerView.messageViewInEditing, 'border-end': composerView.messageViewInEditing and !composerView.hasCurrentPartnerAvatar }">
<t t-if="composerView.isCompact">
<t t-call="mail.Composer.actionButtons"/>
</t>
</div>
</div>
</xpath>
</t>
<t name="mail.Composer.actionButtonsAdvanced"
t-inherit="mail.Composer.actionButtons"
t-inherit-mode="extension"
owl="1">
<xpath expr="//div[hasclass('o_Composer_actionButtons')]" position="replace">
<div class="o_Composer_actionButtons"
t-att-class="{ 'o-composer-is-compact d-flex': composerView.isCompact, 'mt-2': !composerView.isCompact }">
<t t-if="composerView.hasSendButton">
<button class="o_Composer_actionButton o_Composer_button o_Composer_buttonSend fa fa-paper-plane"
t-att-class="{
'o-last': !composerView.hasDiscardButton,
'o-composer-is-compact border-start-0': composerView.isCompact,
'o-has-current-partner-avatar': composerView.hasCurrentPartnerAvatar,
'rounded-0 rounded-end-3': !composerView.hasDiscardButton and composerView.hasCurrentPartnerAvatar and composerView.isCompact,
}"
t-att-disabled="!composerView.composer.canPostMessage ? 'disabled' : ''"
type="button"
t-on-click="composerView.onClickSend">
<t t-if="!messaging.device.isSmall"><t t-esc="composerView.sendButtonText"/></t>
<t t-else=""><i class="fa fa-paper-plane-o"/></t>
</button>
</t>
<t t-if="composerView.hasDiscardButton">
<button class="o_Composer_actionButton o-last o_Composer_button o_Composer_buttonDiscard btn btn-secondary"
t-att-class="{ 'o-composer-is-compact border-start-0': composerView.isCompact, 'o-has-current-partner-avatar': composerView.hasCurrentPartnerAvatar, 'rounded-0 rounded-end-3': composerView.hasCurrentPartnerAvatar and composerView.isCompact }"
type="button" t-on-click="composerView.onClickDiscard">
Discard
</button>
</t>
</div>
</xpath>
</t>
</templates>

51
whatsapp_chat_layout/static/src/xml/discuss_sidebar.xml

@ -0,0 +1,51 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--Rearranged the DiscussSidebar template-->
<templates id="template" xml:space="preserve">
<t name="mail.DiscussSidebarAdvanced"
t-inherit="mail.DiscussSidebar"
t-inherit-mode="extension"
owl="1">
<xpath expr="//div[hasclass('o_DiscussSidebar')]" position="replace">
<div name="root" class="o_DiscussSidebar" t-attf-class="{{ className }}" t-ref="root">
<div style="background-color: #eeedee; margin-top: -23px;">
<div id="img" style="margin-bottom: -53px;"/>
<div class="header d-flex justify-content-center">
<div class="o_DiscussSidebar_startAMeetingButton opacity-75 fa fa-inbox" title="Mail"
id="mail" t-on-click="_onClickMail"
/>
<div class="o_DiscussSidebar_startAMeetingButton fa fa-comments-o" title="Chat"
id="chat" t-on-click="_onClickChat"
/>
<div class="o_DiscussSidebar_startAMeetingButton fa fa-users" title="Channel"
id="channel" t-on-click="_onClickChannel"
/>
<div class="o_DiscussSidebar_startAMeetingButton fa fa-video-camera" title="Start a meeting"
t-on-click="discussView.onClickStartAMeetingButton"
/>
</div>
</div>
<div class="o_DiscussSidebar_category o_DiscussSidebar_categoryMailbox d-flex flex-column flex-grow-0 mail d-none">
<DiscussSidebarMailbox record="discussView.inboxView"/>
<DiscussSidebarMailbox record="discussView.starredView"/>
<DiscussSidebarMailbox record="discussView.historyView"/>
</div>
<div class="channel d-none">
<DiscussSidebarCategory
t-if="discussView.discuss.categoryChannel"
className="'o_DiscussSidebar_category o_DiscussSidebar_categoryChannel'"
record="discussView.discuss.categoryChannel"
/>
</div>
<div class="chat">
<t name="beforeCategoryChat"/>
<DiscussSidebarCategory
t-if="discussView.discuss.categoryChat"
className="'o_DiscussSidebar_category o_DiscussSidebar_categoryChat'"
record="discussView.discuss.categoryChat"
/>
</div>
</div>
</xpath>
</t>
</templates>

38
whatsapp_chat_layout/static/src/xml/discuss_sidebar_category.xml

@ -0,0 +1,38 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--Rearranged the DiscussSidebarCategory template-->
<templates id="template" xml:space="preserve">
<t name="mail.DiscussSidebarCategoryAdvanced"
t-inherit="mail.DiscussSidebarCategory"
t-inherit-mode="extension"
owl="1">
<xpath expr="//div[hasclass('o_DiscussSidebarCategory_header')]" position="replace">
<div class="o_DiscussSidebarCategory_header d-flex align-items-center my-1">
<button t-attf-class="o_DiscussSidebarCategory_title o_DiscussSidebarCategory_headerItem d-flex align-items-baseline mx-1 {{ o_DiscussSidebarCategory_hoverItem }}"
t-on-click="category.onClick">
<i class="o_DiscussSidebarCategory_titleIcon small"
t-att-class="category.isOpen ? 'fa fa-chevron-down' : 'fa fa-chevron-right'"/>
<span class="o_DiscussSidebarCategory_titleText text-uppercase fw-bolder"
style="font-size: 21px;font-family: ui-serif;">
<t t-esc="category.name"/></span>
</button>
<div class="o_DiscussSidebarCategory_headerItem flex-grow-1"/>
<div class="o_DiscussSidebarCategory_commands o_DiscussSidebarCategory_headerItem d-flex me-3">
<t t-if="category.hasViewCommand">
<i t-attf-class="o_DiscussSidebarCategory_command o_DiscussSidebarCategory_commandView fa fa-cog {{ o_DiscussSidebarCategory_hoverItem }}"
title="View or join channels" t-on-click="category.onClickCommandView" role="img"/>
</t>
<t t-if="category.hasAddCommand and category.isOpen">
<i t-attf-class="o_DiscussSidebarCategory_command o_DiscussSidebarCategory_commandAdd fa fa-plus {{ o_DiscussSidebarCategory_hoverItem }} ms-1"
t-on-click="category.onClickCommandAdd" t-att-title="category.commandAddTitleText"
role="img"/>
</t>
</div>
<t t-if="!category.isOpen and category.counter > 0">
<div class="o_DiscussSidebarCategory_counter o_DiscussSidebarCategory_headerItem badge rounded-pill text-bg-primary me-3">
<t t-esc="category.counter"/>
</div>
</t>
</div>
</xpath>
</t>
</templates>

33
whatsapp_chat_layout/static/src/xml/discuss_sidebar_mailbox.xml

@ -0,0 +1,33 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--Rearranged the DiscussSidebarMailbox template-->
<templates id="template" xml:space="preserve">
<t name="mail.DiscussSidebarMailboxAdvanced"
t-inherit="mail.DiscussSidebarMailbox"
t-inherit-mode="extension"
owl="1">
<xpath expr="//button[hasclass('o_DiscussSidebarMailbox')]" position="replace">
<button class="o_DiscussSidebarMailbox btn d-flex align-items-center py-1 px-0 border-0 rounded-0 fw-normal text-dark"
t-att-class="{
'bg-100': discussSidebarMailboxView.mailbox.thread !== messaging.discuss.activeThread,
'o-active bg-200': discussSidebarMailboxView.mailbox.thread === messaging.discuss.activeThread,
'o-starred-box': discussSidebarMailboxView.mailbox === messaging.starred,
}" t-attf-class="{{ className }}" t-on-click="discussSidebarMailboxView.mailbox.thread.onClick"
t-att-data-mailbox-local-id="discussSidebarMailboxView.mailbox.localId"
t-att-data-mailbox-name="discussSidebarMailboxView.mailbox.name"
t-ref="root"
>
<ThreadIcon className="'o_DiscussSidebarMailbox_item ms-4 me-2'"
thread="discussSidebarMailboxView.mailbox.thread"/>
<div class="o_DiscussSidebarMailbox_item o_DiscussSidebarMailbox_name me-2 text-truncate">
<t t-esc="discussSidebarMailboxView.mailbox.name"/>
</div>
<div t-attf-class="o_DiscussSidebarMailbox_item flex-grow-1 {{ discussSidebarMailboxView.mailbox.counter === 0 ? 'me-3': '' }}"/>
<t t-if="discussSidebarMailboxView.mailbox.counter > 0">
<div t-attf-class="o_DiscussSidebarMailbox_counter o_DiscussSidebarMailbox_item badge rounded-pill {{ discussSidebarMailboxView.mailbox === messaging.starred ? 'bg-400 text-light' : 'text-bg-primary' }} ms-1 me-3">
<t t-esc="discussSidebarMailboxView.mailbox.counter"/>
</div>
</t>
</button>
</xpath>
</t>
</templates>

37
whatsapp_chat_layout/views/res_config_settings.xml

@ -0,0 +1,37 @@
<?xml version="1.0" encoding="UTF-8"?>
<!--Adding color and image field in settings-->
<odoo>
<record id="res_config_settings_view_form" model="ir.ui.view">
<field name="name">res.config.settings.view.form.inherit.whatsapp.chat.layout</field>
<field name="model">res.config.settings</field>
<field name="priority" eval="0"/>
<field name="inherit_id" ref="base.res_config_settings_view_form"/>
<field name="arch" type="xml">
<xpath expr="//div[@id='activities_setting']" position="after">
<div class="col-12 col-lg-6 o_setting_box">
<div class="o_setting_right_pane">
<label for="background_color"/>
<div class="text-muted">
Select the Background color for discuss.
</div>
<field name="background_color" widget="color"/>
</div>
<div class="o_setting_right_pane">
<label for="layout_color"/>
<div class="text-muted">
Select the Layout color for discuss.
</div>
<field name="layout_color" widget="color"/>
</div>
<div class="o_setting_right_pane">
<label for="chat_background" class="ml-4" required="1"/>
<div class="text-muted">
Select the Background image for discuss.
</div>
<field name="chat_background" widget="image"/>
</div>
</div>
</xpath>
</field>
</record>
</odoo>
Loading…
Cancel
Save