activecube 0.1.9 → 0.1.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d65e60e75f69a9191397975d522338a4a145050f43a5efdb7c6bc7b415b13595
4
- data.tar.gz: 27a27e6ccbb2b377804fc8b857db498859d3dbc916c11703c44d2e1e37dc40f2
3
+ metadata.gz: 1756ca9a20b9afb872308e649356470299fbc32bce30d34b2b37f759cd335f16
4
+ data.tar.gz: bac53b887ba067e42efe555e00179732be1ad97b33a568cb6ea568dfc5e64975
5
5
  SHA512:
6
- metadata.gz: f30d27c6d9f7e8c2ceea94e58d16c9e65d809c21b900dcd933af8fca16fde2717e9d571e1ba196f3485ab5f686a8944ae47ee48de074099dec338184b134b7c7
7
- data.tar.gz: b610d3a65a8f8b6d7ff140705a4ac28ad2ef0aa63a0fcd1dd535fbc45224660c871276f1f1e5ce7ef61528098fbe057669a17792e30c1a0953205f70fc898ed9
6
+ metadata.gz: 43c32104bacfb934077b7d2ff92e1bfb9659066dc718f232a8971382a506ba73383cb930b2713ab7f7cddeaf87333044aca34a5202a664dcf2f3fc7224af8222
7
+ data.tar.gz: 4732c37e478cea2e99097114a03da08798bee23a70fcc5de8474c5c9fd9819dfd66aa2aa0873462a5a2194a1e2cc1ee0bf73598d8deba960a22eb56f80f44bd8
@@ -35,7 +35,7 @@ module Activecube::Processor
35
35
 
36
36
  outer_table = model.arel_table.class.new('').project(Arel.star)
37
37
 
38
- dimension_names = cube_query.join_fields
38
+ dimension_names = (cube_query.join_fields + cube_query.slices.map{|s| s.key} ).uniq
39
39
 
40
40
  query = outer_table.from(left_query).
41
41
  join(right_query, ::Arel::Nodes::FullOuterJoin).
@@ -118,7 +118,7 @@ module Activecube::Query
118
118
  end
119
119
 
120
120
  def join_fields
121
- slices.map(&:group_by_columns).uniq
121
+ slices.map(&:group_by_columns).flatten.uniq
122
122
  end
123
123
 
124
124
  def orderings
@@ -69,7 +69,10 @@ module Activecube::Query
69
69
 
70
70
  if dimension.class.identity
71
71
  group_by_columns.each do |column|
72
- query = query.project(table[column]).group(table[column])
72
+ if !query.projections.detect{|p| p.kind_of?(::Arel::Attributes::Attribute) && p.name==column}
73
+ query = query.project(table[column])
74
+ end
75
+ query = query.group(table[column])
73
76
  end
74
77
  else
75
78
  query = query.group(attr_alias)
@@ -1,3 +1,3 @@
1
1
  module Activecube
2
- VERSION = "0.1.9"
2
+ VERSION = "0.1.10"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: activecube
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.9
4
+ version: 0.1.10
5
5
  platform: ruby
6
6
  authors:
7
7
  - Aleksey Studnev
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-03-24 00:00:00.000000000 Z
11
+ date: 2020-04-04 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activerecord