| @ -0,0 +1,48 @@ | |||
| .. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg | |||
|     :target: https://www.gnu.org/licenses/agpl-3.0-standalone.html | |||
|     :alt: License: AGPL-3 | |||
| 
 | |||
| Odoo Screen Recording | |||
| ================================================ | |||
| * Odoo Screen Recording to record and store your screen time. | |||
| 
 | |||
| Configuration | |||
| ============= | |||
| No additional Configuration | |||
| 
 | |||
| Company | |||
| ------- | |||
| * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | |||
| 
 | |||
| License | |||
| ------- | |||
| General Public License, Version 3 (AGPL v3). | |||
| ( https://www.gnu.org/licenses/agpl-3.0-standalone.html ) | |||
| 
 | |||
| Credits | |||
| ------- | |||
| * Developer: | |||
| (V14) Anjhana A K | |||
| (V16) Megha AP | |||
| Contact: odoo@cybrosys.com | |||
| 
 | |||
| Contacts | |||
| -------- | |||
| * Mail Contact : odoo@cybrosys.com | |||
| * Website : https://cybrosys.com | |||
| 
 | |||
| Bug Tracker | |||
| ----------- | |||
| Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. | |||
| 
 | |||
| Maintainer | |||
| ========== | |||
| .. image:: https://cybrosys.com/images/logo.png | |||
|    :target: https://cybrosys.com | |||
| This module is maintained by Cybrosys Technologies. | |||
| 
 | |||
| For support and more information, please visit https://www.cybrosys.com | |||
| 
 | |||
| Further information | |||
| =================== | |||
| HTML Description: `<static/description/index.html>`__ | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author:Anjhana A K(<https://www.cybrosys.com>) | |||
| #    You can modify it under the terms of the GNU AFFERO | |||
| #    GENERAL PUBLIC LICENSE (AGPL v3), Version 3. | |||
| # | |||
| #    This program is distributed in the hope that it will be useful, | |||
| #    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
| #    GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE | |||
| #    (AGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| from . import models | |||
| @ -0,0 +1,50 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author:Anjhana A K(<https://www.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': "Odoo Screen Recording", | |||
|     'version': '14.0.1.0.0', | |||
|     'category': "Extra Tools", | |||
|     'summary': """Record your screen any time and store it for further use | |||
|      in odoo""", | |||
|     'description': 'Screen recording in Odoo helps to record multiple screen ' | |||
|                    'at a time to store or monitor the screen activities', | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'website': "https://www.cybrosys.com", | |||
|     'depends': ['base'], | |||
|     'data': [ | |||
|         'security/ir.model.access.csv', | |||
|         'views/video_store_views.xml', | |||
|         'views/assets.xml', | |||
|     ], | |||
|     'qweb': [ | |||
|         "static/src/xml/button_systray.xml", | |||
|         "static/src/xml/video_preview_widget.xml", | |||
|     ], | |||
|     'images': [ | |||
|         'static/description/banner.png' | |||
|     ], | |||
|     'license': 'AGPL-3', | |||
|     'installable': True, | |||
|     'auto_install': False, | |||
|     'application': True, | |||
| } | |||
| @ -0,0 +1,6 @@ | |||
| ## Module <odoo_screen_recording> | |||
| 
 | |||
| #### 08.01.2024 | |||
| #### Version 14.0.1.0.0 | |||
| #### ADD | |||
| - Initial commit for Odoo Screen Recording | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author:Anjhana A K(<https://www.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 video_store | |||
| @ -0,0 +1,43 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author:Anjhana A K(<https://www.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 api, fields, models | |||
| 
 | |||
| 
 | |||
| class VideoStore(models.Model): | |||
|     """In this model you can store recorded data as a record and view it | |||
|     later""" | |||
|     _name = 'video.store' | |||
|     _description = 'Screen record video storage' | |||
|     _rec_name = 'date' | |||
| 
 | |||
|     date = fields.Datetime(string='Date', default=fields.Datetime.now, | |||
|                            help="Date of screen capture") | |||
|     description = fields.Char(string='Description', | |||
|                               help='Add description for recording') | |||
|     video = fields.Char(string='Screen Record', | |||
|                         help="Recorded videos can be view here") | |||
| 
 | |||
|     @api.model | |||
|     def video_record(self, url): | |||
|         """Function used to create a record when the screen record is | |||
|          stopped""" | |||
|         self.create({'description': '', 'video': url}) | |||
|         return True | |||
| 
 | 
| After Width: | Height: | Size: 3.6 KiB | 
| After Width: | Height: | Size: 310 B | 
| After Width: | Height: | Size: 1.3 KiB | 
| After Width: | Height: | Size: 1.4 KiB | 
| After Width: | Height: | Size: 576 B | 
| After Width: | Height: | Size: 733 B | 
| After Width: | Height: | Size: 911 B | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 3.4 KiB | 
| After Width: | Height: | Size: 673 B | 
| After Width: | Height: | Size: 878 B | 
| After Width: | Height: | Size: 653 B | 
| After Width: | Height: | Size: 905 B | 
| After Width: | Height: | Size: 839 B | 
| After Width: | Height: | Size: 427 B | 
| After Width: | Height: | Size: 627 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 988 B | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 48 KiB | 
| After Width: | Height: | Size: 31 KiB | 
| After Width: | Height: | Size: 32 KiB | 
| After Width: | Height: | Size: 32 KiB | 
| After Width: | Height: | Size: 30 KiB | 
| After Width: | Height: | Size: 31 KiB | 
| After Width: | Height: | Size: 297 KiB | 
| After Width: | Height: | Size: 262 KiB | 
| After Width: | Height: | Size: 241 KiB | 
| After Width: | Height: | Size: 288 KiB | 
| After Width: | Height: | Size: 244 KiB | 
| After Width: | Height: | Size: 267 KiB | 
| After Width: | Height: | Size: 406 KiB | 
| After Width: | Height: | Size: 33 KiB | 
| After Width: | Height: | Size: 67 KiB | 
| After Width: | Height: | Size: 84 KiB | 
| After Width: | Height: | Size: 7.6 KiB | 
| @ -0,0 +1,698 @@ | |||
| <div class="container" | |||
|      style="padding: 1rem !important; margin-bottom: 1rem !important;"> | |||
|     <div class="row"> | |||
|         <div class="col-sm-12 col-md-12 col-lg-12 d-flex justify-content-between" | |||
|              style="border-bottom: 1px solid #d5d5d5;"> | |||
|             <div class="my-3"> | |||
|                 <img src="./assets/icons/logo.png" | |||
|                      style="width: auto !important; height: 40px !important;"> | |||
|             </div> | |||
|             <div> | |||
|                 <div style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | |||
|                      class="mr-2"> | |||
|                     <i class="fa fa-check mr-1"></i>Community | |||
|                 </div> | |||
|                 <div style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | |||
|                      class="mr-2"> | |||
|                     <i class="fa fa-check mr-1"></i>Enterprise | |||
|                 </div> | |||
|                 <div style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | |||
|                      class="mr-2"> | |||
|                     <i class="fa fa-check mr-1"></i>Odoo.sh | |||
|                 </div> | |||
|             </div> | |||
|         </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="container" style="padding: 0rem 1.5rem 4rem !important"> | |||
|         <div class="row" style="height: 900px !important;"> | |||
|             <div class="col-sm-12 col-md-12 col-lg-12" | |||
|                  style="padding: 4rem 1rem !important; background-color: #714B67 !important; height: 600px !important; border-radius: 20px !important;"> | |||
|                 <h1 | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #FFFFFF !important;  font-size: 3.5rem !important; text-align: center !important;"> | |||
|                      Odoo Screen Recording</h1> | |||
|                 <p | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 300 !important; color: #FFFFFF !important;  font-size: 1.4rem !important; text-align: center !important;"> | |||
|                     Record Your Screen With Odoo And Store It For Future </p> | |||
|                 <img src="assets/screenshots/hero.gif" class="img-responsive" | |||
|                      width="100%" height="auto"/> | |||
|             </div> | |||
|         </div> | |||
| 
 | |||
|         <div class="row"> | |||
|             <div class="col-md-12" | |||
|                  style="border-bottom: 1px solid #d5d5d5 !important; margin-bottom: 2rem !important"> | |||
|                 <h2 | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;"> | |||
|                     <i class="fa fa-compass mr-2"></i>Explore this module | |||
|                 </h2> | |||
|                 <div class="row"> | |||
|                     <div class="col-md-6"> | |||
|                         <a href="#overview" | |||
|                            style="text-decoration: none !important;"> | |||
|                             <div class="row" | |||
|                                  style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;"> | |||
|                                 <div class="col-8"> | |||
|                                     <h3 | |||
|                                             style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;"> | |||
|                                         Overview</h3> | |||
|                                     <p | |||
|                                             style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;"> | |||
|                                         Learn more about this module</p> | |||
|                                 </div> | |||
|                                 <div class="col-4 text-right d-flex justify-content-end align-items-center"> | |||
|                                     <i class="fa fa-chevron-right" | |||
|                                        style="color: #714B67 !important;"></i> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </a> | |||
|                     </div> | |||
|                     <div class="col-md-6"> | |||
|                         <a href="#features" | |||
|                            style="text-decoration: none !important;"> | |||
|                             <div class="row" | |||
|                                  style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;"> | |||
|                                 <div class="col-8"> | |||
|                                     <h3 | |||
|                                             style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;"> | |||
|                                         Features</h3> | |||
|                                     <p | |||
|                                             style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;"> | |||
|                                         View features of this module</p> | |||
|                                 </div> | |||
|                                 <div class="col-4 text-right d-flex justify-content-end align-items-center"> | |||
|                                     <i class="fa fa-chevron-right" | |||
|                                        style="color: #714B67 !important;"></i> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </a> | |||
|                     </div> | |||
|                     <div class="col-md-6"> | |||
|                         <a href="#screenshots" | |||
|                            style="text-decoration: none !important;"> | |||
|                             <div class="row" | |||
|                                  style="background-color: #f5f2f5 !important; border-radius: 10px !important; margin: 1rem !important; padding: 1.5em !important; height: 100px !important;"> | |||
|                                 <div class="col-8"> | |||
|                                     <h3 | |||
|                                             style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.2rem !important;"> | |||
|                                         Screenshots</h3> | |||
|                                     <p | |||
|                                             style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #714B67 !important; font-size: 0.9rem !important;"> | |||
|                                         See key screenshots of this module</p> | |||
|                                 </div> | |||
|                                 <div class="col-4 text-right d-flex justify-content-end align-items-center"> | |||
|                                     <i class="fa fa-chevron-right" | |||
|                                        style="color: #714B67 !important;"></i> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </a> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
| 
 | |||
|         </div> | |||
| 
 | |||
|         <div class="row" id="overview"> | |||
|             <div class="col-md-12" | |||
|                  style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important"> | |||
|                 <h2 | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;"> | |||
|                     <i class="fa fa-pie-chart mr-2"></i>Overview | |||
|                 </h2> | |||
|             </div> | |||
| 
 | |||
|             <div class="col-mg-12 pl-3"> | |||
|                 <p style="font-family: 'Roboto', sans-serif !important; font-weight: 400 !important; color: #282F33 !important; font-size: 1rem !important; line-height: 30px !important;"> | |||
|                     This application allows to record your screen and store and view recorded video.</p> | |||
|             </div> | |||
|         </div> | |||
|         <div class="row" id="features"> | |||
|             <div class="col-md-12" | |||
|                  style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important"> | |||
|                 <h2 | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;"> | |||
|                     <i class="fa fa-star mr-2"></i>Features | |||
|                 </h2> | |||
|             </div> | |||
|             <div class="col-md-6 pl-3 py-3 d-flex"> | |||
|                 <div> | |||
|                     <img src="assets/icons/check.png"> | |||
|                 </div> | |||
|                 <div> | |||
|                     <h4 | |||
|                             style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;"> | |||
|                         Enterprise & Community Support.</h4> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="col-md-6 pl-3 py-3 d-flex"> | |||
|                 <div> | |||
|                     <img src="assets/icons/check.png"> | |||
|                 </div> | |||
|                 <div> | |||
|                     <h4 style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;"> | |||
|                         Allows to  record your entire screen, window or Chrome tabs</h4> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="col-md-6 pl-3 py-3 d-flex"> | |||
|                 <div> | |||
|                     <img src="assets/icons/check.png"> | |||
|                 </div> | |||
|                 <div> | |||
|                     <p style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;"> | |||
|                              Can record multiple screens at a time</p> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="col-md-6 pl-3 py-3 d-flex"> | |||
|                 <div> | |||
|                     <img src="assets/icons/check.png"> | |||
|                 </div> | |||
|                 <div> | |||
|                     <p style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;"> | |||
|                         Can store the recordings in Odoo.</p> | |||
|                 </div> | |||
|             </div> | |||
|             <div class="col-md-6 pl-3 py-3 d-flex"> | |||
|                 <div> | |||
|                     <img src="assets/icons/check.png"> | |||
|                 </div> | |||
|                 <div> | |||
|                     <p style="font-family: 'Roboto', sans-serif !important; font-weight: 600 !important; color: #282F33 !important; font-size: 1.3rem !important;"> | |||
|                          Able to view and play recorded video in Odoo itself</p> | |||
|                 </div> | |||
|             </div> | |||
|         </div> | |||
|         <div class="row" id="screenshots"> | |||
|             <div class="col-md-12" | |||
|                  style="border-bottom: 1px solid #d5d5d5 !important; margin: 2rem 0 !important"> | |||
|                 <h2 | |||
|                         style="font-family: 'Montserrat', sans-serif !important; font-weight: 600 !important; color: #714B67 !important; font-size: 1.5rem !important;"> | |||
|                     <i class="fa fa-image mr-2"></i>Screenshots | |||
|                 </h2> | |||
|             </div> | |||
|             <div class="col-lg-12 my-2"> | |||
|                 <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         You can see a white camera systray  icon for recording your screen | |||
|         </p> | |||
|                 <img src="assets/screenshots/screenshot1.png" | |||
|                      class="img-responsive img-thumbnail border" width="100%" | |||
|                      height="auto"/> | |||
|             </div> | |||
|             <div class="col-lg-12 my-2"> | |||
|                 <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         After clicking camera icon a popup will appear displaying options for share your screen. Here you can find option to select tabs</p> | |||
|                 <img src="assets/screenshots/screenshot2.png" | |||
|                      class="img-responsive img-thumbnail border" width="100%" | |||
|                      height="auto"/> | |||
|                 <div class="col-lg-12 my-2"> | |||
|                    <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         Here you can see options to choose corresponding window</p> | |||
|                     <img src="assets/screenshots/screenshot3.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|                 <div class="col-lg-12 my-2"> | |||
|                    <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         You also have the option to choose the entire screen.  Simply click the "Share" button to initiate the record. | |||
|         </p> | |||
|                     <img src="assets/screenshots/screenshot4.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|                 <div class="col-lg-12 my-2"> | |||
|                    <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|          When recording starts, the white camera systray icon will change to green. To stop recording, click "Stop sharing" | |||
|       </p> | |||
|                     <img src="assets/screenshots/screenshot5.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|                 <div class="col-lg-12 my-2"> | |||
|                     <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         From the "Screen Capture" app you can access and view all the recorded videos, | |||
|       </p> | |||
|                     <img src="assets/screenshots/screenshot6.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|                    <div class="col-lg-12 my-2"> | |||
|                     <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|         In tree view , you can see the corresponding Date and Time of each video | |||
|       </p> | |||
|                     <img src="assets/screenshots/screenshot7.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|                 <div class="col-lg-12 my-2"> | |||
|                     <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"> | |||
|          In form view , you can see the corresponding Date and Time of each video You can also add description if needed.Also, you can play the video too, | |||
|       </p> | |||
|                     <img src="assets/screenshots/screenshot8.png" | |||
|                          class="img-responsive img-thumbnail border" | |||
|                          width="100%" | |||
|                          height="auto"/> | |||
|                 </div> | |||
|             </div> | |||
|             <!-- SUGGESTED PRODUCTS --> | |||
|             <div class="row"> | |||
|                 <div class="col-lg-12 d-flex flex-column justify-content-center" | |||
|                      style="text-align: center; padding: 2.5rem 1rem !important;"> | |||
|                     <h2 style="color: #212529 !important;">Suggested | |||
|                         Products</h2> | |||
|                     <hr | |||
|                             style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/> | |||
| 
 | |||
|                     <div id="demo1" class="row carousel slide" | |||
|                          data-ride="carousel"> | |||
|                         <!-- The slideshow --> | |||
|                         <div class="carousel-inner"> | |||
|                             <div class="carousel-item active" | |||
|                                  style="min-height:0px"> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/custom_receipts_for_pos/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/1.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/pos_product_addons/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/2.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/pos_report_generator/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/3.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                             <div class="carousel-item" style="min-height:0px"> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/pos_product_creation/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/4.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/product_return_pos/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/5.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                                 <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | |||
|                                      style="float:left"> | |||
|                                     <a href="https://apps.odoo.com/apps/modules/14.0/dashboard_pos/" | |||
|                                        target="_blank"> | |||
|                                         <div style="border-radius:10px"> | |||
|                                             <img class="img img-responsive center-block" | |||
|                                                  style="border-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                                  src="./assets/modules/6.png"> | |||
|                                         </div> | |||
|                                     </a> | |||
|                                 </div> | |||
|                             </div> | |||
|                         </div> | |||
|                         <!-- Left and right controls --> | |||
|                         <a class="carousel-control-prev" href="#demo1" | |||
|                            data-slide="prev" | |||
|                            style="left:-25px;width: 35px;color: #000;"> <span | |||
|                                 class="carousel-control-prev-icon"><i | |||
|                                 class="fa fa-chevron-left" | |||
|                                 style="font-size:24px"></i></span> </a> <a | |||
|                             class="carousel-control-next" href="#demo1" | |||
|                             data-slide="next" | |||
|                             style="right:-25px;width: 35px;color: #000;"> | |||
|                     <span class="carousel-control-next-icon"><i | |||
|                             class="fa fa-chevron-right" | |||
|                             style="font-size:24px"></i></span> | |||
|                     </a> | |||
|                     </div> | |||
|                 </div> | |||
|             </div> | |||
|             <!-- END OF SUGGESTED PRODUCTS --> | |||
| 
 | |||
|             <!-- OUR SERVICES --> | |||
|             <section class="container" style="margin-top: 6rem !important;"> | |||
|                 <div class="row"> | |||
|                     <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center"> | |||
|                         <h2 style="color: #212529 !important;">Our Services</h2> | |||
|                         <hr | |||
|                                 style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/cogs.png" | |||
|                                  class="img-responsive" | |||
|                                  height="48px" width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Customization</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/wrench.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Implementation</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/lifebuoy.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Support</h6> | |||
|                     </div> | |||
| 
 | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/user.png" | |||
|                                  class="img-responsive" | |||
|                                  height="48px" width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Hire | |||
|                             Odoo | |||
|                             Developer</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #54a0ff  !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/puzzle.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Integration</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/update.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Migration</h6> | |||
|                     </div> | |||
| 
 | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/consultation.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Consultancy</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/training.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Implementation</h6> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|                         <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|                              style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|                             <img src="assets/icons/license.png" | |||
|                                  class="img-responsive" height="48px" | |||
|                                  width="48px"> | |||
|                         </div> | |||
|                         <h6 class="text-center" | |||
|                             style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|                             Odoo | |||
|                             Licensing Consultancy</h6> | |||
|                     </div> | |||
|                 </div> | |||
|             </section> | |||
|             <!-- END OF OUR SERVICES --> | |||
| 
 | |||
|             <!-- OUR INDUSTRIES --> | |||
|             <section class="container" style="margin-top: 6rem !important;"> | |||
|                 <div class="row"> | |||
|                     <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center"> | |||
|                         <h2 style="color: #212529 !important;">Our | |||
|                             Industries</h2> | |||
|                         <hr | |||
|                                 style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/trading-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Trading | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Easily procure | |||
|                                 and | |||
|                                 sell your products</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/pos-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 POS | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Easy | |||
|                                 configuration | |||
|                                 and convivial experience</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/education-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Education | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 A platform for | |||
|                                 educational management</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/manufacturing-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Manufacturing | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Plan, track and | |||
|                                 schedule your operations</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/ecom-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 E-commerce & Website | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Mobile | |||
|                                 friendly, | |||
|                                 awe-inspiring product pages</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/service-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Service Management | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Keep track of | |||
|                                 services and invoice</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/restaurant-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Restaurant | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 Run your bar or | |||
|                                 restaurant methodically</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                     <div class="col-lg-3"> | |||
|                         <div class="my-4 d-flex flex-column justify-content-center" | |||
|                              style="background-color: #f6f8f9 !important; border-radius: 10px; padding: 2rem !important; height: 250px !important;"> | |||
|                             <img src="./assets/icons/hotel-black.png" | |||
|                                  class="img-responsive mb-3" height="48px" | |||
|                                  width="48px"> | |||
|                             <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|                                 Hotel Management | |||
|                             </h5> | |||
|                             <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|                                 An | |||
|                                 all-inclusive | |||
|                                 hotel management application</p> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                 </div> | |||
|             </section> | |||
| 
 | |||
|             <!-- END OF OUR INDUSTRIES --> | |||
| 
 | |||
|             <!-- FOOTER --> | |||
|             <!-- Footer Section --> | |||
|             <section class="container" style="margin: 5rem auto 2rem;"> | |||
|                 <div class="row" style="max-width:1540px;"> | |||
|                     <div class="col-lg-12 d-flex flex-column justify-content-center align-items-center"> | |||
|                         <h2 style="color: #212529 !important;">Need Help?</h2> | |||
|                         <hr | |||
|                                 style="border: 3px solid #714B67 !important; background-color: #714B67 !important; width: 80px !important; margin-bottom: 2rem !important;"/> | |||
|                     </div> | |||
|                 </div> | |||
| 
 | |||
|                 <!-- Contact Cards --> | |||
|                 <div class="row d-flex justify-content-center align-items-center" | |||
|                      style="max-width:1540px; margin: 0 auto 2rem auto;"> | |||
| 
 | |||
|                     <div class="col-lg-12" | |||
|                          style="padding: 0rem 3rem 2rem; border-radius: 10px; margin-right: 3rem; "> | |||
| 
 | |||
|                         <div class="row mt-4"> | |||
|                             <div class="col-lg-6"> | |||
|                                 <a href="mailto:odoo@cybrosys.com" | |||
|                                    target="_blank" | |||
|                                    class="btn btn-block mb-2 deep_hover" | |||
|                                    style="text-decoration: none;  background-color: #4d4d4d; color: #FFF;  border-radius: 4px;"><i | |||
|                                         class="fa fa-envelope mr-2"></i>odoo@cybrosys.com</a> | |||
|                             </div> | |||
|                             <div class="col-lg-6"> | |||
|                                 <a href="https://api.whatsapp.com/send?phone=918606827707" | |||
|                                    target="_blank" | |||
|                                    class="btn btn-block mb-2 deep_hover" | |||
|                                    style="text-decoration: none;  background-color: #25D366; color: #FFF;  border-radius: 4px;"><i | |||
|                                         class="fa fa-whatsapp mr-2"></i>+91 | |||
|                                     86068 | |||
|                                     27707</a> | |||
|                             </div> | |||
|                         </div> | |||
|                     </div> | |||
| 
 | |||
|                 </div> | |||
|                 <!-- End of Contact Cards --> | |||
|             </section> | |||
|             <!-- Footer --> | |||
|             <section class="oe_container" style="padding: 2rem 3rem 1rem;"> | |||
|                 <div class="row" | |||
|                      style="max-width:1540px; margin: 0 auto; margin-right: 3rem; "> | |||
|                     <!-- Logo --> | |||
|                     <div class="col-lg-12 d-flex justify-content-center align-items-center" | |||
|                          style="margin-top: 3rem;"> | |||
|                         <img src="https://www.cybrosys.com/images/logo.png" | |||
|                              width="200px" height="auto"/> | |||
|                     </div> | |||
|                     <!-- End of Logo --> | |||
|                     <div class="col-lg-12"> | |||
|                         <hr | |||
|                                 style="margin-top: 3rem;background: linear-gradient(90deg, rgba(2,0,36,0) 0%, rgba(229,229,229,1) 33%, rgba(229,229,229,1) 58%, rgba(0,212,255,0) 100%); height: 2px; border-style: none;"> | |||
|                         <!-- End of Footer Section --> | |||
|                     </div> | |||
|                 </div> | |||
|             </section> | |||
|             <!-- END OF FOOTER --> | |||
| 
 | |||
|         </div> | |||
|     </div> | |||
| </div> | |||
| @ -0,0 +1,79 @@ | |||
| odoo.define('odoo_screen_recording.video', function (require) { | |||
|     "use strict"; | |||
|     var SystrayMenu = require('web.SystrayMenu'); | |||
|     var Widget = require('web.Widget'); | |||
|     var rpc = require("web.rpc"); | |||
|     var VideoButton = Widget.extend({ | |||
|         template: 'ScreenCaptureSystray', | |||
|         events: { | |||
|             'click #capture_screen': '_onClick', | |||
|         }, | |||
|         _onClick: function () { | |||
|             try { | |||
|                 // Get display media stream
 | |||
|                 navigator.mediaDevices.getDisplayMedia({ video: true }) | |||
|                     .then(stream => { | |||
|                         // Change button color to indicate recording
 | |||
|                         let icon = document.querySelector(".record"); | |||
|                         icon.style.color = '#28a745'; | |||
| 
 | |||
|                         // Set up media recorder
 | |||
|                         const mime = MediaRecorder.isTypeSupported("video/webm; codecs=vp9") | |||
|                             ? "video/webm; codecs=vp9" | |||
|                             : "video/webm"; | |||
| 
 | |||
|                         let mediaRecorder = new MediaRecorder(stream, { mimeType: mime }); | |||
|                         let chunks = []; | |||
| 
 | |||
|                         // Event listener for data available
 | |||
|                         mediaRecorder.addEventListener('dataavailable', function (e) { | |||
|                             chunks.push(e.data); | |||
|                         }); | |||
| 
 | |||
|                         // Event listener for recording stop
 | |||
|                         mediaRecorder.addEventListener('stop', function () { | |||
|                             // Change button color back to default
 | |||
|                             let icon = document.querySelector(".record"); | |||
|                             icon.style.color = 'white'; | |||
| 
 | |||
|                             // Create a blob from the recorded chunks
 | |||
|                             let blob = new Blob(chunks, { type: chunks[0].type }); | |||
| 
 | |||
|                             // Convert blob to base64
 | |||
|                             const blobToBase64 = blob => { | |||
|                                 const reader = new FileReader(); | |||
|                                 reader.readAsDataURL(blob); | |||
|                                 return new Promise(resolve => { | |||
|                                     reader.onloadend = () => { | |||
|                                         resolve(reader.result); | |||
|                                     }; | |||
|                                 }); | |||
|                             }; | |||
| 
 | |||
|                             // Process the base64 result
 | |||
|                             blobToBase64(blob).then(res => { | |||
|                                 // Send the base64 data to the Odoo server
 | |||
|                                 rpc.query({ | |||
|                                     model: 'video.store', | |||
|                                     method: 'video_record', | |||
|                                     args: [res], | |||
|                                 }).then(function (response) { }); | |||
|                             }); | |||
|                         }); | |||
| 
 | |||
|                         // Start recording
 | |||
|                         mediaRecorder.start(); | |||
|                     }) | |||
|                     .catch(error => { | |||
|                         console.error('Error capturing screen:', error); | |||
|                         // Handle error as needed
 | |||
|                     }); | |||
|             } catch (e) { | |||
|                 console.error('Error:', e); | |||
|                 // Handle error as needed
 | |||
|             } | |||
|         }, | |||
|     }); | |||
|     SystrayMenu.Items.push(VideoButton); | |||
|     return VideoButton; | |||
| }); | |||
| @ -0,0 +1,16 @@ | |||
| odoo.define('odoo_screen_recording.VideoWidget', function (require) { | |||
|     "use strict"; | |||
|     var AbstractField = require('web.AbstractField'); | |||
|     var core = require('web.core'); | |||
|     var field_registry = require('web.field_registry'); | |||
|     var _t = core._t; | |||
|     var VideoWidget = AbstractField.extend({ | |||
|         template: 'VideoWidget', | |||
|         supportedFieldTypes: ['char'], | |||
|         _render: function () { | |||
|             this._super.apply(this, arguments); | |||
|             this.$el.find('video').attr('src', this.value); | |||
|         }, | |||
|     }); | |||
|     field_registry.add('videoWidget', VideoWidget); | |||
| }); | |||
| @ -0,0 +1,12 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <templates> | |||
|     <!--   Adding button to start recording--> | |||
|     <t t-name="ScreenCaptureSystray"> | |||
|         <li class="o_mail_systray_item"> | |||
|             <a class="toggle-icon" role="button"> | |||
|                     <i class="fa fa-video-camera record" id='capture_screen' | |||
|                        aria-label="Record your screen"/> | |||
|             </a> | |||
|         </li> | |||
|     </t> | |||
| </templates> | |||
| @ -0,0 +1,11 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <templates> | |||
|     <!--    Creating widget to preview video--> | |||
|     <t t-name="VideoWidget"> | |||
|         <div> | |||
|             <video width="320" height="240" controls=""> | |||
|                 <source src="" type="video/mp4"/> | |||
|             </video> | |||
|         </div> | |||
|     </t> | |||
| </templates> | |||
| @ -0,0 +1,12 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <odoo> | |||
|     <!--     Add Js File Path --> | |||
|     <template id="assets_backend" inherit_id="web.assets_backend"> | |||
|         <xpath expr="." position="inside"> | |||
|             <script type="text/javascript" | |||
|                     src="/odoo_screen_recording/static/src/js/button_systray.js"/> | |||
|             <script type="text/javascript" | |||
|                     src="/odoo_screen_recording/static/src/js/video_preview_widget.js"/> | |||
|         </xpath> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,47 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <odoo> | |||
|     <!--    View of video.store model --> | |||
|     <record id="video_store_view_tree" model="ir.ui.view"> | |||
|         <field name="name">video.store.view.tree</field> | |||
|         <field name="model">video.store</field> | |||
|         <field name="arch" type="xml"> | |||
|             <tree> | |||
|                 <field name="date"/> | |||
|                 <field name="description"/> | |||
|             </tree> | |||
|         </field> | |||
|     </record> | |||
|     <record id="video_store_view_form" model="ir.ui.view"> | |||
|         <field name="name">video.store.view.form</field> | |||
|         <field name="model">video.store</field> | |||
|         <field name="arch" type="xml"> | |||
|             <form> | |||
|                 <sheet> | |||
|                     <group> | |||
|                         <group> | |||
|                             <field name="date"/> | |||
|                             <field name="description"/> | |||
|                         </group> | |||
|                         <group> | |||
|                             <field name="video" widget="videoWidget" string=""/> | |||
|                         </group> | |||
|                     </group> | |||
|                 </sheet> | |||
|             </form> | |||
|         </field> | |||
|     </record> | |||
|     <record id="video_store_action" model="ir.actions.act_window"> | |||
|         <field name="name">Screen Capture</field> | |||
|         <field name="res_model">video.store</field> | |||
|         <field name="view_mode">tree,kanban,form</field> | |||
|         <field name="help" type="html"> | |||
|             <p class="o_view_nocontent_smiling_face"> | |||
|                 Record your screen | |||
|             </p> | |||
|         </field> | |||
|     </record> | |||
|     <menuitem id="video_store_menu" name="Screen Capture" | |||
|               sequence="0" | |||
|               web_icon="odoo_screen_recording,static/description/icon.png" | |||
|               action="video_store_action"/> | |||
| </odoo> | |||