@inseefr/lunatic 0.3.0-experimental → 0.3.0-prisme

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.
Files changed (225) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +25 -23
  3. package/lib/index.esm.js +3539 -0
  4. package/lib/index.esm.js.map +1 -0
  5. package/lib/index.js +240 -282
  6. package/lib/index.js.map +1 -1
  7. package/package.json +179 -173
  8. package/src/components/breadcrumb/breadcrumb.scss +22 -22
  9. package/src/components/checkbox/boolean.js +172 -172
  10. package/src/components/checkbox/checkbox.scss +73 -73
  11. package/src/components/checkbox/group.js +231 -231
  12. package/src/components/checkbox/one.js +11 -11
  13. package/src/components/component-wrapper/controls/component.js +70 -70
  14. package/src/components/component-wrapper/controls/controls.scss +6 -6
  15. package/src/components/component-wrapper/controls/index.js +1 -1
  16. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -33
  17. package/src/components/component-wrapper/controls/validators/index.js +16 -16
  18. package/src/components/component-wrapper/controls/validators/input-number.js +23 -23
  19. package/src/components/component-wrapper/index.js +1 -1
  20. package/src/components/component-wrapper/missing/component.js +200 -180
  21. package/src/components/component-wrapper/missing/index.js +1 -1
  22. package/src/components/component-wrapper/missing/missing.scss +32 -32
  23. package/src/components/component-wrapper/wrapper.js +23 -23
  24. package/src/components/components.js +19 -19
  25. package/src/components/datepicker/component.js +26 -30
  26. package/src/components/declarations/component.js +46 -46
  27. package/src/components/declarations/declarations.scss +40 -40
  28. package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -302
  29. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
  30. package/src/components/dropdown/commons/actions.js +65 -65
  31. package/src/components/dropdown/commons/children-to-option.js +9 -9
  32. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
  33. package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
  34. package/src/components/dropdown/commons/components/dropdown.js +204 -183
  35. package/src/components/dropdown/commons/components/panel.js +78 -78
  36. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
  37. package/src/components/dropdown/commons/reducer.js +152 -152
  38. package/src/components/dropdown/commons/tools/index.js +17 -17
  39. package/src/components/dropdown/component.js +135 -135
  40. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -191
  41. package/src/components/dropdown/dropdown-edit/index.js +11 -11
  42. package/src/components/dropdown/dropdown-simple/dropdown.js +173 -171
  43. package/src/components/dropdown/dropdown-simple/index.js +20 -20
  44. package/src/components/dropdown/dropdown.scss +178 -178
  45. package/src/components/icon/icon.scss +15 -15
  46. package/src/components/index.js +2 -0
  47. package/src/components/index.scss +177 -177
  48. package/src/components/input/input-number.js +30 -28
  49. package/src/components/input/input.js +11 -11
  50. package/src/components/input/input.scss +31 -31
  51. package/src/components/loop/component.js +170 -170
  52. package/src/components/loop/loop.scss +13 -13
  53. package/src/components/loop/wrapper.js +15 -15
  54. package/src/components/loop-constructor/block/block.scss +10 -10
  55. package/src/components/loop-constructor/block/component.js +9 -9
  56. package/src/components/loop-constructor/roster/component.js +8 -8
  57. package/src/components/loop-constructor/wrapper/body-component.js +146 -131
  58. package/src/components/loop-constructor/wrapper/component.js +190 -190
  59. package/src/components/modal/component.js +36 -36
  60. package/src/components/modal/index.js +1 -1
  61. package/src/components/modal/modal.scss +33 -33
  62. package/src/components/progress-bar/progress-bar.scss +54 -54
  63. package/src/components/radio/component.js +9 -9
  64. package/src/components/radio/radio.scss +59 -59
  65. package/src/components/sequence/component.js +50 -50
  66. package/src/components/sequence/sequence.scss +10 -10
  67. package/src/components/subsequence/component.js +49 -49
  68. package/src/components/suggester/check-store.js +2 -4
  69. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  70. package/src/components/suggester/components/panel/option-container.js +61 -61
  71. package/src/components/suggester/components/panel/panel.js +47 -47
  72. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  73. package/src/components/suggester/components/selection/label.js +35 -35
  74. package/src/components/suggester/components/selection/selection.js +50 -50
  75. package/src/components/suggester/components/suggester-content.js +2 -2
  76. package/src/components/suggester/components/suggester.js +128 -88
  77. package/src/components/suggester/components/suggester.scss +101 -101
  78. package/src/components/suggester/default-style.scss +125 -125
  79. package/src/components/suggester/find-best-label/find-best-label.js +51 -51
  80. package/src/components/suggester/find-best-label/index.js +1 -1
  81. package/src/components/suggester/idb-suggester.js +73 -67
  82. package/src/components/suggester/lunatic-suggester.js +140 -139
  83. package/src/components/suggester/searching/create-searching.js +49 -49
  84. package/src/components/suggester/searching/index.js +1 -1
  85. package/src/components/suggester/state-management/actions.js +38 -38
  86. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  87. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  88. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  89. package/src/components/suggester/suggester-wrapper.js +127 -121
  90. package/src/components/suggester-loader-widget/loader.js +67 -67
  91. package/src/components/suggester-loader-widget/widget.js +123 -123
  92. package/src/components/table/table.js +173 -171
  93. package/src/components/table/table.scss +26 -26
  94. package/src/components/textarea/component.js +11 -11
  95. package/src/components/textarea/textarea.scss +8 -8
  96. package/src/components/tooltip/tooltip.scss +30 -30
  97. package/src/stories/breadcrumb/breadcrumb.stories.js +21 -21
  98. package/src/stories/checkbox-boolean/data.json +78 -78
  99. package/src/stories/datepicker/data.json +45 -45
  100. package/src/stories/declarations/declarations.stories.js +116 -116
  101. package/src/stories/dropdown/README.md +44 -44
  102. package/src/stories/dropdown/data.json +98 -98
  103. package/src/stories/dropdown/dropdown.stories.js +89 -89
  104. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  105. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  106. package/src/stories/questionnaire/arithmetic.json +247 -247
  107. package/src/stories/questionnaire/calc-var.json +187 -187
  108. package/src/stories/questionnaire/data-logement.json +2691 -2691
  109. package/src/stories/questionnaire/kish.json +275 -0
  110. package/src/stories/questionnaire/logement-queen.json +23390 -22706
  111. package/src/stories/questionnaire/logement-s2.json +46028 -44537
  112. package/src/stories/questionnaire/logement-sequence.json +26741 -26741
  113. package/src/stories/questionnaire/logement.json +21072 -21072
  114. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  115. package/src/stories/questionnaire/questionnaire.stories.js +236 -172
  116. package/src/stories/questionnaire/update-external/data.json +1 -0
  117. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  118. package/src/stories/sequence/sequence.stories.js +32 -32
  119. package/src/stories/subsequence/subsequence.stories.js +32 -32
  120. package/src/stories/suggester/README.md +46 -46
  121. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  122. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  123. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  124. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  125. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  126. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  127. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  128. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  129. package/src/stories/suggester/data-auto.json +232 -232
  130. package/src/stories/suggester/data-vtl.json +82 -82
  131. package/src/stories/suggester/data.json +169 -136
  132. package/src/stories/suggester/naf-rev2/index.js +2 -2
  133. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  134. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  135. package/src/stories/suggester/suggester.stories.js +138 -133
  136. package/src/stories/utils/orchestrator-split.js +119 -0
  137. package/src/stories/utils/orchestrator.js +119 -110
  138. package/src/tests/components/input-number.spec.js +188 -188
  139. package/src/tests/components/loops/roster-loop.json +71 -71
  140. package/src/tests/components/missing-wrapper.spec.js +32 -32
  141. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  142. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  143. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
  144. package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
  145. package/src/utils/components/dragger/dragger.scss +7 -7
  146. package/src/utils/idb-tools/create-db-opener.js +43 -43
  147. package/src/utils/idb-tools/create-open-db.js +25 -25
  148. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  149. package/src/utils/idb-tools/index.js +10 -10
  150. package/src/utils/idb-tools/insert-entity.js +15 -15
  151. package/src/utils/idb-tools/open-db.js +13 -13
  152. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  153. package/src/utils/lib/controls/index.js +1 -1
  154. package/src/utils/lib/controls/utils.js +152 -146
  155. package/src/utils/lib/decorator/title-decorator.js +16 -16
  156. package/src/utils/lib/env.js +2 -2
  157. package/src/utils/lib/index.js +21 -20
  158. package/src/utils/lib/input-number.js +1 -1
  159. package/src/utils/lib/options-positioning.js +9 -9
  160. package/src/utils/lib/pagination/navigation/shared.js +256 -256
  161. package/src/utils/lib/prop-types/lines.js +6 -6
  162. package/src/utils/lib/responses.js +11 -11
  163. package/src/utils/lib/splitting.js +142 -0
  164. package/src/utils/lib/style.js +10 -10
  165. package/src/utils/store-tools/auto-load.js +74 -74
  166. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  167. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  168. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -45
  169. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  170. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  171. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  172. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -54
  173. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -52
  174. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -10
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -17
  177. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -14
  178. package/src/utils/suggester-workers/commons-tokenizer/filters/{filter-accents-to-lower.js → filter-accents.js} +12 -12
  179. package/src/utils/suggester-workers/commons-tokenizer/filters/{filter-accents-to-lower.spec.js → filter-accents.spec.js} +12 -12
  180. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.js +12 -12
  181. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -20
  182. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.js +7 -7
  183. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -18
  184. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.js +13 -13
  185. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -12
  186. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -10
  187. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -12
  188. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  189. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  190. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -2
  191. package/src/utils/suggester-workers/commons-tokenizer/filters/stop-words.js +118 -118
  192. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  193. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  194. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  195. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -13
  196. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  197. package/src/utils/suggester-workers/create-worker.js +56 -56
  198. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  199. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  200. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -30
  201. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  202. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  203. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  204. package/src/utils/suggester-workers/searching/index.js +1 -1
  205. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  206. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  207. package/src/utils/suggester-workers/searching/query-parser/index.js +2 -2
  208. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -7
  209. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.spec.js +24 -24
  210. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -28
  211. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  212. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  213. package/src/utils/suggester-workers/searching/searching.js +70 -70
  214. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  215. package/src/utils/to-expose/calculated-variables.js +113 -113
  216. package/src/utils/to-expose/handler.js +149 -112
  217. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  218. package/src/utils/to-expose/hooks/index.js +2 -1
  219. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  220. package/src/utils/to-expose/hooks/lunatic.js +284 -235
  221. package/src/utils/to-expose/index.js +1 -1
  222. package/src/utils/to-expose/init-questionnaire.js +164 -164
  223. package/src/utils/to-expose/interpret/vtl.js +18 -18
  224. package/src/utils/to-expose/state.js +66 -58
  225. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
@@ -1,11 +1,11 @@
1
- /* eslint-disable no-restricted-globals */
2
- import 'core-js/stable';
3
- import 'regenerator-runtime/runtime';
4
- import searching from './searching';
5
-
6
- self.onmessage = function (e) {
7
- const { search, name, version } = e.data;
8
- searching(search, { name, version }).then(function (result) {
9
- self.postMessage(result);
10
- });
11
- };
1
+ /* eslint-disable no-restricted-globals */
2
+ import 'core-js/stable';
3
+ import 'regenerator-runtime/runtime';
4
+ import searching from './searching';
5
+
6
+ self.onmessage = function (e) {
7
+ const { search, name, version } = e.data;
8
+ searching(search, { name, version }).then(function (result) {
9
+ self.postMessage(result);
10
+ });
11
+ };
@@ -1,113 +1,113 @@
1
- import { interpret } from './interpret';
2
- import {
3
- buildVectorialBindings,
4
- buildBindingsForDeeperComponents,
5
- } from '../lib/loops/bindings';
6
- import { isFunction } from '../lib';
7
- import {
8
- CALCULATED_VAR_CATEGORY,
9
- EVENT_VALUE_CHANGE,
10
- } from '../../constants/event-types';
11
-
12
- export const getCalculatedVariables =
13
- (variables) =>
14
- ({ bindings, updatedVars, logFunction, init = false }) => {
15
- let wip = {};
16
- return Object.entries(variables).reduce((acc, [name, v]) => {
17
- const value = getCalculatedVariable(v, name)(variables)({
18
- bindings,
19
- wip,
20
- updatedVars,
21
- logFunction,
22
- init,
23
- });
24
- return {
25
- ...acc,
26
- [name]: value,
27
- };
28
- }, {});
29
- };
30
-
31
- const getCalculatedVariable =
32
- (v, name) =>
33
- (variables) =>
34
- ({ bindings, wip, updatedVars, logFunction, init }) => {
35
- const { bindingDependencies } = v;
36
- if (!init && !Array.isArray(bindingDependencies)) return v;
37
- if (
38
- Array.isArray(updatedVars) &&
39
- updatedVars.length > 0 &&
40
- Array.isArray(bindingDependencies) &&
41
- !updatedVars.some((ai) => bindingDependencies.includes(ai))
42
- )
43
- return v;
44
- const exactBindings = (bindingDependencies || []).reduce((acc, b) => {
45
- if (bindings[b] !== undefined) return { ...acc, [b]: bindings[b] };
46
- if (wip[b] !== undefined) return { ...acc, [b]: wip[b] };
47
- const varToCalc = variables[b];
48
- if (!varToCalc) return acc;
49
- const newValue = getCalculatedVariable(varToCalc)(variables)({
50
- bindings,
51
- wip,
52
- updatedVars,
53
- init,
54
- });
55
- wip[b] = newValue.value;
56
- return { ...acc, [b]: newValue.value };
57
- }, {});
58
- const { expression, shapeFrom } = v;
59
- const value =
60
- wip[name] !== undefined
61
- ? wip[name]
62
- : getValue(bindings, exactBindings, expression, shapeFrom);
63
- const handleTempMomentValue =
64
- value && value._isAMomentObject ? value.format('DD-MM-YYYY') : value;
65
-
66
- if (
67
- isFunction(logFunction) &&
68
- // Filter only filterResult vars : name.startsWith('FILTER_RESULT_') &&
69
- JSON.stringify(value) !== JSON.stringify(variables[name].value)
70
- ) {
71
- logFunction({
72
- idParadataObject: `${name}`,
73
- typeParadataObject: CALCULATED_VAR_CATEGORY,
74
- type: EVENT_VALUE_CHANGE,
75
- oldValue: value,
76
- newValue: variables[name]?.value,
77
- });
78
- }
79
-
80
- if (shapeFrom)
81
- return {
82
- expression,
83
- bindingDependencies,
84
- value: handleTempMomentValue,
85
- shapeFrom,
86
- };
87
- return {
88
- expression,
89
- bindingDependencies,
90
- value: handleTempMomentValue,
91
- };
92
- };
93
-
94
- const getValue = (bindings, exactBindings, expression, shapeFrom) => {
95
- if (!shapeFrom) {
96
- const vectorialBindings = buildVectorialBindings(exactBindings);
97
- const res = interpret(['VTL'])(vectorialBindings)(expression);
98
- return Array.isArray(res) ? res[0] : res;
99
- }
100
- const shape = bindings[shapeFrom];
101
- return buildShape(exactBindings, expression)(shape);
102
- };
103
-
104
- const buildShape = (exactBindings, expression) => (array) =>
105
- array.map((a, i) => {
106
- const loopBindings = buildBindingsForDeeperComponents(i)(exactBindings);
107
- if (Array.isArray(a)) {
108
- return buildShape(loopBindings, expression)(a);
109
- }
110
- const vectorialBindings = buildVectorialBindings(loopBindings);
111
- const res = interpret(['VTL'])(vectorialBindings)(expression);
112
- return Array.isArray(res) ? res[0] : res;
113
- });
1
+ import { interpret } from './interpret';
2
+ import {
3
+ buildVectorialBindings,
4
+ buildBindingsForDeeperComponents,
5
+ } from '../lib/loops/bindings';
6
+ import { isFunction } from '../lib';
7
+ import {
8
+ CALCULATED_VAR_CATEGORY,
9
+ EVENT_VALUE_CHANGE,
10
+ } from '../../constants/event-types';
11
+
12
+ export const getCalculatedVariables =
13
+ (variables) =>
14
+ ({ bindings, updatedVars, logFunction, init = false }) => {
15
+ let wip = {};
16
+ return Object.entries(variables).reduce((acc, [name, v]) => {
17
+ const value = getCalculatedVariable(v, name)(variables)({
18
+ bindings,
19
+ wip,
20
+ updatedVars,
21
+ logFunction,
22
+ init,
23
+ });
24
+ return {
25
+ ...acc,
26
+ [name]: value,
27
+ };
28
+ }, {});
29
+ };
30
+
31
+ const getCalculatedVariable =
32
+ (v, name) =>
33
+ (variables) =>
34
+ ({ bindings, wip, updatedVars, logFunction, init }) => {
35
+ const { bindingDependencies } = v;
36
+ if (!init && !Array.isArray(bindingDependencies)) return v;
37
+ if (
38
+ Array.isArray(updatedVars) &&
39
+ updatedVars.length > 0 &&
40
+ Array.isArray(bindingDependencies) &&
41
+ !updatedVars.some((ai) => bindingDependencies.includes(ai))
42
+ )
43
+ return v;
44
+ const exactBindings = (bindingDependencies || []).reduce((acc, b) => {
45
+ if (bindings[b] !== undefined) return { ...acc, [b]: bindings[b] };
46
+ if (wip[b] !== undefined) return { ...acc, [b]: wip[b] };
47
+ const varToCalc = variables[b];
48
+ if (!varToCalc) return acc;
49
+ const newValue = getCalculatedVariable(varToCalc)(variables)({
50
+ bindings,
51
+ wip,
52
+ updatedVars,
53
+ init,
54
+ });
55
+ wip[b] = newValue.value;
56
+ return { ...acc, [b]: newValue.value };
57
+ }, {});
58
+ const { expression, shapeFrom } = v;
59
+ const value =
60
+ wip[name] !== undefined
61
+ ? wip[name]
62
+ : getValue(bindings, exactBindings, expression, shapeFrom);
63
+ const handleTempMomentValue =
64
+ value && value._isAMomentObject ? value.format('DD-MM-YYYY') : value;
65
+
66
+ if (
67
+ isFunction(logFunction) &&
68
+ // Filter only filterResult vars : name.startsWith('FILTER_RESULT_') &&
69
+ JSON.stringify(value) !== JSON.stringify(variables[name].value)
70
+ ) {
71
+ logFunction({
72
+ idParadataObject: `${name}`,
73
+ typeParadataObject: CALCULATED_VAR_CATEGORY,
74
+ type: EVENT_VALUE_CHANGE,
75
+ oldValue: value,
76
+ newValue: variables[name]?.value,
77
+ });
78
+ }
79
+
80
+ if (shapeFrom)
81
+ return {
82
+ expression,
83
+ bindingDependencies,
84
+ value: handleTempMomentValue,
85
+ shapeFrom,
86
+ };
87
+ return {
88
+ expression,
89
+ bindingDependencies,
90
+ value: handleTempMomentValue,
91
+ };
92
+ };
93
+
94
+ const getValue = (bindings, exactBindings, expression, shapeFrom) => {
95
+ if (!shapeFrom) {
96
+ const vectorialBindings = buildVectorialBindings(exactBindings);
97
+ const res = interpret(['VTL'])(vectorialBindings)(expression);
98
+ return Array.isArray(res) ? res[0] : res;
99
+ }
100
+ const shape = bindings[shapeFrom];
101
+ return buildShape(exactBindings, expression)(shape);
102
+ };
103
+
104
+ const buildShape = (exactBindings, expression) => (array) =>
105
+ array.map((a, i) => {
106
+ const loopBindings = buildBindingsForDeeperComponents(i)(exactBindings);
107
+ if (Array.isArray(a)) {
108
+ return buildShape(loopBindings, expression)(a);
109
+ }
110
+ const vectorialBindings = buildVectorialBindings(loopBindings);
111
+ const res = interpret(['VTL'])(vectorialBindings)(expression);
112
+ return Array.isArray(res) ? res[0] : res;
113
+ });
@@ -1,112 +1,149 @@
1
- import * as C from '../../constants';
2
- import { buildFilledComponent } from './init-questionnaire';
3
- import { supportedPreferences } from '../../constants/supported-preferences';
4
- import { getCalculatedVariables } from './calculated-variables';
5
- import { isDev } from '../lib';
6
-
7
- export const updateQuestionnaire =
8
- (valueType) =>
9
- (questionnaire) =>
10
- (preferences, logFunction) =>
11
- (updatedValues) => {
12
- if (
13
- !supportedPreferences.includes(valueType) ||
14
- preferences.length === 0 ||
15
- !updatedValues
16
- )
17
- return questionnaire;
18
- const { variables, components, ...other } = questionnaire;
19
- if (!components || components.length === 0) return questionnaire;
20
- const varsAndRefs = Object.entries(updatedValues).reduce(
21
- (acc, [key, value]) => {
22
- const {
23
- newVariables: { COLLECTED, ...otherVars },
24
- refs,
25
- } = acc;
26
- const { componentRef, values } = COLLECTED[key];
27
- const updated = {
28
- componentRef,
29
- values: {
30
- ...values,
31
- [valueType]: buildNewValue(preferences)(valueType)(values)(value),
32
- },
33
- };
34
- const newCollected = { ...COLLECTED, [key]: updated };
35
- return {
36
- newVariables: {
37
- ...otherVars,
38
- COLLECTED: newCollected,
39
- },
40
- refs: [...refs, componentRef],
41
- };
42
- },
43
- { newVariables: variables, refs: [] }
44
- );
45
- const { newVariables, refs: r } = varsAndRefs;
46
- const newVariablesWithCalculated =
47
- valueType === C.COLLECTED
48
- ? addCalculatedVars(newVariables, updatedValues)(logFunction)
49
- : newVariables;
50
- const collectedVars = newVariables[C.COLLECTED];
51
- const newComponents = components.map((c) => {
52
- if (r.includes(c.id)) return buildFilledComponent(collectedVars)(c);
53
- return c;
54
- });
55
- return {
56
- ...other,
57
- variables: newVariablesWithCalculated,
58
- components: newComponents,
59
- };
60
- };
61
-
62
- export const buildNewValue =
63
- (preferences) => (valueType) => (oldValues) => (value) => {
64
- if (preferences.length === 1) return value;
65
- const index = preferences.indexOf(valueType);
66
- if (index < 1) return value;
67
- const valuesByPreference = preferences
68
- .slice(0, index)
69
- .map((p) => oldValues[p])
70
- .filter((v) => v !== null);
71
- const lastValue = valuesByPreference[valuesByPreference.length - 1];
72
- return lastValue === value ? null : value;
73
- };
74
-
75
- const getCollectedAndExternal = (variables) => {
76
- const { COLLECTED } = variables;
77
- const collected = Object.entries(COLLECTED).reduce(
78
- (acc, [k, { values }]) => ({ ...acc, [k]: values.COLLECTED }),
79
- {}
80
- );
81
- return { ...collected, ...variables.EXTERNAL };
82
- };
83
-
84
- const addCalculatedVars = (variables, updatedValues) => (logFunction) => {
85
- if (
86
- !variables[C.CALCULATED] ||
87
- Object.keys(variables[C.CALCULATED]).length === 0
88
- )
89
- return variables;
90
-
91
- if (isDev) {
92
- console.log('Start var calculation');
93
- var start = new Date().getTime();
94
- }
95
-
96
- const { COLLECTED, EXTERNAL, CALCULATED: calculatedVariables } = variables;
97
-
98
- const updatedVars = Object.keys(updatedValues);
99
-
100
- const bindings = getCollectedAndExternal(variables);
101
-
102
- const CALCULATED = getCalculatedVariables(calculatedVariables)({
103
- bindings,
104
- updatedVars,
105
- logFunction,
106
- });
107
-
108
- if (isDev)
109
- console.log(`End var calculation: ${new Date().getTime() - start} ms`);
110
-
111
- return { EXTERNAL, COLLECTED, CALCULATED };
112
- };
1
+ import * as C from '../../constants';
2
+ import { buildFilledComponent } from './init-questionnaire';
3
+ import { supportedPreferences } from '../../constants/supported-preferences';
4
+ import { getCalculatedVariables } from './calculated-variables';
5
+ import { isDev } from '../lib';
6
+
7
+ export const updateQuestionnaire =
8
+ (valueType) =>
9
+ (questionnaire) =>
10
+ (preferences, logFunction) =>
11
+ (updatedValues) => {
12
+ if (
13
+ !supportedPreferences.includes(valueType) ||
14
+ preferences.length === 0 ||
15
+ !updatedValues
16
+ )
17
+ return questionnaire;
18
+ const { variables, components, ...other } = questionnaire;
19
+ if (!components || components.length === 0) return questionnaire;
20
+ const varsAndRefs = Object.entries(updatedValues).reduce(
21
+ (acc, [key, value]) => {
22
+ const {
23
+ newVariables: { COLLECTED, ...otherVars },
24
+ refs,
25
+ } = acc;
26
+ const { componentRef, values } = COLLECTED[key];
27
+ const updated = {
28
+ componentRef,
29
+ values: {
30
+ ...values,
31
+ [valueType]: buildNewValue(preferences)(valueType)(values)(value),
32
+ },
33
+ };
34
+ const newCollected = { ...COLLECTED, [key]: updated };
35
+ return {
36
+ newVariables: {
37
+ ...otherVars,
38
+ COLLECTED: newCollected,
39
+ },
40
+ refs: [...refs, componentRef],
41
+ };
42
+ },
43
+ { newVariables: variables, refs: [] }
44
+ );
45
+ const { newVariables, refs: r } = varsAndRefs;
46
+ const newVariablesWithCalculated = addCalculatedVars(
47
+ newVariables,
48
+ updatedValues
49
+ )(logFunction, preferences);
50
+ const collectedVars = newVariables[C.COLLECTED];
51
+ const newComponents = components.map((c) => {
52
+ if (r.includes(c.id)) return buildFilledComponent(collectedVars)(c);
53
+ return c;
54
+ });
55
+ return {
56
+ ...other,
57
+ variables: newVariablesWithCalculated,
58
+ components: newComponents,
59
+ };
60
+ };
61
+
62
+ export const updateExternals =
63
+ (questionnaire) => (logFunction, preferences) => (updatedValues) => {
64
+ const { variables, ...other } = questionnaire;
65
+ const { EXTERNAL } = variables;
66
+ const newVariables = {
67
+ ...variables,
68
+ EXTERNAL: { ...EXTERNAL, ...updatedValues },
69
+ };
70
+
71
+ const newVariablesWithCalculated = addCalculatedVars(
72
+ newVariables,
73
+ updatedValues
74
+ )(logFunction, preferences);
75
+ return {
76
+ ...other,
77
+ variables: newVariablesWithCalculated,
78
+ };
79
+ };
80
+
81
+ export const buildNewValue =
82
+ (preferences) => (valueType) => (oldValues) => (value) => {
83
+ if (preferences.length === 1) return value;
84
+ const index = preferences.indexOf(valueType);
85
+ if (index < 1) return value;
86
+ const valuesByPreference = preferences
87
+ .slice(0, index)
88
+ .map((p) => oldValues[p])
89
+ .filter((v) => v !== null);
90
+ const lastValue = valuesByPreference[valuesByPreference.length - 1];
91
+ return lastValue === value ? null : value;
92
+ };
93
+
94
+ // Separate methods to avoid perf issue on collect simplest use case
95
+ const getCollectedAndExternal = (preferences) => (variables) => {
96
+ const { COLLECTED, EXTERNAL } = variables;
97
+ if (preferences.length === 1 && preferences[0] === 'COLLECTED')
98
+ return { ...getCollectedAndExternalSimple(COLLECTED), ...EXTERNAL };
99
+ return {
100
+ ...getCollectedAndExternalByPreferences(preferences)(COLLECTED),
101
+ ...EXTERNAL,
102
+ };
103
+ };
104
+
105
+ const getCollectedAndExternalSimple = (variables) =>
106
+ Object.entries(variables).reduce(
107
+ (acc, [k, { values }]) => ({ ...acc, [k]: values.COLLECTED }),
108
+ {}
109
+ );
110
+
111
+ const getCollectedAndExternalByPreferences = (preferences) => (variables) =>
112
+ Object.entries(variables).reduce((acc, [k, { values }]) => {
113
+ const v = preferences.reduce((acc, p) => {
114
+ const value = values[p];
115
+ return [null, ''].includes(value) ? acc : value;
116
+ }, null);
117
+ return { ...acc, [k]: v };
118
+ }, {});
119
+
120
+ const addCalculatedVars =
121
+ (variables, updatedValues) => (logFunction, preferences) => {
122
+ if (
123
+ !variables[C.CALCULATED] ||
124
+ Object.keys(variables[C.CALCULATED]).length === 0
125
+ )
126
+ return variables;
127
+
128
+ if (isDev) {
129
+ console.log('Start var calculation');
130
+ var start = new Date().getTime();
131
+ }
132
+
133
+ const { COLLECTED, EXTERNAL, CALCULATED: calculatedVariables } = variables;
134
+
135
+ const updatedVars = Object.keys(updatedValues);
136
+
137
+ const bindings = getCollectedAndExternal(preferences)(variables);
138
+
139
+ const CALCULATED = getCalculatedVariables(calculatedVariables)({
140
+ bindings,
141
+ updatedVars,
142
+ logFunction,
143
+ });
144
+
145
+ if (isDev)
146
+ console.log(`End var calculation: ${new Date().getTime() - start} ms`);
147
+
148
+ return { EXTERNAL, COLLECTED, CALCULATED };
149
+ };
@@ -1,13 +1,18 @@
1
1
  import { interpret } from '../interpret';
2
2
  import { isDev, buildVectorialBindings } from '../../lib';
3
3
 
4
- let cache = {};
5
-
6
4
  const customFilterPagination = ({ page }, pagination, currentPage) => {
7
- return pagination ? currentPage.split('.')[0] === page : true;
5
+ return pagination ? currentPage?.split('.')[0] === page : true;
8
6
  };
9
7
 
10
- const filterComponents = ({ components, updatedVars, features, bindings }) => {
8
+ const filterComponents = ({
9
+ components,
10
+ updatedVars,
11
+ features,
12
+ bindings,
13
+ cache,
14
+ setCache,
15
+ }) => {
11
16
  const localCache = {};
12
17
  const filtered = components.filter(({ conditionFilter }) => {
13
18
  if (!conditionFilter || !conditionFilter.value) return true;
@@ -24,7 +29,11 @@ const filterComponents = ({ components, updatedVars, features, bindings }) => {
24
29
  localCache[value] = inter;
25
30
  return inter;
26
31
  });
27
- cache = { ...cache, ...localCache };
32
+ if (
33
+ Object.keys(localCache).some((value) => cache[value] !== localCache[value])
34
+ ) {
35
+ setCache((prevCache) => ({ ...prevCache, ...localCache }));
36
+ }
28
37
  return filtered;
29
38
  };
30
39
 
@@ -36,6 +45,8 @@ const buildComponents = ({
36
45
  page,
37
46
  pagination,
38
47
  todo,
48
+ cache,
49
+ setCache,
39
50
  }) => {
40
51
  if (management && !pagination) return components;
41
52
 
@@ -57,6 +68,8 @@ const buildComponents = ({
57
68
  updatedVars,
58
69
  features,
59
70
  bindings,
71
+ cache,
72
+ setCache,
60
73
  });
61
74
  if (isDev) console.log(`End filter: ${new Date().getTime() - start} ms`);
62
75
  return filtered;
@@ -71,14 +84,13 @@ const buildComponents = ({
71
84
  updatedVars,
72
85
  features,
73
86
  bindings,
87
+ cache,
88
+ setCache,
74
89
  });
75
90
  if (isDev) console.log(`End filter: ${new Date().getTime() - start}`);
76
91
  return pageComponentsFiltered;
77
92
  };
78
93
 
79
- let oldComponents = [];
80
- let memoryTodo = {};
81
-
82
94
  export const useFilterComponents = ({
83
95
  questionnaire,
84
96
  management,
@@ -87,10 +99,12 @@ export const useFilterComponents = ({
87
99
  page,
88
100
  pagination,
89
101
  todo,
102
+ cache,
103
+ setCache,
104
+ memoryTodo,
90
105
  }) => {
91
106
  if (Object.keys(todo).length > 0) {
92
- memoryTodo = todo;
93
- return oldComponents;
107
+ return { todo };
94
108
  }
95
109
  const components = buildComponents({
96
110
  components: questionnaire.components,
@@ -100,7 +114,8 @@ export const useFilterComponents = ({
100
114
  page,
101
115
  pagination,
102
116
  todo: memoryTodo,
117
+ cache,
118
+ setCache,
103
119
  });
104
- oldComponents = components;
105
- return components;
120
+ return { components };
106
121
  };
@@ -1 +1,2 @@
1
- export { default } from './lunatic';
1
+ export { default as useLunatic } from './lunatic';
2
+ export { default as useLunaticSplit } from './lunatic-split';