@clxmedia/clxforms-client 1.1.10 → 1.1.12
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/dist/layout-processor.js +4 -4
- package/dist/rules-engine.js +50 -23
- package/dist/rules-processor.js +3 -1
- package/package.json +2 -2
package/dist/layout-processor.js
CHANGED
|
@@ -115,15 +115,15 @@ const CLXFormLayoutProcessor = ({ mode, responseData, formRights }) => {
|
|
|
115
115
|
.map(step => stepProcessor(step))
|
|
116
116
|
.filter(step => step.sections.length > 0)
|
|
117
117
|
.reduce((acc, step) => {
|
|
118
|
-
if (isGated && !
|
|
118
|
+
if (isGated && !isCLXInternalUser) {
|
|
119
119
|
return acc;
|
|
120
120
|
}
|
|
121
|
-
if (step.has_ai && !
|
|
121
|
+
if (step.has_ai && !isCLXInternalUser) {
|
|
122
122
|
blockedByAi = true;
|
|
123
123
|
return acc;
|
|
124
124
|
}
|
|
125
|
-
if (step.is_gate && !
|
|
126
|
-
isGated =
|
|
125
|
+
if (step.is_gate && !step.is_complete && !isGateSatisfied) {
|
|
126
|
+
isGated = true;
|
|
127
127
|
}
|
|
128
128
|
acc.push(step);
|
|
129
129
|
return acc;
|
package/dist/rules-engine.js
CHANGED
|
@@ -44,73 +44,100 @@ exports.CLXRulesEngine = {
|
|
|
44
44
|
}
|
|
45
45
|
},
|
|
46
46
|
evaluateRuleInstance: (ruleInstance) => {
|
|
47
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
47
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
48
|
+
if ((ruleInstance === null || ruleInstance === void 0 ? void 0 : ruleInstance.comparisonType) === 'isAnswered') {
|
|
49
|
+
const isAnswered = ((_a = ruleInstance.subject) === null || _a === void 0 ? void 0 : _a.value) !== undefined && ruleInstance.subject.value !== null;
|
|
50
|
+
return ruleInstance.negate ? !isAnswered : isAnswered;
|
|
51
|
+
}
|
|
48
52
|
if (!ruleInstance ||
|
|
49
53
|
ruleInstance.subject === undefined ||
|
|
50
54
|
ruleInstance.target === undefined ||
|
|
51
55
|
ruleInstance.comparisonType === undefined) {
|
|
52
56
|
return false;
|
|
53
57
|
}
|
|
58
|
+
const negate = (_b = ruleInstance.negate) !== null && _b !== void 0 ? _b : false;
|
|
59
|
+
let result = false;
|
|
54
60
|
switch (ruleInstance.comparisonType) {
|
|
55
61
|
case 'stringEquals':
|
|
56
|
-
|
|
62
|
+
result = ruleInstance.subject.value === ruleInstance.target.value;
|
|
63
|
+
break;
|
|
57
64
|
case 'stringContains':
|
|
58
|
-
|
|
65
|
+
result = (_d = (_c = ruleInstance.subject.value) === null || _c === void 0 ? void 0 : _c.includes(ruleInstance.target.value)) !== null && _d !== void 0 ? _d : false;
|
|
66
|
+
break;
|
|
59
67
|
case 'stringStartsWith':
|
|
60
|
-
|
|
68
|
+
result = (_f = (_e = ruleInstance.subject.value) === null || _e === void 0 ? void 0 : _e.startsWith(ruleInstance.target.value)) !== null && _f !== void 0 ? _f : false;
|
|
69
|
+
break;
|
|
61
70
|
case 'stringEndsWith':
|
|
62
|
-
|
|
71
|
+
result = (_h = (_g = ruleInstance.subject.value) === null || _g === void 0 ? void 0 : _g.endsWith(ruleInstance.target.value)) !== null && _h !== void 0 ? _h : false;
|
|
72
|
+
break;
|
|
63
73
|
case 'stringListContainsAny':
|
|
64
|
-
|
|
74
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
65
75
|
Array.isArray(ruleInstance.target.value) &&
|
|
66
76
|
ruleInstance.target.value.some((item) => ruleInstance.subject.value.includes(item)));
|
|
77
|
+
break;
|
|
67
78
|
case 'stringListContainsAll':
|
|
68
|
-
|
|
79
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
69
80
|
Array.isArray(ruleInstance.target.value) &&
|
|
70
81
|
ruleInstance.target.value.every((item) => ruleInstance.subject.value.includes(item)));
|
|
82
|
+
break;
|
|
71
83
|
case 'stringListContainsNone':
|
|
72
|
-
|
|
84
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
73
85
|
Array.isArray(ruleInstance.target.value) &&
|
|
74
86
|
ruleInstance.target.value.every((item) => !ruleInstance.subject.value.includes(item)));
|
|
87
|
+
break;
|
|
75
88
|
case 'dateEquals':
|
|
76
89
|
case 'dateBefore':
|
|
77
90
|
case 'dateAfter':
|
|
78
|
-
|
|
91
|
+
result = exports.CLXRulesEngine.compareDates(ruleInstance.comparisonType, ruleInstance.subject, ruleInstance.target);
|
|
92
|
+
break;
|
|
79
93
|
case 'stringInList':
|
|
80
|
-
|
|
94
|
+
result = (Array.isArray(ruleInstance.target.value) && ((_j = ruleInstance.target.value) === null || _j === void 0 ? void 0 : _j.includes(ruleInstance.subject.value)));
|
|
95
|
+
break;
|
|
81
96
|
case 'stringNotInList':
|
|
82
|
-
|
|
97
|
+
result = (Array.isArray(ruleInstance.target.value) && !((_k = ruleInstance.target.value) === null || _k === void 0 ? void 0 : _k.includes(ruleInstance.subject.value)));
|
|
98
|
+
break;
|
|
83
99
|
case 'stringListEntryContains':
|
|
84
|
-
|
|
85
|
-
((
|
|
100
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
101
|
+
((_l = ruleInstance.subject.value) === null || _l === void 0 ? void 0 : _l.some((item) => item.includes(ruleInstance.target.value))));
|
|
102
|
+
break;
|
|
86
103
|
case 'stringListEntryStartsWith':
|
|
87
|
-
|
|
88
|
-
((
|
|
104
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
105
|
+
((_m = ruleInstance.subject.value) === null || _m === void 0 ? void 0 : _m.some((item) => item.startsWith(ruleInstance.target.value))));
|
|
106
|
+
break;
|
|
89
107
|
case 'stringListEntryEndsWith':
|
|
90
|
-
|
|
108
|
+
result = (Array.isArray(ruleInstance.subject.value) &&
|
|
91
109
|
ruleInstance.subject.value.some((item) => item.endsWith(ruleInstance.target.value)));
|
|
110
|
+
break;
|
|
92
111
|
case 'stringListEntryEquals':
|
|
93
|
-
|
|
112
|
+
result = (Array.isArray(ruleInstance.subject.value) && ruleInstance.subject.value.includes(ruleInstance.target.value));
|
|
113
|
+
break;
|
|
94
114
|
case 'stringExists':
|
|
95
115
|
if (!ruleInstance.target.value) {
|
|
96
|
-
|
|
116
|
+
result = ruleInstance.subject.value === undefined || ruleInstance.subject.value.length === 0;
|
|
117
|
+
break;
|
|
97
118
|
}
|
|
98
|
-
|
|
119
|
+
result = ruleInstance.subject.value !== undefined && ruleInstance.subject.value.length > 0;
|
|
120
|
+
break;
|
|
99
121
|
case 'fileExists':
|
|
100
122
|
if (ruleInstance.target.value === true) {
|
|
101
|
-
|
|
123
|
+
result = ruleInstance.subject.value !== undefined && Object.keys(ruleInstance.subject.value).length > 0;
|
|
124
|
+
break;
|
|
102
125
|
}
|
|
103
126
|
else {
|
|
104
|
-
|
|
127
|
+
result = ruleInstance.subject.value === undefined || Object.keys(ruleInstance.subject.value).length === 0;
|
|
128
|
+
break;
|
|
105
129
|
}
|
|
106
130
|
case 'booleanEquals':
|
|
107
|
-
|
|
131
|
+
result = ruleInstance.subject.value === ruleInstance.target.value;
|
|
132
|
+
break;
|
|
108
133
|
case 'numberEquals':
|
|
109
134
|
case 'numberGreaterThan':
|
|
110
135
|
case 'numberLessThan':
|
|
111
|
-
|
|
136
|
+
result = exports.CLXRulesEngine.compareNumbers(ruleInstance.comparisonType, ruleInstance.subject.value, ruleInstance.target.value);
|
|
137
|
+
break;
|
|
112
138
|
default:
|
|
113
139
|
return false;
|
|
114
140
|
}
|
|
141
|
+
return negate ? !result : result;
|
|
115
142
|
}
|
|
116
143
|
};
|
package/dist/rules-processor.js
CHANGED
|
@@ -5,12 +5,14 @@ const rules_engine_1 = require("./rules-engine");
|
|
|
5
5
|
const CLXRulesetProcessor = ({ responseData }) => {
|
|
6
6
|
const processRuleSet = (ruleSet) => {
|
|
7
7
|
const evaluateRuleBase = (ruleBase) => {
|
|
8
|
+
var _a;
|
|
8
9
|
if (ruleBase.comparison) {
|
|
9
10
|
const ruleDefinition = ruleBase;
|
|
10
11
|
const ruleInstance = {
|
|
11
12
|
subject: responseData[ruleDefinition.subject] || { value: undefined },
|
|
12
13
|
target: ruleDefinition.target,
|
|
13
|
-
comparisonType: ruleDefinition.comparison
|
|
14
|
+
comparisonType: ruleDefinition.comparison,
|
|
15
|
+
negate: (_a = ruleDefinition.negate) !== null && _a !== void 0 ? _a : false
|
|
14
16
|
};
|
|
15
17
|
return rules_engine_1.CLXRulesEngine.evaluateRuleInstance(ruleInstance);
|
|
16
18
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@clxmedia/clxforms-client",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.12",
|
|
4
4
|
"description": "CLXperience Forms Client",
|
|
5
5
|
"author": "Brandon Thompson <brandont@clxmedia.com>",
|
|
6
6
|
"license": "MIT",
|
|
@@ -44,7 +44,7 @@
|
|
|
44
44
|
"bugs": "https://github.com/adsupnow/xperience-library/clxforms-client",
|
|
45
45
|
"peerDependencies": {},
|
|
46
46
|
"dependencies": {
|
|
47
|
-
"@clxmedia/types": "1.
|
|
47
|
+
"@clxmedia/types": "1.13.0",
|
|
48
48
|
"luxon": "3.4.4"
|
|
49
49
|
},
|
|
50
50
|
"devDependencies": {
|