diff --git a/master_search/README.rst b/master_search/README.rst new file mode 100755 index 000000000..951bb166a --- /dev/null +++ b/master_search/README.rst @@ -0,0 +1,55 @@ +.. image:: https://img.shields.io/badge/license-AGPL--3-blue.svg + :target: https://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 + +Master Search +============= +* Master Search module for Odoo 17 community editions. In this module, Users can + search the records in Customers, Products, Sale, Purchase, Inventory and + Accounting Modules + + +Configuration +============= +No additional Configuration + + +Company +------- +* `Cybrosys Techno Solutions `__ + +License +------- +General Public License, Version 3 (AGPL v3). +(https://www.gnu.org/licenses/agpl-3.0-standalone.html) + +Credits +------- +* Developer: +(v14) Shahil +(v15) Athul +(v16) Rosmy +(v17) Anjhana A K +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 `__ + +Further information +=================== +HTML Description: ``__ diff --git a/master_search/__init__.py b/master_search/__init__.py new file mode 100644 index 000000000..030d38aaa --- /dev/null +++ b/master_search/__init__.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +############################################################################# +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2023-TODAY Cybrosys Technologies() +# Author:Anjhana A K() +# 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 . +# +############################################################################# +from . import models diff --git a/master_search/__manifest__.py b/master_search/__manifest__.py new file mode 100644 index 000000000..676608155 --- /dev/null +++ b/master_search/__manifest__.py @@ -0,0 +1,50 @@ +# -*- coding: utf-8 -*- +############################################################################# +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2023-TODAY Cybrosys Technologies() +# Author:Anjhana A K() +# 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 . +# +############################################################################# +{ + 'name': 'Global Search', + 'version': '17.0.1.0.0', + 'category': 'Extra Tools', + 'summary': """Easy Search in Customers, Products, Sale, Purchase, Inventory + and Accounting modules""", + 'description': """Search, Global Search, Quick Search, Easy Search, Easy + Search in Customers, Products, Sale, Purchase, Inventory and Accounting + modules, Search, Advance search, global search """, + 'author': 'Cybrosys Techno Solutions', + 'company': 'Cybrosys Techno Solutions', + 'maintainer': 'Cybrosys Techno Solutions', + 'website': 'https://www.cybrosys.com', + 'depends': ['base', 'stock', 'sale', 'purchase'], + 'data': [ + 'security/master_search_security.xml', + 'security/ir.model.access.csv', + 'views/master_search_view.xml' + ], + 'assets': { + 'web.assets_backend': [ + 'master_search/static/src/scss/master_search.scss', + ], + }, + 'images': ['static/description/banner.jpg'], + 'license': 'AGPL-3', + 'installable': True, + 'auto_install': False, + 'application': False, +} diff --git a/master_search/doc/RELEASE_NOTES.md b/master_search/doc/RELEASE_NOTES.md new file mode 100644 index 000000000..7b955af26 --- /dev/null +++ b/master_search/doc/RELEASE_NOTES.md @@ -0,0 +1,6 @@ +## Module + +#### 22.11.2023 +#### Version 17.0.1.0.0 +#### ADD +- Initial Commit for Global Search diff --git a/master_search/models/__init__.py b/master_search/models/__init__.py new file mode 100644 index 000000000..ba82cd8c4 --- /dev/null +++ b/master_search/models/__init__.py @@ -0,0 +1,21 @@ +# -*- coding: utf-8 -*- +############################################################################# +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2023-TODAY Cybrosys Technologies() +# Author:Anjhana A K() +# 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 . +# +############################################################################# +from . import master_search diff --git a/master_search/models/master_search.py b/master_search/models/master_search.py new file mode 100644 index 000000000..f3aa1ff20 --- /dev/null +++ b/master_search/models/master_search.py @@ -0,0 +1,316 @@ +# -*- coding: utf-8 -*- +############################################################################# +# +# Cybrosys Technologies Pvt. Ltd. +# +# Copyright (C) 2023-TODAY Cybrosys Technologies() +# Author:Anjhana A K() +# 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 . +# +############################################################################# +from odoo import api, fields, models, _ +from odoo.exceptions import UserError + + +class MasterSearch(models.Model): + """Master search model for easy search""" + _name = 'master.search' + _description = "Model for master search" + _rec_name = 'name' + _order = "create_date desc" + + name = fields.Char(string="Name", default=lambda self: _('Search'), + help='Searched names') + search_string = fields.Char(string="Search", help='Details to search') + search_mode = fields.Selection( + [('all', 'All'), ('active', 'Active'), + ('inactive', 'Inactive')], + string="Search Mode", default="active", help='Search Details based on') + search_by = fields.Selection( + [('any', 'Any'), ('customer', 'Customer'), + ('product', 'Product'), + ('sale details', 'Sale'), + ('purchase details', 'Purchase'), + ('transaction details', 'Inventory'), + ('account details', 'Accounting')], + string="Search By", default='any', help='Search in which model') + master_search_ids = fields.Many2many('master.search', + 'master_search_self_rel', + 'search_id', + 'search_id1', + compute="_get_recent_searches", + limit=1, help='Recent search details') + history_count = fields.Integer(string="History Count", + compute="_get_history_count", + help='Recent search History Count') + customer_ids = fields.Many2many('res.partner', + 'master_search_company_rel', + 'search_id', 'company_id', + help='To fetch datas of customer search') + product_ids = fields.Many2many('product.template', + 'master_search_product_rel', + 'search_id', 'company_id', + help='To fetch datas of product search') + transaction_ids = fields.Many2many('stock.picking', + 'master_search_transaction_rel', + 'search_id', + 'company_id', + string="Inventory", + help='To fetch datas of inventory' + ' search') + customer_count = fields.Integer(string="Company Count", + compute="_get_operator_count", + help='To fetched customer search count') + product_count = fields.Integer(string="Product Count", + compute="_get_product_count", + help='To fetched product search count') + transaction_count = fields.Integer(string="Transaction Count", + compute="_get_transaction_count", + help='To fetched inventory search ' + 'count') + sale_count = fields.Integer(string="Sale Count", compute="_get_sale_count", + help='To fetched sale search count') + purchase_count = fields.Integer(string="Sale Count", + compute="_get_purchase_count", + help='To fetched purchase search count') + account_count = fields.Integer(string="Account Count", + compute="_get_account_count", + help='To fetched account search count') + user_id = fields.Many2one('res.users', string="User", + default=lambda self: self.env.user) + match_entire = fields.Boolean(string="Match entire sentence", + help='Only matched datas to be viewed') + sale_ids = fields.Many2many('sale.order', + 'master_search_sale_details_rel', + 'search_id', 'company_id', + string="Sale", help='To fetch datas of sale ' + 'search') + purchase_ids = fields.Many2many('purchase.order', + 'master_search_purchase_details_rel', + 'search_id', 'company_id', + string="Sale", help='To fetch datas of' + ' purchase search') + account_ids = fields.Many2many('account.move', + 'master_search_account_details_rel', + 'search_id', 'company_id', + string="Account", help='To fetch datas of' + 'account search') + + @api.depends('search_string') + def _get_recent_searches(self): + """ Get recent searches """ + try: + current_id = self.id if isinstance(self.id, int) \ + else self._origin.id + except: + current_id = False + pass + empty_search = self.env['master.search'].search( + [('search_string', 'in', ['', False]), + ('id', 'not in', [current_id, False] + if current_id else [False])]) + if empty_search: + empty_search.unlink() + recent_searches = self.env['master.search'].search([ + ('search_string', 'not in', ['', False])]) + self.master_search_ids = recent_searches + + def action_unlink_search(self): + """ Unlink search """ + self.unlink() + action = self.env.ref('master_search.master_search_action').read()[0] + return action + + @api.depends('master_search_ids') + def _get_history_count(self): + """ Get history count """ + self.history_count = len(self.master_search_ids) + + @api.depends('product_ids') + def _get_product_count(self): + """ Get product count """ + self.product_count = len(self.product_ids) + + @api.depends('customer_ids') + def _get_operator_count(self): + """ Get customer count """ + self.customer_count = len(self.customer_ids) + + @api.depends('transaction_count') + def _get_transaction_count(self): + """ Get transaction details count """ + self.transaction_count = len(self.transaction_ids) + + @api.depends('sale_count') + def _get_sale_count(self): + """ Get sale details count """ + self.sale_count = len(self.sale_ids) + + @api.depends('purchase_count') + def _get_purchase_count(self): + """ Get purchase details count """ + self.purchase_count = len(self.purchase_ids) + + @api.depends('account_count') + def _get_account_count(self): + """ Get account details count """ + self.account_count = len(self.account_ids) + + def action_clear_search(self): + """ clear search input """ + self.search_string = "" + self.name = "Search" + + @api.model_create_multi + def create(self, vals_list): + """ Function for unlink first result and raise error if no string """ + res = super(MasterSearch, self).create(vals_list) + search_index = self.env['master.search'].search_count( + [('user_id', '=', self.env.user.id)]) + # unlink old search result if count greater than 10 + if search_index > 10: + last_search = self.env['master.search'].search( + [('id', '!=', res.id), ('user_id', '=', self.env.user.id)], + order="create_date asc", limit=1) + last_search.unlink() if last_search else False + return res + + def action_search(self): + """ search for the string and store search data """ + if self.search_string and "*" in self.search_string: + return + if not self.search_string: + raise UserError(_("Please provide a search string!")) + search_keys = self.search_string.split(" ") + self.customer_ids = self.product_ids = self.transaction_ids = False + if self.match_entire: + return self._search_query(self.search_string) + for key in search_keys: + self._search_query(key) + self.name = self.search_string + + def _search_query(self, key): + """ search for the model with given key and update result """ + company_id = self.env.user.company_id.id + if self.search_mode == 'all': + active_qry = """ and obj.active in ({},{}) + """.format("'FALSE'", "'TRUE'") + elif self.search_mode == 'active': + active_qry = """ and obj.active in ({})""".format("'TRUE'") + else: + active_qry = """ and obj.active in ({})""".format("'FALSE'") + self._search_customer(key, active_qry) \ + if self.search_by in ['any', 'customer'] else False + self._search_products(key, active_qry, company_id) \ + if self.search_by in ['any', 'product'] else False + self._search_inventory_transactions(key, active_qry, company_id) \ + if self.search_by in ['any', 'transaction details'] else False + self._search_sale_transactions(key, active_qry, company_id) \ + if self.search_by in ['any', 'sale details'] else False + self._search_purchase_transactions(key, active_qry, company_id) \ + if self.search_by in ['any', 'purchase details'] else False + self._search_account_transactions(key, active_qry, company_id) \ + if self.search_by in ['any', 'account details'] else False + + def _search_account_transactions(self, key, active_qry, company_id): + """ Search for all account transactions """ + sp_query = """ SELECT am.id from account_move am + LEFT JOIN res_partner p on p.id = am.partner_id + WHERE am.company_id = {op_id} AND (am.name ILIKE '%{key}%' OR + p.name ILIKE '%{key}%' OR am.state ILIKE '%{key}%') + GROUP BY am.id,p.name + """ + self._cr.execute( + sp_query.format(op_id=company_id, key=key, active=active_qry)) + moves = self._cr.dictfetchall() + move_ids = self.env['account.move'].browse([i['id'] for i in moves]) + self.account_ids += move_ids + + def _search_purchase_transactions(self, key, active_qry, company_id): + """ Search for all purchase transactions """ + sp_query = """ SELECT po.id from purchase_order po + LEFT JOIN res_partner p on p.id = po.partner_id + WHERE po.company_id = {op_id} AND (po.name ILIKE '%{key}%' OR + p.name ILIKE '%{key}%' OR po.state ILIKE '%{key}%') + GROUP BY po.id,p.name + """ + self._cr.execute( + sp_query.format(op_id=company_id, key=key, active=active_qry)) + purchases = self._cr.dictfetchall() + purchase_ids = self.env['purchase.order'].browse( + [i['id'] for i in purchases]) + self.purchase_ids += purchase_ids + + def _search_sale_transactions(self, key, active_qry, company_id): + """ Search for all sale transactions """ + sp_query = """ SELECT sl.id from sale_order sl + LEFT JOIN res_partner p on p.id = sl.partner_id + LEFT JOIN product_pricelist pl ON pl.id = sl.pricelist_id + LEFT JOIN account_payment_term pt ON pt.id = sl.payment_term_id + WHERE sl.company_id = {op_id} AND (sl.name ILIKE '%{key}%' OR + p.name ILIKE '%{key}%' OR sl.state ILIKE '%{key}%' OR + pl.name::text ILIKE '%{key}%') + GROUP BY sl.id,p.name,pl.name,pt.name + """ + self._cr.execute( + sp_query.format(op_id=company_id, key=key, active=active_qry)) + sales = self._cr.dictfetchall() + sale_ids = self.env['sale.order'].browse([i['id'] for i in sales]) + self.sale_ids += sale_ids + + def _search_inventory_transactions(self, key, active_qry, company_id): + """ Search for all inventory transactions """ + sp_query = """ SELECT sp.id from stock_picking sp + LEFT JOIN res_partner p on p.id = sp.partner_id + LEFT JOIN stock_picking_type t ON t.id = sp.picking_type_id + WHERE sp.company_id = {op_id} AND (sp.name ILIKE '%{key}%' OR + p.name ILIKE '%{key}%' OR sp.state ILIKE '%{key}%' OR + t.name::text ILIKE '%{key}%') GROUP BY sp.id,p.name,t.name + """ + self._cr.execute( + sp_query.format(op_id=company_id, key=key, active=active_qry)) + transactions = self._cr.dictfetchall() + transaction_ids = self.env['stock.picking'].browse( + [i['id'] for i in transactions]) + self.transaction_ids += transaction_ids + + def _search_products(self, key, active_qry, company_id): + """ search for products """ + pt_query = """ SELECT pt.id FROM product_template pt + LEFT JOIN product_category pc ON pc.id = pt.categ_id + WHERE (pt.name::text ILIKE '%{key}%' OR + pt.default_code ILIKE '%{key}%' OR pt.type ILIKE '%{key}%' OR + pt.description::text ILIKE '%{key}%' OR pc.name ILIKE '%{key}%') + """ + self._cr.execute(pt_query.format(op_id=company_id, key=key, + active=active_qry).replace( + 'obj', 'pt')) + template_ids = self._cr.dictfetchall() + product_template_ids = self.env['product.template'].browse( + [i['id'] for i in template_ids]) + self.product_ids += product_template_ids + + def _search_customer(self, key, active_qry): + """ search for customer """ + query = """ SELECT r.id from res_partner r WHERE + (r.parent_id is NULL ) AND r.type = 'contact' {active} AND + (r.name ILIKE '%{key}%' OR r.street ILIKE '%{key}%' OR + r.street2 ILIKE '%{key}%' OR r.city ILIKE '%{key}%' OR + r.zip ILIKE '%{key}%' OR r.email ILIKE '%{key}%') """ + query_params = query.format(key=key, active=active_qry).replace( + 'obj', 'r') + self._cr.execute(query_params) + customers = self._cr.dictfetchall() + customer_ids = self.env['res.partner'].browse( + [i['id'] for i in customers]) + self.customer_ids += customer_ids diff --git a/master_search/security/ir.model.access.csv b/master_search/security/ir.model.access.csv new file mode 100755 index 000000000..6fc23818c --- /dev/null +++ b/master_search/security/ir.model.access.csv @@ -0,0 +1,2 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_master_search,access.master.search,model_master_search,base.group_user,1,1,1,1 diff --git a/master_search/security/master_search_security.xml b/master_search/security/master_search_security.xml new file mode 100755 index 000000000..597fc2337 --- /dev/null +++ b/master_search/security/master_search_security.xml @@ -0,0 +1,18 @@ + + + + + Company Search Rule + + [('user_id', '=', user.id)] + + + + Search Rights + 11 + + + Global Search + Global Search Group + + diff --git a/master_search/static/description/assets/icons/check.png b/master_search/static/description/assets/icons/check.png new file mode 100644 index 000000000..c8e85f51d Binary files /dev/null and b/master_search/static/description/assets/icons/check.png differ diff --git a/master_search/static/description/assets/icons/chevron.png b/master_search/static/description/assets/icons/chevron.png new file mode 100644 index 000000000..2089293d6 Binary files /dev/null and b/master_search/static/description/assets/icons/chevron.png differ diff --git a/master_search/static/description/assets/icons/cogs.png b/master_search/static/description/assets/icons/cogs.png new file mode 100644 index 000000000..95d0bad62 Binary files /dev/null and b/master_search/static/description/assets/icons/cogs.png differ diff --git a/master_search/static/description/assets/icons/consultation.png b/master_search/static/description/assets/icons/consultation.png new file mode 100644 index 000000000..8319d4baa Binary files /dev/null and b/master_search/static/description/assets/icons/consultation.png differ diff --git a/master_search/static/description/assets/icons/ecom-black.png b/master_search/static/description/assets/icons/ecom-black.png new file mode 100644 index 000000000..a9385ff13 Binary files /dev/null and b/master_search/static/description/assets/icons/ecom-black.png differ diff --git a/master_search/static/description/assets/icons/education-black.png b/master_search/static/description/assets/icons/education-black.png new file mode 100644 index 000000000..3eb09b27b Binary files /dev/null and b/master_search/static/description/assets/icons/education-black.png differ diff --git a/master_search/static/description/assets/icons/hotel-black.png b/master_search/static/description/assets/icons/hotel-black.png new file mode 100644 index 000000000..130f613be Binary files /dev/null and b/master_search/static/description/assets/icons/hotel-black.png differ diff --git a/master_search/static/description/assets/icons/license.png b/master_search/static/description/assets/icons/license.png new file mode 100644 index 000000000..a5869797e Binary files /dev/null and b/master_search/static/description/assets/icons/license.png differ diff --git a/master_search/static/description/assets/icons/lifebuoy.png b/master_search/static/description/assets/icons/lifebuoy.png new file mode 100644 index 000000000..658d56ccc Binary files /dev/null and b/master_search/static/description/assets/icons/lifebuoy.png differ diff --git a/master_search/static/description/assets/icons/manufacturing-black.png b/master_search/static/description/assets/icons/manufacturing-black.png new file mode 100644 index 000000000..697eb0e9f Binary files /dev/null and b/master_search/static/description/assets/icons/manufacturing-black.png differ diff --git a/master_search/static/description/assets/icons/pos-black.png b/master_search/static/description/assets/icons/pos-black.png new file mode 100644 index 000000000..97c0f90c1 Binary files /dev/null and b/master_search/static/description/assets/icons/pos-black.png differ diff --git a/master_search/static/description/assets/icons/puzzle.png b/master_search/static/description/assets/icons/puzzle.png new file mode 100644 index 000000000..65cf854e7 Binary files /dev/null and b/master_search/static/description/assets/icons/puzzle.png differ diff --git a/master_search/static/description/assets/icons/restaurant-black.png b/master_search/static/description/assets/icons/restaurant-black.png new file mode 100644 index 000000000..4a35eb939 Binary files /dev/null and b/master_search/static/description/assets/icons/restaurant-black.png differ diff --git a/master_search/static/description/assets/icons/service-black.png b/master_search/static/description/assets/icons/service-black.png new file mode 100644 index 000000000..301ab51cb Binary files /dev/null and b/master_search/static/description/assets/icons/service-black.png differ diff --git a/master_search/static/description/assets/icons/trading-black.png b/master_search/static/description/assets/icons/trading-black.png new file mode 100644 index 000000000..9398ba2f1 Binary files /dev/null and b/master_search/static/description/assets/icons/trading-black.png differ diff --git a/master_search/static/description/assets/icons/training.png b/master_search/static/description/assets/icons/training.png new file mode 100644 index 000000000..884ca024d Binary files /dev/null and b/master_search/static/description/assets/icons/training.png differ diff --git a/master_search/static/description/assets/icons/update.png b/master_search/static/description/assets/icons/update.png new file mode 100644 index 000000000..ecbc5a01a Binary files /dev/null and b/master_search/static/description/assets/icons/update.png differ diff --git a/master_search/static/description/assets/icons/user.png b/master_search/static/description/assets/icons/user.png new file mode 100644 index 000000000..6ffb23d9f Binary files /dev/null and b/master_search/static/description/assets/icons/user.png differ diff --git a/master_search/static/description/assets/icons/wrench.png b/master_search/static/description/assets/icons/wrench.png new file mode 100644 index 000000000..6c04dea0f Binary files /dev/null and b/master_search/static/description/assets/icons/wrench.png differ diff --git a/master_search/static/description/assets/misc/Cybrosys R.png b/master_search/static/description/assets/misc/Cybrosys R.png new file mode 100644 index 000000000..da4058087 Binary files /dev/null and b/master_search/static/description/assets/misc/Cybrosys R.png differ diff --git a/master_search/static/description/assets/misc/categories.png b/master_search/static/description/assets/misc/categories.png new file mode 100644 index 000000000..bedf1e0b1 Binary files /dev/null and b/master_search/static/description/assets/misc/categories.png differ diff --git a/master_search/static/description/assets/misc/check-box.png b/master_search/static/description/assets/misc/check-box.png new file mode 100644 index 000000000..42caf24b9 Binary files /dev/null and b/master_search/static/description/assets/misc/check-box.png differ diff --git a/master_search/static/description/assets/misc/compass.png b/master_search/static/description/assets/misc/compass.png new file mode 100644 index 000000000..d5fed8faa Binary files /dev/null and b/master_search/static/description/assets/misc/compass.png differ diff --git a/master_search/static/description/assets/misc/corporate.png b/master_search/static/description/assets/misc/corporate.png new file mode 100644 index 000000000..2eb13edbf Binary files /dev/null and b/master_search/static/description/assets/misc/corporate.png differ diff --git a/master_search/static/description/assets/misc/customer-support.png b/master_search/static/description/assets/misc/customer-support.png new file mode 100644 index 000000000..79efc72ed Binary files /dev/null and b/master_search/static/description/assets/misc/customer-support.png differ diff --git a/master_search/static/description/assets/misc/cybrosys-logo.png b/master_search/static/description/assets/misc/cybrosys-logo.png new file mode 100644 index 000000000..cc3cc0ccf Binary files /dev/null and b/master_search/static/description/assets/misc/cybrosys-logo.png differ diff --git a/master_search/static/description/assets/misc/email.svg b/master_search/static/description/assets/misc/email.svg new file mode 100644 index 000000000..15291cdc3 --- /dev/null +++ b/master_search/static/description/assets/misc/email.svg @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/master_search/static/description/assets/misc/features.png b/master_search/static/description/assets/misc/features.png new file mode 100644 index 000000000..b41769f77 Binary files /dev/null and b/master_search/static/description/assets/misc/features.png differ diff --git a/master_search/static/description/assets/misc/logo.png b/master_search/static/description/assets/misc/logo.png new file mode 100644 index 000000000..478462d3e Binary files /dev/null and b/master_search/static/description/assets/misc/logo.png differ diff --git a/master_search/static/description/assets/misc/phone.svg b/master_search/static/description/assets/misc/phone.svg new file mode 100644 index 000000000..b7bd7f251 --- /dev/null +++ b/master_search/static/description/assets/misc/phone.svg @@ -0,0 +1,3 @@ + + + diff --git a/master_search/static/description/assets/misc/pictures.png b/master_search/static/description/assets/misc/pictures.png new file mode 100644 index 000000000..56d255fe9 Binary files /dev/null and b/master_search/static/description/assets/misc/pictures.png differ diff --git a/master_search/static/description/assets/misc/pie-chart.png b/master_search/static/description/assets/misc/pie-chart.png new file mode 100644 index 000000000..426e05244 Binary files /dev/null and b/master_search/static/description/assets/misc/pie-chart.png differ diff --git a/master_search/static/description/assets/misc/right-arrow.png b/master_search/static/description/assets/misc/right-arrow.png new file mode 100644 index 000000000..730984a06 Binary files /dev/null and b/master_search/static/description/assets/misc/right-arrow.png differ diff --git a/master_search/static/description/assets/misc/star (1) 2.svg b/master_search/static/description/assets/misc/star (1) 2.svg new file mode 100644 index 000000000..5ae9f507a --- /dev/null +++ b/master_search/static/description/assets/misc/star (1) 2.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/master_search/static/description/assets/misc/star.png b/master_search/static/description/assets/misc/star.png new file mode 100644 index 000000000..2eb9ab29f Binary files /dev/null and b/master_search/static/description/assets/misc/star.png differ diff --git a/master_search/static/description/assets/misc/support (1) 1.svg b/master_search/static/description/assets/misc/support (1) 1.svg new file mode 100644 index 000000000..7d37a8f30 --- /dev/null +++ b/master_search/static/description/assets/misc/support (1) 1.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/master_search/static/description/assets/misc/support-email.svg b/master_search/static/description/assets/misc/support-email.svg new file mode 100644 index 000000000..eb70370d6 --- /dev/null +++ b/master_search/static/description/assets/misc/support-email.svg @@ -0,0 +1,6 @@ + + + + + + diff --git a/master_search/static/description/assets/misc/support.png b/master_search/static/description/assets/misc/support.png new file mode 100644 index 000000000..4f18b8b82 Binary files /dev/null and b/master_search/static/description/assets/misc/support.png differ diff --git a/master_search/static/description/assets/misc/tick-mark.svg b/master_search/static/description/assets/misc/tick-mark.svg new file mode 100644 index 000000000..2dbb40187 --- /dev/null +++ b/master_search/static/description/assets/misc/tick-mark.svg @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + diff --git a/master_search/static/description/assets/misc/whatsapp 1.svg b/master_search/static/description/assets/misc/whatsapp 1.svg new file mode 100644 index 000000000..0bfaf8fc6 --- /dev/null +++ b/master_search/static/description/assets/misc/whatsapp 1.svg @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/master_search/static/description/assets/misc/whatsapp.png b/master_search/static/description/assets/misc/whatsapp.png new file mode 100644 index 000000000..d513a5356 Binary files /dev/null and b/master_search/static/description/assets/misc/whatsapp.png differ diff --git a/master_search/static/description/assets/misc/whatsapp.svg b/master_search/static/description/assets/misc/whatsapp.svg new file mode 100644 index 000000000..b618aea1d --- /dev/null +++ b/master_search/static/description/assets/misc/whatsapp.svg @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/master_search/static/description/assets/modules/1.png b/master_search/static/description/assets/modules/1.png new file mode 100644 index 000000000..ba1058c42 Binary files /dev/null and b/master_search/static/description/assets/modules/1.png differ diff --git a/master_search/static/description/assets/modules/2.png b/master_search/static/description/assets/modules/2.png new file mode 100644 index 000000000..6949185dd Binary files /dev/null and b/master_search/static/description/assets/modules/2.png differ diff --git a/master_search/static/description/assets/modules/3.png b/master_search/static/description/assets/modules/3.png new file mode 100644 index 000000000..4e506f79b Binary files /dev/null and b/master_search/static/description/assets/modules/3.png differ diff --git a/master_search/static/description/assets/modules/4.png b/master_search/static/description/assets/modules/4.png new file mode 100644 index 000000000..e78427938 Binary files /dev/null and b/master_search/static/description/assets/modules/4.png differ diff --git a/master_search/static/description/assets/modules/5.gif b/master_search/static/description/assets/modules/5.gif new file mode 100644 index 000000000..2a5f8e659 Binary files /dev/null and b/master_search/static/description/assets/modules/5.gif differ diff --git a/master_search/static/description/assets/modules/5.png b/master_search/static/description/assets/modules/5.png new file mode 100755 index 000000000..272ec20f9 Binary files /dev/null and b/master_search/static/description/assets/modules/5.png differ diff --git a/master_search/static/description/assets/modules/6.png b/master_search/static/description/assets/modules/6.png new file mode 100644 index 000000000..7d5c3154f Binary files /dev/null and b/master_search/static/description/assets/modules/6.png differ diff --git a/master_search/static/description/assets/modules/l2.png b/master_search/static/description/assets/modules/l2.png new file mode 100644 index 000000000..f40a0756d Binary files /dev/null and b/master_search/static/description/assets/modules/l2.png differ diff --git a/master_search/static/description/assets/modules/l3.png b/master_search/static/description/assets/modules/l3.png new file mode 100644 index 000000000..5738a486e Binary files /dev/null and b/master_search/static/description/assets/modules/l3.png differ diff --git a/master_search/static/description/assets/modules/l4.png b/master_search/static/description/assets/modules/l4.png new file mode 100644 index 000000000..8d99e8c68 Binary files /dev/null and b/master_search/static/description/assets/modules/l4.png differ diff --git a/master_search/static/description/assets/modules/l5.png b/master_search/static/description/assets/modules/l5.png new file mode 100644 index 000000000..3415917c2 Binary files /dev/null and b/master_search/static/description/assets/modules/l5.png differ diff --git a/master_search/static/description/assets/modules/l6.png b/master_search/static/description/assets/modules/l6.png new file mode 100644 index 000000000..c7ea331ee Binary files /dev/null and b/master_search/static/description/assets/modules/l6.png differ diff --git a/master_search/static/description/assets/screenshots/hero.gif b/master_search/static/description/assets/screenshots/hero.gif new file mode 100644 index 000000000..5aa362d65 Binary files /dev/null and b/master_search/static/description/assets/screenshots/hero.gif differ diff --git a/master_search/static/description/assets/screenshots/screenshot1.png b/master_search/static/description/assets/screenshots/screenshot1.png new file mode 100644 index 000000000..f45148d12 Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot1.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot2.png b/master_search/static/description/assets/screenshots/screenshot2.png new file mode 100644 index 000000000..3a04dde4f Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot2.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot3.png b/master_search/static/description/assets/screenshots/screenshot3.png new file mode 100644 index 000000000..90dd51586 Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot3.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot4.png b/master_search/static/description/assets/screenshots/screenshot4.png new file mode 100644 index 000000000..57de9c5e0 Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot4.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot5.png b/master_search/static/description/assets/screenshots/screenshot5.png new file mode 100644 index 000000000..514608953 Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot5.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot6.png b/master_search/static/description/assets/screenshots/screenshot6.png new file mode 100644 index 000000000..0e18ab559 Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot6.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot7.png b/master_search/static/description/assets/screenshots/screenshot7.png new file mode 100644 index 000000000..e6b9165bf Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot7.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot8.png b/master_search/static/description/assets/screenshots/screenshot8.png new file mode 100644 index 000000000..4e59df57b Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot8.png differ diff --git a/master_search/static/description/assets/screenshots/screenshot9.png b/master_search/static/description/assets/screenshots/screenshot9.png new file mode 100644 index 000000000..f32e8190d Binary files /dev/null and b/master_search/static/description/assets/screenshots/screenshot9.png differ diff --git a/master_search/static/description/assets/video/master_search.mp4 b/master_search/static/description/assets/video/master_search.mp4 new file mode 100644 index 000000000..0e29d26e1 Binary files /dev/null and b/master_search/static/description/assets/video/master_search.mp4 differ diff --git a/master_search/static/description/assets/video/master_search.webm b/master_search/static/description/assets/video/master_search.webm new file mode 100644 index 000000000..357c7d058 Binary files /dev/null and b/master_search/static/description/assets/video/master_search.webm differ diff --git a/master_search/static/description/banner.jpg b/master_search/static/description/banner.jpg new file mode 100644 index 000000000..1f3f2e27f Binary files /dev/null and b/master_search/static/description/banner.jpg differ diff --git a/master_search/static/description/icon.png b/master_search/static/description/icon.png new file mode 100644 index 000000000..3ff040971 Binary files /dev/null and b/master_search/static/description/icon.png differ diff --git a/master_search/static/description/index.html b/master_search/static/description/index.html new file mode 100644 index 000000000..f1658f753 --- /dev/null +++ b/master_search/static/description/index.html @@ -0,0 +1,795 @@ + + + + + + Odoo App 3 Index + + + + + + + + +
+
+
+
+
+ +
+
+
+ Community +
+
+ Enterprise +
+
+ Odoo.sh +
+
+
+
+
+
+

+ Global Search

+

+ Easy Search in Customers, Products, Sale, Purchase, + Inventory and + Accounting modules. +

+
+ +
+
+
+
+
+

+ Key Highlights +

+
+
+
+
+
+ +
+
+

+ Advance Search + user

+

Users can + search the records in Customers, Products, + Sale, Purchase, Inventory and Accounting Modules +

+
+
+
+
+
+
+ +
+
+

+ Search Module.

+

User gets a + new module where he can make advance and simple + search in different modules + Also possible to search using different + attributes like name, + reference, number, etc.

+
+
+
+
+
+
+ +
+
+
+
+
+ +
+
+

+ On enabling the button inside the user , + he/she gets global search access.

+
+
+
+
+
+
+ +
+
+

+ When the global search is enabled that + particular user can see a new module 'Global + Search'. The global search can be done using + this module.

+
+
+
+
+
+
+ +
+
+

+ Search in All Data.

+
+
+
+
+
+
+ + +
+
+

+ Search in Customer Data.

+
+
+
+
+
+
+ +
+
+

+ Search in Product Data.

+
+
+
+
+
+
+ +
+
+

+ Search in Sale Data.

+
+
+
+
+
+
+ +
+
+

+ Search in Purchase Data.

+
+
+
+
+
+
+ +
+
+

+ Search in Inventory Data.

+
+
+
+
+
+
+ +
+
+

+ Search in Accounting Data.

+
+
+
+ +
+ +
+
+
    +
  • + Dynamic Search View Option +
  • +
  • + Possible to search with different attributes like name, reference, number, etc. + +
  • +
  • + Easily Search Records in Customers, Products, Sale, Purchase, Inventory and Accounting Data +
  • +
  • + Can view Recent searches +
  • + +
+
+
+
+
+
+
Version + 17.0.1.0.0|Released on:22nd November 2023 +
+

+ + Initial Commit for Global Search.

+
+
+
+
+
+
+
+

+ Related Products

+
+
+ +
+
+

+ Our Services

+ +
+
+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Customization

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Implementation

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Support

+
+
+
+
+
+
+ service-icon +
+
+

Hire + Odoo Developer

+
+
+
+
+ +
+
+ service-icon +
+
+

Odoo + Integration

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Migration

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Consultancy

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Implementation

+
+
+
+
+
+
+ service-icon +
+
+

Odoo + Licensing Consultancy

+
+
+
+
+
+
+

+ Our Industries

+ +
+
+
+
+
+
+ +

Trading

+

Easily procure and sell your products

+
+
+
+
+ +

POS

+

Easy configuration and convivial experience

+
+
+
+
+ +

+ Education

+

A platform for educational management

+
+
+
+
+ +

+ Manufacturing

+

Plan, track and schedule your operations

+
+
+
+
+ +

E-commerce & + Website

+

Mobile friendly, awe-inspiring product pages

+
+
+
+
+ +

Service + Management

+

Keep track of services and invoice

+
+
+
+
+ +

+ Restaurant

+

Run your bar or restaurant methodically

+
+
+
+
+ +

Hotel + Management

+

An all-inclusive hotel management application

+
+
+
+
+
+
+

+ Support

+
+
+
+
+
+
+
+ +
+ Need + Help? +

Got + questions or need help? Get in touch.

+
odoo@cybrosys.com +
+
+
+
+
+
+
+
+ +
+ WhatsApp +

Say hi to + us on WhatsApp!

+
+91 + 99456767686 +
+
+
+
+
+
+
+
+
+ + + + + + diff --git a/master_search/static/src/scss/master_search.scss b/master_search/static/src/scss/master_search.scss new file mode 100644 index 000000000..db370a8a1 --- /dev/null +++ b/master_search/static/src/scss/master_search.scss @@ -0,0 +1,36 @@ +.oe_search_tab{ + cursor: pointer; + transition: .2s; + &:hover { + background-color: #7c7bad !important; + } +} +.oe_details_tree{ + display: none; +} + +.oe_details_tree--show{ + display: block !important; +} + +.btn_master_search{ + display: inline-block; + background-color:#5f5e97; + color:#fff !important; + color: #fff;margin-left: 1px; + margin-top: -1px; +} +.btn_master_search:hover{ + background-color: rgb(255, 255, 255) !important; + color: rgb(61, 155, 187) !important; +} +.not-allowed{ + color: #d94242; + border: 1px solid #ea9292; + border-radius: 5px; + background-color: #f9e7e7; + padding: 1px 55px; + width: 370px; + margin-bottom: 5px; + display: none; +} diff --git a/master_search/views/master_search_view.xml b/master_search/views/master_search_view.xml new file mode 100644 index 000000000..a9d168f07 --- /dev/null +++ b/master_search/views/master_search_view.xml @@ -0,0 +1,382 @@ + + + + + Search + master.search + +
+ + + +
+
+
+
+
+
+
+
+
+
+ Recent Searches +
+ + Records Found + + + +
+
+
+ + + + + +
+
+
+
+ Customer Search Results +
+ + Records Found + + + +
+
+
+ + + + + + +
+
+
+
+ Product Search Results +
+ + Records Found + + + +
+
+
+ + + + + + + + + + + +
+
+
+
+ Inventory Search Results +
+ + Records Found + + + +
+
+
+ + + + + + + + + +
+
+
+
+ Sale Search Results +
+ + Records Found + + + +
+
+
+ + + + + + + + + +
+
+
+
+ Purchase Search Results +
+ + Records Found + + + +
+
+
+ + + + + + + +
+
+
+
+ Accounting Search Results +
+ + Records Found + + + +
+
+
+ + + + + + + +
+
+
+ +
+
+ + + Search + master.search + form + {'active_test': False, + 'search_default_filter_active': 1} + + + + +