Class: ActiveReporter::Dimension::Base

Inherits:
Object
  • Object
show all
Defined in:
lib/active_reporter/dimension/base.rb

Direct Known Subclasses

Bin, Category

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, report, options = {}) ⇒ Base

Returns a new instance of Base.



8
9
10
11
12
13
# File 'lib/active_reporter/dimension/base.rb', line 8

def initialize(name, report, options = {})
  @name = name
  @report = report
  @options = options
  validate_params!
end

Instance Attribute Details

#nameObject (readonly)

Returns the value of attribute name.



6
7
8
# File 'lib/active_reporter/dimension/base.rb', line 6

def name
  @name
end

#optionsObject (readonly)

Returns the value of attribute options.



6
7
8
# File 'lib/active_reporter/dimension/base.rb', line 6

def options
  @options
end

#reportObject (readonly)

Returns the value of attribute report.



6
7
8
# File 'lib/active_reporter/dimension/base.rb', line 6

def report
  @report
end

Instance Method Details

#attributeObject



19
20
21
# File 'lib/active_reporter/dimension/base.rb', line 19

def attribute
  options.fetch(:attribute, name)
end

#expressionObject



23
24
25
26
27
28
29
30
31
# File 'lib/active_reporter/dimension/base.rb', line 23

def expression
  @expression ||= if options.include?(:expression)
    options[:expression]
  elsif options.include?(:_alias)
    "'#{options[:_alias]}'"
  else
    "#{table_name}.#{column}"
  end
end

#extract_sql_value(row) ⇒ Object

Given a single (hashified) row of the SQL result, return the Ruby object representing this dimension’s value



55
56
57
# File 'lib/active_reporter/dimension/base.rb', line 55

def extract_sql_value(row)
  sanitize_sql_value(row[sql_value_name])
end

#filter(relation) ⇒ Object

Filter the relation based on any constraints in the params

Raises:

  • (NotImplementedError)


39
40
41
# File 'lib/active_reporter/dimension/base.rb', line 39

def filter(relation)
  raise NotImplementedError
end

#filter_valuesObject



59
60
61
# File 'lib/active_reporter/dimension/base.rb', line 59

def filter_values
  array_param(:only).uniq
end

#filtering?Boolean

Return whether the report should filter by this dimension

Returns:



64
65
66
# File 'lib/active_reporter/dimension/base.rb', line 64

def filtering?
  filter_values.present?
end

#group(relation) ⇒ Object

Group the relation by the expression – ensure this is ordered, too.

Raises:

  • (NotImplementedError)


44
45
46
# File 'lib/active_reporter/dimension/base.rb', line 44

def group(relation)
  raise NotImplementedError
end

#group_valuesObject

Return an ordered array of all values that should appear in ‘Report#data`

Raises:

  • (NotImplementedError)


49
50
51
# File 'lib/active_reporter/dimension/base.rb', line 49

def group_values
  raise NotImplementedError
end

#grouping?Boolean

Returns:



68
69
70
# File 'lib/active_reporter/dimension/base.rb', line 68

def grouping?
  report.groupers.include?(self)
end

#modelObject



15
16
17
# File 'lib/active_reporter/dimension/base.rb', line 15

def model
  @model ||= options[:model].to_s.classify.safe_constantize || options[:model] || report.report_model
end

#null_orderObject



94
95
96
97
98
# File 'lib/active_reporter/dimension/base.rb', line 94

def null_order
  return unless ActiveReporter.database_type == :postgres

  nulls_last? ? "NULLS LAST" : "NULLS FIRST"
end

#nulls_last?Boolean

Returns:



88
89
90
91
92
# File 'lib/active_reporter/dimension/base.rb', line 88

def nulls_last?
  value = dimension_or_root_param(:nulls_last)
  value = !value if sort_desc?
  value
end

#order(relation) ⇒ Object



76
77
78
# File 'lib/active_reporter/dimension/base.rb', line 76

def order(relation)
  relation.order(Arel.sql("#{order_expression} #{sort_order} #{null_order}"))
end

#order_expressionObject



72
73
74
# File 'lib/active_reporter/dimension/base.rb', line 72

def order_expression
  sql_value_name
end

#paramsObject



100
101
102
# File 'lib/active_reporter/dimension/base.rb', line 100

def params
  report.params.fetch(:dimensions, {})[name].presence || {}
end

#relate(relation) ⇒ Object

Do any joins/selects necessary to filter or group the relation.



34
35
36
# File 'lib/active_reporter/dimension/base.rb', line 34

def relate(relation)
  options.fetch(:relation, ->(r) { r }).call(relation)
end

#sort_desc?Boolean

Returns:



80
81
82
# File 'lib/active_reporter/dimension/base.rb', line 80

def sort_desc?
  dimension_or_root_param(:sort_desc)
end

#sort_orderObject



84
85
86
# File 'lib/active_reporter/dimension/base.rb', line 84

def sort_order
  sort_desc? ? "DESC" : "ASC"
end