Commit 3fe18c01 authored by Gergely Ujvari's avatar Gergely Ujvari

Get rid of normalize parameter

We judge whether to normalize or not by the variable type
parent 12d2b302
...@@ -50,7 +50,6 @@ class SearchFilter ...@@ -50,7 +50,6 @@ class SearchFilter
# [facet_name]: # [facet_name]:
# [operator]: 'and'|'or'|'min' (for the elements of the facet terms list) # [operator]: 'and'|'or'|'min' (for the elements of the facet terms list)
# [lowercase]: true|false # [lowercase]: true|false
# [normalize]: true|flase (unicode normalization)
# [terms]: an array for the matched terms for this facet # [terms]: an array for the matched terms for this facet
# The facet selection is done by analyzing each token. # The facet selection is done by analyzing each token.
# It generally expects a <facet_name>:<facet_term> structure for a token # It generally expects a <facet_name>:<facet_term> structure for a token
...@@ -120,42 +119,34 @@ class SearchFilter ...@@ -120,42 +119,34 @@ class SearchFilter
terms: any terms: any
operator: 'and' operator: 'and'
lowercase: true lowercase: true
normalize: true
quote: quote:
terms: quote terms: quote
operator: 'and' operator: 'and'
lowercase: true lowercase: true
normalize: true
result: result:
terms: result terms: result
operator: 'min' operator: 'min'
lowercase: false lowercase: false
normalize: false
since: since:
terms: since terms: since
operator: 'and' operator: 'and'
lowercase: false lowercase: false
normalize: false
tag: tag:
terms: tag terms: tag
operator: 'and' operator: 'and'
lowercase: true lowercase: true
normalize: true
text: text:
terms: text terms: text
operator: 'and' operator: 'and'
lowercase: true lowercase: true
normalize: true
uri: uri:
terms: uri terms: uri
operator: 'or' operator: 'or'
lowercase: true lowercase: true
normalize: true
user: user:
terms: user terms: user
operator: 'or' operator: 'or'
lowercase: true lowercase: true
normalize: true
# This class will process the results of search and generate the correct filter # This class will process the results of search and generate the correct filter
# It expects the following dict format as rules # It expects the following dict format as rules
...@@ -163,7 +154,6 @@ class SearchFilter ...@@ -163,7 +154,6 @@ class SearchFilter
# formatter: to format the value (optional) # formatter: to format the value (optional)
# path: json path mapping to the annotation field # path: json path mapping to the annotation field
# case_sensitive: true|false (default: false) # case_sensitive: true|false (default: false)
# normalize: true| false (default: false)
# and_or: and|or for multiple values should it threat them as 'or' or 'and' (def: or) # and_or: and|or for multiple values should it threat them as 'or' or 'and' (def: or)
# operator: if given it'll use this operator regardless of other circumstances # operator: if given it'll use this operator regardless of other circumstances
# #
...@@ -253,7 +243,6 @@ class QueryParser ...@@ -253,7 +243,6 @@ class QueryParser
# Now generate the clause with the help of the rule # Now generate the clause with the help of the rule
case_sensitive = if rule.case_sensitive? then rule.case_sensitive else false case_sensitive = if rule.case_sensitive? then rule.case_sensitive else false
normalize = if value.normalize? then value.normalize else false
and_or = if rule.and_or? then rule.and_or else 'or' and_or = if rule.and_or? then rule.and_or else 'or'
mapped_field = if rule.path? then rule.path else '/'+category mapped_field = if rule.path? then rule.path else '/'+category
...@@ -265,12 +254,12 @@ class QueryParser ...@@ -265,12 +254,12 @@ class QueryParser
t = if rule.formatter then rule.formatter term else term t = if rule.formatter then rule.formatter term else term
value_part.push t value_part.push t
filter.addClause mapped_field, oper_part, value_part, case_sensitive, normalize, rule.options filter.addClause mapped_field, oper_part, value_part, case_sensitive, rule.options
else else
oper_part = if rule.operator? then rule.operator else 'matches' oper_part = if rule.operator? then rule.operator else 'matches'
for val in terms for val in terms
value_part = if rule.formatter then rule.formatter val else val value_part = if rule.formatter then rule.formatter val else val
filter.addClause mapped_field, oper_part, value_part, case_sensitive, normalize, rule.options filter.addClause mapped_field, oper_part, value_part, case_sensitive, rule.options
class StreamFilter class StreamFilter
...@@ -355,13 +344,12 @@ class StreamFilter ...@@ -355,13 +344,12 @@ class StreamFilter
@filter.clauses = [] @filter.clauses = []
this this
addClause: (field, operator, value, case_sensitive = false, normalize = false, options = {}) -> addClause: (field, operator, value, case_sensitive = false, options = {}) ->
@filter.clauses.push @filter.clauses.push
field: field field: field
operator: operator operator: operator
value: value value: value
case_sensitive: case_sensitive case_sensitive: case_sensitive
normalize: normalize
options: options options: options
this this
......
...@@ -439,7 +439,10 @@ class ViewFilter ...@@ -439,7 +439,10 @@ class ViewFilter
constructor: (searchfilter, stringHelpers) -> constructor: (searchfilter, stringHelpers) ->
@searchfilter = searchfilter @searchfilter = searchfilter
@_normalize = (e) -> stringHelpers.unidecode(e) @_normalize = (e) ->
if typeof e is 'string'
return stringHelpers.unidecode(e)
else return e
_matches: (filter, value, match) -> _matches: (filter, value, match) ->
matches = true matches = true
...@@ -485,12 +488,12 @@ class ViewFilter ...@@ -485,12 +488,12 @@ class ViewFilter
if angular.isArray value if angular.isArray value
if filter.lowercase if filter.lowercase
value = value.map (e) -> e.toLowerCase() value = value.map (e) -> e.toLowerCase()
if filter.normalize
value = value.map (e) => @_normalize(e) value = value.map (e) => @_normalize(e)
return @_arrayMatches filter, value, checker.match return @_arrayMatches filter, value, checker.match
else else
value = value.toLowerCase() if filter.lowercase value = value.toLowerCase() if filter.lowercase
value = @_normalize(value) if filter.normalize value = @_normalize(value)
return @_matches filter, value, checker.match return @_matches filter, value, checker.match
# Filters a set of annotations, according to a given query. # Filters a set of annotations, according to a given query.
...@@ -527,7 +530,6 @@ class ViewFilter ...@@ -527,7 +530,6 @@ class ViewFilter
for _, filter of filters for _, filter of filters
if filter.lowercase if filter.lowercase
filter.terms = filter.terms.map (e) -> e.toLowerCase() filter.terms = filter.terms.map (e) -> e.toLowerCase()
if filter.normalize
filter.terms = filter.terms.map (e) => @_normalize(e) filter.terms = filter.terms.map (e) => @_normalize(e)
# Now that this filter is called with the top level annotations, we have to add the children too # Now that this filter is called with the top level annotations, we have to add the children too
...@@ -564,11 +566,10 @@ class ViewFilter ...@@ -564,11 +566,10 @@ class ViewFilter
if angular.isArray value if angular.isArray value
if filter.lowercase if filter.lowercase
value = value.map (e) -> e.toLowerCase() value = value.map (e) -> e.toLowerCase()
if filter.normalize
value = value.map (e) => @_normalize(e) value = value.map (e) => @_normalize(e)
else else
value = value.toLowerCase() if filter.lowercase value = value.toLowerCase() if filter.lowercase
value = @_normalize(value) if filter.normalize value = @_normalize(value)
matchresult = @_anyMatches filter, value, conf.match matchresult = @_anyMatches filter, value, conf.match
matchterms = matchterms.map (t, i) -> t or matchresult[i] matchterms = matchterms.map (t, i) -> t or matchresult[i]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment