| @ -0,0 +1,46 @@ | |||
| .. image:: https://img.shields.io/badge/license-LGPL--3-green.svg | |||
|     :target: https://www.gnu.org/licenses/lgpl-3.0-standalone.html | |||
|     :alt: License: LGPL-3 | |||
| 
 | |||
| Smart Alerts In Odoo14 | |||
| ====================== | |||
| User can see smart alerts on any model based on different conditions set by the admin. | |||
| 
 | |||
| Configuration | |||
| ============= | |||
| * After installing the module, set the user group, and reload the window. | |||
| 
 | |||
| Company | |||
| ------- | |||
| * `Cybrosys Techno Solutions <https://cybrosys.com/>`__ | |||
| 
 | |||
| License | |||
| ======= | |||
| GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) | |||
| (https://www.gnu.org/licenses/lgpl-3.0-standalone.html) | |||
| 
 | |||
| Credits | |||
| ------- | |||
| * Developer : (V14) Mohammed Irfan T, Contact: odoo@cybrosys.com | |||
| 
 | |||
| Contacts | |||
| -------- | |||
| * Mail Contact : odoo@cybrosys.com | |||
| * Website : https://cybrosys.com | |||
| 
 | |||
| Bug Tracker | |||
| ----------- | |||
| Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. | |||
| 
 | |||
| Maintainer | |||
| ========== | |||
| .. image:: https://cybrosys.com/images/logo.png | |||
|    :target: https://cybrosys.com | |||
| 
 | |||
| This module is maintained by Cybrosys Technologies. | |||
| 
 | |||
| For support and more information, please visit `Our Website <https://cybrosys.com/>`__ | |||
| 
 | |||
| Further information | |||
| =================== | |||
| HTML Description: `<static/description/index.html>`__ | |||
| @ -0,0 +1,22 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Mohammed Irfan T (<https://www.cybrosys.com>) | |||
| # | |||
| #    You can modify it under the terms of the GNU LESSER | |||
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |||
| #    (LGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| 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: Mohammed Irfan T (<https://www.cybrosys.com>) | |||
| # | |||
| #    You can modify it under the terms of the GNU LESSER | |||
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |||
| #    (LGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| { | |||
|     'name': 'Smart Alerts In Odoo14', | |||
|     'version': '14.0.1.0.0', | |||
|     'category': 'Extra Tools', | |||
|     'summary': 'Smart alerts on any model based on different conditions', | |||
|     'description': "User can see smart alerts on any model based on different" | |||
|                    " conditions set by the admin.", | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'website': 'https://www.cybrosys.com', | |||
|     'depends': ['base'], | |||
|     'data': [ | |||
|         'security/smart_alert_warning_groups.xml', | |||
|         'security/ir.model.access.csv', | |||
|         'views/alert_message_views.xml', | |||
|         'views/ir_ui_view_views.xml', | |||
|     ], | |||
|     'images': ['static/description/banner.png'], | |||
|     'license': 'LGPL-3', | |||
|     'installable': True, | |||
|     'auto_install': False, | |||
|     'application': True, | |||
| } | |||
| @ -0,0 +1,7 @@ | |||
| ## Module <smart_alert_warning> | |||
| 
 | |||
| #### 17.01.2024 | |||
| #### Version 14.0.1.0.0 | |||
| #### ADD | |||
| 
 | |||
| - Initial Commit for Smart Alerts | |||
| @ -0,0 +1,23 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Mohammed Irfan T (<https://www.cybrosys.com>) | |||
| # | |||
| #    You can modify it under the terms of the GNU LESSER | |||
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |||
| #    (LGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| from . import alert_message | |||
| from . import ir_ui_view | |||
| @ -0,0 +1,218 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Mohammed Irfan T (<https://www.cybrosys.com>) | |||
| # | |||
| #    You can modify it under the terms of the GNU LESSER | |||
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |||
| #    (LGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| import ast | |||
| from odoo import api, fields, models, _ | |||
| from odoo.exceptions import UserError | |||
| 
 | |||
| OBJECT_VALS = { | |||
|     '=': '!=', | |||
|     '!=': '=', | |||
|     '>': '<', | |||
|     '<': '>', | |||
|     '>=': '<=;', | |||
|     '<=': '>=;', | |||
|     'ilike': 'not in', | |||
|     'not ilike': 'in', | |||
|     'in': 'not in', | |||
|     'not in': 'in' | |||
| } | |||
| 
 | |||
| 
 | |||
| class AlertMessage(models.Model): | |||
|     """ | |||
|         This class used to create the smart alert warnings | |||
|     """ | |||
|     _name = 'alert.message' | |||
|     _description = 'Alert Message' | |||
| 
 | |||
|     name = fields.Char(string='Name', required=True, | |||
|                        help="Name for the smart alert warning") | |||
|     document_type_id = fields.Many2one('ir.model', required=True, | |||
|                                        help="Choose the model in which where " | |||
|                                             "you need to show the warning", | |||
|                                        string="Document Type", | |||
|                                        ondelete='cascade') | |||
|     group_id = fields.Many2one('res.groups', | |||
|                                help="Choose which user groups need to see " | |||
|                                     "the warnings", string="Group") | |||
|     alert_messages = fields.Char(string='Alert Message', required=True, | |||
|                                  help='Alert message that will show ' | |||
|                                       'in the view.') | |||
|     type = fields.Selection([('alert-primary', 'Alert Primary'), | |||
|                              ('alert-secondary', 'Alert Secondary'), | |||
|                              ('alert-success', 'Alert Success'), | |||
|                              ('alert-danger', 'Alert Danger'), | |||
|                              ('alert-warning', 'Alert Warning'), | |||
|                              ('alert-info', 'Alert Info')], | |||
|                             required=True, help='Type of alert message', | |||
|                             string="Type") | |||
|     model_name = fields.Char(string="Model Name", help="name of selected " | |||
|                                                        "model", | |||
|                              related="document_type_id.model") | |||
|     field_filter = fields.Char(default="[]", | |||
|                                help="Add any filtration if you need to show" | |||
|                                     " the warning messages", | |||
|                                string="Field Filter") | |||
|     view_id = fields.Many2one('ir.ui.view', required=True, | |||
|                               domain='[("model", "=", model_name), ' | |||
|                                      '("type", "=", "form"), ' | |||
|                                      '("is_alert_boolean", "=", False)]', | |||
|                               help="Choose the view in which the alert need " | |||
|                                    "to show", string='View') | |||
|     new_view_id = fields.Many2one('ir.ui.view', | |||
|                                   string="Created New view Id", | |||
|                                   readonly=True, | |||
|                                   help="To generate the view id of newly " | |||
|                                        "created record") | |||
|     state = fields.Selection( | |||
|         [('draft', 'Draft'), ('done', 'Done')], | |||
|         default="draft", help="Stages of the record", string="State") | |||
|     is_edit_mode = fields.Boolean(string="Is Edit", | |||
|                                   help="To check is it is in edit mode") | |||
| 
 | |||
|     @api.model | |||
|     def create(self, vals): | |||
|         """ | |||
|             Create a new record with the provided values and set 'is_edit_mode' | |||
|              to True by default. | |||
| 
 | |||
|             :param vals: A dictionary of field values for the new record. | |||
|             :return: The newly created record. | |||
|         """ | |||
|         res = super().create(vals) | |||
|         res.is_edit_mode = True | |||
|         return res | |||
| 
 | |||
|     def create_record(self): | |||
|         """ | |||
|             This method is responsible for creating a new record and related | |||
|             view based on provided parameters and conditions. | |||
| 
 | |||
|             It performs the following actions: | |||
|             - Deletes the existing new_view_id if it exists. | |||
|             - Retrieves model and model_view based on document_type_id and | |||
|             view_id. | |||
|             - Constructs an XML snippet (arch) for the view with dynamic | |||
|             attributes. | |||
|             - Attempts to create the new view and updates related fields. | |||
| 
 | |||
|             :return: The ID of the newly created view. | |||
|         """ | |||
|         if self.new_view_id: | |||
|             self.new_view_id.unlink() | |||
|         model_view = self.view_id | |||
|         class_name = 'alert ' + self.type | |||
|         xml_id = '' | |||
|         if self.group_id.id: | |||
|             xml_ids = self.group_id.get_external_id() | |||
|             xml_id = xml_ids.get(self.group_id.id) | |||
|         filter = ast.literal_eval(self.field_filter) | |||
|         for i in range(len(filter)): | |||
|             if filter[i] == '&': | |||
|                 filter[i] = '|' | |||
|             elif filter[i] == '|': | |||
|                 filter[i] = '&' | |||
|             else: | |||
|                 filter_list = list(filter[i]) | |||
|                 filter_list[1] = OBJECT_VALS[filter[i][1]] | |||
|                 filter[i] = tuple(filter_list) | |||
| 
 | |||
|         invisible_filter = str(filter).replace("'", '"') | |||
|         arch = '<xpath expr="//sheet" position="before">' | |||
|         arch += '<div role="alert" class="' + class_name + '" ' | |||
|         if xml_id: | |||
|             arch += ' groups="' + xml_id + '"' | |||
|         if invisible_filter != '[]': | |||
|             arch += """ attrs='{"invisible": """ + invisible_filter + "}'" | |||
|         arch += '>' + self.alert_messages + '</div></xpath>' | |||
|         if model_view: | |||
|             view_data = { | |||
|                 'name': self.type + '.alert.' + model_view.name + '.' + str( | |||
|                     self.id), | |||
|                 'type': 'form', | |||
|                 'model': self.document_type_id.model, | |||
|                 'priority': 1, | |||
|                 'inherit_id': model_view.id, | |||
|                 'mode': 'extension', | |||
|                 'arch_base': arch.encode('utf-8') | |||
|             } | |||
|             try: | |||
|                 view = self.env["ir.ui.view"].create(view_data) | |||
|                 self.new_view_id = view.id | |||
|                 view.is_alert_boolean = True | |||
|             except: | |||
|                 raise UserError(_("Can't create a view based on this domain")) | |||
|             self.state = 'done' | |||
|             return view.id | |||
| 
 | |||
|     @api.onchange('type', 'alert_messages', 'group_id', 'document_type_id', | |||
|                   'view_id', 'field_filter') | |||
|     def _onchange_type(self): | |||
|         """ | |||
|             Update certain fields when specific fields are changed. | |||
|             This method is automatically triggered when any of the specified | |||
|             fields ('type','alert_messages', 'group_id', 'document_type_id', | |||
|             'view_id', 'field_filter') are changed. It updates the | |||
|             corresponding fields in the original record and sets 'is_edit_mode' | |||
|             to True. | |||
|             Note: This method is meant to be used as an onchange handler in | |||
|             the Odoo framework. | |||
|             :return: None | |||
|         """ | |||
|         self._origin.write({ | |||
|             'type': self.type, | |||
|             'alert_messages': self.alert_messages, | |||
|             'group_id': self.group_id.id, | |||
|             'document_type_id': self.document_type_id.id, | |||
|             'view_id': self.view_id.id, | |||
|             'field_filter': self.field_filter | |||
|         }) | |||
|         self._origin.is_edit_mode = True | |||
| 
 | |||
|     def write(self, vals): | |||
|         """ | |||
|             Override the default write method to update records and perform | |||
|             additional actions. | |||
|         """ | |||
|         super().write(vals) | |||
|         for rec in self: | |||
|             if rec.is_edit_mode: | |||
|                 if rec.state == 'draft': | |||
|                     rec.state = 'done' | |||
|                 rec.is_edit_mode = False | |||
|                 rec.create_record() | |||
| 
 | |||
|     def action_reset_draft(self): | |||
|         """Reset the record into the draft state""" | |||
|         self.state = 'draft' | |||
|         self.new_view_id.unlink() | |||
| 
 | |||
|     def action_done(self): | |||
|         """To change the state of the record to done""" | |||
|         self.state = 'done' | |||
|         self.create_record() | |||
| 
 | |||
|     def unlink(self): | |||
|         """To unlink the alert record on deleting the record""" | |||
|         self.new_view_id.unlink() | |||
|         res = super().unlink() | |||
|         return res | |||
| @ -0,0 +1,30 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ############################################################################# | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| # | |||
| #    Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |||
| #    Author: Mohammed Irfan T (<https://www.cybrosys.com>) | |||
| # | |||
| #    You can modify it under the terms of the GNU LESSER | |||
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |||
| # | |||
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |||
| #    (LGPL v3) along with this program. | |||
| #    If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ############################################################################# | |||
| from odoo import fields, models | |||
| 
 | |||
| 
 | |||
| class View(models.Model): | |||
|     """Inherited model ir.ui.view to add a field""" | |||
|     _inherit = 'ir.ui.view' | |||
| 
 | |||
|     is_alert_boolean = fields.Boolean(string='Smart Alert', | |||
|                                       help="Is this a smart alert view") | |||
| 
 | 
| @ -0,0 +1,23 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <record model="ir.module.category" id="module_category_smart_alert"> | |||
| <!--        Creating category smart alert--> | |||
|         <field name="name">Smart Alert</field> | |||
|         <field name="description">Helps you to create customized alert | |||
|             messages. | |||
|         </field> | |||
|         <field name="sequence">10</field> | |||
|     </record> | |||
|     <record id="smart_alert_warning_group_user" model="res.groups"> | |||
| <!--        Smart alert warning user group User--> | |||
|         <field name="name">Smart Alert Warning: User</field> | |||
|         <field name="category_id" ref="smart_alert_warning.module_category_smart_alert"/> | |||
|     </record> | |||
|     <record id="smart_alert_warning_group_admin" model="res.groups"> | |||
| <!--        Smart alert warning user group Admin--> | |||
|         <field name="name">Smart Alert Warning: Admin</field> | |||
|         <field name="implied_ids" | |||
|                eval="[(4, ref('smart_alert_warning.smart_alert_warning_group_user'))]"/> | |||
|         <field name="category_id" ref="smart_alert_warning.module_category_smart_alert"/> | |||
|     </record> | |||
| </odoo> | |||
| 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: 58 KiB | 
| After Width: | Height: | Size: 57 KiB | 
| After Width: | Height: | Size: 50 KiB | 
| After Width: | Height: | Size: 59 KiB | 
| After Width: | Height: | Size: 56 KiB | 
| After Width: | Height: | Size: 98 KiB | 
| After Width: | Height: | Size: 134 KiB | 
| After Width: | Height: | Size: 94 KiB | 
| After Width: | Height: | Size: 163 KiB | 
| After Width: | Height: | Size: 96 KiB | 
| After Width: | Height: | Size: 163 KiB | 
| After Width: | Height: | Size: 95 KiB | 
| After Width: | Height: | Size: 163 KiB | 
| After Width: | Height: | Size: 158 KiB | 
| After Width: | Height: | Size: 73 KiB | 
| After Width: | Height: | Size: 13 KiB | 
| @ -0,0 +1,562 @@ | |||
| <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;"> | |||
|                     Smart Alerts In Odoo14</h1> | |||
|                 <p style="color:#FFFFFF; padding: 8px 15px; text-align: center; font-size: 24px;">Smart Alerts On Any | |||
|                     Model Based On Different Conditions</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"> | |||
|         This module helps to show smart alerts on any model based on different conditions | |||
|     </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 & Odoo.sh 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;">Alert for any document type.</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;">General and specific alerts.</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;">Secured Alerts.</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;">Different Alert style.</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;">Refresh the page after creating records to apply warning.</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;">User Configuration | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Settings -> Users -> | |||
|                 Access Rights -> Smart Alert</p> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Only Smart Alert | |||
|                 Warning: Admin, Can create and manage the smart alerts.</p> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Only Smart Alert Warning: User, Can View the | |||
|                 created records.</p> | |||
|             <img src="assets/screenshots/alert-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;">Alert Secondary | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">Create a new alert record and refresh the page to apply the warning</p> | |||
|             <img src="assets/screenshots/alert-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;">Alert Message | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;">We can view the alert | |||
|                 message for its corresponding record.</p> | |||
|             <img src="assets/screenshots/alert-5.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;">Alert Warning | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p> | |||
|             <img src="assets/screenshots/alert-6.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;">Alert Message | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p> | |||
|             <img src="assets/screenshots/alert-7.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;">Alert Primary | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p> | |||
|             <img src="assets/screenshots/alert-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;">Alert Message | |||
|             </h3> | |||
|             <p style="font-weight: 400; font-family: 'Montserrat', sans-serif; font-size: 14px;"></p> | |||
|             <img src="assets/screenshots/alert-3.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-lg-12 d-flex flex-column justify-content-center" | |||
|              style="text-align: center; padding: 2.5rem 1rem !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/login_using_qr/" 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/login_using_qr.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-top-left-radius:10px; border-top-right-radius:10px" | |||
|                                          src="./assets/modules/hide_menu_user.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/odoo_dynamic_dashboard/#" | |||
|                                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/odoo_dynamic_dashboard.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/whatsapp_redirect/" 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/whatsapp_redirect.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_user_detail/" 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/login_user_detail.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/todo_list/" 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/todo_list.png"> | |||
|                                 </div> | |||
|                             </a> | |||
|                         </div> | |||
|                     </div> | |||
|                 </div> | |||
|                 <!-- Left and right controls --> | |||
|                 <a class="carousel-control-prev" href="#demo1" data-slide="prev" | |||
|                    style="left:-25px;width: 35px;color: #000;"> <span class="carousel-control-prev-icon"><i | |||
|                         class="fa fa-chevron-left" style="font-size:24px"></i></span> </a> <a | |||
|                     class="carousel-control-next" href="#demo1" data-slide="next" | |||
|                     style="right:-25px;width: 35px;color: #000;"> | |||
|                     <span class="carousel-control-next-icon"><i class="fa fa-chevron-right" | |||
|                                                                 style="font-size:24px"></i></span> | |||
|                 </a> | |||
|             </div> | |||
|         </div> | |||
|     </div> | |||
| <!-- END OF 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,84 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <odoo> | |||
|     <record id="alert_message_action" model="ir.actions.act_window"> | |||
| <!--        Action for module alert.message--> | |||
|         <field name="name">Alert Message</field> | |||
|         <field name="res_model">alert.message</field> | |||
|         <field name="view_mode">tree,form</field> | |||
|     </record> | |||
|     <record id="alert_message_view_form" model="ir.ui.view"> | |||
| <!--        Form view of the model alert.message--> | |||
|         <field name="model">alert.message</field> | |||
|         <field name="name">alert.message.view.form</field> | |||
|         <field name="arch" type="xml"> | |||
|             <form> | |||
|                 <header> | |||
|                     <field name="state" widget="statusbar" | |||
|                            statusbar_visible="draft,done"/> | |||
|                     <button name="action_reset_draft" type="object" | |||
|                             class="btn btn-secondary" | |||
|                             string="Reset to draft" | |||
|                             attrs="{'invisible': [('state', '!=', 'done')]}" | |||
|                             groups="smart_alert_warning.smart_alert_warning_group_admin"/> | |||
|                     <button name="action_done" type="object" | |||
|                             class="btn btn-primary" | |||
|                             string="Done" | |||
|                             attrs="{'invisible': [('state', '!=', 'draft')]}" | |||
|                             groups="smart_alert_warning.smart_alert_warning_group_admin"/> | |||
|                 </header> | |||
|                 <sheet> | |||
|                     <div class="oe_title"> | |||
|                         <h1> | |||
|                             <field name="name" placeholder="Name"/> | |||
|                         </h1> | |||
|                     </div> | |||
|                     <group> | |||
|                         <field name="alert_messages"/> | |||
|                     </group> | |||
|                     <group> | |||
|                         <group> | |||
|                             <field name="group_id"/> | |||
|                             <field name="type"/> | |||
|                             <field name="model_name" invisible="1"/> | |||
|                         </group> | |||
|                         <group> | |||
|                             <field name="document_type_id"/> | |||
|                             <field name="view_id"/> | |||
|                             <field name="new_view_id" invisible="1"/> | |||
|                         </group> | |||
|                     </group> | |||
|                     <notebook> | |||
|                         <page string="Filters"> | |||
|                             <field name="field_filter" | |||
|                                    widget="domain" | |||
|                                    options="{'model': 'model_name'}"/> | |||
|                         </page> | |||
|                     </notebook> | |||
|                 </sheet> | |||
|             </form> | |||
|         </field> | |||
|     </record> | |||
|     <record id="alert_message_view_tree" model="ir.ui.view"> | |||
| <!--        Tree view of the model alert.message--> | |||
|         <field name="model">alert.message</field> | |||
|         <field name="name">alert.message.view.tree</field> | |||
|         <field name="arch" type="xml"> | |||
|             <tree> | |||
|                 <field name="name"/> | |||
|                 <field name="type"/> | |||
|                 <field name="document_type_id"/> | |||
|             </tree> | |||
|         </field> | |||
|     </record> | |||
| <!--    Menu items for the model--> | |||
|     <menuitem id="alert_message_menu_root" name="Smart Alerts" | |||
|               sequence="20" | |||
|               groups="smart_alert_warning.smart_alert_warning_group_admin,smart_alert_warning.smart_alert_warning_group_user" | |||
|               web_icon="smart_alert_warning,static/description/icon.png"/> | |||
|     <menuitem id="alert_message_menu" name="Alerts" | |||
|               parent="alert_message_menu_root" | |||
|               sequence="1"/> | |||
|     <menuitem id="alert_message_menu_child" name="Alerts" | |||
|               parent="alert_message_menu" | |||
|               sequence="2" action="alert_message_action"/> | |||
| </odoo> | |||
| @ -0,0 +1,16 @@ | |||
| <?xml version="1.0" encoding="UTF-8" ?> | |||
| <odoo> | |||
|     <!--    Inherited form view of ir.ui.view--> | |||
|     <record id="view_view_form" model="ir.ui.view"> | |||
|         <field name="name">ir.ui.view.view.form.inherit.smart.alert.warning | |||
|         </field> | |||
|         <field name="model">ir.ui.view</field> | |||
|         <field name="inherit_id" ref="base.view_view_form"/> | |||
|         <field name="arch" type="xml"> | |||
|             <xpath expr="//field[@name='xml_id']" position="after"> | |||
|                 <field name="is_alert_boolean" widget="boolean_toggle" | |||
|                        readonly="1"/> | |||
|             </xpath> | |||
|         </field> | |||
|     </record> | |||
| </odoo> | |||