5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
# File 'lib/chewy_queries.rb', line 5
def search(class_name, type, condition, value, field)
if type == "text"
if condition == "equal"
class_name.query(match_phrase: {"#{field}": value})
elsif condition == "not equal"
class_name.query.not(match: {"#{field}": value}).and(class_name.query.not(match: {"#{field}": "null"}))
elsif condition == "contains"
class_name.query(regexp: {"#{field}": ".*#{value.downcase}.*"}).or(class_name.query(match_phrase: {"#{field}": value}))
elsif condition == "does not contain"
class_name.query.not(regexp: {"#{field}": ".*#{value.downcase}.*"}).and(class_name.query.not(match: {"#{field}": "null"}))
elsif condition == "starts with"
class_name.query(regexp: {"#{field}": "#{value.downcase}.*"})
elsif condition == "does not start with"
class_name.query.not(regexp: {"#{field}": "#{value.downcase}.*"}).and(class_name.query.not(match: {"#{field}": "null"}))
elsif condition == "ends with"
class_name.query(regexp: {"#{field}": ".*#{value.downcase}"})
elsif condition == "does not end with"
class_name.query.not(regexp: {"#{field}": ".*#{value.downcase}"}).and(ContactIndex.query.not(match: {"#{field}": "null"}))
elsif condition == "matches exactly"
class_name.query(match_phrase: {"#{field}": value})
end
elsif type == "number"
if condition == "Is equal to"
class_name.query(match: {"#{field}": value})
elsif condition == "Is not equal to"
class_name.query.not(match: {"#{field}": value})
elsif condition == "Is greater than"
class_name.query(range: {"#{field}": {gt: value}})
elsif condition == "Is less than"
class_name.query(range: {"#{field}": {lt: value}}).and(class_name.query.not(match: {"#{field}": 0}))
elsif condition == "Is provided"
class_name.query.not(match: {"#{field}": 0})
elsif condition == "Is not provided"
class_name.query(match: {"#{field}": 0})
elsif condition == "Is between"
class_name.query(range: {"#{field}": {gt: value.first, lt: value.last}})
end
elsif type == "date"
if value.class != Array
value1 = value.split("T").first
end
if condition == "Is before"
class_name.query(range: {"#{field}": {lt: value1}})
elsif condition == "Is after"
class_name.query(range: {"#{field}": {gt: value1}})
elsif condition == "Is on or before"
class_name.query(range: {"#{field}": {lte: value1}})
elsif condition == "Is on or after"
class_name.query(range: {"#{field}": {gte: value1}})
elsif condition == "equals"
class_name.query(match: {"#{field}": value1})
elsif condition == "does not equal"
class_name.query.not(match: {"#{field}": value1})
elsif condition == "Is provided"
class_name.query.not(match: {"#{field}": 0})
elsif condition == "Is not provided"
class_name.query(match: {"#{field}": 0})
elsif condition == "Is between"
value1 = value.first.split("T").first
value2 = value.last.split("T").first
class_name.query(range: {"#{field}": {gt: value1, lt: value2}})
end
end
end
|