@steedos/objectql 3.0.13-beta.9 → 3.0.13
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/lib/actions/field_updates.js +84 -153
- package/lib/actions/field_updates.js.map +1 -1
- package/lib/actions/index.js +1 -1
- package/lib/actions/workflow_notifications.js +50 -111
- package/lib/actions/workflow_notifications.js.map +1 -1
- package/lib/actions/workflow_outbound_messages.js +43 -94
- package/lib/actions/workflow_outbound_messages.js.map +1 -1
- package/lib/actions/workflow_rule.js +80 -177
- package/lib/actions/workflow_rule.js.map +1 -1
- package/lib/broker.js +19 -49
- package/lib/broker.js.map +1 -1
- package/lib/driver/field-encrytion/index.js +1 -1
- package/lib/driver/field-encrytion/mongosharedconst.js +17 -17
- package/lib/driver/field-encrytion/mongosharedconst.js.map +1 -1
- package/lib/driver/format.js +3 -3
- package/lib/driver/format.js.map +1 -1
- package/lib/driver/index.js +1 -1
- package/lib/driver/metadata.js +286 -387
- package/lib/driver/metadata.js.map +1 -1
- package/lib/driver/metadataOld.js +104 -105
- package/lib/driver/metadataOld.js.map +1 -1
- package/lib/driver/meteorMongo.js +5 -8
- package/lib/driver/meteorMongo.js.map +1 -1
- package/lib/driver/mongo.js +321 -506
- package/lib/driver/mongo.js.map +1 -1
- package/lib/driver/mysql.js +16 -20
- package/lib/driver/mysql.js.map +1 -1
- package/lib/driver/oracle.js +25 -38
- package/lib/driver/oracle.js.map +1 -1
- package/lib/driver/postgres.js +16 -20
- package/lib/driver/postgres.js.map +1 -1
- package/lib/driver/sqlite3.js +15 -19
- package/lib/driver/sqlite3.js.map +1 -1
- package/lib/driver/sqlserver.js +20 -33
- package/lib/driver/sqlserver.js.map +1 -1
- package/lib/errors/index.js +10 -11
- package/lib/errors/index.js.map +1 -1
- package/lib/formula/core.js +307 -594
- package/lib/formula/core.js.map +1 -1
- package/lib/formula/field_formula.js +80 -126
- package/lib/formula/field_formula.js.map +1 -1
- package/lib/formula/index.js +56 -97
- package/lib/formula/index.js.map +1 -1
- package/lib/formula/params.js +11 -11
- package/lib/formula/params.js.map +1 -1
- package/lib/formula/recompute.js +41 -166
- package/lib/formula/recompute.js.map +1 -1
- package/lib/formula/simple_params.js +12 -12
- package/lib/formula/simple_params.js.map +1 -1
- package/lib/formula/util.js +43 -67
- package/lib/formula/util.js.map +1 -1
- package/lib/functions/function.js +68 -86
- package/lib/functions/function.js.map +1 -1
- package/lib/index.js +3 -3
- package/lib/index.js.map +1 -1
- package/lib/services/datasourceServiceFactory.js +77 -111
- package/lib/services/datasourceServiceFactory.js.map +1 -1
- package/lib/services/index.js +3 -3
- package/lib/services/index.js.map +1 -1
- package/lib/summary/core.js +162 -355
- package/lib/summary/core.js.map +1 -1
- package/lib/summary/field_summary.js +44 -71
- package/lib/summary/field_summary.js.map +1 -1
- package/lib/summary/index.js +65 -80
- package/lib/summary/index.js.map +1 -1
- package/lib/summary/recompute.js +19 -47
- package/lib/summary/recompute.js.map +1 -1
- package/lib/triggers/trigger.js +108 -142
- package/lib/triggers/trigger.js.map +1 -1
- package/lib/ts-types/index.js +1 -1
- package/lib/typeorm/driver.js +250 -450
- package/lib/typeorm/driver.js.map +1 -1
- package/lib/typeorm/index.js +1 -1
- package/lib/typeorm/util.js +28 -28
- package/lib/typeorm/util.js.map +1 -1
- package/lib/types/action.js +24 -33
- package/lib/types/action.js.map +1 -1
- package/lib/types/app.js +210 -355
- package/lib/types/app.js.map +1 -1
- package/lib/types/connection.js +42 -78
- package/lib/types/connection.js.map +1 -1
- package/lib/types/dashboard.js +56 -77
- package/lib/types/dashboard.js.map +1 -1
- package/lib/types/datasource.js +359 -705
- package/lib/types/datasource.js.map +1 -1
- package/lib/types/defaultValue.js +53 -65
- package/lib/types/defaultValue.js.map +1 -1
- package/lib/types/field.js +165 -137
- package/lib/types/field.js.map +1 -1
- package/lib/types/field_permission.js +35 -66
- package/lib/types/field_permission.js.map +1 -1
- package/lib/types/index.js +1 -1
- package/lib/types/list_view.d.ts +1 -0
- package/lib/types/list_view.js +37 -43
- package/lib/types/list_view.js.map +1 -1
- package/lib/types/metadata.js +6 -6
- package/lib/types/metadata.js.map +1 -1
- package/lib/types/method_base.js +95 -128
- package/lib/types/method_base.js.map +1 -1
- package/lib/types/object.js +2034 -3015
- package/lib/types/object.js.map +1 -1
- package/lib/types/object_events.js +24 -37
- package/lib/types/object_events.js.map +1 -1
- package/lib/types/object_layouts.js +15 -38
- package/lib/types/object_layouts.js.map +1 -1
- package/lib/types/object_permission.js +99 -85
- package/lib/types/object_permission.js.map +1 -1
- package/lib/types/report.js +70 -98
- package/lib/types/report.js.map +1 -1
- package/lib/types/restrictionRule.js +47 -96
- package/lib/types/restrictionRule.js.map +1 -1
- package/lib/types/schema.js +115 -177
- package/lib/types/schema.js.map +1 -1
- package/lib/types/shareRule.js +53 -102
- package/lib/types/shareRule.js.map +1 -1
- package/lib/types/trigger.js +43 -56
- package/lib/types/trigger.js.map +1 -1
- package/lib/types/validation_rules.js +18 -56
- package/lib/types/validation_rules.js.map +1 -1
- package/lib/util/convert.js +24 -24
- package/lib/util/convert.js.map +1 -1
- package/lib/util/field.js +16 -28
- package/lib/util/field.js.map +1 -1
- package/lib/util/function_expression.js +7 -8
- package/lib/util/function_expression.js.map +1 -1
- package/lib/util/index.d.ts +1 -0
- package/lib/util/index.js +80 -97
- package/lib/util/index.js.map +1 -1
- package/lib/util/locale.js +4 -4
- package/lib/util/locale.js.map +1 -1
- package/lib/util/perf.d.ts +11 -0
- package/lib/util/perf.js +49 -0
- package/lib/util/perf.js.map +1 -0
- package/lib/util/permission_shares.js +7 -7
- package/lib/util/permission_shares.js.map +1 -1
- package/lib/util/suffix.js +19 -19
- package/lib/util/suffix.js.map +1 -1
- package/lib/util/transform.js +1 -1
- package/lib/validators/index.js +10 -10
- package/lib/validators/index.js.map +1 -1
- package/package.json +13 -14
|
@@ -1,82 +1,55 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.getQuotedByFieldSummaryConfigs = exports.getObjectQuotedByFieldSummaryConfigs = exports.getObjectFieldSummaryConfigs = exports.getFieldSummaryConfig = exports.getFieldSummaryConfigs = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
switch (_a.label) {
|
|
9
|
-
case 0: return [4, (0, schema_1.getSteedosSchema)().metadataBroker.call("objects.getObjectFieldSummaryConfigs", { objectApiName: objectApiName, fieldApiName: fieldApiName })];
|
|
10
|
-
case 1: return [2, _a.sent()];
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
}); };
|
|
4
|
+
const schema_1 = require("../types/schema");
|
|
5
|
+
const getFieldSummaryConfigs = async (objectApiName, fieldApiName) => {
|
|
6
|
+
return await (0, schema_1.getSteedosSchema)().metadataBroker.call(`objects.getObjectFieldSummaryConfigs`, { objectApiName, fieldApiName });
|
|
7
|
+
};
|
|
14
8
|
exports.getFieldSummaryConfigs = getFieldSummaryConfigs;
|
|
15
|
-
|
|
16
|
-
return
|
|
17
|
-
|
|
18
|
-
case 0: return [4, (0, schema_1.getSteedosSchema)().metadataBroker.call("objects.getObjectFieldSummaryConfig", { fieldApiFullName: fieldApiFullName })];
|
|
19
|
-
case 1: return [2, _a.sent()];
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
}); };
|
|
9
|
+
const getFieldSummaryConfig = async (fieldApiFullName) => {
|
|
10
|
+
return await (0, schema_1.getSteedosSchema)().metadataBroker.call(`objects.getObjectFieldSummaryConfig`, { fieldApiFullName });
|
|
11
|
+
};
|
|
23
12
|
exports.getFieldSummaryConfig = getFieldSummaryConfig;
|
|
24
|
-
|
|
25
|
-
return
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
case 1: return [2, _a.sent()];
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
}); };
|
|
13
|
+
const getObjectFieldSummaryConfigs = async (objectName, fieldName) => {
|
|
14
|
+
return await (0, exports.getFieldSummaryConfigs)(objectName, fieldName);
|
|
15
|
+
;
|
|
16
|
+
};
|
|
32
17
|
exports.getObjectFieldSummaryConfigs = getObjectFieldSummaryConfigs;
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
return
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
return false;
|
|
67
|
-
}
|
|
68
|
-
})];
|
|
18
|
+
const getObjectQuotedByFieldSummaryConfigs = async (objectName, fieldNames) => {
|
|
19
|
+
const configs = await (0, exports.getFieldSummaryConfigs)();
|
|
20
|
+
return configs.filter((config) => {
|
|
21
|
+
const summaryObjectName = config.summary_object;
|
|
22
|
+
if (summaryObjectName) {
|
|
23
|
+
const summaryFieldName = config.summary_field;
|
|
24
|
+
if (summaryObjectName === objectName) {
|
|
25
|
+
if (fieldNames && fieldNames.length) {
|
|
26
|
+
if (fieldNames.indexOf(summaryFieldName) > -1) {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
const summaryFilters = config.summary_filters;
|
|
30
|
+
if (summaryFilters && summaryFilters.length) {
|
|
31
|
+
return !!fieldNames.find((fieldName) => {
|
|
32
|
+
return new RegExp(`\\b${fieldName}\\b`).test(JSON.stringify(summaryFilters));
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
69
44
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
exports.getObjectQuotedByFieldSummaryConfigs = getObjectQuotedByFieldSummaryConfigs;
|
|
73
|
-
var getQuotedByFieldSummaryConfigs = function (config) { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
|
|
74
|
-
return tslib_1.__generator(this, function (_a) {
|
|
75
|
-
switch (_a.label) {
|
|
76
|
-
case 0: return [4, (0, exports.getObjectQuotedByFieldSummaryConfigs)(config.object_name, [config.field_name])];
|
|
77
|
-
case 1: return [2, _a.sent()];
|
|
45
|
+
else {
|
|
46
|
+
return false;
|
|
78
47
|
}
|
|
79
48
|
});
|
|
80
|
-
}
|
|
49
|
+
};
|
|
50
|
+
exports.getObjectQuotedByFieldSummaryConfigs = getObjectQuotedByFieldSummaryConfigs;
|
|
51
|
+
const getQuotedByFieldSummaryConfigs = async (config) => {
|
|
52
|
+
return await (0, exports.getObjectQuotedByFieldSummaryConfigs)(config.object_name, [config.field_name]);
|
|
53
|
+
};
|
|
81
54
|
exports.getQuotedByFieldSummaryConfigs = getQuotedByFieldSummaryConfigs;
|
|
82
55
|
//# sourceMappingURL=field_summary.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"field_summary.js","sourceRoot":"","sources":["../../src/summary/field_summary.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"field_summary.js","sourceRoot":"","sources":["../../src/summary/field_summary.ts"],"names":[],"mappings":";;;AAEA,4CAAmD;AAG5C,MAAM,sBAAsB,GAAG,KAAK,EAAC,aAAc,EAAE,YAAa,EAAiD,EAAE;IACxH,OAAO,MAAM,IAAA,yBAAgB,GAAE,CAAC,cAAc,CAAC,IAAI,CAAC,sCAAsC,EAAE,EAAC,aAAa,EAAE,YAAY,EAAC,CAAC,CAAA;AAC9H,CAAC,CAAA;AAFY,QAAA,sBAAsB,0BAElC;AAEM,MAAM,qBAAqB,GAAG,KAAK,EAAE,gBAAwB,EAA0C,EAAE;IAC5G,OAAO,MAAM,IAAA,yBAAgB,GAAE,CAAC,cAAc,CAAC,IAAI,CAAC,qCAAqC,EAAE,EAAC,gBAAgB,EAAC,CAAC,CAAA;AAClH,CAAC,CAAA;AAFY,QAAA,qBAAqB,yBAEjC;AAQM,MAAM,4BAA4B,GAAG,KAAK,EAAC,UAAkB,EAAE,SAAkB,EAAiD,EAAE;IACvI,OAAO,MAAM,IAAA,8BAAsB,EAAC,UAAU,EAAE,SAAS,CAAC,CAAC;IAAA,CAAC;AAChE,CAAC,CAAA;AAFY,QAAA,4BAA4B,gCAExC;AASM,MAAM,oCAAoC,GAAG,KAAK,EAAE,UAAkB,EAAE,UAA0B,EAAiD,EAAE;IACxJ,MAAM,OAAO,GAAG,MAAM,IAAA,8BAAsB,GAAE,CAAC;IAC/C,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAqC,EAAE,EAAE;QAC5D,MAAM,iBAAiB,GAAG,MAAM,CAAC,cAAc,CAAC;QAChD,IAAG,iBAAiB,EAAC,CAAC;YAClB,MAAM,gBAAgB,GAAG,MAAM,CAAC,aAAa,CAAC;YAC9C,IAAG,iBAAiB,KAAK,UAAU,EAAC,CAAC;gBACjC,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,EAAE,CAAC;oBAClC,IAAG,UAAU,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,EAAC,CAAC;wBAC1C,OAAO,IAAI,CAAC;oBAChB,CAAC;oBACD,MAAM,cAAc,GAAG,MAAM,CAAC,eAAe,CAAC;oBAC9C,IAAG,cAAc,IAAI,cAAc,CAAC,MAAM,EAAC,CAAC;wBAExC,OAAO,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,EAAC,EAAE;4BAClC,OAAO,IAAI,MAAM,CAAC,MAAM,SAAS,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAA;wBAChF,CAAC,CAAC,CAAA;oBACN,CAAC;oBACD,OAAO,KAAK,CAAC;gBACjB,CAAC;qBACG,CAAC;oBACD,OAAO,IAAI,CAAC;gBAChB,CAAC;YACL,CAAC;iBACG,CAAC;gBACD,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC;aACI,CAAC;YACF,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC,CAAC,CAAC;AACP,CAAC,CAAA;AAhCY,QAAA,oCAAoC,wCAgChD;AAMM,MAAM,8BAA8B,GAAG,KAAK,EAAC,MAAqC,EAAiD,EAAE;IACxI,OAAO,MAAM,IAAA,4CAAoC,EAAC,MAAM,CAAC,WAAW,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;AAC/F,CAAC,CAAA;AAFY,QAAA,8BAA8B,kCAE1C"}
|
package/lib/summary/index.js
CHANGED
|
@@ -1,97 +1,82 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.isSummaryFieldTypeSupported = exports.getSummaryDataType = exports.initSummaryConfig = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const type_1 = require("./type");
|
|
6
|
+
const formula_1 = require("../formula");
|
|
7
|
+
const _ = require("lodash");
|
|
8
|
+
const metadata_registrar_1 = require("@steedos/metadata-registrar");
|
|
9
9
|
tslib_1.__exportStar(require("./type"), exports);
|
|
10
10
|
tslib_1.__exportStar(require("./field_summary"), exports);
|
|
11
11
|
tslib_1.__exportStar(require("./core"), exports);
|
|
12
12
|
tslib_1.__exportStar(require("./recompute"), exports);
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return [2];
|
|
25
|
-
}
|
|
26
|
-
referenceToField = _.find(summaryObject.fields, function (item) {
|
|
27
|
-
return item.type === "master_detail" && item.reference_to === object_name;
|
|
28
|
-
});
|
|
29
|
-
if (!referenceToField) {
|
|
30
|
-
throw new Error("Can't fount a master_detail type field that reference_to the master object '".concat(object_name, "' on the summary_object '").concat(summary_object, "'."));
|
|
31
|
-
}
|
|
32
|
-
summaryConfig.reference_to_field = referenceToField.name;
|
|
33
|
-
summaryConfig.reference_to_field_reference_to = referenceToField.reference_to_field;
|
|
34
|
-
if (!summaryConfig.data_type) {
|
|
35
|
-
throw new Error("Invalid field type summary '".concat(field_name, "' on the object '").concat(object_name, "', miss data_type property."));
|
|
36
|
-
}
|
|
37
|
-
return [4, (0, exports.getSummaryDataType)(summaryConfig, summaryObject)];
|
|
38
|
-
case 1:
|
|
39
|
-
dataType = _a.sent();
|
|
40
|
-
if (dataType !== summaryConfig.data_type) {
|
|
41
|
-
throw new Error("The data_type of the summary field '".concat(field_name, "' on the object '").concat(object_name, "' is incorrect, it should be '").concat(dataType, "' but is set to '").concat(summaryConfig.data_type, "'."));
|
|
42
|
-
}
|
|
43
|
-
summaryConfig.data_type = dataType;
|
|
44
|
-
return [2];
|
|
45
|
-
}
|
|
13
|
+
const initSummaryConfig = async (summaryConfig) => {
|
|
14
|
+
const objectConfigs = (0, metadata_registrar_1.getObjectConfigs)("default");
|
|
15
|
+
const { summary_object, field_name, object_name } = summaryConfig;
|
|
16
|
+
let summaryObject = _.find(objectConfigs, (item) => {
|
|
17
|
+
return item.name === summary_object;
|
|
18
|
+
});
|
|
19
|
+
if (!summaryObject) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const referenceToField = _.find(summaryObject.fields, (item) => {
|
|
23
|
+
return item.type === "master_detail" && item.reference_to === object_name;
|
|
46
24
|
});
|
|
47
|
-
|
|
25
|
+
if (!referenceToField) {
|
|
26
|
+
throw new Error(`Can't fount a master_detail type field that reference_to the master object '${object_name}' on the summary_object '${summary_object}'.`);
|
|
27
|
+
}
|
|
28
|
+
summaryConfig.reference_to_field = referenceToField.name;
|
|
29
|
+
summaryConfig.reference_to_field_reference_to = referenceToField.reference_to_field;
|
|
30
|
+
if (!summaryConfig.data_type) {
|
|
31
|
+
throw new Error(`Invalid field type summary '${field_name}' on the object '${object_name}', miss data_type property.`);
|
|
32
|
+
}
|
|
33
|
+
const dataType = await (0, exports.getSummaryDataType)(summaryConfig, summaryObject);
|
|
34
|
+
if (dataType !== summaryConfig.data_type) {
|
|
35
|
+
throw new Error(`The data_type of the summary field '${field_name}' on the object '${object_name}' is incorrect, it should be '${dataType}' but is set to '${summaryConfig.data_type}'.`);
|
|
36
|
+
}
|
|
37
|
+
summaryConfig.data_type = dataType;
|
|
38
|
+
};
|
|
48
39
|
exports.initSummaryConfig = initSummaryConfig;
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
if (!field) return [3, 3];
|
|
65
|
-
fieldType = field.type;
|
|
66
|
-
if (!(fieldType === "formula")) return [3, 2];
|
|
40
|
+
const getSummaryDataType = async (summaryConfig, summaryObject) => {
|
|
41
|
+
const { summary_object, summary_type, summary_field, field_name, object_name } = summaryConfig;
|
|
42
|
+
let result;
|
|
43
|
+
let needSummaryField = true;
|
|
44
|
+
if (summary_type === type_1.SteedosSummaryTypeValue.COUNT) {
|
|
45
|
+
needSummaryField = false;
|
|
46
|
+
}
|
|
47
|
+
else if (!summary_field) {
|
|
48
|
+
throw new Error(`You have to set a summary_field property for the field '${field_name}' of the object '${object_name}' when the summary_type is not set to 'count'.`);
|
|
49
|
+
}
|
|
50
|
+
if (summary_field && needSummaryField) {
|
|
51
|
+
const field = summaryObject.fields[summary_field];
|
|
52
|
+
if (field) {
|
|
53
|
+
let fieldType = field.type;
|
|
54
|
+
if (fieldType === "formula") {
|
|
67
55
|
fieldType = field.data_type;
|
|
68
|
-
|
|
69
|
-
case 1:
|
|
70
|
-
isQuotingTwoWay = _a.sent();
|
|
56
|
+
const isQuotingTwoWay = await (0, formula_1.isFormulaFieldQuotingObjectAndFields)(summary_object, summary_field, object_name, [field_name]);
|
|
71
57
|
if (isQuotingTwoWay) {
|
|
72
|
-
throw new Error(
|
|
73
|
-
}
|
|
74
|
-
_a.label = 2;
|
|
75
|
-
case 2:
|
|
76
|
-
if (fieldType === "summary") {
|
|
77
|
-
fieldType = field.data_type;
|
|
58
|
+
throw new Error(`Do not refer to each other, the field '${field_name}' of the master object '${object_name}' is summarizing a formula type summary_field '${summary_field}' of the detail object '${summary_object}', but the formula type field of the detail object exactly quoting the field of the master object, which is not allowed.`);
|
|
78
59
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
result = type_1.SteedosSummaryDataTypeValue.Number;
|
|
88
|
-
_a.label = 6;
|
|
89
|
-
case 6: return [2, result];
|
|
60
|
+
}
|
|
61
|
+
if (fieldType === "summary") {
|
|
62
|
+
fieldType = field.data_type;
|
|
63
|
+
}
|
|
64
|
+
if (!(0, exports.isSummaryFieldTypeSupported)(summary_type, fieldType)) {
|
|
65
|
+
throw new Error(`The summary data_type '${fieldType}' on the field '${field_name}' of the object '${object_name}' is not supported for the summary_type '${summary_type}' which only support these types: ${type_1.SupportedSummaryFieldTypes[summary_type]}.`);
|
|
66
|
+
}
|
|
67
|
+
result = fieldType;
|
|
90
68
|
}
|
|
91
|
-
|
|
92
|
-
}
|
|
69
|
+
else {
|
|
70
|
+
throw new Error(`The summary_field '${summary_field}' is not a field of the summary_object '${summary_object}'.`);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
result = type_1.SteedosSummaryDataTypeValue.Number;
|
|
75
|
+
}
|
|
76
|
+
return result;
|
|
77
|
+
};
|
|
93
78
|
exports.getSummaryDataType = getSummaryDataType;
|
|
94
|
-
|
|
79
|
+
const isSummaryFieldTypeSupported = (summaryType, summaryFieldType) => {
|
|
95
80
|
return !!(type_1.SupportedSummaryFieldTypes[summaryType] && type_1.SupportedSummaryFieldTypes[summaryType].indexOf(summaryFieldType) > -1);
|
|
96
81
|
};
|
|
97
82
|
exports.isSummaryFieldTypeSupported = isSummaryFieldTypeSupported;
|
package/lib/summary/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/summary/index.ts"],"names":[],"mappings":";;;;AAQA
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/summary/index.ts"],"names":[],"mappings":"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"}
|
package/lib/summary/recompute.js
CHANGED
|
@@ -1,54 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.recomputeFieldSummaryValues = exports.recomputeSummaryValues = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
return [4, (0, core_1.updateReferenceTosFieldSummaryValue)(docs, fieldSummaryConfig, userSession)];
|
|
20
|
-
case 2:
|
|
21
|
-
_a.sent();
|
|
22
|
-
return [2];
|
|
23
|
-
}
|
|
24
|
-
});
|
|
25
|
-
});
|
|
4
|
+
const index_1 = require("../index");
|
|
5
|
+
const field_summary_1 = require("./field_summary");
|
|
6
|
+
const core_1 = require("./core");
|
|
7
|
+
const runCurrentFieldSummary = async function (fieldSummaryConfig, userSession) {
|
|
8
|
+
const { object_name: objectName, reference_to_field_reference_to } = fieldSummaryConfig;
|
|
9
|
+
const fieldName = reference_to_field_reference_to || "_id";
|
|
10
|
+
const docs = await (0, index_1.getSteedosSchema)().getObject(objectName).find({ filters: [], fields: [fieldName] });
|
|
11
|
+
await (0, core_1.updateReferenceTosFieldSummaryValue)(docs, fieldSummaryConfig, userSession);
|
|
12
|
+
};
|
|
13
|
+
const recomputeSummaryValues = async (fieldId, userSession) => {
|
|
14
|
+
let config = await (0, field_summary_1.getFieldSummaryConfig)(fieldId);
|
|
15
|
+
if (!config) {
|
|
16
|
+
throw new Error(`recomputeSummaryValues:${fieldId} not found in field_summary configs.`);
|
|
17
|
+
}
|
|
18
|
+
return await (0, exports.recomputeFieldSummaryValues)(config, userSession);
|
|
26
19
|
};
|
|
27
|
-
var recomputeSummaryValues = function (fieldId, userSession) { return tslib_1.__awaiter(void 0, void 0, void 0, function () {
|
|
28
|
-
var config;
|
|
29
|
-
return tslib_1.__generator(this, function (_a) {
|
|
30
|
-
switch (_a.label) {
|
|
31
|
-
case 0: return [4, (0, field_summary_1.getFieldSummaryConfig)(fieldId)];
|
|
32
|
-
case 1:
|
|
33
|
-
config = _a.sent();
|
|
34
|
-
if (!config) {
|
|
35
|
-
throw new Error("recomputeSummaryValues:".concat(fieldId, " not found in field_summary configs."));
|
|
36
|
-
}
|
|
37
|
-
return [4, (0, exports.recomputeFieldSummaryValues)(config, userSession)];
|
|
38
|
-
case 2: return [2, _a.sent()];
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
}); };
|
|
42
20
|
exports.recomputeSummaryValues = recomputeSummaryValues;
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
case 1:
|
|
48
|
-
_a.sent();
|
|
49
|
-
return [2, true];
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
}); };
|
|
21
|
+
const recomputeFieldSummaryValues = async (fieldSummaryConfig, userSession) => {
|
|
22
|
+
await runCurrentFieldSummary(fieldSummaryConfig, userSession);
|
|
23
|
+
return true;
|
|
24
|
+
};
|
|
53
25
|
exports.recomputeFieldSummaryValues = recomputeFieldSummaryValues;
|
|
54
26
|
//# sourceMappingURL=recompute.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"recompute.js","sourceRoot":"","sources":["../../src/summary/recompute.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"recompute.js","sourceRoot":"","sources":["../../src/summary/recompute.ts"],"names":[],"mappings":";;;AAOA,oCAA4C;AAE5C,mDAAwD;AACxD,iCAA6D;AAE7D,MAAM,sBAAsB,GAAG,KAAK,WAAW,kBAAiD,EAAE,WAAgB;IAC9G,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,+BAA+B,EAAE,GAAG,kBAAkB,CAAC;IACxF,MAAM,SAAS,GAAG,+BAA+B,IAAI,KAAK,CAAC;IAC3D,MAAM,IAAI,GAAG,MAAM,IAAA,wBAAgB,GAAE,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;IACtG,MAAM,IAAA,0CAAmC,EAAC,IAAI,EAAE,kBAAkB,EAAE,WAAW,CAAC,CAAC;AACrF,CAAC,CAAA;AAMM,MAAM,sBAAsB,GAAG,KAAK,EAAE,OAAe,EAAE,WAAgB,EAAE,EAAE;IAC9E,IAAI,MAAM,GAAG,MAAM,IAAA,qCAAqB,EAAC,OAAO,CAAC,CAAC;IAClD,IAAI,CAAC,MAAM,EAAE,CAAC;QACV,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,sCAAsC,CAAC,CAAC;IAC7F,CAAC;IACD,OAAO,MAAM,IAAA,mCAA2B,EAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AAClE,CAAC,CAAA;AANY,QAAA,sBAAsB,0BAMlC;AAMM,MAAM,2BAA2B,GAAG,KAAK,EAAE,kBAAiD,EAAE,WAAgB,EAAE,EAAE;IACrH,MAAM,sBAAsB,CAAC,kBAAkB,EAAE,WAAW,CAAC,CAAC;IAC9D,OAAO,IAAI,CAAC;AAChB,CAAC,CAAA;AAHY,QAAA,2BAA2B,+BAGvC"}
|