| @ -0,0 +1,50 @@ | |||
| .. 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 | |||
| 
 | |||
| POS Chat Box | |||
| ============= | |||
| Using the POS screen, this module facilitates user communication. | |||
| 
 | |||
| Configuration | |||
| ============= | |||
| * No additional configurations needed | |||
| 
 | |||
| Company | |||
| ------- | |||
| * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | |||
| 
 | |||
| Credits | |||
| ------- | |||
| * Developers: (V16) yadhukrishnan | |||
|                 (V17) Gayathri V | |||
|                 (V18) Abbas P | |||
| Contact : odoo@cybrosys.com | |||
| 
 | |||
| License | |||
| ------- | |||
| Affero General Public License, Version 3 (AGPL v3). | |||
| (https://www.gnu.org/licenses/agpl-3.0-standalone.html) | |||
| 
 | |||
| 
 | |||
| Contacts | |||
| -------- | |||
| * Mail Contact : odoo@cybrosys.com | |||
| * Website : https://cybrosys.com | |||
| 
 | |||
| Bug Tracker | |||
| ----------- | |||
| Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. | |||
| 
 | |||
| Maintainer | |||
| ========== | |||
| .. image:: https://cybrosys.com/images/logo.png | |||
|    :target: https://cybrosys.com | |||
| 
 | |||
| This module is maintained by Cybrosys Technologies. | |||
| 
 | |||
| For support and more information, please visit `Our Website <https://cybrosys.com/>`__ | |||
| 
 | |||
| Further information | |||
| =================== | |||
| HTML Description: `<static/description/index.html>`__ | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Abbas P (odoo@cybrosys.com) | |||
| # | |||
| #    You can modify it under the terms of the GNU AFFERO | |||
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |||
| # | |||
| #    This program is distributed in the hope that it will be useful, | |||
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |||
| #    (AGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| ################################################################################ | |||
| from . import controllers | |||
| @ -0,0 +1,46 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Abbas P (odoo@cybrosys.com) | |||
| # | |||
| #    You can modify it under the terms of the GNU AFFERO | |||
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |||
| # | |||
| #    This program is distributed in the hope that it will be useful, | |||
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |||
| #    (AGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| ################################################################################ | |||
| { | |||
|     'name': 'POS Chat Box', | |||
|     'category': 'Point Of Sale', | |||
|     'version': '18.0.1.0.0', | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'website': 'https://www.cybrosys.com', | |||
|     'summary': """POS Chat Box For Odoo18 Community and Enterprise Edition""", | |||
|     'description': """Using the POS screen, this module facilitates user ' | |||
|                    'communication.""", | |||
|     'depends': ['web','point_of_sale'], | |||
|     'assets': { | |||
|         'point_of_sale._assets_pos': [ | |||
|             '/pos_chatter/static/src/xml/pos_systray_icon.xml', | |||
|             '/pos_chatter/static/src/js/pos_systray_icon.js', | |||
|             '/pos_chatter/static/src/js//pos_msg_view.js', | |||
|             '/pos_chatter/static/src/js/pos_chat_view.js', | |||
|         ], | |||
|     }, | |||
|     'images': ['static/description/banner.png'], | |||
|     'license': 'AGPL-3', | |||
|     'installable': True, | |||
|     'application': False, | |||
|     'auto_install': False, | |||
| } | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Abbas P (odoo@cybrosys.com) | |||
| # | |||
| #    You can modify it under the terms of the GNU AFFERO | |||
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |||
| # | |||
| #    This program is distributed in the hope that it will be useful, | |||
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |||
| #    (AGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| ################################################################################ | |||
| from . import systray | |||
| @ -0,0 +1,110 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Abbas P (odoo@cybrosys.com) | |||
| # | |||
| #    You can modify it under the terms of the GNU AFFERO | |||
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |||
| # | |||
| #    This program is distributed in the hope that it will be useful, | |||
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |||
| #    (AGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| ################################################################################ | |||
| from odoo import http | |||
| from odoo.http import request | |||
| 
 | |||
| 
 | |||
| class SystrayController(http.Controller): | |||
|     """ | |||
|     The PosSystray Getting values to the pos chatter list, pos message and write | |||
|      the record to "mail.message". | |||
|     Methods: | |||
|         get_data_pos_systray(self): | |||
|            Getting data to the Message chatter list | |||
|         get_data_chat_box(self, **kw): | |||
|            kw contain the id of the channel and getting the message of the | |||
|            corresponding channel id. | |||
|         action_create_message_mail(self, **kw): | |||
|            creating new record in "mail.message" | |||
|     """ | |||
| 
 | |||
|     @http.route('/pos_systray/message_data', auth='public', type='json') | |||
|     def get_data_pos_systray(self): | |||
|         """ | |||
|         Summary: | |||
|             Getting data to the Message chatter list. | |||
|         Return: | |||
|             it contains details about chatter list. | |||
|         """ | |||
|         return [{'id': mail_channel_id.id, | |||
|                  'type': mail_channel_id.channel_type, | |||
|                  'name': mail_channel_id.name, | |||
|                  'message_body': request.env['mail.message'].search( | |||
|                      [('model', '=', 'discuss.channel'), | |||
|                       ('res_id', '=', mail_channel_id.id)], limit=1).body | |||
|                  } for mail_channel_id in request.env['discuss.channel'].search([]) | |||
|                 for partner_id in mail_channel_id.channel_partner_ids | |||
|                 if partner_id.id == request.env.user.partner_id.id] | |||
| 
 | |||
|     @http.route('/pos_systray/chat_message', auth='public', type='json') | |||
|     def get_data_chat_box(self, **kw): | |||
|         """ | |||
|         Summary: | |||
|             getting the message of the corresponding channel id. | |||
|         Args: | |||
|         all_message_list = [] | |||
|         mail_channel_ids = request.env['mail.channel'].search([]) | |||
|         for mail_channel_id in mail_channel_ids: | |||
|             for partner_id in mail_channel_id.channel_partner_ids: | |||
|                 if partner_id.id == request.env.user.partner_id.id: | |||
|                     message_id = request.env['mail.message'].search( | |||
|                         [('model', '=', 'mail.channel'), | |||
|                          ('res_id', '=', mail_channel_id.id)], limit=1) | |||
|                     all_message_list.append({ | |||
|                         'id': mail_channel_id.id, | |||
|                         'type': mail_channel_id.channel_type, | |||
|                         'name': mail_channel_id.name, | |||
|                         'message_body': message_id.body | |||
|                     })dict): | |||
|                 it contains channel id of the clicked channel. | |||
|         """ | |||
|         return { | |||
|             'name': request.env['discuss.channel'].browse(int(kw['data'])).name, | |||
|             'messages': [{ | |||
|                 'body': message_id.body, | |||
|                 'author': message_id.author_id.name, | |||
|                 'flag': 1 if message_id.author_id.id == request.env.user. | |||
|                 partner_id.id else 0 | |||
|             } for message_id in request.env['mail.message'].search( | |||
|                 [('model', '=', 'discuss.channel'), | |||
|                  ('res_id', '=', int(kw['data']))]).sorted('create_date') | |||
|             ], | |||
|             'channel_id': int(kw['data']) | |||
|         } | |||
| 
 | |||
|     @http.route('/pos_chatter/send_message', auth='public', type='json') | |||
|     def action_create_message_mail(self, **kw): | |||
|         """ | |||
|         Summary: | |||
|            creating new record in "mail.message" | |||
|         Args: | |||
|             kw(dict): | |||
|                 it contains channel id of the clicked channel. | |||
|         """ | |||
|         data = kw['data'] | |||
|         request.env['mail.message'].sudo().create({ | |||
|             'body': "<p>" + data['msg_body'] + "</p>", | |||
|             'model': 'discuss.channel', | |||
|             'res_id': int(data['res_id']), | |||
|             'message_type': 'comment', | |||
|             'author_id': request.env.user.partner_id.id | |||
|         }) | |||
|         return True | |||
| @ -0,0 +1,6 @@ | |||
| ## Module <pos_chatter> | |||
| 
 | |||
| #### 15.02.2025 | |||
| #### Version 18.0.1.0.0 | |||
| ##### ADD | |||
| - Initial Commit for POS Chat Box | |||
| After Width: | Height: | Size: 2.2 KiB | 
| After Width: | Height: | Size: 28 KiB | 
| After Width: | Height: | Size: 628 KiB | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 210 KiB | 
| After Width: | Height: | Size: 209 KiB | 
| After Width: | Height: | Size: 109 KiB | 
| After Width: | Height: | Size: 495 B | 
| After Width: | Height: | Size: 1.0 KiB | 
| After Width: | Height: | Size: 624 B | 
| After Width: | Height: | Size: 136 KiB | 
| After Width: | Height: | Size: 214 KiB | 
| After Width: | Height: | Size: 36 KiB | 
| After Width: | Height: | Size: 3.6 KiB | 
| After Width: | Height: | Size: 310 B | 
| After Width: | Height: | Size: 929 B | 
| After Width: | Height: | Size: 1.3 KiB | 
| After Width: | Height: | Size: 3.3 KiB | 
| After Width: | Height: | Size: 1.4 KiB | 
| After Width: | Height: | Size: 17 KiB | 
| After Width: | Height: | Size: 542 B | 
| After Width: | Height: | Size: 576 B | 
| After Width: | Height: | Size: 733 B | 
| After Width: | Height: | Size: 4.3 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 4.0 KiB | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 152 KiB | 
| After Width: | Height: | Size: 2.2 KiB | 
| After Width: | Height: | Size: 911 B | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 600 B | 
| After Width: | Height: | Size: 673 B | 
| After Width: | Height: | Size: 2.0 KiB | 
| After Width: | Height: | Size: 462 B | 
| After Width: | Height: | Size: 2.1 KiB | 
| After Width: | Height: | Size: 926 B | 
| After Width: | Height: | Size: 9.0 KiB | 
| After Width: | Height: | Size: 23 KiB | 
| After Width: | Height: | Size: 7.0 KiB | 
| After Width: | Height: | Size: 878 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 653 B | 
| After Width: | Height: | Size: 800 B | 
| After Width: | Height: | Size: 905 B | 
| After Width: | Height: | Size: 189 KiB | 
| After Width: | Height: | Size: 4.3 KiB | 
| After Width: | Height: | Size: 839 B | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 5.9 KiB | 
| After Width: | Height: | Size: 1.6 KiB | 
| After Width: | Height: | Size: 34 KiB | 
| After Width: | Height: | Size: 26 KiB | 
| After Width: | Height: | Size: 3.8 KiB | 
| After Width: | Height: | Size: 23 KiB | 
| After Width: | Height: | Size: 1.9 KiB | 
| After Width: | Height: | Size: 2.3 KiB | 
| After Width: | Height: | Size: 427 B | 
| After Width: | Height: | Size: 627 B | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 988 B | 
| After Width: | Height: | Size: 3.7 KiB | 
| After Width: | Height: | Size: 5.0 KiB | 
| After Width: | Height: | Size: 875 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 767 KiB | 
| After Width: | Height: | Size: 138 KiB | 
| After Width: | Height: | Size: 760 KiB | 
| After Width: | Height: | Size: 92 KiB | 
| After Width: | Height: | Size: 697 KiB | 
| After Width: | Height: | Size: 1.1 MiB | 
| After Width: | Height: | Size: 106 KiB | 
| After Width: | Height: | Size: 111 KiB | 
| After Width: | Height: | Size: 144 KiB | 
| After Width: | Height: | Size: 880 KiB | 
| After Width: | Height: | Size: 86 KiB | 
| After Width: | Height: | Size: 6.4 KiB | 
| @ -0,0 +1,904 @@ | |||
| <!DOCTYPE html> | |||
| <html lang="en"> | |||
| <head> | |||
|     <meta charset="UTF-8"/> | |||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"/> | |||
|     <title>POS Chat Box</title> | |||
|     <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" | |||
|           rel="stylesheet"/> | |||
|     <link rel="preconnect" href="https://fonts.googleapis.com"> | |||
|     <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> | |||
|     <link href="https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap" | |||
|           rel="stylesheet"> | |||
|     <link rel="stylesheet" | |||
|           href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.6.0/css/all.min.css"/> | |||
|     <link rel="stylesheet" | |||
|           href="https://cdnjs.cloudflare.com/ajax/libs/OwlCarousel2/2.3.4/assets/owl.carousel.min.css"/> | |||
|     <style> | |||
|         :root { | |||
|             --primary-color: #7f54b3; | |||
|             --bg-white: #fff; | |||
|             --text-color: #121212; | |||
|             --text-color-light: #64728f; | |||
|         } | |||
| 
 | |||
|         body { | |||
|             font-family: "Montserrat", sans-serif; | |||
|         } | |||
| 
 | |||
|         .nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active { | |||
|             color: #121212; | |||
|             font-family: Montserrat; | |||
|             font-size: 16px !important; | |||
|             font-weight: 500 !important; | |||
|             border-radius: 30px; | |||
|             line-height: normal; | |||
|             text-transform: capitalize; | |||
|             background-color: #F5F5F5; | |||
|             border: none; | |||
|             margin-bottom: 0; | |||
|             padding: 12px 24px; | |||
|         } | |||
| 
 | |||
|         .nav-tabs .nav-link:focus, .nav-tabs .nav-link:hover { | |||
|             border-color: transparent; | |||
|             isolation: isolate; | |||
|         } | |||
| 
 | |||
|         .nav-tabs .nav-link:focus-visible { | |||
|             border-color: transparent; | |||
|             box-shadow: none; | |||
|         } | |||
| 
 | |||
|         /* owl-carosel */ | |||
|         .owl-carousel .owl-nav { | |||
|             position: absolute; | |||
|             top: 42%; | |||
|             width: 100%; | |||
|             display: flex; | |||
|             justify-content: space-between; | |||
|             transform: translateY(-42%); | |||
|         } | |||
| 
 | |||
|         .owl-carousel .owl-nav button.owl-prev { | |||
|             position: absolute; | |||
|             right: -36px; | |||
|             font-size: 28px; | |||
|             background-color: #e4e4e4; | |||
|             border-radius: 20px; | |||
|             width: 40px; | |||
|             height: 40px; | |||
|             display: flex; | |||
|             justify-content: center; | |||
|             align-items: center; | |||
|         } | |||
| 
 | |||
|         .owl-carousel .owl-nav button.owl-next { | |||
|             position: absolute; | |||
|             left: -36px; | |||
|             font-size: 28px; | |||
|             background-color: #e4e4e4; | |||
|             border-radius: 20px; | |||
|             width: 40px; | |||
|             height: 40px; | |||
|             display: flex; | |||
|             justify-content: center; | |||
|             align-items: center; | |||
| 
 | |||
|         } | |||
| 
 | |||
|     </style> | |||
| </head> | |||
| <body> | |||
| <!-- overview --> | |||
| <div class="container"> | |||
|     <div class="my-5"> | |||
|         <!-- button tab --> | |||
|         <!--  --> | |||
|         <!-- version support --> | |||
|         <div class="my-3 d-flex align-items-center justify-content-end"> | |||
|             <div class="text-center" | |||
|                  style="background-color:#017E84 !important; font-size:0.8rem !important; color:#fff !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width:120px !important"> | |||
|                 Community | |||
|             </div> | |||
|             <div class="text-center" | |||
|                  style="background-color:#875A7B !important; color:#fff !important; font-size:0.8rem !important; font-weight:500 !important; padding:4px !important; margin:0 3px !important; border-radius:50px !important; min-width:120px !important"> | |||
|                 Enterprise | |||
|             </div> | |||
| 
 | |||
|         </div> | |||
|         <div class="tab-content" id="myTabContent"> | |||
|             <!-- description --> | |||
|             <div class="tab-pane fade show active" id="home" role="tabpanel" | |||
|                  aria-labelledby="home-tab"> | |||
|                 <div class="position-relative" | |||
|                      style="border-radius: 16px; background: #f8f8f8; padding: 20px 0;"> | |||
|                     <div class="row " style=" | |||
|           padding: 2rem 0rem 0 !important; | |||
|         "> | |||
|                         <div class="col-lg-8 mx-auto gap-4 d-flex flex-column align-items-center"> | |||
|                             <p class="my-1 text-center text-uppercase" | |||
|                                style=" | |||
|               letter-spacing: 4px !important; | |||
|               color: #7f54b3; | |||
|               font-weight: bold; | |||
|               text-align: center; | |||
|               font-size: 14px; | |||
|               font-weight: 600; | |||
|               line-height: 15.96px; | |||
|               text-transform: uppercase;"> | |||
|                                 A Module for Chat in POS. | |||
|                             </p> | |||
|                             <h1 class="text-center text-uppercase my-0" | |||
|                                 style=" | |||
|               color: #121212; | |||
|               font-size: 46px; | |||
|               font-weight: 700; | |||
|               line-height: normal; | |||
|             ">POS Chat Box</span> | |||
|                             </h1> | |||
|                         </div> | |||
|                         <div class="col-lg-12 d-flex justify-content-center align-items-center" | |||
|                              style="margin: 3rem 0;"> | |||
|                             <img src="./assets/icons/brand-pair.svg" | |||
|                                  width="100%" | |||
|                                  height="auto" | |||
|                                  style="width: 50%" | |||
|                                  class="img-responsive"/> | |||
|                         </div> | |||
|                         <div class="col-md-12 text-center"> | |||
|                             <a href="mailto:odoo@cybrosys.com" | |||
|                                target="_blank" | |||
|                                style="background-color: transparent;border-radius: 35px; | |||
|               font-family: Montserrat; | |||
|               display: inline-block; | |||
|               padding: 7px 33px; | |||
|               border: 1px solid #7f54b3; | |||
|               color: #7f54b3; | |||
|               text-decoration: none; | |||
|             " | |||
|                                class="mx-1 mb-2 deep-1 deep_hover"> | |||
|                                 <img class="img" | |||
|                                      style="width: 24px" | |||
|                                      src="./assets/icons/mail.svg"/> | |||
|                                 <span class="pl-2" | |||
|                                       style=" font-size: 16px; vertical-align: middle" | |||
|                                 >Email Us</span | |||
|                                 > | |||
|                             </a> | |||
|                             <a href="skype:cybroopenerp?chat" | |||
|                                target="_blank" | |||
|                                style=" | |||
|               background-color: #7f289b; | |||
|               font-family: Montserrat; | |||
|               display: inline-block; | |||
|               padding: 7px 33px; | |||
|               border: 1px solid #7f289b; | |||
|               border-radius: 35px; | |||
|               text-decoration: none; | |||
|             " | |||
|                                class="mx-1 mb-2 deep-1 deep_hover"> | |||
|                                 <img | |||
|                                         class="img" | |||
|                                         style="width: 24px" | |||
|                                         src="./assets/icons/skype-fill.svg" | |||
|                                 /> | |||
|                                 <span | |||
|                                         class="pl-2" | |||
|                                         style="color: #fff; font-size: 16px; vertical-align: middle" | |||
|                                 >Skype Us</span | |||
|                                 > | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="d-flex justify-content-center mt-2"> | |||
|                             <img src="./assets/icons/hero.gif" | |||
|                                  class="w-100" | |||
|                                  style="z-index: 3; height: auto;"> | |||
|                         </div> | |||
|                     </div> | |||
|                     <div class="position-absolute bottom-0" | |||
|                          style="z-index: 1; width: 100%;"> | |||
|                         <img src="./assets/icons/banner-bg.svg" | |||
|                              class="img-fluid w-100"> | |||
|                     </div> | |||
|                     <div class="position-absolute bottom-0 end-0" | |||
|                          style=" z-index: 2;"> | |||
|                         <img src="./assets/icons/patter.svg"> | |||
|                     </div> | |||
|                 </div> | |||
| 
 | |||
|                 <!-- key-highlight --> | |||
|                 <div class="" style="border-radius: 16px; | |||
|      padding: 60px 40px; | |||
|      border: 1px solid #EBEEF2; | |||
|      background: #F5F5F7; | |||
|      box-shadow: 0px 5px 20px -11px rgba(0, 0, 0, 0.25); "> | |||
|                     <div class="row"> | |||
|                         <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center"> | |||
|                             <h2 style=" color: #121212; | |||
|             text-align: center; | |||
|             font-size: 40px; | |||
|             font-weight: 700; | |||
|             text-transform: uppercase; padding-bottom: 50px;">Key | |||
|                                 Highlights</h2> | |||
|                         </div> | |||
|                         <div class="col-lg-4"> | |||
|                             <div class="mb-4 d-flex flex-column justify-content-center gap-3" | |||
|                                  style="border-radius: 12px; border: 1px solid  #B6BCCD; | |||
|             background:  #FFF;padding:32px "> | |||
|                                 <div class="d-flex justify-content-center align-items-center" | |||
|                                      style="background-color:#7847D9 !important; border-radius:8px !important; height:42px; width:42px"> | |||
|                                     <img src="./assets/icons/feature-icon.svg" | |||
|                                          class="img-responsive" height="26px" | |||
|                                          width="26px"> | |||
|                                 </div> | |||
|                                 <h5 class="m-0" | |||
|                                     style="color:#000 !important; font-weight:bold"> | |||
|                                     Users can use chatter in the pos session. | |||
|                                 </h5> | |||
|                                 <p class="m-0" | |||
|                                    style="font-size:0.9rem; color:var(--text-color-light); font-size: 16px; font-weight: 400;"></p> | |||
| 
 | |||
| 
 | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="col-lg-4"> | |||
|                             <div class="mb-4 d-flex flex-column justify-content-center gap-3" | |||
|                                  style="border-radius: 12px; | |||
|           border: 1px solid  #B6BCCD; | |||
|           background:  #FFF;padding:32px "> | |||
|                                 <div class="d-flex justify-content-center align-items-center" | |||
|                                      style="background-color:#7847D9 !important; border-radius:8px !important; height:42px; width:42px"> | |||
|                                     <img src="./assets/icons/feature-icon.svg" | |||
|                                          class="img-responsive" height="26px" | |||
|                                          width="26px"> | |||
|                                 </div> | |||
|                                 <h5 class="m-0" | |||
|                                     style="color:#000 !important; font-weight:bold"> | |||
|                                     Supports In Both Odoo Community & Enterprise | |||
|                                 </h5> | |||
| 
 | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|                 <!--code  --> | |||
|                 <div class="my-5"> | |||
|                     <div class="position-relative" | |||
|                          style=" padding: 5rem 4rem 5rem 4rem; background-color: #0A1425; border-radius: 12px;"> | |||
|                         <div class="d-flex flex-column gap-4"> | |||
|                             <span class="wrapper-subtitle" | |||
|                                   style="font-size: 40px; font-weight: 700; color: #fff;line-height: 60px; text-transform: capitalize; width: 450px;  font-family: Montserrat;">POS Chat Box</span> | |||
|                             <h3 class="wrapper-details" | |||
|                                 style="font-size: 20px; font-weight: 400; color: #fff; line-height: 32px;  "> | |||
|                                 Are you ready to make your business more | |||
|                                 organized? | |||
|                                 <br> Improve now! | |||
|                             </h3> | |||
|                             <div class="d-flex gap-3"> | |||
|                                 <a href="mailto:odoo@cybrosys.com" | |||
|                                    class="shop-btn" style="cursor: pointer; border-radius: 16px; display: flex; justify-content: center; align-items: center; gap: 7px; | |||
|             border: 1px solid  #ffffff33; | |||
|             background-color: #ffffff14; | |||
|             backdrop-filter: blur(10px); color: #fff; padding: 12px 16px 12px 16px; text-decoration: none;"> | |||
|              <span style="border-radius: 12px; | |||
|              background-color: #ffffff1a; | |||
|              backdrop-filter: blur(6px);padding: 12px;  "> | |||
|               <img src="./assets/icons/banner-mail.svg"> | |||
|            </span> | |||
|                                     <span style="font-weight: 500;font-family: Montserrat;">odoo@cybrosys.com</span> | |||
|                                 </a> | |||
|                                 <a href="tel:+91 9074270811" class="shop-btn" | |||
|                                    style="cursor: pointer; border-radius: 16px; display: flex; justify-content: center; align-items: center; gap: 7px; | |||
|              border: 1px solid  #ffffff33; | |||
|              background-color: #ffffff14; | |||
|             backdrop-filter: blur(10px); color: #fff; padding: 12px 22px 12px 18px; text-decoration: none;"> | |||
|              <span style="border-radius: 12px; | |||
|              background-color: #ffffff1a; | |||
|              backdrop-filter: blur(6px);padding: 12px;"> | |||
|               <img src="./assets/icons/banner-call.svg"> | |||
|            </span> | |||
|                                     <span style="font-weight: 500;font-family: Montserrat;">+91 9074270811</span> | |||
|                                 </a> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div class="position-absolute bottom-0 end-0"> | |||
|                             <img src="./assets/icons/banner-pattern.svg" | |||
|                                  style="width: 540px;"> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|                 <!-- end-code --> | |||
|                 <!--  --> | |||
|                 <!-- screenshot and other --> | |||
| 
 | |||
|                 <div class="mb-4 bg-white" | |||
|                      style=" border: 1px solid #EBEEF2; border-radius: 6px; box-shadow: 0px 8px 20px -4px rgba(0, 0, 0, 0.10); border: 1px solid #EBEEF2;"> | |||
|                     <div> | |||
|                         <ul class="nav nav-tabs justify-content-center bg-white py-2" | |||
|                             id="myTab" role="tablist" | |||
|                             style="border-radius: 6px 6px 0 0;"> | |||
|                             <li class="nav-item"> | |||
|                                 <a aria-controls="overview" | |||
|                                    aria-bs-selected="true" | |||
|                                    class="nav-link active" data-bs-toggle="tab" | |||
|                                    href="#overview" id="overview-tab" role="tab" | |||
|                                    style="color:#121212; font-weight:500; font-size:16px"> | |||
|                                     Screenshots</a> | |||
|                             </li> | |||
|                             <li class="nav-item"> | |||
|                                 <a aria-controls="feature" | |||
|                                    aria-bs-selected="false" | |||
|                                    class="nav-link py-2" data-bs-toggle="tab" | |||
|                                    href="#feature" id="feature-tab" role="tab" | |||
|                                    style="color:#121212; font-weight:500; font-size:16px">Features</a> | |||
|                             </li> | |||
|                             <li class="nav-item"> | |||
|                                 <a aria-controls="faq" aria-bs-selected="false" | |||
|                                    class="nav-link" data-bs-toggle="tab" | |||
|                                    href="#faq" id="faq-tab" role="tab" | |||
|                                    style="color:#121212; font-weight:500; font-size:16px"> | |||
|                                     FAQs</a> | |||
|                             </li> | |||
|                             <li class="nav-item"> | |||
|                                 <a aria-controls="releases" | |||
|                                    aria-bs-selected="false" class="nav-link" | |||
|                                    data-bs-toggle="tab" href="#releases" | |||
|                                    id="releases-tab" role="tab" | |||
|                                    style="color:#121212; font-weight:500; font-size:16px">Releases</a> | |||
|                             </li> | |||
|                         </ul> | |||
|                     </div> | |||
|                     <div class="tab-content p-md-5 p-2 py-3" id="myTabContent"> | |||
|                         <div aria-labelledby="overview-tab" | |||
|                              class="tab-pane fade show active" id="overview" | |||
|                              role="tabpanel"> | |||
|                             <div class="position-relative mb-4" | |||
|                                  style="border-radius:10px"> | |||
|                                 <img alt="acc_bg" | |||
|                                      class="w-100 h-100 position-absolute img-fluid left_0" | |||
|                                      loading="lazy" | |||
|                                      src="//apps.odoocdn.com/apps/assets/17.0/ks_dashboard_ninja/ai-img/o3.png?007008f" | |||
|                                      style=""> | |||
|                             </div> | |||
|                             <!-- screenshots section--> | |||
|                             <div class="position-relative mb-4" | |||
|                                  style="border-radius:10px; background-color:#f4f4f4"> | |||
|                                 <div class="p-md-5 p-3 position-relative"> | |||
|                                     <div class="row"> | |||
|                                         <div class="col-md-12"> | |||
|                                             <h1 style="font-weight:bold; font-size:calc(1.1rem + 1vw); line-height:120%; text-align:center; text-transform:capitalize; font-size: 40px; | |||
|                               font-weight: 700;"> | |||
|                                       <span style="color:#121212; font-size:calc(1.1rem + 1vw)">Chat Button on POS screen. | |||
|                                       </span> | |||
|                                                 <span style="color: #7f54b3; font-size:calc(1.1rem + 1vw)"></span> | |||
|                                             </h1> | |||
|                                         </div> | |||
|                                         <div class="col-md-12 mb-4"> | |||
|                                             <p style="font-weight:400; font-size:16px; line-height:150%; text-align:center;  color:#64728f"> | |||
|                                             </p> | |||
|                                         </div> | |||
|                                         <div class="col-md-12 mb-4"> | |||
| 
 | |||
|                                         </div> | |||
|                                         <div class="col-md-12 text-center"> | |||
|                                             <div class="d-inline-block p-3 shadow-sm" | |||
|                                                  style="background-color:#fff; border-radius:10px"> | |||
|                                                 <img alt="" class="img-fluid" | |||
|                                                      loading="lazy" | |||
|                                                      src="./assets/screenshots/ss1.png" | |||
|                                                      style="min-height: 1px;"> | |||
|                                             </div> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="position-relative mb-4" | |||
|                                  style="border-radius:10px; background-color:#f4f4f4"> | |||
|                                 <div class="p-md-5 p-3 position-relative"> | |||
|                                     <div class="row"> | |||
|                                         <div class="col-md-12"> | |||
|                                             <h1 style="font-weight:bold; font-size:calc(1.1rem + 1vw); line-height:120%; text-align:center; text-transform:capitalize; font-size: 40px; | |||
|                               font-weight: 700;"> | |||
|                                                 Chat list. | |||
|                                             </h1> | |||
|                                         </div> | |||
| 
 | |||
|                                         <div class="col-md-12 text-center"> | |||
|                                             <div class="d-inline-block p-3 shadow-sm" | |||
|                                                  style="background-color:#fff; border-radius:10px"> | |||
|                                                 <div class="col-md-12 mb-4"> | |||
|                                                     <p style="font-weight:400; font-size:16px; line-height:150%; text-align:center;  color:#64728f"> | |||
|                                                     </p> | |||
|                                                 </div> | |||
|                                                 <img alt="" class="img-fluid" | |||
|                                                      loading="lazy" | |||
|                                                      src="./assets/screenshots/ss2.png" | |||
|                                                      style="min-height: 1px;"> | |||
|                                             </div> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="position-relative mb-4" | |||
|                                  style="border-radius:10px; background-color:#f4f4f4"> | |||
|                                 <div class="p-md-5 p-3 position-relative"> | |||
|                                     <div class="row"> | |||
|                                         <div class="col-md-12"> | |||
|                                             <h1 style="font-weight:bold; font-size:calc(1.1rem + 1vw); line-height:120%; text-align:center; text-transform:capitalize; font-size: 40px; | |||
|                   font-weight: 700;"> | |||
|                                                 On clicking an item in chat list, chat window open in pos screen. | |||
|                                             </h1> | |||
|                                             <p style="font-weight:400; font-size:16px; line-height:150%; text-align:center;  color:var(--text-color-light)"> | |||
|                                             </p> | |||
| 
 | |||
|                                         </div> | |||
| 
 | |||
|                                         <div class="col-md-12 text-center"> | |||
|                                             <div class="d-inline-block p-3 shadow-sm" | |||
|                                                  style="background-color:#fff; border-radius:10px"> | |||
|                                                 <img alt="" class="img-fluid" | |||
|                                                      loading="lazy" | |||
|                                                      src="./assets/screenshots/ss3.png" | |||
|                                                      style="min-height: 1px;"> | |||
|                                             </div> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
| 
 | |||
|                             </div> | |||
|                         </div> | |||
|                         <div aria-labelledby="feature-tab" | |||
|                              class="tab-pane fade show py-1" id="feature" | |||
|                              role="tabpanel"> | |||
|                             <div class="row py-4"> | |||
|                                 <!-- Features Section --> | |||
|                                 <div class="col-md-6 col-sm-12 p-3"> | |||
|                                     <div class="d-flex flex-column align-items-start h-100" | |||
|                                          style="padding:30px; border-radius:12px; background-color:#faf8ff"> | |||
|                                         <div class="d-flex align-items-center justify-content-center"> | |||
|                                             <div class="d-flex align-items-center justify-content-center " | |||
|                                                  style="width:36px; height:36px; border-radius:50%; background-color:#7847D9 ; margin-right:10px"> | |||
|                                                 <i class="fa fa-star  " | |||
|                                                    style="color:#fff; font-size:14px"></i> | |||
|                                             </div> | |||
|                                             <p style="color:#1A202C; font-weight:600; font-size:1.2rem; margin-bottom:2px"> | |||
|                                                 Community Support</p> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                                 <div class="col-md-6 col-sm-12 p-3"> | |||
|                                     <div class="d-flex flex-column align-items-start h-100" | |||
|                                          style="padding:30px; border-radius:12px; background-color:#faf8ff"> | |||
|                                         <div class="d-flex align-items-center justify-content-center"> | |||
|                                             <div class="d-flex align-items-center justify-content-center " | |||
|                                                  style="width:36px; height:36px; border-radius:50%; background-color:#7847D9 ; margin-right:10px"> | |||
|                                                 <i class="fa fa-star  " | |||
|                                                    style="color:#fff; font-size:14px"></i> | |||
|                                             </div> | |||
|                                             <p style="color:#1A202C; font-weight:600; font-size:1.2rem; margin-bottom:2px"> | |||
|                                                 Login by using face recognition</p> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div aria-labelledby="faq-tab" | |||
|                              class="tab-pane fade show" id="faq" | |||
|                              role="tabpanel"> | |||
|                             <div class="row" | |||
|                                  style=" background-color:#fff !important"> | |||
|                                 <div class="col-md-12" aria-labelledby="faq-tab" | |||
|                                      id="faq" role="tabpanel"> | |||
|                                     <div class="accordion mb-4" id="accordion6"> | |||
|                                         <div style="background-color:#fff"> | |||
|                                             <!-- accordian --> | |||
|                                             <div class="accordion" | |||
|                                                  id="accordion_faq"> | |||
|                                                 <!-- Question 1 --> | |||
|                                                 <div class="" | |||
|                                                      style="margin:1rem 0rem"> | |||
|                                                     <div aria-expanded="false" | |||
|                                                          class=" card-header collapsed" | |||
|                                                          data-bs-toggle="collapse" | |||
|                                                          data-bs-target="#collapseFAQOne" | |||
|                                                          href="#collapseFAQOne" | |||
|                                                          aria-controls="collapseFAQOne" | |||
|                                                          style="cursor: pointer; background-color:#f8f8f8; border:none; border-top-right-radius:10px; border-top-left-radius:10px; padding: 12px 24px;"> | |||
|                                                         <a class="card-title text-decoration-none" | |||
|                                                            style=" font-size:18px; line-height:30px; font-weight:500; color:#040f3a"> | |||
|                                                             Can multiple employees use Face Recognition for login? | |||
|                                                             <img alt="" | |||
|                                                                  class="float-end" | |||
|                                                                  src="//apps.odoocdn.com/apps/assets/16.0/index_test_odoo/assets/icons/down.svg?6ef7fd7" | |||
|                                                                  width="25px"> | |||
|                                                         </a> | |||
|                                                     </div> | |||
|                                                     <div class="accordion-collapse collapse" | |||
|                                                          aria-labelledby="collapseFAQOne" | |||
|                                                          data-bs-parent="#accordion_faq" | |||
|                                                          id="collapseFAQOne" | |||
|                                                          style=" box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px; border: 1px solid #f8f8f8; border-bottom-right-radius:10px; border-bottom-left-radius:10px"> | |||
|                                                         <p style=" padding:0.75rem 1.25rem; font-size:16px; line-height:27px;  color:#888; font-weight:normal; border-bottom-right-radius:10px; border-bottom-left-radius:10px"> | |||
|                                                             Yes, any employee whose image is set in the employee profile | |||
|                                                             and is selected in the POS configuration settings can use | |||
|                                                             Face Recognition for login. | |||
|                                                         </p> | |||
|                                                     </div> | |||
|                                                 </div> | |||
|                                                 <!-- Question 2 --> | |||
|                                                 <div style="margin:1rem 0rem"> | |||
|                                                     <div aria-expanded="false" | |||
|                                                          class="cursor-pointer card-header collapsed" | |||
|                                                          data-bs-toggle="collapse" | |||
|                                                          aria-controls="collapseFAQThree" | |||
|                                                          data-bs-target="#collapseFAQThree" | |||
|                                                          style="cursor: pointer; background-color:#f8f8f8; border:1px solid #f8f8f8; border-top-right-radius:10px; border-top-left-radius:10px; padding: 12px 24px"> | |||
|                                                         <a class="card-title text-decoration-none" | |||
|                                                            style=" font-size:18px; line-height:30px; font-weight:500; color:#040f3a"> | |||
|                                                             What happens if the face does not match? | |||
|                                                             <img alt="" | |||
|                                                                  class="float-end" | |||
|                                                                  src="//apps.odoocdn.com/apps/assets/16.0/index_test_odoo/assets/icons/down.svg?6ef7fd7" | |||
|                                                                  width="25px"> | |||
|                                                         </a> | |||
|                                                     </div> | |||
|                                                     <div class="accordion-collapse collapse" | |||
|                                                          aria-labelledby="collapseFAQThree" | |||
|                                                          data-bs-parent="#accordion_faq" | |||
|                                                          id="collapseFAQThree" | |||
|                                                          style="box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px; border: 1px solid #f8f8f8; border-bottom-right-radius:10px; border-bottom-left-radius:10px"> | |||
|                                                         <p style="padding:0.75rem 1.25rem; font-size:16px; line-height:27px;  color:#888; font-weight:normal; border-bottom-right-radius:10px; border-bottom-left-radius:10px"> | |||
|                                                             If the system fails to recognize the employee's face, | |||
|                                                             login will not be allowed, and the employee may need to | |||
|                                                             retry after setting latest image in the Employee module. | |||
|                                                         </p> | |||
|                                                     </div> | |||
|                                                 </div> | |||
| 
 | |||
| 
 | |||
|                                             </div> | |||
|                                             <!--  --> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <div aria-labelledby="releases-tab" | |||
|                              class="tab-pane fade show" id="releases" | |||
|                              role="tabpanel"> | |||
|                             <!-- Release Notes --> | |||
|                             <div class="row pt-5 m-0"> | |||
|                                 <div class="col-md-3"> | |||
|                                     <h4 style="font-size:16px; font-weight:600; color:#514F4F; margin:0; line-height:26px;"> | |||
|                                         Latest Release 18.0.1.0.0 | |||
|                                     </h4> | |||
|                                     <span style="font-size:14px; color:#7A7979; display:block; margin-bottom:20px;"> | |||
|                                           27th December, 2024 | |||
|                                     </span> | |||
|                                 </div> | |||
|                                 <div class="col-md-8"> | |||
|                                     <div style="padding:0 0 40px"> | |||
|                                         <div style="margin:0 0 10px"> | |||
|                                             <div style="display:inline-block; padding:0px 8px; color:#514F4F; background-color:#FFD8D8; border-radius:20px"> | |||
|                                                 Add | |||
|                                             </div> | |||
|                                         </div> | |||
|                                         <div class="d-flex m-0" | |||
|                                              style="color:#7A7979;"> | |||
|                                             <ul class="pl-3 mb-0"> | |||
|                                                 <li> | |||
|                                                     Initial Commit | |||
|                                                 </li> | |||
| 
 | |||
|                                             </ul> | |||
|                                         </div> | |||
|                                     </div> | |||
|                                     <div style="padding:0 0 0; border-bottom:1px solid #E3E3E3"> | |||
|                                     </div> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|                 <!--  --> | |||
|                 <!-- related post --> | |||
|                 <!--  --> | |||
|                 <section class="oe_container mt32"> | |||
|                     <h2 style="color: #091E42;font-family: "Montserrat";text-align: center;margin: 25px auto;text-transform: uppercase;" | |||
|                         class="oe_slogan"> | |||
|                         <b>Related Products</b> | |||
|                     </h2> | |||
|                     <div id="demo" class="row carousel slide mt64 mb32" data-bs-ride="carousel"> | |||
|                         <!-- The slideshow --> | |||
|                         <div class="carousel-inner"> | |||
|                             <div class="carousel-item active"> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/base_accounting_kit" | |||
|                                        target="_blank" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px; padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/1.jpg"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Odoo 18 Full Accounting Kit</h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/ohrms_core" target="_blank" | |||
|                                        style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px; padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/2.jpg"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Open HRMS Core</h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/woo_commerce" | |||
|                                        target="_blank" style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px;padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/3.jpg"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Odoo WooCommerce Connector </h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="carousel-item"> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/dynamic_accounts_report" | |||
|                                        target="_blank" | |||
|                                        style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px; padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/4.png"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Odoo18 Dynamic Accounting Reports</h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/hide_menu_user" target="_blank" | |||
|                                        style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px; padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/5.jpg"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Hide Any Menu User Wise</h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" style="float: left; padding: 10px;"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/18.0/odoo_dynamic_dashboard" | |||
|                                        target="_blank" | |||
|                                        style="color: #000; text-decoration: none;"> | |||
|                                         <div style="border-radius: 6px; padding: 16px; border: 1px solid #cbcbcb;" | |||
|                                              class="shadow-sm"> | |||
|                                             <img class="img img-responsive center-block" style=" max-width: 100%;" | |||
|                                                  src="./assets/modules/6.gif"/> | |||
|                                             <h4 class="mt0 text-truncate" | |||
|                                                 style="text-align:center;width:100% margin-bottom: 8px; font-weight: 600; padding-top: 16px; text-decoration:none;font-size: 18px; padding-bottom: 8px; margin-bottom: 0px"> | |||
|                                                 Odoo Dynamic Dashboard</h4> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <!-- Left and right controls --> | |||
|                         <a class="carousel-control-prev" href="#demo" data-bs-slide="prev" | |||
|                            style="margin-left: -30px;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="#demo" data-bs-slide="next" | |||
|                            style="margin-right: -30px;width: 35px;color: #000;"> | |||
|                             <span class="carousel-control-next-icon"> | |||
|                                 <i class="fa fa-chevron-right" style="font-size:24px"></i> | |||
|                             </span> | |||
|                         </a> | |||
|                     </div> | |||
|                 </section> | |||
|                 <!-- service-section --> | |||
| 
 | |||
|                 <section id="services" class="mt-5" style="border-radius: 16px; | |||
|                                                             border: 1px solid #EBEEF2; | |||
|                                                             background: var(--Neutral-N0, #FFF); | |||
|                                                             padding: 60px 40px; | |||
|                                                             box-shadow: 0px 5px 20px -11px rgba(0, 0, 0, 0.25);"> | |||
|                     <div class="text-center mt-4"><h3 class="mb-0" style="color: #000; | |||
|                                                                   text-align: center; | |||
|                                                                   font-family: Montserrat; | |||
|                                                                   font-size: 40px; | |||
|                                                                   font-style: normal; | |||
|                                                                   font-weight: 700; | |||
|                                                                   line-height: normal; | |||
|                                                                   text-transform: uppercase; | |||
|                                                                   padding-bottom: 50px;"> | |||
|                         Our Services</h3></div> | |||
|                     <div class="row mt-3"> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#FFE2E5; margin:auto; gap: 16px; border-radius: 8px;"> | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#FA5A7D; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/gear.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|                                   color: var(--text-color); | |||
|                                   font-weight: 600;"> Odoo Customization</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#FFF4DE; margin:auto; gap: 16px; border-radius: 8px;"> | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#FF947A; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/wrench-icon.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|                     color: var(--text-color); | |||
|                     font-weight: 600;"> Odoo Implementation</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#DCFCE7; margin:auto; gap: 16px; border-radius: 8px;"> | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#3CD856; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/life-ring-icon.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|                   color: var(--text-color); | |||
|                   font-weight: 600;">Odoo Support</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#F3E8FF; margin:auto; gap: 16px; border-radius: 8px;"> | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#BF83FF; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/arrows-repeat.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|                 color: var(--text-color); | |||
|                 font-weight: 600;">Odoo Migration</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#F1F9FF; margin:auto; gap: 16px; border-radius: 8px;"> | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#01649C; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/puzzle-piece-icon.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|               color: var(--text-color); | |||
|               font-weight: 600;">Odoo integration</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#EDF8ED; margin:auto; gap: 16px; border-radius: 8px;"> | |||
| 
 | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#69CC70; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/odoo-consultancy.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|             color: var(--text-color); | |||
|             font-weight: 600;">Odoo Consultancy</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#F1F6FF; margin:auto; gap: 16px; border-radius: 8px;"> | |||
| 
 | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#2E4556; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/odoo-licencing.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|           color: var(--text-color); | |||
|           font-weight: 600;">Odoo Licensing</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                         <div class="col-lg-3 col-sm-12 mb-3"> | |||
|                             <a href="#" style="text-decoration:none"> | |||
|                                 <div class="btn-lg btn-block p-4 mb-2 d-flex flex-column justify-content-center align-items-center" | |||
|                                      style="font-size:25px; font-weight:bold;background-color:#FAF6EA; margin:auto; gap: 16px; border-radius: 8px;"> | |||
| 
 | |||
|                                     <div class="d-flex justify-content-center align-items-center" | |||
|                                          style="background-color:#FCD12C; border-radius:50%; height:56px; width:56px"> | |||
|                                         <img src="./assets/icons/hire-odoo.svg" | |||
|                                              class="img-responsive" | |||
|                                              height="28px" width="28px"> | |||
|                                     </div> | |||
|                                     <span style="font-size: 18px; | |||
|           color: var(--text-color); | |||
|           font-weight: 600;">Hire Odoo Developer</span> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                     </div> | |||
|             </div> | |||
|             <!-- licence --> | |||
|             <div class="tab-pane fade" id="profile" role="tabpanel" | |||
|                  aria-labelledby="profile-tab"> | |||
|                 <div class="px-5"> | |||
|                     .... | |||
|                 </div> | |||
|             </div> | |||
|             <!--  --> | |||
|         </div> | |||
|         </section> | |||
|         <!--  --> | |||
|     </div> | |||
| </div> | |||
| </body> | |||
| <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js"></script> | |||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.7.1/jquery.min.js" | |||
|         integrity="sha512-v2CJ7UaYy4JwqLDIrZUI/4hqeoQieOmAZNXBeQyjo21dadnwR+8ZaIJVT8EE2iyI61OV8e6M8PP2/4hpQINQ/g==" | |||
|         crossorigin="anonymous" referrerpolicy="no-referrer"></script> | |||
| <script src="https://cdnjs.cloudflare.com/ajax/libs/OwlCarousel2/2.3.4/owl.carousel.min.js"></script> | |||
| <script> | |||
|     $('.owl-carousel').owlCarousel({ | |||
|         rtl: true, | |||
|         loop: true, | |||
|         margin: 10, | |||
|         nav: true, | |||
|         responsive: { | |||
|             0: { | |||
|                 items: 1 | |||
|             }, | |||
|             600: { | |||
|                 items: 3 | |||
|             }, | |||
|             1000: { | |||
|                 items: 3 | |||
|             } | |||
|         } | |||
|     }) | |||
| </script> | |||
| </html> | |||
| @ -0,0 +1,142 @@ | |||
| /** @odoo-module **/ | |||
| import { rpc } from "@web/core/network/rpc"; | |||
| const { xml, onMounted, useState, useExternalListener, useRef } = owl; | |||
| 
 | |||
| export class ChatMsgView extends owl.Component { | |||
|     setup() { | |||
|         super.setup(...arguments); | |||
|         this.flag_scroll = 1; | |||
|         this.flag = 0; | |||
|         this.root = useRef("root"); | |||
|         onMounted(this.render_messages); | |||
|         useExternalListener(window, "click", this.ext_close_window, true); | |||
|         this.state = useState({ | |||
|             name: "", | |||
|             data: [], | |||
|             id: null | |||
|         }); | |||
|     } | |||
| 
 | |||
|     /** Function for enter key to send messages */ | |||
|     keyEnter(event) { | |||
|         if (event.key === "Enter") { | |||
|             this._onClickMessageSend(); | |||
|         } | |||
|     } | |||
| 
 | |||
|     /** Fetch old messages */ | |||
|     async render_messages() { | |||
|         try { | |||
|             const result = await rpc('/pos_systray/chat_message', { data: this.props.channel_id }); | |||
| 
 | |||
|             if (!this.root.el) return; | |||
| 
 | |||
|             let message_list = []; | |||
|             const messages = result.messages || []; | |||
| 
 | |||
|             messages.forEach((message) => { | |||
|                 const htmlString = message.body; | |||
|                 const parser = new DOMParser(); | |||
|                 const parsedHtml = parser.parseFromString(htmlString, 'text/html'); | |||
|                 const plainText = parsedHtml.documentElement.textContent; | |||
| 
 | |||
|                 message_list.push({ | |||
|                     body: plainText, | |||
|                     author: message.author, | |||
|                     flag: message.flag | |||
|                 }); | |||
|             }); | |||
| 
 | |||
|             this.state.data = message_list; | |||
|             this.state.name = result.name; | |||
|             this.state.id = result.channel_id; | |||
| 
 | |||
|             if (this.flag_scroll === 1) { | |||
|                 const element = this.root.el.querySelector("#msg_content"); | |||
|                 if (element) element.scrollTop = element.scrollHeight; | |||
|             } | |||
| 
 | |||
|             if (this.flag === 0) { | |||
|                 setTimeout(() => this.render_messages(), 1000); | |||
|                 this.flag_scroll = 0; | |||
|             } | |||
|         } catch (error) { | |||
|             console.error("Error fetching messages:", error); | |||
|         } | |||
|     } | |||
| 
 | |||
|     /** Close chat window */ | |||
|     close_window() { | |||
|         this.__owl__.remove(); | |||
|         this.flag = 1; | |||
|         this.flag_scroll = 0; | |||
|     } | |||
| 
 | |||
|     /** Close the chat window when clicking outside */ | |||
|     ext_close_window(event) { | |||
|         if (this.root.el && !this.root.el.contains(event.target)) { | |||
|             this.__owl__.remove(); | |||
|             this.flag = 1; | |||
|             this.flag_scroll = 0; | |||
|         } | |||
|     } | |||
| 
 | |||
|     /** Send message */ | |||
|     async _onClickMessageSend() { | |||
|         if (!this.root.el) return; | |||
| 
 | |||
|         const input = this.root.el.querySelector("#message_to_send"); | |||
|         const res_id = this.root.el.querySelector("#button_send")?.getAttribute("value"); | |||
| 
 | |||
|         if (!input || !res_id || !input.value.trim()) return; | |||
| 
 | |||
|         const data = { | |||
|             res_id: res_id, | |||
|             msg_body: input.value.trim() | |||
|         }; | |||
| 
 | |||
|         try { | |||
|             await rpc('/pos_chatter/send_message', { data }); | |||
|             input.value = ""; | |||
|             this.render_messages(); | |||
|         } catch (error) { | |||
|             console.error("Error sending message:", error); | |||
|         } | |||
|     } | |||
| } | |||
| 
 | |||
| ChatMsgView.template = xml` | |||
| <div id="pos_chat_view" style="position:fixed;width:325px;background:#fff;bottom:5px;right:5px;height:500px;border-radius:10px;" t-ref="root"> | |||
|     <div style="width=100%;background:#875A7B;height:36px;border-top-left-radius: 10px;border-top-right-radius: 10px;"> | |||
|         <div style="padding: 10px;display:flex;"> | |||
|             <i style="margin-left:10px;color: white;width:30px;" class="fa fa-lock" /> | |||
|             <span style="margin-left:5px;color: white;width:225px;" t-esc="state.name" /> | |||
|             <i style="color: white;width:30px;cursor: pointer;text-align: center;" t-on-click="close_window" class="fa fa-times" /> | |||
|         </div> | |||
|         <div id="msg_content" style="height:400px;background-color: white;overflow-y: scroll;"> | |||
|             <t t-foreach="state.data" t-as="data" t-key="state.id"> | |||
|                 <t t-if="data.flag == 0"> | |||
|                     <p style="text-align:left;margin-left: 10px;"> | |||
|                         <small style="color:#9c9a97;" t-esc="data.author" /><br /> | |||
|                         <t t-raw="data.body" /> | |||
|                     </p> | |||
|                 </t> | |||
|                 <t t-else=""> | |||
|                     <p style="text-align:right;margin-right: 10px;"> | |||
|                         <small style="color:#9c9a97;">You</small><br /> | |||
|                         <t t-esc="data.body" /> | |||
|                     </p> | |||
|                 </t> | |||
|             </t> | |||
|         </div> | |||
|         <hr /> | |||
|         <div class="row"> | |||
|             <div class="col-9"> | |||
|                 <input id="message_to_send" type="text" style="border:none;width: 265px;margin-left: 17px;outline:none;height: 25px;" placeholder="Message" t-on-keypress="keyEnter" /> | |||
|             </div> | |||
|             <div class="col-3"> | |||
|                 <i style="margin-left:7px;cursor: pointer;" id="button_send" class="fa fa-paper-plane" t-att-value="state.id" t-on-click="_onClickMessageSend" /> | |||
|             </div> | |||
|         </div> | |||
|     </div> | |||
| </div>`; | |||
| @ -0,0 +1,151 @@ | |||
| /** @odoo-module **/ | |||
| import { rpc } from "@web/core/network/rpc"; | |||
| const { mount, xml, onMounted, useState, useRef } = owl; | |||
| import { ChatMsgView } from "./pos_chat_view"; | |||
| 
 | |||
| export class PosMsgView extends owl.Component { | |||
|     setup() { | |||
|         super.setup(); | |||
|         this.root = useRef("root"); | |||
|         onMounted(this.render_msg_view); | |||
|         this.MsgWindow = new ChatMsgView(); | |||
|         this.state = useState({ | |||
|             data: [], | |||
|         }); | |||
|     } | |||
| 
 | |||
|     /** Fetch all chat messages */ | |||
|     render_msg_view() { | |||
|         rpc("/pos_systray/message_data").then((data) => { | |||
|             const message_list = data.map((message) => { | |||
|                 const parser = new DOMParser(); | |||
|                 const parsedHtml = parser.parseFromString(message.message_body, "text/html"); | |||
|                 const plainText = parsedHtml.documentElement.textContent; | |||
|                 return { | |||
|                     id: message.id, | |||
|                     type: message.type, | |||
|                     name: message.name, | |||
|                     message_body: plainText, | |||
|                 }; | |||
|             }); | |||
|             this.state.data = message_list; | |||
|         }); | |||
|     } | |||
| 
 | |||
|     /** Toggle visibility between All, Chat, and Channels */ | |||
|     toggleView(activeButtonId, activeSectionId) { | |||
|         ["all_message", "all_chat", "all_channels"].forEach((id) => { | |||
|             this.root.el.querySelector(`#${id}`).style.display = id === activeSectionId ? "block" : "none"; | |||
|         }); | |||
| 
 | |||
|         ["all_message_button", "all_chat_button", "all_channels_button"].forEach((id) => { | |||
|             this.root.el.querySelector(`#${id}`).style.color = id === activeButtonId ? "#000" : "#9c9a97"; | |||
|         }); | |||
|     } | |||
| 
 | |||
|     _onClickAllMessage() { | |||
|         this.toggleView("all_message_button", "all_message"); | |||
|     } | |||
| 
 | |||
|     _onClickAllChannels() { | |||
|         this.toggleView("all_channels_button", "all_channels"); | |||
|     } | |||
| 
 | |||
|     _onClickAllChat() { | |||
|         this.toggleView("all_chat_button", "all_chat"); | |||
|     } | |||
| 
 | |||
|     /** Open chat view */ | |||
|     _onClickToMessage(ev) { | |||
|         const channel_id = ev.currentTarget.getAttribute("value"); | |||
|         this.__owl__.remove(); | |||
| 
 | |||
|         if (!document.querySelector("#pos_chat_view")) { | |||
|             this.schedule_dropdown = mount(ChatMsgView, document.body, { props: { channel_id } }); | |||
|         } else { | |||
|             this.schedule_dropdown = mount(ChatMsgView, document.body, { props: { channel_id } }); | |||
|         } | |||
|     } | |||
| } | |||
| 
 | |||
| PosMsgView.template = xml` | |||
|     <div class="pos_systray_template" t-ref="root" | |||
|         style="height:auto;width:350px;background-color:#f3f3f3;position:fixed;right:5px;top:49px;padding:10px;margin: 7px 14px;"> | |||
| 
 | |||
|         <div style="display:flex;height: 27px;"> | |||
|             <p style="margin-left:10px;cursor: pointer;" id="all_message_button" | |||
|                t-on-click="_onClickAllMessage">All</p> | |||
|             <p style="margin-left:10px;cursor: pointer;color:#9c9a97;" id="all_chat_button" | |||
|                t-on-click="_onClickAllChat">Chat</p> | |||
|             <p style="margin-left:10px;cursor: pointer;color:#9c9a97;" id="all_channels_button" | |||
|                t-on-click="_onClickAllChannels">Channels</p> | |||
|         </div> | |||
| 
 | |||
|         <hr/> | |||
| 
 | |||
|         <div id="all_message"> | |||
|             <t t-foreach="state.data" t-as="data" t-key="data.id"> | |||
|                 <div style="background-color: #e7f3fe;border-left: 6px solid #2196F3; | |||
|                 margin-bottom: 15px;padding: 4px 12px;display:flex;cursor:pointer;" t-att-value="data.id" | |||
|                     t-on-click="_onClickToMessage"> | |||
| 
 | |||
|                     <div style="width:30px"> | |||
|                         <t t-if="data.type == 'channel'"> | |||
|                             <i style="margin:40%" class="fa fa-users"/> | |||
|                         </t> | |||
|                         <t t-else=""> | |||
|                             <i style="margin:40%" class="fa fa-user"/> | |||
|                         </t> | |||
|                     </div> | |||
| 
 | |||
|                     <div style="margin-left: 20px;width: 250px"> | |||
|                         <span t-esc="data.name"/> | |||
|                         <br/> | |||
|                         <small style="color:#9c9a97;" t-raw="data.message_body"/> | |||
|                     </div> | |||
|                 </div> | |||
|             </t> | |||
|         </div> | |||
| 
 | |||
|         <div id="all_chat" style="display:none"> | |||
|             <t t-foreach="state.data" t-as="data" t-key="data.id"> | |||
|                 <t t-if="data.type == 'chat'"> | |||
|                     <div style="background-color: #ddffdd;  border-left: 6px solid #04AA6D; | |||
|                     margin-bottom: 15px;padding: 4px 12px;display:flex;cursor:pointer;" t-att-value="data.id" | |||
|                          t-on-click="_onClickToMessage"> | |||
| 
 | |||
|                         <div style="width:30px"> | |||
|                             <i style="margin:8px" class="fa fa-user"/> | |||
|                         </div> | |||
| 
 | |||
|                         <div style="margin-left: 20px;width: 250px"> | |||
|                             <span t-esc="data.name"/> | |||
|                             <br/> | |||
|                             <small style="color:#9c9a97;" t-raw="data.message_body"/> | |||
|                         </div> | |||
|                     </div> | |||
|                 </t> | |||
|             </t> | |||
|         </div> | |||
| 
 | |||
|         <div id="all_channels" style="display:none"> | |||
|             <t t-foreach="state.data" t-as="data" t-key="data.id"> | |||
|                 <t t-if="data.type == 'channel'"> | |||
|                     <div style="background-color: #ffffcc;border-left: 6px solid #ffeb3b; | |||
|                         margin-bottom: 15px;padding: 4px 12px;display:flex;cursor:pointer;" t-att-value="data.id" | |||
|                          t-on-click="_onClickToMessage"> | |||
| 
 | |||
|                         <div style="width:30px"> | |||
|                             <i style="margin:8px" class="fa fa-users"/> | |||
|                         </div> | |||
| 
 | |||
|                         <div style="margin-left: 20px;width: 250px"> | |||
|                             <span t-esc="data.name"/> | |||
|                             <br/> | |||
|                             <small style="color:#9c9a97;" t-raw="data.message_body"/> | |||
|                         </div> | |||
|                     </div> | |||
|                 </t> | |||
|             </t> | |||
|         </div> | |||
|     </div>`; | |||
| @ -0,0 +1,23 @@ | |||
| /** @odoo-module **/ | |||
| import { Component, useRef } from "@odoo/owl"; | |||
| import { mount } from "@odoo/owl"; | |||
| import { Navbar } from "@point_of_sale/app/navbar/navbar"; | |||
| import { patch } from "@web/core/utils/patch"; | |||
| import { PosMsgView } from "./pos_msg_view"; | |||
| 
 | |||
| patch(Navbar.prototype, { | |||
|     setup() { | |||
|         super.setup(); | |||
|         this.message = useRef('root'); | |||
|     }, | |||
|     onClick(ev) { | |||
|         const systrayElements = document.querySelectorAll(".pos_systray_template"); | |||
|         if (systrayElements.length === 0) { | |||
|             this.schedule_dropdown = mount(PosMsgView, document.body); | |||
|         } else { | |||
|             this.schedule_dropdown?.then((res) => { | |||
|                 res.__owl__.remove(); | |||
|             }); | |||
|         } | |||
|     }, | |||
| }); | |||
| @ -0,0 +1,14 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | |||
| <templates id="template" xml:space="preserve"> | |||
|     <!-- Inherit point_of_sale.Navbar View to Modify it --> | |||
|     <t t-name="Chrome" t-inherit="point_of_sale.Navbar" | |||
|        t-inherit-mode="extension" owl="1"> | |||
|          <xpath expr="//div[hasclass('status-buttons')]" position="inside"> | |||
|               <div class="ticket-button" id="pos_systray_chatter_icon" | |||
|                    t-att-class="{ highlight: props.isTicketScreenShown }" | |||
|                    t-on-click="onClick" style="cursor: pointer;"> | |||
|                 <i class="fa fa-comments"/> | |||
|               </div> | |||
|         </xpath> | |||
|     </t> | |||
| </templates> | |||