From 8ab84c710745e098cf7b9ef5c8b07df3bbcab587 Mon Sep 17 00:00:00 2001 From: Stephane Le Roy Date: Wed, 14 Jan 2015 09:43:14 +0100 Subject: [PATCH] Add search on boolean fields in structured search Add search on boolean fields in structured search: - search for true or false - search for missing value --- dist/app.js | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/dist/app.js b/dist/app.js index 361ca726..bb9465ff 100644 --- a/dist/app.js +++ b/dist/app.js @@ -1182,6 +1182,14 @@ } else if(op === "query_string") { query["default_field"] = field; query["query"] = value; + } else if(op === "boolean") { + op = "term"; + if(value === "true") { + value = true; + } else { + value = false; + } + query[field] = value; } else if(op === "missing") { op = "constant_score" var missing = {}, filter = {}; @@ -3920,6 +3928,8 @@ } else if(spec.type === 'long' || spec.type === 'integer' || spec.type === 'float' || spec.type === 'byte' || spec.type === 'short' || spec.type === 'double') { ops = ["term", "range", "fuzzy", "query_string", "missing"]; + } else if(spec.type === 'boolean') { + ops = ["boolean", "missing"]; } else if(spec.type === 'date') { ops = ["term", "range", "fuzzy", "query_string", "missing"]; } else if(spec.type === 'geo_point') { @@ -3936,6 +3946,8 @@ op.siblings().remove(".qual,.range,.fuzzy"); if(opv === 'term' || opv === 'wildcard' || opv === 'prefix' || opv === "query_string" || opv === 'text') { op.after({ tag: "INPUT", cls: "qual", type: "text" }); + } else if(opv === 'boolean') { + op.after(this._boolean_template()); } else if(opv === 'range') { op.after(this._range_template()); } else if(opv === 'fuzzy') { @@ -3989,7 +4001,12 @@ { tag: "SELECT", cls: "fuzzyop", children: ["max_expansions", "min_similarity"].map(ut.option_template) }, { tag: "INPUT", cls: "fuzzyqual", type: "text" } ]}; + }, + + _boolean_template: function() { + return { tag: "SELECT", cls: "qual", children: ["true", "false"].map(ut.option_template) }; } + }); })( this.jQuery, this.app, this.i18n );