| @ -0,0 +1,45 @@ | |||||
|  | .. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg | ||||
|  |     :target: https://www.gnu.org/licenses/gpl-3.0-standalone.html | ||||
|  |     :alt: License: AGPL-3 | ||||
|  | Password Hint | ||||
|  | ============= | ||||
|  | This module helps you to add a password hint when sign up so that you can use it during login. | ||||
|  | 
 | ||||
|  | Configuration | ||||
|  | ============= | ||||
|  | * No additional configurations needed | ||||
|  | 
 | ||||
|  | Company | ||||
|  | ------- | ||||
|  | * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | ||||
|  | 
 | ||||
|  | License | ||||
|  | ------- | ||||
|  | GNU AFFERO GENERAL PUBLIC LICENSE Version 3 (AGPL v3). | ||||
|  | (https://www.gnu.org/licenses/gpl-3.0-standalone.html) | ||||
|  | 
 | ||||
|  | Credits | ||||
|  | ------- | ||||
|  | * Developers: V(14) Mohamed Muzammil VP odoo@cybrosys.com | ||||
|  | 
 | ||||
|  | Contacts | ||||
|  | -------- | ||||
|  | * Mail Contact : odoo@cybrosys.com | ||||
|  | * Website : https://cybrosys.com | ||||
|  | 
 | ||||
|  | Bug Tracker | ||||
|  | ----------- | ||||
|  | Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. | ||||
|  | 
 | ||||
|  | Maintainer | ||||
|  | ========== | ||||
|  | .. image:: https://cybrosys.com/images/logo.png | ||||
|  |    :target: https://cybrosys.com | ||||
|  | 
 | ||||
|  | This module is maintained by Cybrosys Technologies. | ||||
|  | 
 | ||||
|  | For support and more information, please visit `Our Website <https://cybrosys.com/>`__ | ||||
|  | 
 | ||||
|  | Further information | ||||
|  | =================== | ||||
|  | HTML Description: `<static/description/index.html>`__ | ||||
| @ -0,0 +1,23 @@ | |||||
|  | # -*- coding: utf-8 -*- | ||||
|  | ############################################################################### | ||||
|  | # | ||||
|  | #    Cybrosys Technologies Pvt. Ltd. | ||||
|  | # | ||||
|  | #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | ||||
|  | #    Author: Mohamed Muzammil VP (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,45 @@ | |||||
|  | # -*- coding: utf-8 -*- | ||||
|  | ############################################################################### | ||||
|  | # | ||||
|  | #    Cybrosys Technologies Pvt. Ltd. | ||||
|  | # | ||||
|  | #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | ||||
|  | #    Author: Mohamed Muzammil VP (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': 'Password Hint ', | ||||
|  |     'version': '14.0.1.0.0', | ||||
|  |     'category': 'Extra Tools', | ||||
|  |     'summary': 'This Module Allows To Set An Password Hint', | ||||
|  |     'description': 'Enhance password recovery with a personalized clue for ' | ||||
|  |                    'your login credentials, ensuring easier recall without ' | ||||
|  |                    'compromising security.', | ||||
|  |     'author': 'Cybrosys Techno Solutions', | ||||
|  |     'company': 'Cybrosys Techno Solutions', | ||||
|  |     'maintainer': 'Cybrosys Techno Solutions', | ||||
|  |     'website': "https://cybrosys.com/", | ||||
|  |     'depends': ['base', 'web', 'auth_signup'], | ||||
|  |     'data': [ | ||||
|  |         'views/assets.xml', | ||||
|  |         'views/res_users_views.xml', | ||||
|  |         'views/auth_signup_login_templates.xml', | ||||
|  |     ], | ||||
|  |     'images': ['static/description/banner.png'], | ||||
|  |     'license': 'AGPL-3', | ||||
|  |     'installable': True, | ||||
|  |     'auto_install': False, | ||||
|  |     'application': False, | ||||
|  | } | ||||
| @ -0,0 +1,22 @@ | |||||
|  | # -*- coding: utf-8 -*- | ||||
|  | ############################################################################### | ||||
|  | # | ||||
|  | #    Cybrosys Technologies Pvt. Ltd. | ||||
|  | # | ||||
|  | #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | ||||
|  | #    Author: Mohamed Muzammil VP (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 password_hint | ||||
| @ -0,0 +1,63 @@ | |||||
|  | # -*- coding: utf-8 -*- | ||||
|  | ############################################################################### | ||||
|  | # | ||||
|  | #    Cybrosys Technologies Pvt. Ltd. | ||||
|  | # | ||||
|  | #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | ||||
|  | #    Author: Mohamed Muzammil VP (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 | ||||
|  | from odoo.addons.auth_signup.controllers.main import AuthSignupHome | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | class PasswordHint(AuthSignupHome): | ||||
|  |     """ | ||||
|  |         A class that handles password hints during user signup and retrieval. | ||||
|  |         Inherits from AuthSignupHome, a class that provides authentication and | ||||
|  |         signup functionality for web users in the Odoo web application | ||||
|  |         framework. | ||||
|  |     """ | ||||
|  |     @http.route('/web/signup', type='http', auth='public', website=True, | ||||
|  |                 sitemap=False) | ||||
|  |     def web_auth_signup(self, *args, **kw): | ||||
|  |         """ | ||||
|  |         Handle user signup and set password hint if provided. | ||||
|  |         Args: | ||||
|  |             *args: Variable-length argument list. | ||||
|  |             **kw: Keyword arguments. | ||||
|  |         Returns: | ||||
|  |             Result of calling the parent method. | ||||
|  |         """ | ||||
|  |         res = super(PasswordHint, self).web_auth_signup() | ||||
|  |         if kw.get('hint'): | ||||
|  |             user = request.env['res.users'].sudo().search( | ||||
|  |                 [('login', '=', kw['login'])]) | ||||
|  |             user.password_hint = kw.get('hint') | ||||
|  |         return res | ||||
|  | 
 | ||||
|  |     @http.route('/website/password/hint', type='json', auth='public', | ||||
|  |                 website=True) | ||||
|  |     def button_password_hint(self, params): | ||||
|  |         """ | ||||
|  |         Retrieve password hint for a given user login. | ||||
|  |         Args: | ||||
|  |             params: JSON object containing user login. | ||||
|  |         Returns: | ||||
|  |             JSON response containing password hint. | ||||
|  |         """ | ||||
|  |         return request.env['res.users'].sudo().search( | ||||
|  |             [('login', '=', params)]).password_hint | ||||
| @ -0,0 +1,6 @@ | |||||
|  | ## Module <password_hint> | ||||
|  | 
 | ||||
|  | #### 09.01.2024 | ||||
|  | #### Version 14.0.1.0.0 | ||||
|  | #### ADD | ||||
|  | - Initial Commit for Password Hint | ||||
| @ -0,0 +1,22 @@ | |||||
|  | # -*- coding: utf-8 -*- | ||||
|  | ############################################################################### | ||||
|  | # | ||||
|  | #    Cybrosys Technologies Pvt. Ltd. | ||||
|  | # | ||||
|  | #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | ||||
|  | #    Author: Mohamed Muzammil VP (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: Mohamed Muzammil VP (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 fields, models | ||||
|  | 
 | ||||
|  | 
 | ||||
|  | class ResUsers(models.Model): | ||||
|  |     """ | ||||
|  |      This model extends the 'res.users' model to add a 'password_hint' field | ||||
|  |      that stores the password hint provided by users during sign-up. | ||||
|  |      Fields: | ||||
|  |          password_hint (Char): A string field that stores the password hint | ||||
|  |          provided by users during sign-up. | ||||
|  |      """ | ||||
|  |     _inherit = 'res.users' | ||||
|  | 
 | ||||
|  |     password_hint = fields.Char(string='Password Hint', | ||||
|  |                                 help='This field stores the password hint ' | ||||
|  |                                      'provided during sign-up.') | ||||
| 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: 59 KiB | 
| After Width: | Height: | Size: 57 KiB | 
| After Width: | Height: | Size: 58 KiB | 
| After Width: | Height: | Size: 57 KiB | 
| After Width: | Height: | Size: 50 KiB | 
| After Width: | Height: | Size: 51 KiB | 
| After Width: | Height: | Size: 532 KiB | 
| After Width: | Height: | Size: 80 KiB | 
| After Width: | Height: | Size: 550 KiB | 
| After Width: | Height: | Size: 300 KiB | 
| After Width: | Height: | Size: 247 KiB | 
| After Width: | Height: | Size: 246 KiB | 
| After Width: | Height: | Size: 146 KiB | 
| After Width: | Height: | Size: 44 KiB | 
| After Width: | Height: | Size: 8.0 KiB | 
| @ -0,0 +1,639 @@ | |||||
|  | <div style="background-color: #714B67; height: 810px; width: 100%; padding: 15px; position: relative;"> | ||||
|  |    <!-- TITLE BAR --> | ||||
|  |    <div class="d-flex align-items-center justify-content-between" | ||||
|  |       style="border-bottom: 1px solid #875A7B; padding: 15px; display: flex; justify-content: space-between; align-items: center;"> | ||||
|  |       <img src="assets/misc/cybrosys-logo.png" width="42" height="42" | ||||
|  |          style="width: 42px; height: 42px;"/> | ||||
|  |       <div> | ||||
|  |          <div | ||||
|  |             style="color: #7C7BAD; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | ||||
|  |             class="mr-2"> | ||||
|  |             <i class="fa fa-check mr-1"></i>Community | ||||
|  |          </div> | ||||
|  |          <div | ||||
|  |             style="color: #875A7B; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;" | ||||
|  |             class="mr-2"> | ||||
|  |             <i class="fa fa-check mr-1"></i>Enterprise | ||||
|  |          </div> | ||||
|  | <!--         <div--> | ||||
|  | <!--            style="color: #017E84; font-size: 14px; font-family: 'Montserrat', sans-serif; font-weight: bold; background-color: white; display: inline-block; padding: 3px 10px; border-radius: 50px;"--> | ||||
|  | <!--            class="mr-2">--> | ||||
|  | <!--            <i class="fa fa-check mr-1"></i>Odoo.sh--> | ||||
|  | <!--         </div>--> | ||||
|  |       </div> | ||||
|  |    </div> | ||||
|  |    <!-- END OF TITLE BAR --> | ||||
|  |    <div class="container"> | ||||
|  |       <div class="row"> | ||||
|  |          <div class="col-sm-12 col-md-12 col-lg-12"> | ||||
|  |             <!-- APP HERO --> | ||||
|  |             <h1 style="color: #FFFFFF; font-weight: bolder; font-size: 50px; text-align: center; margin-top: 50px;"> | ||||
|  |                Password Hint | ||||
|  |             </h1> | ||||
|  |             <p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;"> | ||||
|  |                Set Password Hint for Users to Remember Password. | ||||
|  |             </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"> | ||||
|  |       In most password systems, users are required to create a unique and | ||||
|  |       strong | ||||
|  |       password for security purposes. However, passwords can be forgotten, | ||||
|  |       especially if they are complex and not frequently used. A password hint | ||||
|  |       is a feature in password systems that helps users remember their | ||||
|  |       password. | ||||
|  |    </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: 40px; margin-bottom: 40px"> | ||||
|  |          <img src="assets/misc/check-box.png" class="mr-2"/> | ||||
|  |          <span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Community & | ||||
|  |          Enterprise Support.</span> | ||||
|  |       </div> | ||||
|  |       <div class="d-flex align-items-center" | ||||
|  |          style="margin-top: 30px; margin-bottom: 30px"> | ||||
|  |          <img src="assets/misc/check-box.png" class="mr-2"/> | ||||
|  |          <span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Set Password reminder when sign up. | ||||
|  |          </span> | ||||
|  |       </div> | ||||
|  |       <div class="d-flex align-items-center" | ||||
|  |          style="margin-top: 30px; margin-bottom: 30px"> | ||||
|  |          <img src="assets/misc/check-box.png" class="mr-2"/> | ||||
|  |          <span style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Helps To Remember Password</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;">Set Password Hint while Signup. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/0.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |       <div style="display: block; margin: 30px auto;"> | ||||
|  |          <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">The Password Hint field in user form allows the user to set a | ||||
|  |             Password Hint. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/1.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |       <div style="display: block; margin: 30px auto;"> | ||||
|  |          <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">Click the Password Hint button for showing the Password Hint. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/2.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |       <div style="display: block; margin: 30px auto;"> | ||||
|  |          <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">If there is a Password Hint in the corresponding user form, the popup will | ||||
|  |             show the Password Hint. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/3.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |       <div style="display: block; margin: 30px auto;"> | ||||
|  |          <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">If there is no Password Hint, the pop-up will show 'Password Hint not Found' message. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/4.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |       <div style="display: block; margin: 30px auto;"> | ||||
|  |          <h3 style="font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: bold;">If the Email field is Empty. | ||||
|  |          </h3> | ||||
|  |          <img src="assets/screenshots/5.png" class="img-thumbnail"> | ||||
|  |       </div> | ||||
|  |    </div> | ||||
|  | </div> | ||||
|  | <!-- END OF SCREENSHOTS SECTION --> | ||||
|  | <!-- RELATED PRODUCTS --> | ||||
|  | <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/categories.png"/> | ||||
|  |    </div> | ||||
|  |    <h2 class="mt-2" | ||||
|  |       style="font-family: 'Montserrat', sans-serif; font-size: 24px; font-weight: bold;"> | ||||
|  |       Related | ||||
|  |       Products | ||||
|  |    </h2> | ||||
|  | </div> | ||||
|  | <div class="row"> | ||||
|  |    <div class="col-sm-12"> | ||||
|  |       <div id="demo1" class="row carousel slide" data-ride="carousel"> | ||||
|  |          <!-- The slideshow --> | ||||
|  |          <div class="carousel-inner" style="padding: 30px;"> | ||||
|  |             <div class="carousel-item" style="min-height: 198.656px;"> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/odoo_dynamic_dashboard/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/1.png"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/gatepass_slip/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/2.png"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/hide_menu_user/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/3.png"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |             </div> | ||||
|  |             <div class="carousel-item active" | ||||
|  |                style="min-height: 198.656px;"> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/login_user_detail/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/4.png"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/login_using_qr/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/5.png"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |                <div class="col-xs-12 col-sm-4 col-md-4 mb16 mt16" | ||||
|  |                   style="float:left"> | ||||
|  |                   <a href="https://apps.odoo.com/apps/modules/14.0/multi_branch_base/" | ||||
|  |                      target="_blank"> | ||||
|  |                      <div style="border-radius:10px"> | ||||
|  |                         <img class="img img-responsive center-block" | ||||
|  |                            style="border-radius: 0px;" | ||||
|  |                            src="assets/modules/6.jpg"> | ||||
|  |                      </div> | ||||
|  |                   </a> | ||||
|  |                </div> | ||||
|  |             </div> | ||||
|  |          </div> | ||||
|  |          <!-- Left and right controls --> | ||||
|  |          <a class="carousel-control-prev" href="#demo1" data-slide="prev" | ||||
|  |             style="width:35px; color:#000"> <span | ||||
|  |             class="carousel-control-prev-icon"><i | ||||
|  |             class="fa fa-chevron-left" | ||||
|  |             style="font-size:24px"></i></span> | ||||
|  |          </a> <a class="carousel-control-next" href="#demo1" | ||||
|  |             data-slide="next" style="width:35px; color:#000"> | ||||
|  |          <span class="carousel-control-next-icon"><i | ||||
|  |             class="fa fa-chevron-right" | ||||
|  |             style="font-size:24px"></i></span> | ||||
|  |          </a> | ||||
|  |       </div> | ||||
|  |    </div> | ||||
|  | </div> | ||||
|  | <!-- END OF RELATED PRODUCTS --> | ||||
|  | <!-- OUR SERVICES --> | ||||
|  | <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,78 @@ | |||||
|  | odoo.define('password_hint.hint', function (require) { | ||||
|  | 'use strict'; | ||||
|  |     /* Import dependencies */ | ||||
|  |     var publicWidget = require('web.public.widget'); | ||||
|  |     const ajax = require('web.ajax'); | ||||
|  |     const Dialog = require('web.Dialog'); | ||||
|  |     /** | ||||
|  |      * This widget enhances the behavior of the login form by allowing users to request a password hint | ||||
|  |      * based on their entered login value (email). It communicates with the server to retrieve the hint | ||||
|  |      * and displays it in a dialog box. | ||||
|  |      */ | ||||
|  |     publicWidget.registry.LoginForm = publicWidget.Widget.extend({ | ||||
|  |         selector: '.oe_login_form', | ||||
|  |         events: { | ||||
|  |             'change #login': '_onChangeLogin', | ||||
|  |             'click #passhint': 'OnClickHint', | ||||
|  |         }, | ||||
|  |         /** | ||||
|  |          * Capture login value on change event. | ||||
|  |          * @param {Event} ev - The event object representing the change. | ||||
|  |          */ | ||||
|  |         _onChangeLogin: function (ev){ | ||||
|  |             var loginValue = '' | ||||
|  |             this.loginValue = ev.currentTarget.value | ||||
|  |         }, | ||||
|  |         /** | ||||
|  |          * Handle the click event on the password hint button. | ||||
|  |          * Requests and displays password hint based on login value. | ||||
|  |          */ | ||||
|  |         OnClickHint: function () { | ||||
|  |             //Block executes if there is a value in the Email field
 | ||||
|  |             var self = this | ||||
|  |             if (this.loginValue) { | ||||
|  |                 ajax.jsonRpc("/website/password/hint", 'call', { | ||||
|  |                     'params': this.loginValue | ||||
|  |                 }).then(function(data) { | ||||
|  |                     if (data) { | ||||
|  |                     //If password hint is found returns the password hint.
 | ||||
|  |                         var dialog = new Dialog(null, { | ||||
|  |                             title: "Password Hint", | ||||
|  |                             size: 'medium', | ||||
|  |                             $content: "<div>"+data+"<div>", | ||||
|  |                             buttons: [{ | ||||
|  |                                 text: "Close", | ||||
|  |                                 close: true | ||||
|  |                             }] | ||||
|  |                         }); | ||||
|  |                         dialog.open(); | ||||
|  |                     } else { | ||||
|  |                         //Else block to show if the Password Hint is not found for the given Email.
 | ||||
|  |                         var dialog = new Dialog(null, { | ||||
|  |                             title: "Password Hint", | ||||
|  |                             size: 'medium', | ||||
|  |                             $content: "<div>"+'Password Hint not Found'+"<div>", | ||||
|  |                             buttons: [{ | ||||
|  |                                 text: "Close", | ||||
|  |                                 close: true | ||||
|  |                             }] | ||||
|  |                         }); | ||||
|  |                         dialog.open(); | ||||
|  |                     } | ||||
|  |                 }); | ||||
|  |             } else { | ||||
|  |                 //Block executes if there is no value found in Email filed.
 | ||||
|  |                 var dialog = new Dialog(null, { | ||||
|  |                     title: "Password Hint", | ||||
|  |                     size: 'medium', | ||||
|  |                     $content: "<div>"+'Please Enter the Email'+"<div>", | ||||
|  |                     buttons: [{ | ||||
|  |                         text: "Close", | ||||
|  |                         close: true | ||||
|  |                     }] | ||||
|  |                 }); | ||||
|  |                 dialog.open(); | ||||
|  |             } | ||||
|  |         }, | ||||
|  |     }); | ||||
|  | }); | ||||
| @ -0,0 +1,11 @@ | |||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||
|  | <odoo> | ||||
|  |     <!--Connecting .js file with odoo--> | ||||
|  |     <template id="assets_frontend" name="assets" | ||||
|  |               inherit_id="web.assets_frontend"> | ||||
|  |         <xpath expr="." position="inside"> | ||||
|  |             <script type="text/javascript" | ||||
|  |                     src="/password_hint/static/src/js/password_hint.js"/> | ||||
|  |         </xpath> | ||||
|  |     </template> | ||||
|  | </odoo> | ||||
| @ -0,0 +1,29 @@ | |||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||
|  | <odoo> | ||||
|  |     <!-- | ||||
|  |      Template to add a password hint field to the sign-up form. | ||||
|  |      --> | ||||
|  |     <template id="password_hint_field" inherit_id="auth_signup.fields" | ||||
|  |               name="Password hint"> | ||||
|  |         <xpath expr="//div[hasclass('field-confirm_password')]" | ||||
|  |                position="after"> | ||||
|  |             <div class="mb-3 field-hint"> | ||||
|  |                 <label for="hint">Set Password Hint</label> | ||||
|  |                 <input type="text" name="hint" id="hint" | ||||
|  |                        class="form-control form-control-sm" | ||||
|  |                        placeholder="something related to password"/> | ||||
|  |             </div> | ||||
|  |         </xpath> | ||||
|  |     </template> | ||||
|  |     <!-- | ||||
|  |     Template to add a password hint button to the login form. | ||||
|  |     --> | ||||
|  |     <template id="password_hint_login" inherit_id="web.login" | ||||
|  |               name="password hint button"> | ||||
|  |         <xpath expr="//button[hasclass('btn-primary')]" position="after"> | ||||
|  |             <div style="padding-top: 5px;"> | ||||
|  |                 <a id="passhint" style="cursor:pointer; color:#3aadaa;">Password Hint</a> | ||||
|  |             </div> | ||||
|  |         </xpath> | ||||
|  |     </template> | ||||
|  | </odoo> | ||||
| @ -0,0 +1,17 @@ | |||||
|  | <?xml version="1.0" encoding="utf-8"?> | ||||
|  | <odoo> | ||||
|  |     <!--This XML code defines a new view for the `res.users` model in Odoo. It inherits | ||||
|  |     the `view_users_form` view and adds a new field for the password hint.--> | ||||
|  |     <record id="view_users_form" model="ir.ui.view"> | ||||
|  |         <field name="name">res.users.view.form.inherit.password.hint</field> | ||||
|  |         <field name="model">res.users</field> | ||||
|  |         <field name="inherit_id" ref="base.view_users_form"/> | ||||
|  |         <field name="arch" type="xml"> | ||||
|  |             <xpath expr="//page[@name='references']/group/group[@name='preferences']" position="before"> | ||||
|  |                  <group> | ||||
|  |                     <field name="password_hint" placeholder="Password hint"/> | ||||
|  |                 </group> | ||||
|  |             </xpath> | ||||
|  |         </field> | ||||
|  |     </record> | ||||
|  | </odoo> | ||||