| @ -0,0 +1,50 @@ | |||
| .. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg | |||
|     :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html | |||
|     :alt: License: AGPL-3 | |||
| 
 | |||
| Logout Idle User | |||
| ================ | |||
| user can see their personal information and can download | |||
| 
 | |||
| 
 | |||
| Configuration | |||
| ============= | |||
| * No additional configurations needed | |||
| 
 | |||
| Company | |||
| ------- | |||
| * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | |||
| 
 | |||
| Credits | |||
| ------- | |||
| * Developer : (V14) Yadhukrishnan, odoo@cybrosys.com | |||
| 
 | |||
| 
 | |||
| Contacts | |||
| -------- | |||
| * Mail Contact : odoo@cybrosys.com | |||
| * Website : https://cybrosys.com | |||
| 
 | |||
| License | |||
| ------- | |||
| Affero General Public License, Version 3 `(AGPL v3). | |||
| <http://www.gnu.org/licenses/agpl-3.0-standalone.html>`__ | |||
| 
 | |||
| 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,22 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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 | |||
| from . import models | |||
| @ -0,0 +1,44 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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': 'Logout Idle User', | |||
|     'version': '14.0.1.0.0', | |||
|     'summary': 'Auto logout idle user with fixed time', | |||
|     'description': """User can fix the timer in the user's profile, if the user | |||
|      is in idle mode the user will logout from session  | |||
|      automatically""", | |||
|     'category': 'Extra Tools', | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'website': 'https://www.cybrosys.com', | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'license': 'AGPL-3', | |||
|     'depends': ['base'], | |||
|     'images': ['static/description/banner.png'], | |||
|     'data': [ | |||
|         'views/res_users_views.xml', | |||
|         'views/assets.xml' | |||
|     ], | |||
|     'qweb': ['static/src/xml/systray.xml'], | |||
|     'installable': True, | |||
|     'application': False, | |||
|     'auto_install': False | |||
| } | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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 auto_logout_idle_user_odoo | |||
| @ -0,0 +1,50 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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 AutoLogoutIdleUSer(http.Controller): | |||
|     """ | |||
|     The EasyLanguageSelector passing minute that selected in the  login user | |||
|     account. | |||
| 
 | |||
|         Methods: | |||
|             get_idle_time(self): | |||
|                 when the page is loaded adding total activated languages options | |||
|                  to the selection field. | |||
|                 return a list variable. | |||
| 
 | |||
|     """ | |||
| 
 | |||
|     @http.route('/get_idle_time/timer', auth='public', type='json') | |||
|     def get_idle_time(self): | |||
|         """ | |||
| 
 | |||
|         Summary: | |||
|             Getting value that selected from the login user account and pass it | |||
|             to the js function. | |||
|         return: | |||
|             type:It is a variable, that contain selected minutes. | |||
| 
 | |||
|         """ | |||
|         if request.env.user.enable_idle: | |||
|             return request.env.user.idle_time | |||
| @ -0,0 +1,6 @@ | |||
| ## Module <auto_logout_idle_user_odoo> | |||
| 
 | |||
| #### 02.09.2023 | |||
| #### Version 14.0.1.0.0 | |||
| ##### ADD | |||
| - Initial Commit for Logout Idle User | |||
| @ -0,0 +1,21 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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 res_users | |||
| @ -0,0 +1,37 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################ | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: Yadhukrishnan K (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 models, fields | |||
| 
 | |||
| 
 | |||
| class ResUsers(models.Model): | |||
|     """In the class Users is used  to adding fields in 'res.users' for getting | |||
|     idle time of user""" | |||
|     _inherit = "res.users" | |||
| 
 | |||
|     enable_idle = fields.Boolean(string="Enable Idle Time", | |||
|                                  help="Enable Idle Timer") | |||
|     idle_time = fields.Integer(string="Idle Time (In minutes)", default=10, | |||
|                                help="Set Idle Time For theis User") | |||
| 
 | |||
|     _sql_constraints = [ | |||
|         ('positive_idle_time', 'CHECK(idle_time >= 1)', | |||
|          'Idle Time should be a positive number.'), | |||
|     ] | |||
| 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: 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: 1.5 KiB | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 1.9 KiB | 
| After Width: | Height: | Size: 1.1 KiB | 
| After Width: | Height: | Size: 2.1 KiB | 
| After Width: | Height: | Size: 4.4 KiB | 
| After Width: | Height: | Size: 589 B | 
| After Width: | Height: | Size: 3.4 KiB | 
| After Width: | Height: | Size: 1.7 KiB | 
| After Width: | Height: | Size: 2.3 KiB | 
| After Width: | Height: | Size: 967 B | 
| After Width: | Height: | Size: 1.6 KiB | 
| After Width: | Height: | Size: 3.8 KiB | 
| After Width: | Height: | Size: 5.0 KiB | 
| After Width: | Height: | Size: 51 KiB | 
| After Width: | Height: | Size: 52 KiB | 
| After Width: | Height: | Size: 54 KiB | 
| After Width: | Height: | Size: 52 KiB | 
| After Width: | Height: | Size: 53 KiB | 
| After Width: | Height: | Size: 136 KiB | 
| After Width: | Height: | Size: 77 KiB | 
| After Width: | Height: | Size: 415 KiB | 
| After Width: | Height: | Size: 97 KiB | 
| After Width: | Height: | Size: 46 KiB | 
| After Width: | Height: | Size: 7.4 KiB | 
| After Width: | Height: | Size: 21 KiB | 
| After Width: | Height: | Size: 129 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 801 B | 
| After Width: | Height: | Size: 3.4 KiB | 
| After Width: | Height: | Size: 51 KiB | 
| After Width: | Height: | Size: 52 KiB | 
| After Width: | Height: | Size: 53 KiB | 
| After Width: | Height: | Size: 52 KiB | 
| After Width: | Height: | Size: 54 KiB | 
| After Width: | Height: | Size: 142 KiB | 
| After Width: | Height: | Size: 3.5 KiB | 
| After Width: | Height: | Size: 2.3 KiB | 
| After Width: | Height: | Size: 3.7 KiB | 
| @ -0,0 +1,543 @@ | |||
| <div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;"> | |||
|   <!-- TITLE BAR --> | |||
|   <div class="d-flex align-items-center justify-content-between" | |||
|     style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;"> | |||
|     <img src="assets/misc/cybrosys-logo.png" width="42" height="42" style="width: 42px; height: 42px;" /> | |||
|     <div> | |||
|       <div | |||
|         style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | |||
|         class="mr-2"> | |||
|         <i class="fa fa-check mr-1"></i>Community | |||
|       </div> | |||
|       <div | |||
|         style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | |||
|         class="mr-2"> | |||
|         <i class="fa fa-check mr-1"></i>Odoo.sh | |||
|       </div> | |||
|     </div> | |||
|   </div> | |||
|   <!-- END OF TITLE BAR --> | |||
|   <div class="container"> | |||
|     <div class="row"> | |||
|       <div class="col-sm-12 col-md-12 col-lg-12"> | |||
|         <!-- APP HERO --> | |||
|         <h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;"> | |||
|           Logout Idle User | |||
|         </h1> | |||
|         <p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">Logout the User in Idle Mode.</p> | |||
|         <!-- END OF APP HERO --> | |||
|         <img src="assets/screenshots/hero.gif" class="img-responsive" | |||
|           style="width: 100%; margin-left: auto; margin-right: auto;"/> | |||
|       </div> | |||
|     </div> | |||
|   </div> | |||
| </div> | |||
| 
 | |||
| <!-- NAVIGATION SECTION --> | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px; margin-top: 300px;"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/compass.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Explore This | |||
|     Module</h2> | |||
| </div> | |||
| <div class="row my-4" style="font-family: 'Montserrat', sans-serif;"> | |||
|   <div class="col-sm-12 col-md-6 my-3"> | |||
|     <a href="#overview"> | |||
|       <div class="d-flex justify-content-between align-items-center" | |||
|         style="background-color: #f5f5f5; padding: 30px; width: 100%;"> | |||
|         <div> | |||
|           <span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Overview</span> | |||
|           <span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33;  display: block;">Learn | |||
|             more about this | |||
|             module</span> | |||
|         </div> | |||
|         <img src="assets/misc/right-arrow.png" width="36" height="36" /> | |||
|       </div> | |||
|     </a> | |||
|   </div> | |||
|   <div class="col-sm-12 col-md-6 my-3"> | |||
|     <a href="#features"> | |||
|       <div class="d-flex justify-content-between align-items-center" | |||
|         style="background-color: #f5f5f5; padding: 30px; width: 100%;"> | |||
|         <div> | |||
|           <span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Features</span> | |||
|           <span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33;  display: block;">View | |||
|             features of this | |||
|             module</span> | |||
|         </div> | |||
|         <img src="assets/misc/right-arrow.png" width="36" height="36" /> | |||
|       </div> | |||
|     </a> | |||
|   </div> | |||
|   <div class="col-sm-12 col-md-6 my-3"> | |||
|     <a href="#screenshots"> | |||
|       <div class="d-flex justify-content-between align-items-center" | |||
|         style="background-color: #f5f5f5; padding: 30px; width: 100%;"> | |||
|         <div> | |||
|           <span style="color: #714B67; font-size: 24px; font-weight: 500; display: block;">Screenshots</span> | |||
|           <span style="color: #714B67; font-size: 16px; font-weight: 400; color:#282F33;  display: block;">View | |||
|             screenshots for this | |||
|             module</span> | |||
|         </div> | |||
|         <img src="assets/misc/right-arrow.png" width="36" height="36" /> | |||
|       </div> | |||
|     </a> | |||
|   </div> | |||
| </div> | |||
| <!-- END OF NAVIGATION SECTION --> | |||
| 
 | |||
| <!-- OVERVIEW SECTION --> | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="overview"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/pie-chart.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Overview | |||
|   </h2> | |||
| </div> | |||
| <div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> | |||
|   <div class="col-sm-12 py-4"> | |||
|     When the user in idle mode, this module redirect to the login page after a fixed time. | |||
|   </div> | |||
| 
 | |||
| </div> | |||
| <!-- END OF OVERVIEW SECTION --> | |||
| 
 | |||
| <!-- FEATURES SECTION --> | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="features"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/features.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Features | |||
|   </h2> | |||
| </div> | |||
| <div class="row" style="font-family: 'Montserrat', sans-serif; font-weight: 400; font-size: 14px; line-height: 200%;"> | |||
|   <div class="col-sm-12 col-md-6"> | |||
|     <div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px"> | |||
|       <img src="assets/misc/check-box.png" class="mr-2" /> | |||
|       <span style="font-family: 'Montserrat', sans-serif; font-size:  18px; font-weight: bold;">A protection to your odoo session.</span> | |||
|     </div> | |||
|   </div> | |||
|   <div class="col-sm-12 col-md-6"> | |||
|     <div class="d-flex align-items-center" style="margin-top: 30px; margin-bottom: 30px"> | |||
|       <img src="assets/misc/check-box.png" class="mr-2" /> | |||
|       <span style="font-family: 'Montserrat', sans-serif; font-size:  18px; font-weight: bold;">User can set their idle time in their profile.</span> | |||
|     </div> | |||
|   </div> | |||
| </div> | |||
| <!-- END OF FEATURES SECTION --> | |||
| 
 | |||
| <!-- SCREENSHOTS SECTION --> | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;" id="screenshots"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/pictures.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Screenshots | |||
|   </h2> | |||
| </div> | |||
| <div class="row"> | |||
|   <div class="col-sm-12"> | |||
| 
 | |||
|     <div style="display: block; margin: 30px auto;"> | |||
|       <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Idle Timer</h3> | |||
|       <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">User need to enable the option idle timer under Settings ->  Users & Companies -> Users  -> Preferences after that set time for idle.</p> | |||
|       <img src="assets/screenshots/Screenshot.png" class="img-thumbnail"> | |||
|     </div> | |||
| 
 | |||
|     <div style="display: block; margin: 30px auto;"> | |||
|      <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Timer On Systray | |||
|      </h3> | |||
|       <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">After completion of above step a timer will be displayed in the systray | |||
|       </p> | |||
|       <img src="assets/screenshots/Screenshot2.png" class="img-thumbnail"> | |||
|     </div> | |||
| 
 | |||
|     <div style="display: block; margin: 30px auto;"> | |||
|       <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Logout User | |||
|       </h3> | |||
|       <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">After completion of timer the user will be logout automatically. | |||
|       </p> | |||
|       <img src="assets/screenshots/Screenshot3.png" class="img-thumbnail"> | |||
|     </div> | |||
|   </div> | |||
|   </div> | |||
| <!-- END OF SCREENSHOTS SECTION --> | |||
| 
 | |||
|         <!-- 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/product_approval_management/" | |||
|                            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/l1.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/dynamic_accounts_report/" | |||
|                            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/l2.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/shopify_odoo_connector/" | |||
|                            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/l3.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/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/l4.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/multiple_reference_per_product/" | |||
|                            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/l5.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> | |||
| <!-- OUR SERVICES --> | |||
| 
 | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/star.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our Services | |||
|   </h2> | |||
| </div> | |||
| 
 | |||
| <div class="container my-5"> | |||
|   <div class="row"> | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #1dd1a1 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/cogs.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Customization</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #ff6b6b !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/wrench.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Implementation</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #6462CD !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/lifebuoy.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Support</h6> | |||
|     </div> | |||
| 
 | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #ffa801 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/user.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Hire | |||
|         Odoo | |||
|         Developer</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #54a0ff  !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/puzzle.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Integration</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #6d7680 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/update.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Migration</h6> | |||
|     </div> | |||
| 
 | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #786fa6 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/consultation.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Consultancy</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #f8a5c2 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/training.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Implementation</h6> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-4 d-flex flex-column justify-content-center align-items-center my-4"> | |||
|       <div class="d-flex justify-content-center align-items-center mx-3 my-3" | |||
|         style="background-color: #e6be26 !important; border-radius: 15px !important; height: 80px; width: 80px;"> | |||
|         <img src="assets/icons/license.png" class="img-responsive" height="48px" width="48px"> | |||
|       </div> | |||
|       <h6 class="text-center" style="font-family: Montserrat, 'sans-serif' !important; font-weight: bold;"> | |||
|         Odoo | |||
|         Licensing Consultancy</h6> | |||
|     </div> | |||
|   </div> | |||
| 
 | |||
| </div> | |||
| 
 | |||
| <!-- END OF OUR SERVICES --> | |||
| 
 | |||
| <!-- OUR INDUSTRIES --> | |||
| 
 | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/corporate.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Our | |||
|     Industries | |||
|   </h2> | |||
| </div> | |||
| 
 | |||
| <div class="container my-5"> | |||
|   <div class="row"> | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/trading-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Trading | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Easily procure | |||
|           and | |||
|           sell your products</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/pos-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           POS | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Easy | |||
|           configuration | |||
|           and convivial experience</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/education-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Education | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           A platform for | |||
|           educational management</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/manufacturing-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Manufacturing | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Plan, track and | |||
|           schedule your operations</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/ecom-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           E-commerce & Website | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Mobile | |||
|           friendly, | |||
|           awe-inspiring product pages</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/service-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Service Management | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Keep track of | |||
|           services and invoice</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/restaurant-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Restaurant | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           Run your bar or | |||
|           restaurant methodically</p> | |||
|       </div> | |||
|     </div> | |||
| 
 | |||
|     <div class="col-lg-3"> | |||
|       <div class="my-4 d-flex flex-column justify-content-center" | |||
|         style="background-color: #f6f8f9 !important; border-radius: 0px; padding: 2rem !important; height: 250px !important;"> | |||
|         <img src="assets/icons/hotel-black.png" class="img-responsive mb-3" height="48px" width="48px"> | |||
|         <h5 style="font-family: Montserrat, sans-serif !important; color: #000 !important; font-weight: bold;"> | |||
|           Hotel Management | |||
|         </h5> | |||
|         <p style="font-family: Montserrat, sans-serif !important; font-size: 0.9rem !important;"> | |||
|           An | |||
|           all-inclusive | |||
|           hotel management application</p> | |||
|       </div> | |||
|     </div> | |||
|   </div> | |||
| </div> | |||
| 
 | |||
| <!-- END OF OUR INDUSTRIES --> | |||
| 
 | |||
| <!-- SUPPORT --> | |||
| <div class="d-flex align-items-center" style="border-bottom: 2px solid #714B67; padding: 15px 0px;"> | |||
|   <div class="d-flex justify-content-center align-items-center mr-2" | |||
|     style="background-color: #F5F5F5; border-radius: 0px; width: 40px; height: 40px;"> | |||
|     <img src="assets/misc/customer-support.png" /> | |||
|   </div> | |||
|   <h2 class="mt-2" style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;">Support | |||
|   </h2> | |||
| </div> | |||
| <div class="container mt-5"> | |||
|   <div class="row"> | |||
|     <div class="col-sm-12 col-md-6"> | |||
|       <div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;"> | |||
|         <div class="mr-4 d-flex justify-content-center align-items-center" | |||
|           style="background-color: #714B67; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;"> | |||
|           <img src="assets/misc/support.png" height="48" width="48" style="width: 42px; height: 42px;" /> | |||
|         </div> | |||
|         <div> | |||
|           <h4>Need Help?</h4> | |||
|           <p style="line-height: 100%;">Got questions or need help? Get in touch.</p> | |||
|           <a href="mailto:odoo@cybrosys.com"> | |||
|             <p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;"> | |||
|               odoo@cybrosys.com</p> | |||
|           </a> | |||
|         </div> | |||
|       </div> | |||
|     </div> | |||
|     <div class="col-sm-12 col-md-6"> | |||
|       <div style="background-color: #F6F8F9; padding: 30px; display: flex; align-items: center;"> | |||
|         <div class="mr-4 d-flex justify-content-center align-items-center" | |||
|           style="background-color: #2AC44D; display: inline-block; height: 70px; width: 70px; display: flex; align-items: center; justify-content: center;"> | |||
|           <img src="assets/misc/whatsapp.png" height="52" width="52" style="width: 52px; height: 52px;" /> | |||
|         </div> | |||
|         <div> | |||
|           <h4>WhatsApp</h4> | |||
|           <p style="line-height: 100%;">Say hi to us on WhatsApp!</p> | |||
|           <a href="https://api.whatsapp.com/send?phone=918606827707"> | |||
|             <p style="font-weight: 400; font-size: 28px; line-height: 80%; color: #714B67;">+91 86068 | |||
|               27707</p> | |||
|           </a> | |||
|         </div> | |||
|       </div> | |||
|     </div> | |||
|   </div> | |||
|   <div class="row"> | |||
|     <div class="col-sm-12 my-5 d-flex justify-content-center align-items-center"> | |||
|       <img src="assets/misc/logo.png" width="144" height="31" style="width:144px; height: 31px; margin-top: 40px;" /> | |||
|     </div> | |||
|   </div> | |||
| </div> | |||
| <!-- END OF SUPPORT --> | |||
| @ -0,0 +1,122 @@ | |||
| odoo.define('auto_logout_idle_user_odoo.systray', function(require) { | |||
|     "use strict"; | |||
|     var SystrayMenu = require('web.SystrayMenu'); | |||
|     var Widget = require('web.Widget'); | |||
|     var ajax = require('web.ajax'); | |||
|     var TimerWidget = Widget.extend({ | |||
|         template: 'TimerSystray', | |||
|         willStart: function() { | |||
|             var self = this; | |||
|             return this._super().then(function() { | |||
|                 self.get_idle_time(); | |||
|             }); | |||
|         }, | |||
|         /** | |||
|         Getting minutes through python for the corresponding user | |||
|         */ | |||
|         get_idle_time: function() { | |||
|             var self = this | |||
|             var now = new Date().getTime(); | |||
|             ajax.rpc('/get_idle_time/timer').then(function(data) { | |||
|                 if (data) { | |||
|                     self.minutes = data | |||
|                     self.idle_timer() | |||
|                 } | |||
|             }) | |||
|         }, | |||
|         /** | |||
|         Passing values of the countdown to the xml | |||
|         */ | |||
|         idle_timer: function() { | |||
|             var self = this; | |||
|             var nowt = new Date().getTime(); | |||
|             var date = new Date(nowt); | |||
|             date.setMinutes(date.getMinutes() + self.minutes); | |||
|             var updatedTimestamp = date.getTime(); | |||
|             /** Running the count down using setInterval function */ | |||
|             var idle = setInterval(function() { | |||
|                 var now = new Date().getTime(); | |||
|                 var distance = updatedTimestamp - now; | |||
|                 var days = Math.floor(distance / (1000 * 60 * 60 * 24)); | |||
|                 var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); | |||
|                 var minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60)); | |||
|                 var seconds = Math.floor((distance % (1000 * 60)) / 1000); | |||
|                 if (hours && days) { | |||
|                     self.el.querySelector("#idle_timer").innerHTML = days + "d " + hours + "h " + minutes + "m " + seconds + "s "; | |||
|                 } else if (hours) { | |||
|                     self.el.querySelector("#idle_timer").innerHTML = hours + "h " + minutes + "m " + seconds + "s "; | |||
|                 } else { | |||
|                     self.el.querySelector("#idle_timer").innerHTML = minutes + "m " + seconds + "s "; | |||
|                     if(minutes == 1 && seconds == 0){ | |||
|                          self.displayNotification({ | |||
|                             message: ("You will be logged out in 1 minute."), | |||
|                             sticky: true, | |||
|                         }) | |||
|                     } | |||
|                 } | |||
|                 /** If the countdown is zero the link is redirect to the login page*/ | |||
|                 if (distance < 0) { | |||
|                     clearInterval(idle); | |||
|                     self.el.querySelector("#idle_timer").innerHTML = "EXPIRED"; | |||
|                     location.replace("/web/session/logout") | |||
|                 } | |||
|             }, 1000); | |||
|             /** | |||
|             Checking if the onmousemove event is occur | |||
|             */ | |||
|             document.onmousemove = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
| 
 | |||
|             }; | |||
|             /** | |||
|             Checking if the onkeypress event is occur | |||
|             */ | |||
|             document.onkeypress = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
|             }; | |||
|             /** | |||
|             Checking if the onclick event is occur | |||
|             */ | |||
|             document.onclick = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
|             }; | |||
|             /** | |||
|             Checking if the ontouchstart event is occur | |||
|             */ | |||
|             document.ontouchstart = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
|             } | |||
|             /** | |||
|             Checking if the onmousedown event is occur | |||
|             */ | |||
|             document.onmousedown = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
|             } | |||
|             /** | |||
|             Checking if the onload event is occur | |||
|             */ | |||
|             document.onload = () => { | |||
|                 var nowt = new Date().getTime(); | |||
|                 var date = new Date(nowt); | |||
|                 date.setMinutes(date.getMinutes() + self.minutes); | |||
|                 updatedTimestamp = date.getTime(); | |||
|             } | |||
|         }, | |||
|     }); | |||
|     SystrayMenu.Items.push(TimerWidget); | |||
| }) | |||
| @ -0,0 +1,10 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <templates> | |||
|     <!--    Adding icon to systray --> | |||
|     <t t-name="TimerSystray"> | |||
|         <li style="display:flex;margin-top: 16px;" t-ref="root"> | |||
|             <i class="fa fa-clock-o systray-icon"/> | |||
|             <p id="idle_timer" style="margin-top: -3px;margin-left: 3px;"/> | |||
|         </li> | |||
|     </t> | |||
| </templates> | |||
| @ -0,0 +1,8 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <template id="assets_backend" name="im assets" inherit_id="web.assets_backend"> | |||
|         <xpath expr="." position="inside"> | |||
|             <script type="text/javascript" src="/auto_logout_idle_user_odoo/static/src/js/systray.js"/> | |||
|         </xpath> | |||
|     </template> | |||
| </odoo> | |||
| @ -0,0 +1,19 @@ | |||
| <?xml version="1.0" encoding="Big5" ?> | |||
| <odoo> | |||
|     <!-- Inherit Form View to Modify it --> | |||
|     <record id="res_users_view_form" model="ir.ui.view"> | |||
|         <field name="name">res.users.view.form.inherit.auto.logout.idle.user.odoo</field> | |||
|         <field name="model">res.users</field> | |||
|         <field name="inherit_id" ref="base.view_users_form"/> | |||
|         <field name="arch" type="xml"> | |||
|             <xpath expr="//group[@name='messaging']" position="after"> | |||
|                 <group> | |||
|                     <group string="IDLE TIMER"> | |||
|                         <field name="enable_idle" /> | |||
|                         <field name="idle_time" widget="float_time"  attrs="{'invisible': [('enable_idle', '=', False)]}"/> | |||
|                     </group> | |||
|                 </group> | |||
|             </xpath> | |||
|         </field> | |||
|     </record> | |||
| </odoo> | |||