Browse Source
Merge pull request #621 from adhoc-dev/9.0-mig-base_name_search_improved
Merge pull request #621 from adhoc-dev/9.0-mig-base_name_search_improved
Port to 9.0 base_name_search_improvedpull/650/merge
Daniel Reis
8 years ago
committed by
GitHub
22 changed files with 598 additions and 0 deletions
-
121base_name_search_improved/README.rst
-
2base_name_search_improved/__init__.py
-
19base_name_search_improved/__openerp__.py
-
29base_name_search_improved/i18n/de.po
-
29base_name_search_improved/i18n/es.po
-
29base_name_search_improved/i18n/fi.po
-
29base_name_search_improved/i18n/fr.po
-
29base_name_search_improved/i18n/hr.po
-
29base_name_search_improved/i18n/hr_HR.po
-
29base_name_search_improved/i18n/it.po
-
29base_name_search_improved/i18n/pt_BR.po
-
30base_name_search_improved/i18n/sl.po
-
29base_name_search_improved/i18n/tr.po
-
BINbase_name_search_improved/images/image0.png
-
BINbase_name_search_improved/images/image1.png
-
BINbase_name_search_improved/images/image2.png
-
2base_name_search_improved/models/__init__.py
-
83base_name_search_improved/models/ir_model.py
-
BINbase_name_search_improved/static/description/icon.png
-
5base_name_search_improved/tests/__init__.py
-
54base_name_search_improved/tests/test_name_search.py
-
21base_name_search_improved/views/ir_model.xml
@ -0,0 +1,121 @@ |
|||
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg |
|||
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html |
|||
:alt: License: AGPL-3 |
|||
|
|||
==================== |
|||
Improved Name Search |
|||
==================== |
|||
|
|||
Extends the name search feature to use additional, more relaxed |
|||
matching methods, and to allow searching into configurable additional |
|||
record fields. |
|||
|
|||
The name search is the lookup feature to select a related record. |
|||
For example, selecting a Customer on a new Sales order. |
|||
|
|||
For example, typing "john brown" doesn't match "John M. Brown". |
|||
The relaxed search also looks up for records containing all the words, |
|||
so "John M. Brown" would be a match. |
|||
It also tolerates words in a different order, so searching |
|||
for "brown john" also works. |
|||
|
|||
.. image:: images/image0.png |
|||
|
|||
Additionally, an Administrator can configure other fields to also lookup into. |
|||
For example, Customers could be additionally searched by City or Phone number. |
|||
|
|||
.. image:: images/image2.png |
|||
|
|||
How it works: |
|||
|
|||
Regular name search is performed, and the additional search logic is only |
|||
triggered if not enough results are found. |
|||
This way, no overhead is added on searches that would normally yield results. |
|||
|
|||
But if not enough results are found, then additional search methods are tried. |
|||
The specific methods used are: |
|||
|
|||
- Try regular search on each of the additional fields |
|||
- Try ordered word search on each of the search fields |
|||
- Try unordered word search on each of the search fields |
|||
|
|||
All results found are presented in that order, |
|||
hopefully presenting them in order of relevance. |
|||
|
|||
|
|||
Installation |
|||
============ |
|||
|
|||
No specific requirements. |
|||
|
|||
|
|||
Configuration |
|||
============= |
|||
|
|||
The fuzzy search is automatically enabled on all Models. |
|||
Note that this only affects typing in related fields. |
|||
The regular ``search()``, used in the top right search box, is not affected. |
|||
|
|||
Additional search fields can be configured at Settings > Technical > Database > Models, |
|||
using the "Name Search Fields" field. |
|||
|
|||
.. image:: images/image1.png |
|||
|
|||
|
|||
Usage |
|||
===== |
|||
|
|||
Just type into any related field, such as Customer on a Sale Order. |
|||
|
|||
|
|||
.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas |
|||
:alt: Try me on Runbot |
|||
:target: https://runbot.odoo-community.org/runbot/149/9.0 |
|||
|
|||
.. repo_id is available in https://github.com/OCA/maintainer-tools/blob/master/tools/repos_with_ids.txt |
|||
.. branch is "8.0" for example |
|||
|
|||
Known issues / Roadmap |
|||
====================== |
|||
|
|||
* Also use fuzzy search, such as the Levenshtein distance: |
|||
https://www.postgresql.org/docs/9.5/static/fuzzystrmatch.html |
|||
* The list of additional fields to search could benefit from caching, for efficiency. |
|||
* This feature could also be implemented for regular ``search`` on the ``name`` field. |
|||
|
|||
|
|||
Bug Tracker |
|||
=========== |
|||
|
|||
Bugs are tracked on `GitHub Issues |
|||
<https://github.com/OCA/server-tools/issues>`_. In case of trouble, please |
|||
check there if your issue has already been reported. If you spotted it first, |
|||
help us smashing it by providing a detailed and welcomed feedback. |
|||
|
|||
Credits |
|||
======= |
|||
|
|||
Images |
|||
------ |
|||
|
|||
* Odoo Community Association: `Icon <https://github.com/OCA/maintainer-tools/blob/master/template/module/static/description/icon.svg>`_. |
|||
|
|||
Contributors |
|||
------------ |
|||
|
|||
* Daniel Reis <https://github.com/dreispt> |
|||
|
|||
Maintainer |
|||
---------- |
|||
|
|||
.. image:: https://odoo-community.org/logo.png |
|||
:alt: Odoo Community Association |
|||
:target: https://odoo-community.org |
|||
|
|||
This module is maintained by the OCA. |
|||
|
|||
OCA, or the Odoo Community Association, is a nonprofit organization whose |
|||
mission is to support the collaborative development of Odoo features and |
|||
promote its widespread use. |
|||
|
|||
To contribute to this module, please visit https://odoo-community.org. |
@ -0,0 +1,2 @@ |
|||
# -*- coding: utf-8 -*- |
|||
from . import models |
@ -0,0 +1,19 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# © 2016 Daniel Reis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
|||
{ |
|||
'name': 'Improved Name Search', |
|||
'summary': 'Friendlier search when typing in relation fields', |
|||
'version': '9.0.1.0.0', |
|||
'category': 'Uncategorized', |
|||
'website': 'https://odoo-community.org/', |
|||
'author': 'Daniel Reis, Odoo Community Association (OCA)', |
|||
'license': 'AGPL-3', |
|||
'data': [ |
|||
'views/ir_model.xml', |
|||
], |
|||
'depends': [ |
|||
'base', |
|||
], |
|||
'installable': True, |
|||
} |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Rudolf Schnapka <rs@techno-flex.de>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Rudolf Schnapka <rs@techno-flex.de>, 2016\n" |
|||
"Language-Team: German (https://www.transifex.com/oca/teams/23907/de/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: de\n" |
|||
"Plural-Forms: nplurals=2; plural=(n != 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modelle" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Carles Antoli <carlesantoli@hotmail.com>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Carles Antoli <carlesantoli@hotmail.com>, 2016\n" |
|||
"Language-Team: Spanish (https://www.transifex.com/oca/teams/23907/es/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: es\n" |
|||
"Plural-Forms: nplurals=2; plural=(n != 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modelos" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Jarmo Kortetjärvi <jarmo.kortetjarvi@gmail.com>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-09-21 00:47+0000\n" |
|||
"PO-Revision-Date: 2016-09-21 00:47+0000\n" |
|||
"Last-Translator: Jarmo Kortetjärvi <jarmo.kortetjarvi@gmail.com>, 2016\n" |
|||
"Language-Team: Finnish (https://www.transifex.com/oca/teams/23907/fi/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: fi\n" |
|||
"Plural-Forms: nplurals=2; plural=(n != 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Mallit" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# OCA Transbot <transbot@odoo-community.org>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: OCA Transbot <transbot@odoo-community.org>, 2016\n" |
|||
"Language-Team: French (https://www.transifex.com/oca/teams/23907/fr/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: fr\n" |
|||
"Plural-Forms: nplurals=2; plural=(n > 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modèles" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Bole <bole@dajmi5.com>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-09-21 00:47+0000\n" |
|||
"PO-Revision-Date: 2016-09-21 00:47+0000\n" |
|||
"Last-Translator: Bole <bole@dajmi5.com>, 2016\n" |
|||
"Language-Team: Croatian (https://www.transifex.com/oca/teams/23907/hr/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: hr\n" |
|||
"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modeli" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Bole <bole@dajmi5.com>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-09-21 00:47+0000\n" |
|||
"PO-Revision-Date: 2016-09-21 00:47+0000\n" |
|||
"Last-Translator: Bole <bole@dajmi5.com>, 2016\n" |
|||
"Language-Team: Croatian (Croatia) (https://www.transifex.com/oca/teams/23907/hr_HR/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: hr_HR\n" |
|||
"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modeli" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Paolo Valier <paolo.valier@hotmail.it>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Paolo Valier <paolo.valier@hotmail.it>, 2016\n" |
|||
"Language-Team: Italian (https://www.transifex.com/oca/teams/23907/it/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: it\n" |
|||
"Plural-Forms: nplurals=2; plural=(n != 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modelli" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Armando Vulcano Junior <vulcano@uol.com.br>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Armando Vulcano Junior <vulcano@uol.com.br>, 2016\n" |
|||
"Language-Team: Portuguese (Brazil) (https://www.transifex.com/oca/teams/23907/pt_BR/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: pt_BR\n" |
|||
"Plural-Forms: nplurals=2; plural=(n > 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modelos" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
@ -0,0 +1,30 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# OCA Transbot <transbot@odoo-community.org>, 2016 |
|||
# Matjaž Mozetič <m.mozetic@matmoz.si>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Matjaž Mozetič <m.mozetic@matmoz.si>, 2016\n" |
|||
"Language-Team: Slovenian (https://www.transifex.com/oca/teams/23907/sl/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: sl\n" |
|||
"Plural-Forms: nplurals=4; plural=(n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n%100==4 ? 2 : 3);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modeli" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "Polja iskanja po imenu" |
@ -0,0 +1,29 @@ |
|||
# Translation of Odoo Server. |
|||
# This file contains the translation of the following modules: |
|||
# * base_name_search_improved |
|||
# |
|||
# Translators: |
|||
# Ahmet Altınışık <aaltinisik@altinkaya.com.tr>, 2016 |
|||
msgid "" |
|||
msgstr "" |
|||
"Project-Id-Version: Odoo Server 8.0\n" |
|||
"Report-Msgid-Bugs-To: \n" |
|||
"POT-Creation-Date: 2016-06-17 02:42+0000\n" |
|||
"PO-Revision-Date: 2016-06-17 02:42+0000\n" |
|||
"Last-Translator: Ahmet Altınışık <aaltinisik@altinkaya.com.tr>, 2016\n" |
|||
"Language-Team: Turkish (https://www.transifex.com/oca/teams/23907/tr/)\n" |
|||
"MIME-Version: 1.0\n" |
|||
"Content-Type: text/plain; charset=UTF-8\n" |
|||
"Content-Transfer-Encoding: \n" |
|||
"Language: tr\n" |
|||
"Plural-Forms: nplurals=2; plural=(n > 1);\n" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: model:ir.model,name:base_name_search_improved.model_ir_model |
|||
msgid "Models" |
|||
msgstr "Modeller" |
|||
|
|||
#. module: base_name_search_improved |
|||
#: field:ir.model,name_search_ids:0 |
|||
msgid "Name Search Fields" |
|||
msgstr "" |
After Width: 896 | Height: 281 | Size: 16 KiB |
After Width: 890 | Height: 206 | Size: 11 KiB |
After Width: 894 | Height: 279 | Size: 15 KiB |
@ -0,0 +1,2 @@ |
|||
# -*- coding: utf-8 -*- |
|||
from . import ir_model |
@ -0,0 +1,83 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# © 2016 Daniel Reis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
|||
|
|||
from openerp import models, fields, api |
|||
from openerp import SUPERUSER_ID |
|||
from openerp import tools |
|||
|
|||
|
|||
# Extended name search is only used on some operators |
|||
ALLOWED_OPS = set(['ilike', 'like']) |
|||
|
|||
|
|||
@tools.ormcache(skiparg=0) |
|||
def _get_rec_names(self): |
|||
"List of fields to search into" |
|||
model = self.env['ir.model'].search( |
|||
[('model', '=', str(self._model))]) |
|||
rec_name = [self._rec_name] or [] |
|||
other_names = model.name_search_ids.mapped('name') |
|||
return rec_name + other_names |
|||
|
|||
|
|||
def _extend_name_results(self, domain, results, limit): |
|||
result_count = len(results) |
|||
if result_count < limit: |
|||
domain += [('id', 'not in', [x[0] for x in results])] |
|||
recs = self.search(domain, limit=limit - result_count) |
|||
results.extend(recs.name_get()) |
|||
return results |
|||
|
|||
|
|||
class ModelExtended(models.Model): |
|||
_inherit = 'ir.model' |
|||
|
|||
name_search_ids = fields.Many2many( |
|||
'ir.model.fields', |
|||
string='Name Search Fields') |
|||
|
|||
def _register_hook(self, cr, ids=None): |
|||
|
|||
def make_name_search(): |
|||
|
|||
@api.model |
|||
def name_search(self, name='', args=None, |
|||
operator='ilike', limit=100): |
|||
# Perform standard name search |
|||
res = name_search.origin( |
|||
self, name=name, args=args, operator=operator, limit=limit) |
|||
enabled = self.env.context.get('name_search_extended', True) |
|||
# Perform extended name search |
|||
# Note: Empty name causes error on |
|||
# Customer->More->Portal Access Management |
|||
if name and enabled and operator in ALLOWED_OPS: |
|||
# Support a list of fields to search on |
|||
all_names = _get_rec_names(self) |
|||
base_domain = args or [] |
|||
# Try regular search on each additional search field |
|||
for rec_name in all_names[1:]: |
|||
domain = [(rec_name, operator, name)] |
|||
res = _extend_name_results( |
|||
self, base_domain + domain, res, limit) |
|||
# Try ordered word search on each of the search fields |
|||
for rec_name in all_names: |
|||
domain = [(rec_name, operator, name.replace(' ', '%'))] |
|||
res = _extend_name_results( |
|||
self, base_domain + domain, res, limit) |
|||
# Try unordered word search on each of the search fields |
|||
for rec_name in all_names: |
|||
domain = [(rec_name, operator, x) |
|||
for x in name.split() if x] |
|||
res = _extend_name_results( |
|||
self, base_domain + domain, res, limit) |
|||
return res |
|||
return name_search |
|||
|
|||
if ids is None: |
|||
ids = self.search(cr, SUPERUSER_ID, []) |
|||
for model in self.browse(cr, SUPERUSER_ID, ids): |
|||
Model = self.pool.get(model.model) |
|||
if Model: |
|||
Model._patch_method('name_search', make_name_search()) |
|||
return super(ModelExtended, self)._register_hook(cr) |
After Width: 128 | Height: 128 | Size: 9.2 KiB |
@ -0,0 +1,5 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# © 2016 Daniel Reis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
|||
|
|||
from . import test_name_search |
@ -0,0 +1,54 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# © 2016 Daniel Reis |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
|||
|
|||
from openerp.tests.common import TransactionCase, at_install, post_install |
|||
|
|||
|
|||
@at_install(False) |
|||
@post_install(True) |
|||
class NameSearchCase(TransactionCase): |
|||
|
|||
def setUp(self): |
|||
super(NameSearchCase, self).setUp() |
|||
phone_field = self.env.ref('base.field_res_partner_phone') |
|||
model_partner = self.env.ref('base.model_res_partner') |
|||
model_partner.name_search_ids = phone_field |
|||
self.Partner = self.env['res.partner'] |
|||
self.partner1 = self.Partner.create( |
|||
{'name': 'Luigi Verconti', |
|||
'customer': True, |
|||
'phone': '+351 555 777 333'}) |
|||
self.partner2 = self.Partner.create( |
|||
{'name': 'Ken Shabby', |
|||
'customer': True, |
|||
'phone': '+351 555 333 777'}) |
|||
self.partner3 = self.Partner.create( |
|||
{'name': 'Johann Gambolputty of Ulm', |
|||
'supplier': True, |
|||
'phone': '+351 777 333 555'}) |
|||
|
|||
def test_RelevanceOrderedResults(self): |
|||
"""Return results ordered by relevance""" |
|||
res = self.Partner.name_search('555 777') |
|||
self.assertEqual( |
|||
res[0][0], self.partner1.id, |
|||
'Match full string honoring spaces') |
|||
self.assertEqual( |
|||
res[1][0], self.partner2.id, |
|||
'Match words honoring order of appearance') |
|||
self.assertEqual( |
|||
res[2][0], self.partner3.id, |
|||
'Match all words, regardless of order of appearance') |
|||
|
|||
def test_NameSearchMustMatchAllWords(self): |
|||
"""Must Match All Words""" |
|||
res = self.Partner.name_search('ulm 555 777') |
|||
self.assertFalse(res) |
|||
|
|||
def test_MustHonorDomain(self): |
|||
"""Must also honor a provided Domain""" |
|||
res = self.Partner.name_search('+351', args=[('supplier', '=', True)]) |
|||
gambulputty = self.partner3.id |
|||
self.assertEqual(len(res), 1) |
|||
self.assertEqual(res[0][0], gambulputty) |
@ -0,0 +1,21 @@ |
|||
<?xml version="1.0" encoding="utf-8"?> |
|||
<!-- © 2016 Daniel Reis |
|||
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). --> |
|||
|
|||
<openerp> |
|||
|
|||
<record id="view_model_form" model="ir.ui.view"> |
|||
<field name="name">Add Name Searchable to Models</field> |
|||
<field name="model">ir.model</field> |
|||
<field name="inherit_id" ref="base.view_model_form"/> |
|||
<field name="arch" type="xml"> |
|||
<field name="state" position="after"> |
|||
<field name="name_search_ids" |
|||
widget="many2many_tags" |
|||
domain="[('model_id', '=', id)]" |
|||
/> |
|||
</field> |
|||
</field> |
|||
</record> |
|||
|
|||
</openerp> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue