@forestadmin-experimental/datasource-cosmos 1.8.1 → 1.8.3
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.
|
@@ -27,11 +27,34 @@ export default class AggregationConverter {
|
|
|
27
27
|
* Year: 4 chars -> "2024", Month: 7 -> "2024-01", Day: 10 -> "2024-01-15"
|
|
28
28
|
*/
|
|
29
29
|
private static DATE_OPERATION_TO_LENGTH;
|
|
30
|
+
/** Date operations that require post-processing rollup from daily data */
|
|
31
|
+
private static ROLLUP_OPERATIONS;
|
|
30
32
|
/**
|
|
31
33
|
* Build a Cosmos DB expression that truncates a date field to the given granularity.
|
|
32
|
-
* Uses LEFT() on ISO 8601 string dates
|
|
34
|
+
* Uses LEFT() on ISO 8601 string dates.
|
|
35
|
+
* Week and Quarter query at Day granularity for performance (avoids
|
|
36
|
+
* expensive computed expressions in GROUP BY) and roll up in post-processing.
|
|
33
37
|
*/
|
|
34
38
|
private static buildDateGroupExpression;
|
|
39
|
+
/**
|
|
40
|
+
* Compute the Monday of the week for a given "YYYY-MM-DD" date string.
|
|
41
|
+
*/
|
|
42
|
+
private static getMonday;
|
|
43
|
+
/**
|
|
44
|
+
* Compute the first day of the quarter for a "YYYY-MM-DD" date string.
|
|
45
|
+
* Returns "YYYY-MM-01" where MM is 01, 04, 07, or 10.
|
|
46
|
+
*/
|
|
47
|
+
private static getQuarterStart;
|
|
48
|
+
/**
|
|
49
|
+
* Reduce two values according to the aggregation operation.
|
|
50
|
+
*/
|
|
51
|
+
private static reduce;
|
|
52
|
+
/**
|
|
53
|
+
* Roll up daily aggregation results into coarser time buckets.
|
|
54
|
+
* Used for Week and Quarter to avoid expensive Cosmos DB computed expressions.
|
|
55
|
+
* Applies the correct reduction per aggregation operation.
|
|
56
|
+
*/
|
|
57
|
+
private static rollupResults;
|
|
35
58
|
/**
|
|
36
59
|
* Build aggregation query with grouping
|
|
37
60
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aggregation-converter.d.ts","sourceRoot":"","sources":["../../src/utils/aggregation-converter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EACL,eAAe,EACf,WAAW,EAEX,aAAa,EACd,MAAM,iCAAiC,CAAC;AAMzC,MAAM,CAAC,OAAO,OAAO,oBAAoB;IACvC;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,SAAS,CAGrB;IAEH,OAAO,CAAC,MAAM,CAAC,qBAAqB,CAMlC;IAEF;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IAS5B;;OAEG;IACH,MAAM,CAAC,qBAAqB,CAC1B,WAAW,EAAE,WAAW,EACxB,aAAa,CAAC,EAAE,aAAa,EAC7B,KAAK,CAAC,EAAE,MAAM,GACb,YAAY;IAiBf;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAUvC;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,wBAAwB,CAIrC;IAEF;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"aggregation-converter.d.ts","sourceRoot":"","sources":["../../src/utils/aggregation-converter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EACL,eAAe,EACf,WAAW,EAEX,aAAa,EACd,MAAM,iCAAiC,CAAC;AAMzC,MAAM,CAAC,OAAO,OAAO,oBAAoB;IACvC;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,SAAS,CAGrB;IAEH,OAAO,CAAC,MAAM,CAAC,qBAAqB,CAMlC;IAEF;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IAS5B;;OAEG;IACH,MAAM,CAAC,qBAAqB,CAC1B,WAAW,EAAE,WAAW,EACxB,aAAa,CAAC,EAAE,aAAa,EAC7B,KAAK,CAAC,EAAE,MAAM,GACb,YAAY;IAiBf;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAUvC;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,wBAAwB,CAIrC;IAEF,0EAA0E;IAC1E,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAgC;IAEhE;;;;;OAKG;IACH,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAevC;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,SAAS;IASxB;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,eAAe;IAO9B;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,MAAM;IAWrB;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,aAAa;IA0C5B;;OAEG;IACH,OAAO,CAAC,MAAM,CAAC,4BAA4B;IAuC3C;;OAEG;IACH;;;;OAIG;IACH,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAIpC,MAAM,CAAC,yBAAyB,CAC9B,UAAU,EAAE,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,EAC1C,WAAW,EAAE,WAAW,GACvB,eAAe,EAAE;CA8BrB"}
|
|
@@ -47,15 +47,89 @@ class AggregationConverter {
|
|
|
47
47
|
}
|
|
48
48
|
/**
|
|
49
49
|
* Build a Cosmos DB expression that truncates a date field to the given granularity.
|
|
50
|
-
* Uses LEFT() on ISO 8601 string dates
|
|
50
|
+
* Uses LEFT() on ISO 8601 string dates.
|
|
51
|
+
* Week and Quarter query at Day granularity for performance (avoids
|
|
52
|
+
* expensive computed expressions in GROUP BY) and roll up in post-processing.
|
|
51
53
|
*/
|
|
52
54
|
static buildDateGroupExpression(field, operation) {
|
|
55
|
+
// Week/Quarter: query at Day level, roll up in processAggregationResults
|
|
56
|
+
if (this.ROLLUP_OPERATIONS.has(operation)) {
|
|
57
|
+
return `LEFT(${field}, 10)`;
|
|
58
|
+
}
|
|
53
59
|
const length = this.DATE_OPERATION_TO_LENGTH[operation];
|
|
54
60
|
if (!length) {
|
|
55
61
|
throw new Error(`Unsupported date operation: "${operation}"`);
|
|
56
62
|
}
|
|
57
63
|
return `LEFT(${field}, ${length})`;
|
|
58
64
|
}
|
|
65
|
+
/**
|
|
66
|
+
* Compute the Monday of the week for a given "YYYY-MM-DD" date string.
|
|
67
|
+
*/
|
|
68
|
+
static getMonday(dateStr) {
|
|
69
|
+
const date = new Date(`${dateStr}T00:00:00Z`);
|
|
70
|
+
const day = date.getUTCDay(); // 0=Sun, 1=Mon, ..., 6=Sat
|
|
71
|
+
const diff = (day + 6) % 7; // days since Monday
|
|
72
|
+
date.setUTCDate(date.getUTCDate() - diff);
|
|
73
|
+
return date.toISOString().slice(0, 10);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Compute the first day of the quarter for a "YYYY-MM-DD" date string.
|
|
77
|
+
* Returns "YYYY-MM-01" where MM is 01, 04, 07, or 10.
|
|
78
|
+
*/
|
|
79
|
+
static getQuarterStart(dateStr) {
|
|
80
|
+
const month = parseInt(dateStr.slice(5, 7), 10);
|
|
81
|
+
const quarterStartMonth = Math.floor((month - 1) / 3) * 3 + 1;
|
|
82
|
+
return `${dateStr.slice(0, 4)}-${String(quarterStartMonth).padStart(2, '0')}-01`;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Reduce two values according to the aggregation operation.
|
|
86
|
+
*/
|
|
87
|
+
static reduce(op, current, incoming) {
|
|
88
|
+
switch (op) {
|
|
89
|
+
case 'Max':
|
|
90
|
+
return Math.max(current, incoming);
|
|
91
|
+
case 'Min':
|
|
92
|
+
return Math.min(current, incoming);
|
|
93
|
+
default: // Sum, Count, Avg
|
|
94
|
+
return current + incoming;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Roll up daily aggregation results into coarser time buckets.
|
|
99
|
+
* Used for Week and Quarter to avoid expensive Cosmos DB computed expressions.
|
|
100
|
+
* Applies the correct reduction per aggregation operation.
|
|
101
|
+
*/
|
|
102
|
+
static rollupResults(results, aggregation) {
|
|
103
|
+
const group = aggregation.groups[0];
|
|
104
|
+
const op = aggregation.operation;
|
|
105
|
+
const bucketFn = group.operation === 'Week' ? this.getMonday : this.getQuarterStart;
|
|
106
|
+
const buckets = new Map();
|
|
107
|
+
const counts = new Map();
|
|
108
|
+
for (const result of results) {
|
|
109
|
+
const rawValue = result.group[group.field];
|
|
110
|
+
if (rawValue != null) {
|
|
111
|
+
const bucketKey = bucketFn(String(rawValue));
|
|
112
|
+
const value = Number(result.value) || 0;
|
|
113
|
+
if (buckets.has(bucketKey)) {
|
|
114
|
+
buckets.set(bucketKey, this.reduce(op, buckets.get(bucketKey), value));
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
buckets.set(bucketKey, value);
|
|
118
|
+
}
|
|
119
|
+
counts.set(bucketKey, (counts.get(bucketKey) || 0) + 1);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
// For Avg, divide the accumulated sum by the number of days
|
|
123
|
+
if (op === 'Avg') {
|
|
124
|
+
for (const [key, sum] of buckets) {
|
|
125
|
+
buckets.set(key, sum / counts.get(key));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return Array.from(buckets.entries()).map(([key, value]) => ({
|
|
129
|
+
value,
|
|
130
|
+
group: { [group.field]: key },
|
|
131
|
+
}));
|
|
132
|
+
}
|
|
59
133
|
/**
|
|
60
134
|
* Build aggregation query with grouping
|
|
61
135
|
*/
|
|
@@ -102,13 +176,19 @@ class AggregationConverter {
|
|
|
102
176
|
}
|
|
103
177
|
return [{ value: this.extractAggregateValue(rawResults[0]), group: {} }];
|
|
104
178
|
}
|
|
105
|
-
|
|
179
|
+
const results = rawResults.map(result => {
|
|
106
180
|
const group = {};
|
|
107
181
|
aggregation.groups.forEach((groupDef, index) => {
|
|
108
182
|
group[groupDef.field] = serializer_1.default.serializeValue(result.groupKey || result[`group${index}`]);
|
|
109
183
|
});
|
|
110
184
|
return { value: this.extractAggregateValue(result), group };
|
|
111
185
|
});
|
|
186
|
+
// Roll up daily results into Week/Quarter buckets
|
|
187
|
+
const dateOp = aggregation.groups[0]?.operation;
|
|
188
|
+
if (dateOp && this.ROLLUP_OPERATIONS.has(dateOp)) {
|
|
189
|
+
return this.rollupResults(results, aggregation);
|
|
190
|
+
}
|
|
191
|
+
return results;
|
|
112
192
|
}
|
|
113
193
|
}
|
|
114
194
|
/**
|
|
@@ -136,5 +216,7 @@ AggregationConverter.DATE_OPERATION_TO_LENGTH = {
|
|
|
136
216
|
Month: 7,
|
|
137
217
|
Day: 10,
|
|
138
218
|
};
|
|
219
|
+
/** Date operations that require post-processing rollup from daily data */
|
|
220
|
+
AggregationConverter.ROLLUP_OPERATIONS = new Set(['Week', 'Quarter']);
|
|
139
221
|
exports.default = AggregationConverter;
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aggregation-converter.js","sourceRoot":"","sources":["../../src/utils/aggregation-converter.ts"],"names":[],"mappings":"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"}
|