Class: ForestLiana::OperatorValueParser
- Inherits:
-
Object
- Object
- ForestLiana::OperatorValueParser
- Defined in:
- app/services/forest_liana/operator_value_parser.rb
Class Method Summary collapse
- .get_condition(field, operator, value, resource, timezone) ⇒ Object
- .get_field_name(field, resource) ⇒ Object
- .parse(value) ⇒ Object
Class Method Details
.get_condition(field, operator, value, resource, timezone) ⇒ Object
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'app/services/forest_liana/operator_value_parser.rb', line 34 def self.get_condition(field, operator, value, resource, timezone) field_name = self.get_field_name(field, resource) operator_date_interval_parser = OperatorDateIntervalParser .new(value, timezone) if operator_date_interval_parser.is_interval_date_value() filter = operator_date_interval_parser.get_interval_date_filter() "#{field_name} #{filter}" else # NOTICE: Set the integer value instead of a string if "enum" type # NOTICE: Rails 3 do not have a defined_enums method if resource.respond_to?(:defined_enums) && resource.defined_enums.has_key?(field) value = resource.defined_enums[field][value] end where = "#{field_name} #{operator}" where += " '#{value}'" if value where end end |
.get_field_name(field, resource) ⇒ Object
57 58 59 60 61 62 63 64 65 66 |
# File 'app/services/forest_liana/operator_value_parser.rb', line 57 def self.get_field_name(field, resource) if field.split(':').size < 2 "#{resource.quoted_table_name}." + "#{ActiveRecord::Base.connection.quote_column_name(field)}" else association = field.split(':')[0].pluralize "#{ActiveRecord::Base.connection.quote_column_name(association)}." + "#{ActiveRecord::Base.connection.quote_column_name(field.split(':')[1])}" end end |
.parse(value) ⇒ Object
4 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 |
# File 'app/services/forest_liana/operator_value_parser.rb', line 4 def self.parse(value) operator = nil value_comparison = nil if value.first == '!' operator = '!=' value_comparison = value[1..-1] elsif value.first == '>' operator = '>' value_comparison = value[1..-1] elsif value.first == '<' operator = '<' value_comparison = value[1..-1] elsif value.include?('*') operator = 'LIKE' value_comparison = value.gsub('*', '%') elsif value === '$present' operator = 'IS NOT NULL' value_comparison = nil elsif value === '$blank' operator = 'IS NULL' value_comparison = nil else operator = '=' value_comparison = value end [operator, value_comparison] end |