Browse Source

Dec 04 : [ADD] Initial Commit 'voice_note_in_chatter'

pull/254/merge
RisvanaCybro 1 year ago
parent
commit
8120079205
  1. 46
      voice_note_in_chatter/README.rst
  2. 19
      voice_note_in_chatter/__init__.py
  3. 48
      voice_note_in_chatter/__manifest__.py
  4. 5
      voice_note_in_chatter/doc/RELEASE_NOTES.md
  5. BIN
      voice_note_in_chatter/static/description/assets/icons/check.png
  6. BIN
      voice_note_in_chatter/static/description/assets/icons/chevron.png
  7. BIN
      voice_note_in_chatter/static/description/assets/icons/cogs.png
  8. BIN
      voice_note_in_chatter/static/description/assets/icons/consultation.png
  9. BIN
      voice_note_in_chatter/static/description/assets/icons/ecom-black.png
  10. BIN
      voice_note_in_chatter/static/description/assets/icons/education-black.png
  11. BIN
      voice_note_in_chatter/static/description/assets/icons/hotel-black.png
  12. BIN
      voice_note_in_chatter/static/description/assets/icons/license.png
  13. BIN
      voice_note_in_chatter/static/description/assets/icons/lifebuoy.png
  14. BIN
      voice_note_in_chatter/static/description/assets/icons/logo.png
  15. BIN
      voice_note_in_chatter/static/description/assets/icons/manufacturing-black.png
  16. BIN
      voice_note_in_chatter/static/description/assets/icons/pos-black.png
  17. BIN
      voice_note_in_chatter/static/description/assets/icons/puzzle.png
  18. BIN
      voice_note_in_chatter/static/description/assets/icons/restaurant-black.png
  19. BIN
      voice_note_in_chatter/static/description/assets/icons/service-black.png
  20. BIN
      voice_note_in_chatter/static/description/assets/icons/trading-black.png
  21. BIN
      voice_note_in_chatter/static/description/assets/icons/training.png
  22. BIN
      voice_note_in_chatter/static/description/assets/icons/update.png
  23. BIN
      voice_note_in_chatter/static/description/assets/icons/user.png
  24. BIN
      voice_note_in_chatter/static/description/assets/icons/wrench.png
  25. BIN
      voice_note_in_chatter/static/description/assets/modules/1.png
  26. BIN
      voice_note_in_chatter/static/description/assets/modules/2.png
  27. BIN
      voice_note_in_chatter/static/description/assets/modules/3.jpg
  28. BIN
      voice_note_in_chatter/static/description/assets/modules/4.png
  29. BIN
      voice_note_in_chatter/static/description/assets/modules/5.png
  30. BIN
      voice_note_in_chatter/static/description/assets/modules/6.jpg
  31. BIN
      voice_note_in_chatter/static/description/assets/screenshots/hero.gif
  32. BIN
      voice_note_in_chatter/static/description/assets/screenshots/voice_1.png
  33. BIN
      voice_note_in_chatter/static/description/assets/screenshots/voice_2.png
  34. BIN
      voice_note_in_chatter/static/description/assets/screenshots/voice_3.png
  35. BIN
      voice_note_in_chatter/static/description/assets/screenshots/voice_4.png
  36. BIN
      voice_note_in_chatter/static/description/banner.jpg
  37. BIN
      voice_note_in_chatter/static/description/icon.png
  38. 586
      voice_note_in_chatter/static/description/index.html
  39. 25
      voice_note_in_chatter/static/src/js/attachment_card.js
  40. 17
      voice_note_in_chatter/static/src/js/record_voice_component.js
  41. 28
      voice_note_in_chatter/static/src/js/record_voice_model.js
  42. 105
      voice_note_in_chatter/static/src/js/voice_in_odoo.js
  43. 101
      voice_note_in_chatter/static/src/xml/voice_in_odoo.xml

46
voice_note_in_chatter/README.rst

@ -0,0 +1,46 @@
.. 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
Voice Message In Odoo
=====================
This module allows a option to record voice and send voice messages in chatter.
Configuration
=============
* No Additional configuration is needed.
License
=======
GNU AFFERO GENERAL PUBLIC LICENSE, Version 3 (AGPLv3)
http://www.gnu.org/licenses/agpl-3.0-standalone.html
Company
-------
* `Cybrosys Techno Solutions <https://cybrosys.com/>`__
Credits
-------
Developer: (V15) Farhana Jahan PT , 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>`__

19
voice_note_in_chatter/__init__.py

@ -0,0 +1,19 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Farhana Jahan PT (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.
################################################################################

48
voice_note_in_chatter/__manifest__.py

@ -0,0 +1,48 @@
# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Farhana Jahan PT (odoo@cybrosys.com)
#
# You can modify it under the terms of the GNU AFFERO
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
#
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
# (AGPL v3) along with this program.
################################################################################
{
'name': 'Voice Message In Odoo',
'version': '15.0.1.0.0',
'category': 'Discuss',
'summary': 'Send voice message in Chatter.',
'description': "This module provides an option to record voice and "
"send voice messages in Chatter.",
'author': 'Cybrosys Techno Solutions',
'company': 'Cybrosys Techno Solutions',
'maintainer': 'Cybrosys Techno Solutions',
'website': 'https://www.cybrosys.com',
'depends': ['base', 'mail'],
'assets': {
'web.assets_qweb': [
'/voice_note_in_chatter/static/src/xml/voice_in_odoo.xml',
],
'web.assets_backend': [
'voice_note_in_chatter/static/src/js/record_voice_component.js',
'voice_note_in_chatter/static/src/js/voice_in_odoo.js',
'voice_note_in_chatter/static/src/js/record_voice_model.js',
'voice_note_in_chatter/static/src/js/attachment_card.js',
]
},
'images': ['static/description/banner.jpg'],
'license': 'AGPL-3',
'installable': True,
'auto_install': False,
'application': False,
}

5
voice_note_in_chatter/doc/RELEASE_NOTES.md

@ -0,0 +1,5 @@
## Module <voice_note_in_chatter>
#### 01.11.2023
#### Version 15.0.1.0.0
#### ADD
-Initial Commit for Voice Message In Odoo

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 310 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 576 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 733 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 911 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
voice_note_in_chatter/static/description/assets/icons/logo.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.4 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 673 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 878 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 653 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 905 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 839 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 427 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 627 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 988 B

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 106 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 83 KiB

BIN
voice_note_in_chatter/static/description/assets/modules/3.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 89 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

BIN
voice_note_in_chatter/static/description/assets/modules/6.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 48 KiB

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

Binary file not shown.

After

Width:  |  Height:  |  Size: 73 KiB

BIN
voice_note_in_chatter/static/description/assets/screenshots/voice_1.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 45 KiB

BIN
voice_note_in_chatter/static/description/assets/screenshots/voice_2.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

BIN
voice_note_in_chatter/static/description/assets/screenshots/voice_3.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

BIN
voice_note_in_chatter/static/description/assets/screenshots/voice_4.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
voice_note_in_chatter/static/description/banner.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 111 KiB

BIN
voice_note_in_chatter/static/description/icon.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.5 KiB

586
voice_note_in_chatter/static/description/index.html

@ -0,0 +1,586 @@
<div class="container" style="padding: 1rem !important; margin-bottom: 1rem !important;">
<div class="row">
<div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between"
style="border-bottom: 1px solid #d5d5d5;">
<div class="my-3">
<img src="./assets/icons/logo.png" style="width: auto !important; height: 40px !important;">
</div>
<div class="my-3 d-flex align-items-center">
<div
style="background-color: #7C7BAD !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Community
</div>
<div
style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Enterprise
</div>
<div
style="background-color: #875A7B !important; color: #fff !important; font-weight: 600 !important; padding: 5px 15px 8px !important; margin: 0 5px !important;">
<i class="fa fa-check mr-1"></i>Odoo.sh
</div>
</div>
</div>
</div>
</div>
<div class="container" style="padding: 0rem 1.5rem 4rem !important">
<div class="row" style="height: 900px !important;">
<div class="col-sm-12 col-md-12 col-lg-12"
style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;">
<h1
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important; font-size: 3.5rem !important; text-align: center !important;">
Voice Message In Odoo</h1>
<p
style="font-family: 'Montserrat', sans-serif !important; font-weight: 300 !important; color: #FFFFFF !important; font-size: 1.4rem !important; text-align: center !important;">
Option to Record Voice and Send Voice Messages in Chatter.
</p>
<img src="assets/screenshots/hero.gif" class="img-responsive" width="100%" height="auto" />
</div>
</div>
<div class="row">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-compass mr-2"></i>Explore this module
</h2>
</div>
<div class="col-md-6">
<a href="#overview" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Overview</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
Learn more about this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#features" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Features</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
View features of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
<div class="col-md-6">
<a href="#screenshots" style="text-decoration: none !important;">
<div class="row"
style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;">
<div class="col-8">
<h3
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;">
Screenshots</h3>
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;">
See key screenshots of this module</p>
</div>
<div class="col-4 text-right d-flex justify-content-end align-items-center">
<i class="fa fa-chevron-right" style="color: #714B67 !important;"></i>
</div>
</div>
</a>
</div>
</div>
<div class="row" id="overview">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-pie-chart mr-2"></i>Overview
</h2>
</div>
<div class="col-mg-12 pl-3">
<p
style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;">
In Odoo, we do not have an option to send voice messages. This app will
allow us to record voice. Additionally, we can download this voice. This
app ensures the security of the site, as it will display an alert if
we're using an unsecured site (HTTP). We can only record voice on
secured sites.
</div>
</div>
<div class="row" id="features">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-star mr-2"></i>Features
</h2>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">Added a new icon for recording voice in odoo.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">We can send recorded voice.</h4>
</div>
</div>
<div class="col-md-6 pl-3 py-3 d-flex">
<div>
<img src="assets/icons/check.png">
</div>
<div>
<h4
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">If you're running on unsecured site, an alert will shown, we can not able to record voice in unsecured site(Need HTTPS).</h4>
</div>
</div>
</div>
<div class="row" id="screenshots">
<div class="col-md-12" style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important">
<h2
style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;">
<i class="fa fa-image mr-2"></i>Screenshots
</h2>
</div>
<div class="col-lg-12 my-2">
<h4 class="mt-2"
style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;">
If you're running on unsecured site, an alert will shown, we can
not able to record voice in unsecured site( Need HTTPS ).</h4>
<img src="assets/screenshots/voice_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;">
Here we can record the voice,if we are using HTTPS. The same
button will perform the start and stop function.</h3>
<img src="assets/screenshots/voice_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;">
The recorded voice will send while clicking send button.</h3>
<img src="assets/screenshots/voice_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;">
We can also send voice messages in popup chat in odoo.</h3>
<img src="assets/screenshots/voice_4.png" class="img-thumbnail">
</div>
</div>
</div>
<!-- SUGGESTED PRODUCTS -->
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center"
style="text-align: center; padding: 2.5rem 1rem !important;">
<h2 style="color: #212529 !important;">Suggested Products</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
<div id="demo1" class="row carousel slide" data-ride="carousel">
<!-- The slideshow -->
<div class="carousel-inner">
<div class="carousel-item active" style="min-height:0px">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/email_id_validation/"
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/15.0/autosuggestion_in_discuss/"
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/15.0/mail_to_child_contact/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/3.jpg">
</div>
</a>
</div>
</div>
<div class="carousel-item active"
style="min-height: 198.656px;">
<div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16"
style="float:left">
<a href="https://apps.odoo.com/apps/modules/15.0/auto_daily_weekly_report/"
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/15.0/project_task_timer/"
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/15.0/field_timepicker/"
target="_blank">
<div style="border-radius:10px">
<img class="img img-responsive center-block"
style="border-radius: 0px;"
src="assets/modules/6.jpg">
</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 -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Services</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</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: #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>
</section>
<!-- END OF OUR SERVICES -->
<!-- OUR INDUSTRIES -->
<section class="container" style="margin-top: 6rem !important;">
<div class="row">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Our Industries</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
<div class="col-lg-3">
<div class="my-4 d-flex flex-column justify-content-center"
style="background-color: #f6f8f9 !important; border-radius: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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: 10px; 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>
</section>
<!-- END OF OUR INDUSTRIES -->
<!-- FOOTER -->
<!-- Footer Section -->
<section class="container" style="margin: 5rem auto 2rem;">
<div class="row" style="max-width:1540px;">
<div class="col-lg-12 d-flex flex-column justify-content-center align-items-center">
<h2 style="color: #212529 !important;">Need Help?</h2>
<hr
style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;" />
</div>
</div>
<!-- Contact Cards -->
<div class="row d-flex justify-content-center align-items-center"
style="max-width:1540px; margin: 0 auto 2rem auto;">
<div class="col-lg-12" style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; ">
<div class="row mt-4">
<div class="col-lg-6">
<a href="mailto:odoo@cybrosys.com" target="_blank" class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #4d4d4d; color: #FFF; border-radius: 4px;"><i
class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a>
</div>
<div class="col-lg-6">
<a href="https://api.whatsapp.com/send?phone=918606827707" target="_blank"
class="btn btn-block mb-2 deep_hover"
style="text-decoration: none; background-color: #25D366; color: #FFF; border-radius: 4px;"><i
class="fa fa-whatsapp mr-2"></i>WhatsApp</a>
</div>
</div>
</div>
</div>
<!-- End of Contact Cards -->
</section>
<!-- Footer -->
<section class="oe_container" style="padding: 2rem 3rem 1rem;">
<div class="row" style="max-width:1540px; margin: 0 auto; margin-right: 3rem; ">
<!-- Logo -->
<div class="col-lg-12 d-flex justify-content-center align-items-center" style="margin-top: 3rem;">
<img src="https://www.cybrosys.com/images/logo.png" width="200px" height="auto" />
</div>
<!-- End of Logo -->
<div class="col-lg-12">
<hr
style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;">
<!-- End of Footer Section -->
</div>
</div>
</section>
<!-- END OF FOOTER -->
</div>

25
voice_note_in_chatter/static/src/js/attachment_card.js

@ -0,0 +1,25 @@
/** @odoo-module */
import {
AttachmentCard
} from "@mail/components/attachment_card/attachment_card";
import {
patch
} from "@web/core/utils/patch";
patch(AttachmentCard.prototype, "attachment_card", {
/**
* Play Audio Attachment.
*/
onPlay(ev) {
var audioElements = $('.o_attachment_audio');
//Pause Audio When other Audio plays
audioElements.each(function(index, element) {
if (ev.target != element.children[0]) {
for (let i = 0; i < element.children.length; i++) {
const childElement = element.children[i];
childElement.pause()
}
}
});
}
});

17
voice_note_in_chatter/static/src/js/record_voice_component.js

@ -0,0 +1,17 @@
/** @odoo-module **/
import { registerMessagingComponent } from '@mail/utils/messaging_component';
const { Component } = owl;
export class AttachmentAudio extends Component {
/**
* @returns {AttachmentAudio}
*/
get attachmentAudio() {
return this.props.record;
}
}
Object.assign(AttachmentAudio, {
props: { record: Object },
template: 'web.AttachmentAudioField',
});
registerMessagingComponent(AttachmentAudio);

28
voice_note_in_chatter/static/src/js/record_voice_model.js

@ -0,0 +1,28 @@
/** @odoo-module **/
import { registerNewModel } from '@mail/model/model_core';
import { attr, one2one } from '@mail/model/model_field';
function audio(dependencies) {
class AttachmentAudio extends dependencies['mail.model'] {}
AttachmentAudio.fields = {
/**
* Determines the attachment of this Audio.
*/
attachment:one2one('mail.attachment', {
inverse: 'attachment',
readonly: true
}),
/**
* Download Audio Attachment.
*/
downloadUrl: attr({
related:'attachment.downloadUrl'
}),
};
AttachmentAudio.identifyingFields = ['attachment'];
AttachmentAudio.modelName = 'mail.attachmentAudio';
return AttachmentAudio;
}
registerNewModel('mail.attachmentAudio', audio);

105
voice_note_in_chatter/static/src/js/voice_in_odoo.js

@ -0,0 +1,105 @@
/** @odoo-module **/
import {
registerInstancePatchModel,
registerFieldPatchModel,
registry
} from '@mail/model/model_core';
import Dialog from "web.Dialog";
const {
_t
} = require('web.core');
const composer_view = registry['mail.composer_view']
import {
one2one
} from '@mail/model/model_field';
var flag = false;
var recorder, gumStream;
registerInstancePatchModel('mail.composer_view', 'mail/static/src/models/composer_view/composer_view.js', {
recordVoice: function() {
//Check security of site
if (location.href.includes('https:')) {
/**
* Asks for access to the user's microphone if not granted yet, then
* starts recording.
*/
var self = this;
if (recorder && recorder.state == "recording") {
recorder.stop();
gumStream.getAudioTracks()[0].stop();
if (this.el.children.length == 4) {
this.el.children[2].children[1].children[0].children[1].children[1].style.color = "";
this.el.children[2].children[1].children[0].children[1].children[1].style.background = "";
} else {
this.el.children[1].children[1].children[0].children[1].children[1].style.color = "";
this.el.children[1].children[1].children[0].children[1].children[1].style.background = "";
}
} else {
if (this.el.children.length == 4) {
this.el.children[2].children[1].children[0].children[1].children[1].style.color = "#008000";
this.el.children[2].children[1].children[0].children[1].children[1].style.background = "#b5f1b5";
} else {
this.el.children[1].children[1].children[0].children[1].children[1].style.color = "#008000";
this.el.children[1].children[1].children[0].children[1].children[1].style.background = "#b5f1b5";
}
var audioElements = $('.o_attachment_audio');
//Pause Audio When Recording a new Audio
audioElements.each(function(index, element) {
for (let i = 0; i < element.children.length; i++) {
const childElement = element.children[i];
childElement.pause()
}
});
navigator.mediaDevices.getUserMedia({
audio: true
}).then((stream) => {
gumStream = stream;
recorder = new MediaRecorder(stream);
recorder.ondataavailable = async function(event) {
var reader = new FileReader();
reader.readAsDataURL(event.data);
reader.onloadend = async function() {
var data = reader.result;
var fl = [];
var array = data.split(','),
mime = array[0].match(/:(.*?);/)[1],
bstr = atob(array[1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
var voice_file = new File([u8arr], 'message.mp3', {
type: mime
});
fl.push(voice_file);
await self._fileUploaderRef.comp.uploadFiles(fl)
};
};
recorder.start();
});
}
} else {
//If the site is not https,an alert will display.
if (flag == false) {
flag = true
var dialog = new Dialog(this, {
size: 'medium',
buttons: '',
$content: $('<div>', {
text: _t("Site is not secure,use secured site(https)")
}),
}).open()
}
}
},
});
/**
* Registers a field patch model for the 'mail.attachment' model.
*/
registerFieldPatchModel('mail.attachment', 'mail/static/src/models/attachment/attachment.js', {
attachment: one2one('mail.attachmentAudio', {
inverse: 'attachment',
isCausal: true,
}),
});

101
voice_note_in_chatter/static/src/xml/voice_in_odoo.xml

@ -0,0 +1,101 @@
<?xml version="1.0" encoding="utf-8" ?>
<template name="VoiceChatter" id="chatter" xml:space="preserve">
<!-- Add Voice icon in chatter -->
<t t-inherit="mail.Composer" t-inherit-mode="extension" owl="1">
<xpath expr="//button[hasclass('o_Composer_buttonAttachment')]"
position="before">
<button class="o_Composer_button o_Composer_toolButton btn btn-light fa fa-microphone border-0 rounded-pill mx-1"
id="record_voice" title="Voice" aria-label="Voice"
type="button"
t-on-click="composerView.recordVoice.bind(this)">
</button>
</xpath>
</t>
<t t-name="voiceChatterMessage" t-inherit="mail.AttachmentCard"
t-inherit-mode="extension" owl="1">
<xpath expr="//div[hasclass('o_AttachmentCard')]" position="replace">
<t t-if="attachmentCard.attachment.extension != 'mp3'">
<div class="o_AttachmentCard o-has-card-details d-flex rounded bg-300"
t-att-class="{
'o-isUploading': attachmentCard.attachment.isUploading,
'o-viewable': attachmentCard.attachment.isViewable,
}"
t-att-title="attachmentCard.attachment.displayName ? attachmentCard.attachment.displayName : undefined"
role="menu"
t-att-aria-label="attachmentCard.attachment.displayName"
t-att-data-id="attachmentCard.attachment.localId">
<!-- Image style-->
<!-- o_image from mimetype.scss -->
<div class="o_AttachmentCard_image o_image flex-shrink-0 m-1"
t-on-click="attachmentCard.onClickImage"
t-att-class="{'o-attachment-viewable opacity-75-hover': attachmentCard.attachment.isViewable,}"
role="menuitem" aria-label="Preview"
t-att-tabindex="attachmentCard.attachment.isViewable ? 0 : -1"
t-att-aria-disabled="!attachmentCard.attachment.isViewable"
t-att-data-mimetype="attachmentCard.attachment.mimetype">
</div>
<!-- Attachment details -->
<div class="o_AttachmentCard_details d-flex justify-content-center flex-column px-1">
<t t-if="attachmentCard.attachment.displayName">
<div class="o_AttachmentCard_filename text-truncate">
<t t-esc="attachmentCard.attachment.displayName"/>
</div>
</t>
<t t-if="attachmentCard.attachment.extension">
<small class="o_AttachmentCard_extension text-uppercase">
<t t-esc="attachmentCard.attachment.extension"/>
</small>
</t>
</div>
<!-- Attachment aside -->
<div class="o_AttachmentCard_aside position-relative rounded-end overflow-hidden"
t-att-class="{ 'o-hasMultipleActions d-flex flex-column': attachmentCard.hasMultipleActions }">
<!-- Uploading icon -->
<t t-if="attachmentCard.attachment.isUploading and attachmentCard.attachmentList.composerViewOwner">
<div class="o_AttachmentCard_asideItem o_AttachmentCard_asideItemUploading d-flex justify-content-center align-items-center w-100 h-100"
title="Uploading">
<i class="fa fa-spin fa-spinner"/>
</div>
</t>
<!-- Uploaded icon -->
<t t-if="!attachmentCard.attachment.isUploading and attachmentCard.attachmentList.composerViewOwner">
<div class="o_AttachmentCard_asideItem o_AttachmentCard_asideItemUploaded d-flex justify-content-center align-items-center w-100 h-100 text-primary"
title="Uploaded">
<i class="fa fa-check"/>
</div>
</t>
<!-- Remove button -->
<t t-if="attachmentCard.attachment.isDeletable">
<button class="o_AttachmentCard_asideItem o_AttachmentCard_asideItemUnlink btn top-0 justify-content-center align-items-center d-flex w-100 h-100 rounded-0"
t-attf-class="{{ attachmentCard.attachmentList.composerViewOwner ? 'o-pretty position-absolute btn-primary transition-base' : 'bg-300' }}"
t-on-click="attachmentCard.onClickUnlink"
title="Remove">
<i class="fa fa-trash" role="img"
aria-label="Remove"/>
</button>
</t>
<!-- Download button -->
<t t-if="!attachmentCard.attachmentList.composerViewOwner and !attachmentCard.attachment.isUploading">
<button class="o_AttachmentCard_asideItem o_AttachmentCard_asideItemDownload btn d-flex justify-content-center align-items-center w-100 h-100 rounded-0 bg-300"
t-on-click="attachmentCard.attachment.onClickDownload"
title="Download">
<i class="fa fa-download" role="img"
aria-label="Download"/>
</button>
</t>
</div>
</div>
</t>
<!-- Download Audio -->
<t t-else="">
<t t-log="attachmentCard.attachment.downloadUrl"/>
<div class="o_attachment_audio">
<audio controls="" t-on-play="onPlay()">
<source t-att-src="attachmentCard.attachment.downloadUrl"
type="audio/mp3"/>
</audio>
</div>
</t>
</xpath>
</t>
</template>
Loading…
Cancel
Save