@cubejs-client/core 0.33.47 → 0.33.58

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.
package/index.d.ts CHANGED
@@ -96,9 +96,13 @@ declare module '@cubejs-client/core' {
96
96
  */
97
97
  subscribe?: boolean;
98
98
  /**
99
- * A Cube.js API instance. If not provided will be taken from `CubeProvider`
99
+ * A Cube API instance. If not provided will be taken from `CubeProvider`
100
100
  */
101
101
  cubejsApi?: CubejsApi;
102
+ /**
103
+ * If enabled, all members of the 'number' type will be automatically converted to numerical values on the client side
104
+ */
105
+ castNumerics?: boolean;
102
106
  /**
103
107
  * Function that receives `ProgressResult` on each `Continue wait` message.
104
108
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cubejs-client/core",
3
- "version": "0.33.47",
3
+ "version": "0.33.58",
4
4
  "engines": {},
5
5
  "repository": {
6
6
  "type": "git",
@@ -45,5 +45,5 @@
45
45
  "eslint-plugin-node": "^5.2.1",
46
46
  "jest": "^26.0.1"
47
47
  },
48
- "gitHead": "56fdafca61e135266bc19d2c34497f7affcdb4da"
48
+ "gitHead": "49caef372253236528bcf96b74fbda2447709541"
49
49
  }
package/src/ResultSet.js CHANGED
@@ -169,7 +169,7 @@ class ResultSet {
169
169
  range.end
170
170
  ];
171
171
 
172
- if (originalTimeDimension) {
172
+ if (originalTimeDimension?.dateRange) {
173
173
  const [originalStart, originalEnd] = originalTimeDimension.dateRange;
174
174
 
175
175
  dateRange = [
package/src/index.js CHANGED
@@ -257,24 +257,51 @@ class CubejsApi {
257
257
  * @returns ResultSet
258
258
  * @private
259
259
  */
260
- loadResponseInternal(response) {
260
+ loadResponseInternal(response, options = {}) {
261
261
  if (
262
- response.results.length &&
263
- response.results[0].query.responseFormat &&
264
- response.results[0].query.responseFormat === ResultType.COMPACT
262
+ response.results.length
265
263
  ) {
266
- response.results.forEach((result, j) => {
267
- const data = [];
268
- result.data.dataset.forEach((r) => {
269
- const row = {};
270
- result.data.members.forEach((m, i) => {
271
- row[m] = r[i];
264
+ if (options.castNumerics) {
265
+ response.results.forEach((result) => {
266
+ const numericMembers = Object.entries({
267
+ ...result.annotation.measures,
268
+ ...result.annotation.dimensions,
269
+ }).map(([k, v]) => {
270
+ if (v.type === 'number') {
271
+ return k;
272
+ }
273
+
274
+ return undefined;
275
+ }).filter(Boolean);
276
+
277
+ result.data = result.data.map((row) => {
278
+ numericMembers.forEach((key) => {
279
+ if (row[key] != null) {
280
+ row[key] = Number(row[key]);
281
+ }
282
+ });
283
+
284
+ return row;
272
285
  });
273
- data.push(row);
274
286
  });
275
- response.results[j].data = data;
276
- });
287
+ }
288
+
289
+ if (response.results[0].query.responseFormat &&
290
+ response.results[0].query.responseFormat === ResultType.COMPACT) {
291
+ response.results.forEach((result, j) => {
292
+ const data = [];
293
+ result.data.dataset.forEach((r) => {
294
+ const row = {};
295
+ result.data.members.forEach((m, i) => {
296
+ row[m] = r[i];
297
+ });
298
+ data.push(row);
299
+ });
300
+ response.results[j].data = data;
301
+ });
302
+ }
277
303
  }
304
+
278
305
  return new ResultSet(response, {
279
306
  parseDateMeasures: this.parseDateMeasures
280
307
  });
@@ -293,7 +320,7 @@ class CubejsApi {
293
320
  query,
294
321
  queryType: 'multi',
295
322
  }),
296
- this.loadResponseInternal.bind(this),
323
+ (response) => this.loadResponseInternal(response, options),
297
324
  options,
298
325
  callback
299
326
  );
@@ -312,7 +339,7 @@ class CubejsApi {
312
339
  query,
313
340
  queryType: 'multi',
314
341
  }),
315
- this.loadResponseInternal.bind(this),
342
+ (response) => this.loadResponseInternal(response, options),
316
343
  { ...options, subscribe: true },
317
344
  callback
318
345
  );
@@ -241,6 +241,16 @@ describe('drill down query', () => {
241
241
  timeDimensions: [],
242
242
  })
243
243
  );
244
+ const resultSet5 = new ResultSet(
245
+ loadResponse({
246
+ timeDimensions: [
247
+ {
248
+ dimension: 'Orders.ts',
249
+ granularity: 'week',
250
+ }
251
+ ]
252
+ })
253
+ );
244
254
 
245
255
  it('handles a query with a time dimension', () => {
246
256
  expect(
@@ -366,4 +376,27 @@ describe('drill down query', () => {
366
376
  timezone: 'UTC'
367
377
  });
368
378
  });
379
+
380
+ it('snap date range to granularity if the date range is not defined in the time dimension', () => {
381
+ expect(
382
+ resultSet5.drillDown({ xValues: ['2020-08-01T00:00:00.000'] })
383
+ ).toEqual({
384
+ measures: [],
385
+ segments: [],
386
+ dimensions: ['Orders.id', 'Orders.title'],
387
+ filters: [
388
+ {
389
+ member: 'Orders.count',
390
+ operator: 'measureFilter',
391
+ },
392
+ ],
393
+ timeDimensions: [
394
+ {
395
+ dimension: 'Orders.ts',
396
+ dateRange: ['2020-07-27T00:00:00.000', '2020-08-02T23:59:59.999'],
397
+ },
398
+ ],
399
+ timezone: 'UTC',
400
+ });
401
+ });
369
402
  });