Class: Workarea::Reports::Searches

Inherits:
Object
  • Object
show all
Includes:
Report
Defined in:
app/queries/workarea/reports/searches.rb

Instance Method Summary collapse

Methods included from Report

#cache_key, #count, #ends_at, #initialize, #limit, #more_results?, #results, #slug, #sort, #sort_by, #sort_direction, #sort_value, #starts_at

Instance Method Details

#aggregationObject



9
10
11
# File 'app/queries/workarea/reports/searches.rb', line 9

def aggregation
  [filter_date_range, project_used_fields, group_by_query_id]
end

#filter_date_rangeObject



13
14
15
16
17
18
19
20
# File 'app/queries/workarea/reports/searches.rb', line 13

def filter_date_range
  {
    '$match' => {
      'reporting_on' => { '$gte' => starts_at.utc, '$lte' => ends_at.utc },
      'total_results' => total_results_query
    }
  }
end

#group_by_query_idObject



37
38
39
40
41
42
43
44
45
46
47
48
49
50
# File 'app/queries/workarea/reports/searches.rb', line 37

def group_by_query_id
  {
    '$group' => {
      '_id' => '$query_id',
      'query_string' => { '$first' => '$query_string' },
      'total_results' => { '$last' => '$total_results' },
      'searches' => { '$sum' => '$searches' },
      'orders' => { '$sum' => '$orders' },
      'units_sold' => { '$sum' => '$units_sold' },
      'discounts' => { '$sum' => '$discounts' },
      'revenue' => { '$sum' => '$revenue' }
    }
  }
end

#project_used_fieldsObject



22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'app/queries/workarea/reports/searches.rb', line 22

def project_used_fields
  {
    '$project' => {
      'query_id' => 1,
      'query_string' => 1,
      'total_results' => 1,
      'searches' => 1,
      'orders' => 1,
      'units_sold' => 1,
      'discounts' => 1,
      'revenue' => 1
    }
  }
end