Skip to content

Commit

Permalink
[MIG] Migrate web_search_with_and from 8.0 to 10.0
Browse files Browse the repository at this point in the history
  • Loading branch information
Creamaster committed Mar 20, 2017
1 parent a408946 commit ed1c8fc
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 35 deletions.
13 changes: 11 additions & 2 deletions web_search_with_and/README.rst
Expand Up @@ -26,7 +26,15 @@ Usage

.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas
:alt: Try me on Runbot
:target: https://runbot.odoo-community.org/runbot/162/8.0
:target: https://runbot.odoo-community.org/runbot/162/10.0

Bug Tracker
===========

Bugs are tracked on `GitHub Issues
<https://github.com/OCA/{project_repo}/issues>`_. In case of trouble, please
check there if your issue has already been reported. If you spotted it first,
help us smash it by providing detailed and welcomed feedback.

Credits
=======
Expand All @@ -35,6 +43,7 @@ Contributors
------------

* Andrius Preimantas <andrius@versada.lt>
* Adrien Didenot <adrien.didenot@horanet.com>

Maintainer
----------
Expand All @@ -49,4 +58,4 @@ 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 http://odoo-community.org.
To contribute to this module, please visit http://odoo-community.org.
@@ -1,10 +1,10 @@
# -*- coding: utf-8 -*-
# © 2015 Andrius Preimantas <andrius@versada.lt>
# Copyright 2015 Andrius Preimantas <andrius@versada.lt>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

{
'name': "Use AND conditions on omnibar search",
'version': '8.0.1.0.0',
'version': '10.0.1.0.0',
'author': 'Versada UAB, Odoo Community Association (OCA)',
'license': 'AGPL-3',
'category': 'web',
Expand Down
16 changes: 7 additions & 9 deletions web_search_with_and/data/data.xml
@@ -1,10 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<openerp>
<data>
<template id="assets_backend" name="web_view_editor assets" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
<script type="text/javascript" src="/web_search_with_and/static/src/js/search.js"/>
</xpath>
</template>
</data>
</openerp>
<odoo>
<template id="assets_backend" name="web_view_editor assets" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
<script type="text/javascript" src="/web_search_with_and/static/src/js/search.js"/>
</xpath>
</template>
</odoo>
Binary file added web_search_with_and/static/description/icon.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
54 changes: 32 additions & 22 deletions web_search_with_and/static/src/js/search.js
@@ -1,43 +1,53 @@
openerp.web_search_with_and = function (instance) {
odoo.define('web_search_with_and', function (require) {
"use strict";

instance.web.SearchView = instance.web.SearchView.extend({
var SearchView = require('web.SearchView');
var Backbone = window.Backbone;

SearchView.include({
// Override the base method to detect a 'shift' event
select_completion: function (e, ui) {
var self = this;
if (e.shiftKey) {
if (e.shiftKey
&& ui.item.facet.values
&& ui.item.facet.values.length
&& String(ui.item.facet.values[0].value).trim() !== "") {
// In case of an 'AND' search a new facet is added regarding of the previous facets
e.preventDefault();

var input_index = _(this.input_subviews).indexOf(
this.subviewForRoot(
this.$('div.oe_searchview_input:focus')[0]));
this.query.add(ui.item.facet, {at: input_index / 2, shiftKey: true});
this.query.add(ui.item.facet, {shiftKey: true});
} else {
this._super(e, ui);

return this._super.apply(this, arguments);
}
},
}
});

instance.web.search.SearchQuery = instance.web.search.SearchQuery.extend({
SearchView.SearchQuery.prototype = SearchView.SearchQuery.extend({
// Override the odoo method to (conditionally) add a search facet even if a existing
// facet for the same field/category already exists
add: function (values, options) {

options = options || {};
if (options.shiftKey) {

if (!values) {
values = [];
} else if (!(values instanceof Array)) {
values = [values];
}
if (!values) {
values = [];
}
else if (!(values instanceof Array)) {
values = [values];
}

if (options.shiftKey) {
delete options.shiftKey;
_(values).each(function (value) {
var model = this._prepareModel(value, options);
Backbone.Collection.prototype.add.call(this, model, options);
}, this);

return this;
}
else {
return this.constructor.__super__.add.apply(this, arguments);
return this.constructor.__super__.add.call(this, values, options);
}
},
});
};
}
}).prototype;

});

0 comments on commit ed1c8fc

Please sign in to comment.