@warlock.js/cascade 1.0.5 → 1.0.7
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/cjs/aggregate/DeselectPipeline.d.ts +10 -0
- package/cjs/aggregate/DeselectPipeline.d.ts.map +1 -0
- package/cjs/aggregate/DeselectPipeline.js +17 -0
- package/cjs/aggregate/DeselectPipeline.js.map +1 -0
- package/cjs/aggregate/GeoNearPipeline.d.ts +34 -0
- package/cjs/aggregate/GeoNearPipeline.d.ts.map +1 -0
- package/cjs/aggregate/GeoNearPipeline.js +44 -0
- package/cjs/aggregate/GeoNearPipeline.js.map +1 -0
- package/cjs/aggregate/GroupByPipeline.d.ts +12 -0
- package/cjs/aggregate/GroupByPipeline.d.ts.map +1 -0
- package/cjs/aggregate/GroupByPipeline.js +28 -0
- package/cjs/aggregate/GroupByPipeline.js.map +1 -0
- package/cjs/aggregate/LimitPipeline.d.ts +10 -0
- package/cjs/aggregate/LimitPipeline.d.ts.map +1 -0
- package/cjs/aggregate/LimitPipeline.js +14 -0
- package/cjs/aggregate/LimitPipeline.js.map +1 -0
- package/cjs/aggregate/LookupPipeline.d.ts +19 -0
- package/cjs/aggregate/LookupPipeline.d.ts.map +1 -0
- package/cjs/aggregate/LookupPipeline.js +19 -0
- package/cjs/aggregate/LookupPipeline.js.map +1 -0
- package/cjs/aggregate/OrWherePipeline.d.ts +23 -0
- package/cjs/aggregate/OrWherePipeline.d.ts.map +1 -0
- package/cjs/aggregate/OrWherePipeline.js +42 -0
- package/cjs/aggregate/OrWherePipeline.js.map +1 -0
- package/cjs/aggregate/SelectPipeline.d.ts +10 -0
- package/cjs/aggregate/SelectPipeline.d.ts.map +1 -0
- package/cjs/aggregate/SelectPipeline.js +26 -0
- package/cjs/aggregate/SelectPipeline.js.map +1 -0
- package/cjs/aggregate/SkipPipeline.d.ts +10 -0
- package/cjs/aggregate/SkipPipeline.d.ts.map +1 -0
- package/cjs/aggregate/SkipPipeline.js +14 -0
- package/cjs/aggregate/SkipPipeline.js.map +1 -0
- package/cjs/aggregate/SortByPipeline.d.ts +10 -0
- package/cjs/aggregate/SortByPipeline.d.ts.map +1 -0
- package/cjs/aggregate/SortByPipeline.js +18 -0
- package/cjs/aggregate/SortByPipeline.js.map +1 -0
- package/cjs/aggregate/SortPipeline.d.ts +11 -0
- package/cjs/aggregate/SortPipeline.d.ts.map +1 -0
- package/cjs/aggregate/SortPipeline.js +18 -0
- package/cjs/aggregate/SortPipeline.js.map +1 -0
- package/cjs/aggregate/SortRandomPipeline.d.ts +10 -0
- package/cjs/aggregate/SortRandomPipeline.d.ts.map +1 -0
- package/cjs/aggregate/SortRandomPipeline.js +16 -0
- package/cjs/aggregate/SortRandomPipeline.js.map +1 -0
- package/cjs/aggregate/UnwindPipeline.d.ts +14 -0
- package/cjs/aggregate/UnwindPipeline.d.ts.map +1 -0
- package/cjs/aggregate/UnwindPipeline.js +19 -0
- package/cjs/aggregate/UnwindPipeline.js.map +1 -0
- package/cjs/aggregate/WhereExpression.d.ts +17 -0
- package/cjs/aggregate/WhereExpression.d.ts.map +1 -0
- package/cjs/aggregate/WhereExpression.js +149 -0
- package/cjs/aggregate/WhereExpression.js.map +1 -0
- package/cjs/aggregate/WhereExpressionPipeline.d.ts +10 -0
- package/cjs/aggregate/WhereExpressionPipeline.d.ts.map +1 -0
- package/cjs/aggregate/WhereExpressionPipeline.js +15 -0
- package/cjs/aggregate/WhereExpressionPipeline.js.map +1 -0
- package/cjs/aggregate/WherePipeline.d.ts +13 -0
- package/cjs/aggregate/WherePipeline.d.ts.map +1 -0
- package/cjs/aggregate/WherePipeline.js +12 -0
- package/cjs/aggregate/WherePipeline.js.map +1 -0
- package/cjs/aggregate/aggregate.d.ts +358 -0
- package/cjs/aggregate/aggregate.d.ts.map +1 -0
- package/cjs/aggregate/aggregate.js +680 -0
- package/cjs/aggregate/aggregate.js.map +1 -0
- package/cjs/aggregate/expressions.d.ts +361 -0
- package/cjs/aggregate/expressions.d.ts.map +1 -0
- package/cjs/aggregate/expressions.js +536 -0
- package/cjs/aggregate/expressions.js.map +1 -0
- package/cjs/aggregate/index.d.ts +21 -0
- package/cjs/aggregate/index.d.ts.map +1 -0
- package/cjs/aggregate/parsePipelines.d.ts +5 -0
- package/cjs/aggregate/parsePipelines.d.ts.map +1 -0
- package/cjs/aggregate/parsePipelines.js +6 -0
- package/cjs/aggregate/parsePipelines.js.map +1 -0
- package/cjs/aggregate/pipeline.d.ts +31 -0
- package/cjs/aggregate/pipeline.d.ts.map +1 -0
- package/cjs/aggregate/pipeline.js +42 -0
- package/cjs/aggregate/pipeline.js.map +1 -0
- package/cjs/aggregate/types.d.ts +8 -0
- package/cjs/aggregate/types.d.ts.map +1 -0
- package/cjs/aggregate/types.js +31 -0
- package/cjs/aggregate/types.js.map +1 -0
- package/cjs/blueprint/blueprint-column.d.ts +82 -0
- package/cjs/blueprint/blueprint-column.d.ts.map +1 -0
- package/cjs/blueprint/blueprint.d.ts +162 -0
- package/cjs/blueprint/blueprint.d.ts.map +1 -0
- package/cjs/blueprint/blueprint.js +340 -0
- package/cjs/blueprint/blueprint.js.map +1 -0
- package/cjs/blueprint/index.d.ts +3 -0
- package/cjs/blueprint/index.d.ts.map +1 -0
- package/cjs/blueprint/model-blueprint.d.ts +15 -0
- package/cjs/blueprint/model-blueprint.d.ts.map +1 -0
- package/cjs/blueprint/model-blueprint.js +16 -0
- package/cjs/blueprint/model-blueprint.js.map +1 -0
- package/cjs/casts/arrayOf.d.ts +5 -0
- package/cjs/casts/arrayOf.d.ts.map +1 -0
- package/cjs/casts/arrayOf.js +18 -0
- package/cjs/casts/arrayOf.js.map +1 -0
- package/cjs/casts/cast-email.d.ts +2 -0
- package/cjs/casts/cast-email.d.ts.map +1 -0
- package/cjs/casts/cast-email.js +5 -0
- package/cjs/casts/cast-email.js.map +1 -0
- package/cjs/casts/castModel.d.ts +3 -0
- package/cjs/casts/castModel.d.ts.map +1 -0
- package/cjs/casts/castModel.js +49 -0
- package/cjs/casts/castModel.js.map +1 -0
- package/cjs/casts/expiresAfter.d.ts +3 -0
- package/cjs/casts/expiresAfter.d.ts.map +1 -0
- package/cjs/casts/expiresAfter.js +5 -0
- package/cjs/casts/expiresAfter.js.map +1 -0
- package/cjs/casts/index.d.ts +9 -0
- package/cjs/casts/index.d.ts.map +1 -0
- package/cjs/casts/oneOf.d.ts +3 -0
- package/cjs/casts/oneOf.d.ts.map +1 -0
- package/cjs/casts/oneOf.js +22 -0
- package/cjs/casts/oneOf.js.map +1 -0
- package/cjs/casts/random-string.d.ts +2 -0
- package/cjs/casts/random-string.d.ts.map +1 -0
- package/cjs/casts/random-string.js +5 -0
- package/cjs/casts/random-string.js.map +1 -0
- package/cjs/casts/randomInteger.d.ts +2 -0
- package/cjs/casts/randomInteger.d.ts.map +1 -0
- package/cjs/casts/randomInteger.js +7 -0
- package/cjs/casts/randomInteger.js.map +1 -0
- package/cjs/casts/shapedArray.d.ts +26 -0
- package/cjs/casts/shapedArray.d.ts.map +1 -0
- package/cjs/casts/shapedArray.js +100 -0
- package/cjs/casts/shapedArray.js.map +1 -0
- package/cjs/config.d.ts +4 -0
- package/cjs/config.d.ts.map +1 -0
- package/cjs/config.js +10 -0
- package/cjs/config.js.map +1 -0
- package/cjs/connection.d.ts +45 -0
- package/cjs/connection.d.ts.map +1 -0
- package/cjs/connection.js +98 -0
- package/cjs/connection.js.map +1 -0
- package/cjs/database.d.ts +49 -0
- package/cjs/database.d.ts.map +1 -0
- package/cjs/database.js +85 -0
- package/cjs/database.js.map +1 -0
- package/cjs/index.d.ts +11 -1
- package/cjs/index.d.ts.map +1 -1
- package/cjs/index.js +1 -5
- package/cjs/index.js.map +1 -1
- package/cjs/migration/index.d.ts +4 -0
- package/cjs/migration/index.d.ts.map +1 -0
- package/cjs/migration/migrate.d.ts +13 -0
- package/cjs/migration/migrate.d.ts.map +1 -0
- package/cjs/migration/migrate.js +72 -0
- package/cjs/migration/migrate.js.map +1 -0
- package/cjs/migration/migration-office.d.ts +21 -0
- package/cjs/migration/migration-office.d.ts.map +1 -0
- package/cjs/migration/migration-office.js +40 -0
- package/cjs/migration/migration-office.js.map +1 -0
- package/cjs/migration/migration-officer.d.ts +33 -0
- package/cjs/migration/migration-officer.d.ts.map +1 -0
- package/cjs/migration/migration-officer.js +55 -0
- package/cjs/migration/migration-officer.js.map +1 -0
- package/cjs/migration/types.d.ts +34 -0
- package/cjs/migration/types.d.ts.map +1 -0
- package/cjs/model/ModelAggregate.d.ts +84 -0
- package/cjs/model/ModelAggregate.d.ts.map +1 -0
- package/cjs/model/ModelAggregate.js +164 -0
- package/cjs/model/ModelAggregate.js.map +1 -0
- package/cjs/model/ModelSync.d.ts +74 -0
- package/cjs/model/ModelSync.d.ts.map +1 -0
- package/cjs/model/ModelSync.js +215 -0
- package/cjs/model/ModelSync.js.map +1 -0
- package/cjs/model/RelationshipWithMany.d.ts +24 -0
- package/cjs/model/RelationshipWithMany.d.ts.map +1 -0
- package/cjs/model/RelationshipWithMany.js +42 -0
- package/cjs/model/RelationshipWithMany.js.map +1 -0
- package/cjs/model/base-model.d.ts +155 -0
- package/cjs/model/base-model.d.ts.map +1 -0
- package/cjs/model/base-model.js +230 -0
- package/cjs/model/base-model.js.map +1 -0
- package/cjs/model/crud-model.d.ts +117 -0
- package/cjs/model/crud-model.d.ts.map +1 -0
- package/cjs/model/crud-model.js +352 -0
- package/cjs/model/crud-model.js.map +1 -0
- package/cjs/model/index.d.ts +10 -0
- package/cjs/model/index.d.ts.map +1 -0
- package/cjs/model/joinable.d.ts +87 -0
- package/cjs/model/joinable.d.ts.map +1 -0
- package/cjs/model/joinable.js +155 -0
- package/cjs/model/joinable.js.map +1 -0
- package/cjs/model/master-mind.d.ts +44 -0
- package/cjs/model/master-mind.d.ts.map +1 -0
- package/cjs/model/master-mind.js +129 -0
- package/cjs/model/master-mind.js.map +1 -0
- package/cjs/model/model-events.d.ts +57 -0
- package/cjs/model/model-events.d.ts.map +1 -0
- package/cjs/model/model-events.js +102 -0
- package/cjs/model/model-events.js.map +1 -0
- package/cjs/model/model.d.ts +401 -0
- package/cjs/model/model.d.ts.map +1 -0
- package/cjs/model/model.js +1028 -0
- package/cjs/model/model.js.map +1 -0
- package/cjs/model/types.d.ts +113 -0
- package/cjs/model/types.d.ts.map +1 -0
- package/cjs/model/types.js +11 -0
- package/cjs/model/types.js.map +1 -0
- package/cjs/query/index.d.ts +2 -0
- package/cjs/query/index.d.ts.map +1 -0
- package/cjs/query/query.d.ts +228 -0
- package/cjs/query/query.d.ts.map +1 -0
- package/cjs/query/query.js +675 -0
- package/cjs/query/query.js.map +1 -0
- package/cjs/query/types.d.ts +56 -0
- package/cjs/query/types.d.ts.map +1 -0
- package/cjs/types.d.ts +62 -0
- package/cjs/types.d.ts.map +1 -0
- package/cjs/utils/connectToDatabase.d.ts +3 -0
- package/cjs/utils/connectToDatabase.d.ts.map +1 -0
- package/cjs/utils/connectToDatabase.js +3 -0
- package/cjs/utils/connectToDatabase.js.map +1 -0
- package/cjs/utils/deep-diff.d.ts +9 -0
- package/cjs/utils/deep-diff.d.ts.map +1 -0
- package/cjs/utils/deep-diff.js +44 -0
- package/cjs/utils/deep-diff.js.map +1 -0
- package/cjs/utils/dropAllDatabaseIndexes.d.ts +2 -0
- package/cjs/utils/dropAllDatabaseIndexes.d.ts.map +1 -0
- package/cjs/utils/dropAllDatabaseIndexes.js +10 -0
- package/cjs/utils/dropAllDatabaseIndexes.js.map +1 -0
- package/cjs/utils/index.d.ts +5 -0
- package/cjs/utils/index.d.ts.map +1 -0
- package/cjs/utils/joinable-proxy.d.ts +3 -0
- package/cjs/utils/joinable-proxy.d.ts.map +1 -0
- package/cjs/utils/joinable-proxy.js +14 -0
- package/cjs/utils/joinable-proxy.js.map +1 -0
- package/cjs/utils/listDatabaseIndexes.d.ts +4 -0
- package/cjs/utils/listDatabaseIndexes.d.ts.map +1 -0
- package/cjs/utils/listDatabaseIndexes.js +101 -0
- package/cjs/utils/listDatabaseIndexes.js.map +1 -0
- package/cjs/utils/onceConnected.d.ts +2 -0
- package/cjs/utils/onceConnected.d.ts.map +1 -0
- package/cjs/utils/onceConnected.js +8 -0
- package/cjs/utils/onceConnected.js.map +1 -0
- package/esm/connection.js +1 -1
- package/esm/connection.js.map +1 -1
- package/esm/utils/deep-diff.d.ts.map +1 -1
- package/esm/utils/deep-diff.js +5 -3
- package/esm/utils/deep-diff.js.map +1 -1
- package/package.json +1 -1
- package/cjs/commands/create-new-app/get-app-path.d.ts +0 -2
- package/cjs/commands/create-new-app/get-app-path.d.ts.map +0 -1
- package/cjs/commands/create-new-app/get-app-path.js +0 -8
- package/cjs/commands/create-new-app/get-app-path.js.map +0 -1
- package/cjs/commands/create-new-app/index.d.ts +0 -2
- package/cjs/commands/create-new-app/index.d.ts.map +0 -1
- package/cjs/commands/create-new-app/index.js +0 -44
- package/cjs/commands/create-new-app/index.js.map +0 -1
- package/cjs/commands/create-new-app/select-app-type.d.ts +0 -2
- package/cjs/commands/create-new-app/select-app-type.d.ts.map +0 -1
- package/cjs/commands/create-new-app/types.d.ts +0 -9
- package/cjs/commands/create-new-app/types.d.ts.map +0 -1
- package/cjs/commands/create-warlock-app/index.d.ts +0 -3
- package/cjs/commands/create-warlock-app/index.d.ts.map +0 -1
- package/cjs/commands/create-warlock-app/index.js +0 -18
- package/cjs/commands/create-warlock-app/index.js.map +0 -1
- package/cjs/helpers/app.d.ts +0 -51
- package/cjs/helpers/app.d.ts.map +0 -1
- package/cjs/helpers/app.js +0 -127
- package/cjs/helpers/app.js.map +0 -1
- package/cjs/helpers/exec.d.ts +0 -10
- package/cjs/helpers/exec.d.ts.map +0 -1
- package/cjs/helpers/exec.js +0 -69
- package/cjs/helpers/exec.js.map +0 -1
- package/cjs/helpers/package-manager.d.ts +0 -6
- package/cjs/helpers/package-manager.d.ts.map +0 -1
- package/cjs/helpers/package-manager.js +0 -22
- package/cjs/helpers/package-manager.js.map +0 -1
- package/cjs/helpers/paths.d.ts +0 -4
- package/cjs/helpers/paths.d.ts.map +0 -1
- package/cjs/helpers/paths.js +0 -8
- package/cjs/helpers/paths.js.map +0 -1
- package/cjs/helpers/project-builder-helpers.d.ts +0 -7
- package/cjs/helpers/project-builder-helpers.d.ts.map +0 -1
- package/cjs/helpers/project-builder-helpers.js +0 -44
- package/cjs/helpers/project-builder-helpers.js.map +0 -1
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
'use strict';var supportiveIs=require('@mongez/supportive-is'),timeWizard=require('@mongez/time-wizard'),expressions=require('./expressions.js');function escapeString(value) {
|
|
2
|
+
return String(value).replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
|
|
3
|
+
}
|
|
4
|
+
function escapeRegex(value, escapeOnly = false) {
|
|
5
|
+
if (value instanceof RegExp === false) {
|
|
6
|
+
// escape the value special characters
|
|
7
|
+
value = escapeString(value);
|
|
8
|
+
if (escapeOnly === false) {
|
|
9
|
+
value = new RegExp(value, "gi");
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
return value;
|
|
13
|
+
}
|
|
14
|
+
function parseValuesInObject(valuesObject) {
|
|
15
|
+
for (const key in valuesObject) {
|
|
16
|
+
const value = valuesObject[key];
|
|
17
|
+
if (value instanceof Date) {
|
|
18
|
+
valuesObject[key] = timeWizard.toUTC(value);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return valuesObject;
|
|
22
|
+
}
|
|
23
|
+
class WhereExpression {
|
|
24
|
+
/**
|
|
25
|
+
* Operators list
|
|
26
|
+
*/
|
|
27
|
+
static operators = {
|
|
28
|
+
"=": "$eq",
|
|
29
|
+
"!=": "$ne",
|
|
30
|
+
not: "$not",
|
|
31
|
+
">": "$gt",
|
|
32
|
+
">=": "$gte",
|
|
33
|
+
"<": "$lt",
|
|
34
|
+
"<=": "$lte",
|
|
35
|
+
in: "$in",
|
|
36
|
+
nin: "$nin",
|
|
37
|
+
notIn: "$nin",
|
|
38
|
+
all: "$all",
|
|
39
|
+
exists: "$exists",
|
|
40
|
+
type: "$type",
|
|
41
|
+
mod: "$mod",
|
|
42
|
+
regex: "$regex",
|
|
43
|
+
between: "$between",
|
|
44
|
+
notBetween: "$between",
|
|
45
|
+
geoIntersects: "$geoIntersects",
|
|
46
|
+
geoWithin: "$geoWithin",
|
|
47
|
+
near: "$near",
|
|
48
|
+
nearSphere: "$nearSphere",
|
|
49
|
+
elemMatch: "$elemMatch",
|
|
50
|
+
size: "$size",
|
|
51
|
+
like: "$regex",
|
|
52
|
+
notLike: "$regex",
|
|
53
|
+
startsWith: "$regex",
|
|
54
|
+
endsWith: "$regex",
|
|
55
|
+
notStartsWith: "$regex",
|
|
56
|
+
notEndsWith: "$regex",
|
|
57
|
+
};
|
|
58
|
+
static parse(...args) {
|
|
59
|
+
if (args.length === 1 && supportiveIs.isPlainObject(args[0]))
|
|
60
|
+
return parseValuesInObject(args[0]);
|
|
61
|
+
const column = args[0];
|
|
62
|
+
let operator = args[1];
|
|
63
|
+
let value = args[2];
|
|
64
|
+
// if the length is two, then the operator will be =
|
|
65
|
+
if (args.length === 2) {
|
|
66
|
+
value = operator;
|
|
67
|
+
operator = "=";
|
|
68
|
+
}
|
|
69
|
+
if (operator === "like") {
|
|
70
|
+
value = new RegExp(escapeRegex(value), "gi");
|
|
71
|
+
}
|
|
72
|
+
else if (operator === "notLike") {
|
|
73
|
+
value = new RegExp(escapeRegex(value), "gi");
|
|
74
|
+
operator = "not";
|
|
75
|
+
value = {
|
|
76
|
+
$regex: value,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
else if (operator === "startsWith") {
|
|
80
|
+
value = escapeRegex(value, true);
|
|
81
|
+
value = new RegExp(`^${value}`);
|
|
82
|
+
}
|
|
83
|
+
else if (operator === "endsWith") {
|
|
84
|
+
value = escapeRegex(value, true);
|
|
85
|
+
value = new RegExp(`${value}$`);
|
|
86
|
+
}
|
|
87
|
+
else if (operator === "notStartsWith") {
|
|
88
|
+
value = escapeRegex(value, true);
|
|
89
|
+
value = {
|
|
90
|
+
$regex: new RegExp(`^${value}`),
|
|
91
|
+
};
|
|
92
|
+
operator = "not";
|
|
93
|
+
}
|
|
94
|
+
else if (operator === "notEndsWith") {
|
|
95
|
+
value = escapeRegex(value, true);
|
|
96
|
+
value = {
|
|
97
|
+
$regex: new RegExp(`${value}$`),
|
|
98
|
+
};
|
|
99
|
+
operator = "not";
|
|
100
|
+
}
|
|
101
|
+
if (value instanceof Date) {
|
|
102
|
+
value = timeWizard.toUTC(value);
|
|
103
|
+
}
|
|
104
|
+
else if (Array.isArray(value)) {
|
|
105
|
+
value = value.map(item => {
|
|
106
|
+
if (item instanceof Date) {
|
|
107
|
+
return timeWizard.toUTC(item);
|
|
108
|
+
}
|
|
109
|
+
return item;
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
let expression = {
|
|
113
|
+
[WhereExpression.operators[operator]]: value,
|
|
114
|
+
};
|
|
115
|
+
if (operator === "in" && typeof value === "string") {
|
|
116
|
+
expression = {
|
|
117
|
+
$in: expressions.$agg.columnName(value),
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
else if (operator === "notIn" && typeof value === "string") {
|
|
121
|
+
expression = {
|
|
122
|
+
$not: {
|
|
123
|
+
$in: expressions.$agg.columnName(value),
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
else if (operator === "between") {
|
|
128
|
+
expression = {
|
|
129
|
+
$gte: value[0],
|
|
130
|
+
$lte: value[1],
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
else if (operator === "notBetween") {
|
|
134
|
+
expression = {
|
|
135
|
+
$not: {
|
|
136
|
+
$gte: value[0],
|
|
137
|
+
$lte: value[1],
|
|
138
|
+
},
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
// now add the data
|
|
142
|
+
return {
|
|
143
|
+
[column]: expression,
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
const toOperator = (operator) => {
|
|
148
|
+
return WhereExpression.operators[operator];
|
|
149
|
+
};exports.WhereExpression=WhereExpression;exports.parseValuesInObject=parseValuesInObject;exports.toOperator=toOperator;//# sourceMappingURL=WhereExpression.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WhereExpression.js","sources":["../../src/aggregate/WhereExpression.ts"],"sourcesContent":[null],"names":["toUTC","isPlainObject","$agg"],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Pipeline } from "./pipeline";
|
|
2
|
+
export declare class WhereExpressionPipeline extends Pipeline {
|
|
3
|
+
protected readonly column: string;
|
|
4
|
+
protected readonly expression: any;
|
|
5
|
+
/**
|
|
6
|
+
* Constructor
|
|
7
|
+
*/
|
|
8
|
+
constructor(column: string, expression: any);
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=WhereExpressionPipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WhereExpressionPipeline.d.ts","sourceRoot":"","sources":["../../src/aggregate/WhereExpressionPipeline.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,qBAAa,uBAAwB,SAAQ,QAAQ;IAKjD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM;IACjC,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,GAAG;IALpC;;OAEG;gBAEkB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,GAAG;CAOrC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';var pipeline=require('./pipeline.js');class WhereExpressionPipeline extends pipeline.Pipeline {
|
|
2
|
+
column;
|
|
3
|
+
expression;
|
|
4
|
+
/**
|
|
5
|
+
* Constructor
|
|
6
|
+
*/
|
|
7
|
+
constructor(column, expression) {
|
|
8
|
+
super("match");
|
|
9
|
+
this.column = column;
|
|
10
|
+
this.expression = expression;
|
|
11
|
+
this.data({
|
|
12
|
+
[column]: expression,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}exports.WhereExpressionPipeline=WhereExpressionPipeline;//# sourceMappingURL=WhereExpressionPipeline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WhereExpressionPipeline.js","sources":["../../src/aggregate/WhereExpressionPipeline.ts"],"sourcesContent":[null],"names":["Pipeline"],"mappings":"mDAEM,MAAO,uBAAwB,SAAQA,iBAAQ,CAAA;AAK9B,IAAA,MAAA,CAAA;AACA,IAAA,UAAA,CAAA;AALrB;;AAEG;IACH,WACqB,CAAA,MAAc,EACd,UAAe,EAAA;QAElC,KAAK,CAAC,OAAO,CAAC,CAAC;QAHI,IAAM,CAAA,MAAA,GAAN,MAAM,CAAQ;QACd,IAAU,CAAA,UAAA,GAAV,UAAU,CAAK;QAGlC,IAAI,CAAC,IAAI,CAAC;YACR,CAAC,MAAM,GAAG,UAAU;AACrB,SAAA,CAAC,CAAC;KACJ;AACF"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { GenericObject } from "@mongez/reinforcements";
|
|
2
|
+
import { Pipeline } from "./pipeline";
|
|
3
|
+
import type { WhereOperator } from "./types";
|
|
4
|
+
export declare class WherePipeline extends Pipeline {
|
|
5
|
+
/**
|
|
6
|
+
* Constructor
|
|
7
|
+
*/
|
|
8
|
+
constructor(expression: GenericObject);
|
|
9
|
+
}
|
|
10
|
+
export declare function wherePipeline(column: string, value: any): WherePipeline;
|
|
11
|
+
export declare function wherePipeline(column: string, operator: WhereOperator, value: any): WherePipeline;
|
|
12
|
+
export declare function wherePipeline(column: GenericObject): WherePipeline;
|
|
13
|
+
//# sourceMappingURL=WherePipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WherePipeline.d.ts","sourceRoot":"","sources":["../../src/aggregate/WherePipeline.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAE5D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAE7C,qBAAa,aAAc,SAAQ,QAAQ;IACzC;;OAEG;gBACgB,UAAU,EAAE,aAAa;CAK7C;AAED,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,aAAa,CAAC;AACzE,wBAAgB,aAAa,CAC3B,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,aAAa,EACvB,KAAK,EAAE,GAAG,GACT,aAAa,CAAC;AACjB,wBAAgB,aAAa,CAAC,MAAM,EAAE,aAAa,GAAG,aAAa,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';var WhereExpression=require('./WhereExpression.js'),pipeline=require('./pipeline.js');class WherePipeline extends pipeline.Pipeline {
|
|
2
|
+
/**
|
|
3
|
+
* Constructor
|
|
4
|
+
*/
|
|
5
|
+
constructor(expression) {
|
|
6
|
+
super("match");
|
|
7
|
+
this.data(expression);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
function wherePipeline(...args) {
|
|
11
|
+
return new WherePipeline(WhereExpression.WhereExpression.parse.apply(null, args));
|
|
12
|
+
}exports.WherePipeline=WherePipeline;exports.wherePipeline=wherePipeline;//# sourceMappingURL=WherePipeline.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WherePipeline.js","sources":["../../src/aggregate/WherePipeline.ts"],"sourcesContent":[null],"names":["Pipeline","WhereExpression"],"mappings":"mGAKM,MAAO,aAAc,SAAQA,iBAAQ,CAAA;AACzC;;AAEG;AACH,IAAA,WAAA,CAAmB,UAAyB,EAAA;QAC1C,KAAK,CAAC,OAAO,CAAC,CAAC;AAEf,QAAA,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;KACvB;AACF,CAAA;AASe,SAAA,aAAa,CAAC,GAAG,IAAW,EAAA;AAC1C,IAAA,OAAO,IAAI,aAAa,CAACC,+BAAe,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,IAAW,CAAC,CAAC,CAAC;AAC3E"}
|
|
@@ -0,0 +1,358 @@
|
|
|
1
|
+
import type { GenericObject } from "@mongez/reinforcements";
|
|
2
|
+
import type { ChunkCallback, Filter, PaginationListing } from "../model";
|
|
3
|
+
import { ModelEvents } from "../model/model-events";
|
|
4
|
+
import { GroupByPipeline } from "./GroupByPipeline";
|
|
5
|
+
import type { LookupPipelineOptions } from "./LookupPipeline";
|
|
6
|
+
import type { UnwindOptions } from "./UnwindPipeline";
|
|
7
|
+
import type { Pipeline } from "./pipeline";
|
|
8
|
+
import type { WhereOperator } from "./types";
|
|
9
|
+
export declare class Aggregate {
|
|
10
|
+
readonly collection: string;
|
|
11
|
+
/**
|
|
12
|
+
* Collection pipelines
|
|
13
|
+
*/
|
|
14
|
+
pipelines: (Pipeline | GenericObject)[];
|
|
15
|
+
/**
|
|
16
|
+
* Aggregate events
|
|
17
|
+
*/
|
|
18
|
+
static _events: ModelEvents;
|
|
19
|
+
/**
|
|
20
|
+
* Query manager
|
|
21
|
+
*/
|
|
22
|
+
query: import("../query").Query;
|
|
23
|
+
/**
|
|
24
|
+
* Constructor
|
|
25
|
+
*/
|
|
26
|
+
constructor(collection: string);
|
|
27
|
+
/**
|
|
28
|
+
* Get the events instance
|
|
29
|
+
*/
|
|
30
|
+
static events(): ModelEvents;
|
|
31
|
+
/**
|
|
32
|
+
* Sort by the given column
|
|
33
|
+
*/
|
|
34
|
+
sort(column: string, direction?: "asc" | "desc"): this;
|
|
35
|
+
/**
|
|
36
|
+
* @alias sort
|
|
37
|
+
*/
|
|
38
|
+
orderBy(column: string, direction?: "asc" | "desc"): this;
|
|
39
|
+
/**
|
|
40
|
+
* Order by descending
|
|
41
|
+
*/
|
|
42
|
+
sortByDesc(column: string): this;
|
|
43
|
+
/**
|
|
44
|
+
* Order by descending
|
|
45
|
+
*/
|
|
46
|
+
orderByDesc(column: string): this;
|
|
47
|
+
/**
|
|
48
|
+
* Sort by multiple columns
|
|
49
|
+
*/
|
|
50
|
+
sortBy(columns: Record<string, "desc" | "asc">): this;
|
|
51
|
+
/**
|
|
52
|
+
* Sort randomly
|
|
53
|
+
*/
|
|
54
|
+
random(limit?: number): this;
|
|
55
|
+
/**
|
|
56
|
+
* Order by latest created records
|
|
57
|
+
*/
|
|
58
|
+
latest(column?: string): this;
|
|
59
|
+
/**
|
|
60
|
+
* Order by oldest created records
|
|
61
|
+
*/
|
|
62
|
+
oldest(column?: string): this;
|
|
63
|
+
/**
|
|
64
|
+
* Group by aggregate
|
|
65
|
+
*/
|
|
66
|
+
groupBy(GroupByPipeline: GroupByPipeline): this;
|
|
67
|
+
groupBy(GroupByPipeline: GenericObject, groupByData?: GenericObject): this;
|
|
68
|
+
groupBy(groupByColumns: string[], groupByData?: GenericObject): this;
|
|
69
|
+
groupBy(groupBy_id: string | null): this;
|
|
70
|
+
groupBy(groupBy_id: string | null, groupByData: GenericObject): this;
|
|
71
|
+
/**
|
|
72
|
+
* Group by year
|
|
73
|
+
*/
|
|
74
|
+
groupByYear(column: string, groupByData?: GenericObject): this;
|
|
75
|
+
/**
|
|
76
|
+
* Group by month and year
|
|
77
|
+
*/
|
|
78
|
+
groupByMonthAndYear(column: string, groupByData?: GenericObject): this;
|
|
79
|
+
/**
|
|
80
|
+
* Group by month only
|
|
81
|
+
*/
|
|
82
|
+
groupByMonth(column: string, groupByData?: GenericObject): this;
|
|
83
|
+
/**
|
|
84
|
+
* Group by day, month and year
|
|
85
|
+
*/
|
|
86
|
+
groupByDate(column: string, groupByData?: GenericObject): this;
|
|
87
|
+
/**
|
|
88
|
+
* Group by week and year
|
|
89
|
+
*/
|
|
90
|
+
groupByWeek(column: string, groupByData?: GenericObject): this;
|
|
91
|
+
/**
|
|
92
|
+
* Group by day only
|
|
93
|
+
*/
|
|
94
|
+
groupByDayOfMonth(column: string, groupByData?: GenericObject): this;
|
|
95
|
+
/**
|
|
96
|
+
* Pluck only the given column
|
|
97
|
+
*/
|
|
98
|
+
pluck(column: string): Promise<any[]>;
|
|
99
|
+
/**
|
|
100
|
+
* Get average of the given column
|
|
101
|
+
*/
|
|
102
|
+
avg(column: string): Promise<any>;
|
|
103
|
+
/**
|
|
104
|
+
* {@alias} avg
|
|
105
|
+
*/
|
|
106
|
+
average(column: string): Promise<any>;
|
|
107
|
+
/**
|
|
108
|
+
* Sum values of the given column
|
|
109
|
+
*/
|
|
110
|
+
sum(column: string): Promise<any>;
|
|
111
|
+
/**
|
|
112
|
+
* Get minimum value of the given column
|
|
113
|
+
*/
|
|
114
|
+
min(column: string): Promise<any>;
|
|
115
|
+
/**
|
|
116
|
+
* Get maximum value of the given column
|
|
117
|
+
*/
|
|
118
|
+
max(column: string): Promise<any>;
|
|
119
|
+
/**
|
|
120
|
+
* Get distinct value for the given column using aggregation
|
|
121
|
+
*/
|
|
122
|
+
distinct<T = any>(column: string): Promise<T[]>;
|
|
123
|
+
/**
|
|
124
|
+
* {@alias} distinct
|
|
125
|
+
*/
|
|
126
|
+
unique<T = any>(column: string): Promise<T[]>;
|
|
127
|
+
/**
|
|
128
|
+
* Get distinct values that are not empty
|
|
129
|
+
*/
|
|
130
|
+
distinctHeavy<T = any>(column: string): Promise<T[]>;
|
|
131
|
+
/**
|
|
132
|
+
* {@alias} distinctHeavy
|
|
133
|
+
*/
|
|
134
|
+
uniqueHeavy<T = any>(column: string): Promise<T[]>;
|
|
135
|
+
/**
|
|
136
|
+
* Get values list of the given column
|
|
137
|
+
*/
|
|
138
|
+
values<T = any>(column: string): Promise<T>;
|
|
139
|
+
/**
|
|
140
|
+
* Limit the number of results
|
|
141
|
+
*/
|
|
142
|
+
limit(limit: number): this;
|
|
143
|
+
/**
|
|
144
|
+
* Skip the given number of results
|
|
145
|
+
*/
|
|
146
|
+
skip(skip: number): this;
|
|
147
|
+
/**
|
|
148
|
+
* Select the given columns
|
|
149
|
+
*/
|
|
150
|
+
select(...columns: string[]): this;
|
|
151
|
+
select(columns: string[] | Record<string, 0 | 1 | boolean>): this;
|
|
152
|
+
/**
|
|
153
|
+
* Deselect the given columns
|
|
154
|
+
*/
|
|
155
|
+
deselect(columns: string[]): this;
|
|
156
|
+
/**
|
|
157
|
+
* Unwind/Extract the given column
|
|
158
|
+
*/
|
|
159
|
+
unwind(column: string, options?: UnwindOptions): this;
|
|
160
|
+
/**
|
|
161
|
+
* Add where stage
|
|
162
|
+
*/
|
|
163
|
+
where(column: string, value: any): this;
|
|
164
|
+
where(column: string, operator: WhereOperator, value: any): this;
|
|
165
|
+
where(column: GenericObject): this;
|
|
166
|
+
/**
|
|
167
|
+
* Add comparison between two or more columns
|
|
168
|
+
*/
|
|
169
|
+
whereColumns(column1: string, operator: WhereOperator, ...otherColumns: string[]): this;
|
|
170
|
+
/**
|
|
171
|
+
* Or Where stage
|
|
172
|
+
*/
|
|
173
|
+
orWhere(...operations: GenericObject[]): this;
|
|
174
|
+
orWhere(...operations: [column: string, value: any][]): this;
|
|
175
|
+
/**
|
|
176
|
+
* Perform a text search
|
|
177
|
+
* Please note that this method will add the `match` stage to the beginning of the pipeline
|
|
178
|
+
* Also it will add `score` field to the result automatically
|
|
179
|
+
*
|
|
180
|
+
* @warning This method will not work if the collection is not indexed for text search
|
|
181
|
+
*/
|
|
182
|
+
textSearch(query: string, moreFilters?: GenericObject): this;
|
|
183
|
+
/**
|
|
184
|
+
* Where null
|
|
185
|
+
*/
|
|
186
|
+
whereNull(column: string): this;
|
|
187
|
+
/**
|
|
188
|
+
* Where not null
|
|
189
|
+
*/
|
|
190
|
+
whereNotNull(column: string): this;
|
|
191
|
+
/**
|
|
192
|
+
* Where like operator
|
|
193
|
+
*/
|
|
194
|
+
whereLike(column: string, value: string): this;
|
|
195
|
+
/**
|
|
196
|
+
* Where not like operator
|
|
197
|
+
*/
|
|
198
|
+
whereNotLike(column: string, value: string): this;
|
|
199
|
+
/**
|
|
200
|
+
* Where column starts with the given value
|
|
201
|
+
*/
|
|
202
|
+
whereStartsWith(column: string, value: string | number): this;
|
|
203
|
+
/**
|
|
204
|
+
* Where column not starts with the given value
|
|
205
|
+
*/
|
|
206
|
+
whereNotStartsWith(column: string, value: string | number): this;
|
|
207
|
+
/**
|
|
208
|
+
* Where column ends with the given value
|
|
209
|
+
*/
|
|
210
|
+
whereEndsWith(column: string, value: string | number): this;
|
|
211
|
+
/**
|
|
212
|
+
* Where column not ends with the given value
|
|
213
|
+
*/
|
|
214
|
+
whereNotEndsWith(column: string, value: string | number): this;
|
|
215
|
+
/**
|
|
216
|
+
* Where between operator
|
|
217
|
+
*/
|
|
218
|
+
whereBetween(column: string, value: [any, any]): this;
|
|
219
|
+
/**
|
|
220
|
+
* Where date between operator
|
|
221
|
+
*/
|
|
222
|
+
whereDateBetween(column: string, value: [Date, Date]): this;
|
|
223
|
+
/**
|
|
224
|
+
* Where date not between operator
|
|
225
|
+
*/
|
|
226
|
+
whereDateNotBetween(column: string, value: [Date, Date]): this;
|
|
227
|
+
/**
|
|
228
|
+
* Where not between operator
|
|
229
|
+
*/
|
|
230
|
+
whereNotBetween(column: string, value: [any, any]): this;
|
|
231
|
+
/**
|
|
232
|
+
* Where exists operator
|
|
233
|
+
*/
|
|
234
|
+
whereExists(column: string): this;
|
|
235
|
+
/**
|
|
236
|
+
* Where not exists operator
|
|
237
|
+
*/
|
|
238
|
+
whereNotExists(column: string): this;
|
|
239
|
+
/**
|
|
240
|
+
* Where size operator
|
|
241
|
+
*/
|
|
242
|
+
whereSize(column: string, size: number): this;
|
|
243
|
+
whereSize(column: string, operator: ">" | ">=" | "=" | "<" | "<=", size: number): this;
|
|
244
|
+
/**
|
|
245
|
+
* Add project pipeline
|
|
246
|
+
*
|
|
247
|
+
*/
|
|
248
|
+
project(data: Record<string, any>): this;
|
|
249
|
+
/**
|
|
250
|
+
* Where in operator
|
|
251
|
+
* If value is a string, it will be treated as a column name
|
|
252
|
+
*/
|
|
253
|
+
whereIn(column: string, values: string | any[]): this;
|
|
254
|
+
/**
|
|
255
|
+
* Where not in operator
|
|
256
|
+
* If value is a string, it will be treated as a column name
|
|
257
|
+
*/
|
|
258
|
+
whereNotIn(column: string, values: string | any[]): this;
|
|
259
|
+
/**
|
|
260
|
+
* // TODO: Make a proper implementation
|
|
261
|
+
* Where location near
|
|
262
|
+
*/
|
|
263
|
+
whereNear(column: string, value: [number, number], _distance: number): this;
|
|
264
|
+
/**
|
|
265
|
+
* // TODO: Make a proper implementation
|
|
266
|
+
* Get nearby location between the given min and max distance
|
|
267
|
+
*/
|
|
268
|
+
whereNearByIn(column: string, value: [number, number], _minDistance: number, _maxDistance: number): Promise<this>;
|
|
269
|
+
/**
|
|
270
|
+
* Lookup the given collection
|
|
271
|
+
*/
|
|
272
|
+
lookup(options: LookupPipelineOptions): this;
|
|
273
|
+
/**
|
|
274
|
+
* Add field to the pipeline
|
|
275
|
+
*/
|
|
276
|
+
addField(field: string, value: any): this;
|
|
277
|
+
/**
|
|
278
|
+
* Add fields to the pipeline
|
|
279
|
+
*/
|
|
280
|
+
addFields(fields: GenericObject): this;
|
|
281
|
+
/**
|
|
282
|
+
* Get new pipeline instance
|
|
283
|
+
*/
|
|
284
|
+
pipeline(...pipelines: Pipeline[]): this;
|
|
285
|
+
/**
|
|
286
|
+
* Unshift pipeline to the beginning of the pipelines
|
|
287
|
+
*/
|
|
288
|
+
unshiftPipelines(pipelines: Pipeline[]): this;
|
|
289
|
+
/**
|
|
290
|
+
* Add mongodb plain stage
|
|
291
|
+
*/
|
|
292
|
+
addPipeline(pipeline: any): this;
|
|
293
|
+
/**
|
|
294
|
+
* Add mongodb plain stages
|
|
295
|
+
*/
|
|
296
|
+
addPipelines(pipelines: any[]): this;
|
|
297
|
+
/**
|
|
298
|
+
* Get pipelines
|
|
299
|
+
*/
|
|
300
|
+
getPipelines(): (Pipeline | GenericObject)[];
|
|
301
|
+
/**
|
|
302
|
+
* Get only first result
|
|
303
|
+
*/
|
|
304
|
+
first(mapData?: (data: any) => any): Promise<any>;
|
|
305
|
+
/**
|
|
306
|
+
* Get last result
|
|
307
|
+
*/
|
|
308
|
+
last(filters?: Filter): Promise<any>;
|
|
309
|
+
/**
|
|
310
|
+
* Delete records
|
|
311
|
+
*/
|
|
312
|
+
delete(): Promise<number>;
|
|
313
|
+
/**
|
|
314
|
+
* Get the data
|
|
315
|
+
*/
|
|
316
|
+
get(mapData?: (data: any) => any): Promise<any[]>;
|
|
317
|
+
/**
|
|
318
|
+
* Chunk documents based on the given limit
|
|
319
|
+
*/
|
|
320
|
+
chunk<T = any>(limit: number, callback: ChunkCallback<T>, mapData?: (data: any) => any): Promise<void>;
|
|
321
|
+
/**
|
|
322
|
+
* Paginate records based on the given filter
|
|
323
|
+
*/
|
|
324
|
+
paginate<T = any>(page?: number, limit?: number, mapData?: (data: any) => T): Promise<PaginationListing<T>>;
|
|
325
|
+
/**
|
|
326
|
+
* Explain the query
|
|
327
|
+
*/
|
|
328
|
+
explain(): Promise<any>;
|
|
329
|
+
/**
|
|
330
|
+
* Update the given data
|
|
331
|
+
*/
|
|
332
|
+
update(data: any): Promise<any>;
|
|
333
|
+
/**
|
|
334
|
+
* Unset the given columns
|
|
335
|
+
*/
|
|
336
|
+
unset(...columns: string[]): Promise<any>;
|
|
337
|
+
/**
|
|
338
|
+
* Execute the query
|
|
339
|
+
*/
|
|
340
|
+
execute(): Promise<any>;
|
|
341
|
+
/**
|
|
342
|
+
* Count the results
|
|
343
|
+
*/
|
|
344
|
+
count(): Promise<number>;
|
|
345
|
+
/**
|
|
346
|
+
* Parse pipelines
|
|
347
|
+
*/
|
|
348
|
+
parse(): any[];
|
|
349
|
+
/**
|
|
350
|
+
* Reset the pipeline
|
|
351
|
+
*/
|
|
352
|
+
reset(): this;
|
|
353
|
+
/**
|
|
354
|
+
* Clone the aggregate class
|
|
355
|
+
*/
|
|
356
|
+
clone(): this;
|
|
357
|
+
}
|
|
358
|
+
//# sourceMappingURL=aggregate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aggregate.d.ts","sourceRoot":"","sources":["../../src/aggregate/aggregate.ts"],"names":[],"mappings":"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"}
|