@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,33 +1,44 @@
1
- import compareAsc from 'date-fns/compareAsc';
2
- import format from 'date-fns/format';
3
-
4
- export const minMaxValidatorDatepicker =
5
- ({ min, max, id }) =>
6
- (value) => {
7
- const errorMessage = getMessage(min, max, value);
8
- if (errorMessage) return { id: `control-${id}`, errorMessage };
9
- return null;
10
- };
11
-
12
- const getMessage = (min, max, value) => {
13
- if (!value) {
14
- return undefined;
15
- }
16
- const dateFormat = 'dd/MM/yyyy';
17
- const date = new Date(value);
18
- if (isNaN(Date.parse(min))) return undefined;
19
- if (isNaN(Date.parse(max))) return undefined;
20
- const minDate = new Date(min);
21
- const maxDate = new Date(max);
22
- const minDateAsString = minDate ? format(minDate, dateFormat) : '';
23
- const maxDateAsString = maxDate ? format(maxDate, dateFormat) : '';
24
- if (!min && isDef(max) && compareAsc(date, maxDate) > 0)
25
- return `La date doit être inférieure au ${maxDateAsString}`;
26
- else if (isDef(min) && !max && compareAsc(date, minDate) > 0)
27
- return `La date doit être supérieure au ${minDateAsString}`;
28
- else if (isDef(min) && isDef(max) && (date < minDate || date > maxDate))
29
- return `La date doit être comprise entre le ${minDateAsString} et le ${maxDateAsString}`;
30
- return undefined;
31
- };
32
-
33
- const isDef = (d) => d;
1
+ import compareAsc from 'date-fns/compareAsc';
2
+ import format from 'date-fns/format';
3
+
4
+ export const minMaxValidatorDatepicker =
5
+ ({ min, max, id }) =>
6
+ (value) => {
7
+ const errorMessage = getMessage(min, max, value);
8
+ if (errorMessage) return { id: `control-${id}`, errorMessage };
9
+ return null;
10
+ };
11
+
12
+ const getMessage = (min, max, value) => {
13
+ if (!value) {
14
+ return undefined;
15
+ }
16
+ const dateFormat = 'dd-MM-yyyy';
17
+ const date = new Date(value);
18
+ if (isDef(min) && isDef(max)) {
19
+ const minDate = new Date(min);
20
+ const maxDate = new Date(max);
21
+ if (date < minDate || date > maxDate) {
22
+ const minDateAsString = minDate ? format(minDate, dateFormat) : '';
23
+ const maxDateAsString = maxDate ? format(maxDate, dateFormat) : '';
24
+ return `La date doit être comprise entre le ${minDateAsString} et le ${maxDateAsString}`;
25
+ }
26
+ }
27
+ if (isDef(min)) {
28
+ const minDate = new Date(min);
29
+ if (compareAsc(date, minDate) < 0) {
30
+ const minDateAsString = minDate ? format(minDate, dateFormat) : '';
31
+ return `La date doit être supérieure au ${minDateAsString}`;
32
+ }
33
+ }
34
+ if (isDef(max)) {
35
+ const maxDate = new Date(max);
36
+ if (compareAsc(date, maxDate) > 0) {
37
+ const maxDateAsString = maxDate ? format(maxDate, dateFormat) : '';
38
+ return `La date doit être inférieure au ${maxDateAsString}`;
39
+ }
40
+ }
41
+ return undefined;
42
+ };
43
+
44
+ const isDef = (d) => !isNaN(Date.parse(d));
@@ -1,16 +1,16 @@
1
- import { minMaxValidatorInputNumber } from './input-number';
2
- import { minMaxValidatorDatepicker } from './datepicker';
3
- import * as U from '../../../../utils/lib';
4
-
5
- export const getTypeControls = (props) => {
6
- const { min, max, value, response, preferences, componentType, id } = props;
7
- const v =
8
- value || value === null
9
- ? value
10
- : U.getResponseByPreference(preferences)(response);
11
- if (componentType === 'InputNumber')
12
- return minMaxValidatorInputNumber({ id, min, max })(v);
13
- if (componentType === 'Datepicker')
14
- return minMaxValidatorDatepicker({ id, min, max })(v);
15
- return null;
16
- };
1
+ import { minMaxValidatorInputNumber } from './input-number';
2
+ import { minMaxValidatorDatepicker } from './datepicker';
3
+ import * as U from '../../../../utils/lib';
4
+
5
+ export const getTypeControls = (props) => {
6
+ const { min, max, value, response, preferences, componentType, id } = props;
7
+ const v =
8
+ value || value === null
9
+ ? value
10
+ : U.getResponseByPreference(preferences)(response);
11
+ if (componentType === 'InputNumber')
12
+ return minMaxValidatorInputNumber({ id, min, max })(v);
13
+ if (componentType === 'Datepicker')
14
+ return minMaxValidatorDatepicker({ id, min, max })(v);
15
+ return null;
16
+ };
@@ -1,23 +1,23 @@
1
- export const minMaxValidatorInputNumber =
2
- ({ min, max, id }) =>
3
- (value) => {
4
- const errorMessage = getMessage(min, max, value);
5
- if (errorMessage) return { id: `control-${id}`, errorMessage };
6
- return null;
7
- };
8
-
9
- const getMessage = (min, max, value) => {
10
- if (!value) {
11
- return undefined;
12
- }
13
- const valueNumber = Number(value);
14
- if (!min && isDef(max) && valueNumber > max)
15
- return `La valeur doit être inférieure à ${max}`;
16
- else if (isDef(min) && !max && valueNumber < min)
17
- return `La valeur doit être supérieure à ${min}`;
18
- else if (isDef(min) && isDef(max) && (valueNumber < min || valueNumber > max))
19
- return `La valeur doit être comprise entre ${min} et ${max}`;
20
- return undefined;
21
- };
22
-
23
- const isDef = (number) => number || number === 0;
1
+ export const minMaxValidatorInputNumber =
2
+ ({ min, max, id }) =>
3
+ (value) => {
4
+ const errorMessage = getMessage(min, max, value);
5
+ if (errorMessage) return { id: `control-${id}`, errorMessage };
6
+ return null;
7
+ };
8
+
9
+ const getMessage = (min, max, value) => {
10
+ if (!value) {
11
+ return undefined;
12
+ }
13
+ const valueNumber = Number(value);
14
+ if (!min && isDef(max) && valueNumber > max)
15
+ return `La valeur doit être inférieure à ${max}`;
16
+ else if (isDef(min) && !max && valueNumber < min)
17
+ return `La valeur doit être supérieure à ${min}`;
18
+ else if (isDef(min) && isDef(max) && (valueNumber < min || valueNumber > max))
19
+ return `La valeur doit être comprise entre ${min} et ${max}`;
20
+ return undefined;
21
+ };
22
+
23
+ const isDef = (number) => number || number === 0;
@@ -1 +1 @@
1
- export { default } from './wrapper';
1
+ export { default } from './wrapper';
@@ -1,180 +1,200 @@
1
- import React, { useEffect } from 'react';
2
- import KeyboardEventHandler from 'react-keyboard-event-handler';
3
- import Button from '../../button';
4
- import * as U from '../../../utils/lib';
5
- import './missing.scss';
6
-
7
- const Missing = ({ Component, props }) => {
8
- const {
9
- dontKnowButton = "Don't know",
10
- refusedButton = 'Refused',
11
- missingResponse,
12
- handleChange,
13
- preferences,
14
- missingStrategy,
15
- missingShortcut = { dontKnow: '', refused: '' },
16
- response,
17
- responses,
18
- cells,
19
- components,
20
- savingType,
21
- bindings,
22
- shortcut,
23
- componentType,
24
- missingLoopIteration,
25
- } = props;
26
-
27
- const buttonState = U.getResponseByPreference(preferences)(missingResponse);
28
-
29
- useEffect(() => {
30
- if (
31
- buttonState !== null &&
32
- U.hasToCleanMissing(savingType)({
33
- response,
34
- responses,
35
- cells,
36
- components,
37
- })
38
- ) {
39
- handleChange({ [U.getResponseName(missingResponse)]: null });
40
- }
41
- }, [
42
- buttonState,
43
- handleChange,
44
- savingType,
45
- response,
46
- responses,
47
- cells,
48
- components,
49
- missingResponse,
50
- ]);
51
-
52
- const getVarsToClean = () =>
53
- U.getToClean(savingType)({
54
- response,
55
- responses,
56
- cells,
57
- components,
58
- });
59
-
60
- const onClick = (value) => () => {
61
- const isSameValue = buttonState === value;
62
- if (!isSameValue) {
63
- const toClean = getVarsToClean();
64
- if (Object.keys(toClean)) {
65
- const { missingLoopIteration, currentPage } = props;
66
- const currentIterationIndex = getCurrentIterationIndex({
67
- currentPage,
68
- missingLoopIteration,
69
- });
70
- handleChange(toClean);
71
- if (U.isFunction(missingStrategy)) {
72
- const { fullBindings } = props;
73
- const toHandle = getVarsToHandle({
74
- toClean,
75
- fullBindings,
76
- currentIterationIndex,
77
- });
78
- const missingBindings = getMissingBindings({
79
- currentIterationIndex,
80
- bindings,
81
- fullBindings,
82
- toHandle,
83
- });
84
- missingStrategy(missingBindings);
85
- }
86
- } else {
87
- if (U.isFunction(missingStrategy)) missingStrategy(bindings);
88
- }
89
- handleChange({ [U.getResponseName(missingResponse)]: value });
90
- }
91
- };
92
-
93
- if (
94
- componentType === 'Loop' ||
95
- missingLoopIteration ||
96
- missingLoopIteration === 0
97
- )
98
- return <Component {...props} />;
99
-
100
- return (
101
- <div className="missing-wrapper">
102
- <div className="missing-component">
103
- <Component {...props} />
104
- </div>
105
- <div className="missing-buttons">
106
- <span
107
- className={`missing-button${
108
- buttonState === U.DK ? '-active' : ''
109
- } missing-button-dk${buttonState === U.DK ? '-active' : ''}`}
110
- >
111
- <Button
112
- label="dont-know-button"
113
- value={dontKnowButton}
114
- onClick={onClick(U.DK)}
115
- />
116
- </span>
117
- <span
118
- className={`missing-button${
119
- buttonState === U.RF ? '-active' : ''
120
- } missing-button-rf${buttonState === U.RF ? '-active' : ''}`}
121
- >
122
- <Button
123
- label="refused-button"
124
- value={refusedButton}
125
- onClick={onClick(U.RF)}
126
- />
127
- </span>
128
- </div>
129
- {shortcut &&
130
- missingShortcut &&
131
- missingShortcut.dontKnow &&
132
- missingShortcut.refused && (
133
- <KeyboardEventHandler
134
- handleKeys={Object.values(missingShortcut)}
135
- onKeyEvent={(key, e) => {
136
- e.preventDefault();
137
- if (key === missingShortcut.dontKnow) onClick(U.DK)();
138
- if (key === missingShortcut.refused) onClick(U.RF)();
139
- }}
140
- handleFocusableElements
141
- />
142
- )}
143
- </div>
144
- );
145
- };
146
-
147
- export default Missing;
148
-
149
- // TODO: make it recursive for Loop into Loop
150
- const getCurrentIterationIndex = ({ currentPage, missingLoopIteration }) => {
151
- const { currentIteration } = U.splitPage(currentPage, 1);
152
- if (currentIteration) return currentIteration - 1;
153
- if (missingLoopIteration || missingLoopIteration === 0)
154
- return missingLoopIteration;
155
- return null;
156
- };
157
-
158
- // TODO: make it recursive for Loop into Loop
159
- const getVarsToHandle = ({ toClean, fullBindings, currentIterationIndex }) => {
160
- if (currentIterationIndex || currentIterationIndex === 0) {
161
- return Object.entries(toClean).reduce((acc, [name, value]) => {
162
- const newValue = fullBindings[name].map((v, i) =>
163
- i === currentIterationIndex ? value : v
164
- );
165
- return { ...acc, [name]: newValue };
166
- }, {});
167
- }
168
- return toClean;
169
- };
170
-
171
- const getMissingBindings = ({
172
- bindings,
173
- fullBindings,
174
- currentIterationIndex,
175
- toHandle,
176
- }) => {
177
- if (currentIterationIndex || currentIterationIndex === 0)
178
- return { ...fullBindings, ...toHandle };
179
- return { ...bindings, ...toHandle };
180
- };
1
+ import React, { useEffect, useState } from 'react';
2
+ import KeyboardEventHandler from 'react-keyboard-event-handler';
3
+ import Button from '../../button';
4
+ import * as U from '../../../utils/lib';
5
+ import './missing.scss';
6
+
7
+ const Missing = ({ Component, props }) => {
8
+ const {
9
+ dontKnowButton = "Don't know",
10
+ refusedButton = 'Refused',
11
+ missingResponse,
12
+ handleChange,
13
+ preferences,
14
+ missingStrategy,
15
+ missingShortcut = { dontKnow: '', refused: '' },
16
+ response,
17
+ responses,
18
+ cells,
19
+ components,
20
+ savingType,
21
+ bindings,
22
+ shortcut,
23
+ componentType,
24
+ paginatedLoop,
25
+ } = props;
26
+
27
+ const missingResponseName = U.getResponseName(missingResponse);
28
+ const buttonState = U.getResponseByPreference(preferences)(missingResponse);
29
+ const [oldMissingValue] = useState(() => buttonState);
30
+
31
+ const [bindingsForMissingStrategy, setBindingsForMissingStrategy] =
32
+ useState(null);
33
+
34
+ /**
35
+ * Sources split: use MissingStragy only if missingResponse has been updated
36
+ * Ensures that missingResponse is persisted when the source has to be changed
37
+ */
38
+ useEffect(() => {
39
+ const isSameValue = buttonState === oldMissingValue;
40
+ if (bindingsForMissingStrategy && !isSameValue) {
41
+ if (U.isFunction(missingStrategy))
42
+ missingStrategy(bindingsForMissingStrategy);
43
+ setBindingsForMissingStrategy(null);
44
+ }
45
+ }, [
46
+ bindingsForMissingStrategy,
47
+ missingStrategy,
48
+ buttonState,
49
+ oldMissingValue,
50
+ ]);
51
+
52
+ useEffect(() => {
53
+ if (
54
+ buttonState !== null &&
55
+ U.hasToCleanMissing(savingType)({
56
+ response,
57
+ responses,
58
+ cells,
59
+ components,
60
+ })
61
+ ) {
62
+ handleChange({ [missingResponseName]: null });
63
+ }
64
+ }, [
65
+ buttonState,
66
+ handleChange,
67
+ savingType,
68
+ response,
69
+ responses,
70
+ cells,
71
+ components,
72
+ missingResponseName,
73
+ ]);
74
+
75
+ const getVarsToClean = () =>
76
+ U.getToClean(savingType)({
77
+ response,
78
+ responses,
79
+ cells,
80
+ components,
81
+ });
82
+
83
+ const onClick = (value) => () => {
84
+ const isSameValue = buttonState === value;
85
+ if (!isSameValue) {
86
+ const toClean = getVarsToClean();
87
+ if (Object.keys(toClean)) {
88
+ const { currentPage } = props;
89
+ const currentIterationIndex = getCurrentIterationIndex({
90
+ currentPage,
91
+ });
92
+ handleChange(toClean);
93
+ if (U.isFunction(missingStrategy)) {
94
+ const { fullBindings } = props;
95
+ const toHandle = getVarsToHandle({
96
+ toClean,
97
+ fullBindings,
98
+ currentIterationIndex,
99
+ });
100
+ const missingBindings = getMissingBindings({
101
+ currentIterationIndex,
102
+ bindings,
103
+ fullBindings,
104
+ toHandle,
105
+ });
106
+ setBindingsForMissingStrategy(missingBindings);
107
+ }
108
+ } else {
109
+ if (U.isFunction(missingStrategy))
110
+ setBindingsForMissingStrategy(bindings);
111
+ }
112
+ handleChange({ [missingResponseName]: value });
113
+ }
114
+ };
115
+
116
+ if ((componentType === 'Loop' && paginatedLoop) || !missingResponse)
117
+ return <Component {...props} />;
118
+
119
+ return (
120
+ <div className="missing-wrapper">
121
+ <div className="missing-component">
122
+ <Component {...props} />
123
+ </div>
124
+ <div className="missing-buttons">
125
+ <span
126
+ className={`missing-button${
127
+ buttonState === U.DK ? '-active' : ''
128
+ } missing-button-dk${buttonState === U.DK ? '-active' : ''}`}
129
+ >
130
+ <Button
131
+ label="dont-know-button"
132
+ value={dontKnowButton}
133
+ disabled={!missingResponseName || missingResponseName?.length === 0}
134
+ onClick={onClick(U.DK)}
135
+ />
136
+ </span>
137
+ <span
138
+ className={`missing-button${
139
+ buttonState === U.RF ? '-active' : ''
140
+ } missing-button-rf${buttonState === U.RF ? '-active' : ''}`}
141
+ >
142
+ <Button
143
+ label="refused-button"
144
+ value={refusedButton}
145
+ disabled={!missingResponseName || missingResponseName?.length === 0}
146
+ onClick={onClick(U.RF)}
147
+ />
148
+ </span>
149
+ </div>
150
+ {shortcut &&
151
+ missingResponseName?.length > 0 &&
152
+ missingShortcut &&
153
+ missingShortcut.dontKnow &&
154
+ missingShortcut.refused && (
155
+ <KeyboardEventHandler
156
+ handleKeys={Object.values(missingShortcut)}
157
+ onKeyEvent={(key, e) => {
158
+ e.preventDefault();
159
+ if (key === missingShortcut.dontKnow) onClick(U.DK)();
160
+ if (key === missingShortcut.refused) onClick(U.RF)();
161
+ }}
162
+ handleFocusableElements
163
+ />
164
+ )}
165
+ </div>
166
+ );
167
+ };
168
+
169
+ export default Missing;
170
+
171
+ // TODO: make it recursive for Loop into Loop
172
+ const getCurrentIterationIndex = ({ currentPage }) => {
173
+ const { currentIteration } = U.splitPage(currentPage, 1);
174
+ if (currentIteration) return currentIteration - 1;
175
+ return null;
176
+ };
177
+
178
+ // TODO: make it recursive for Loop into Loop
179
+ const getVarsToHandle = ({ toClean, fullBindings, currentIterationIndex }) => {
180
+ if (currentIterationIndex || currentIterationIndex === 0) {
181
+ return Object.entries(toClean).reduce((acc, [name, value]) => {
182
+ const newValue = fullBindings[name].map((v, i) =>
183
+ i === currentIterationIndex ? value : v
184
+ );
185
+ return { ...acc, [name]: newValue };
186
+ }, {});
187
+ }
188
+ return toClean;
189
+ };
190
+
191
+ const getMissingBindings = ({
192
+ bindings,
193
+ fullBindings,
194
+ currentIterationIndex,
195
+ toHandle,
196
+ }) => {
197
+ if (currentIterationIndex || currentIterationIndex === 0)
198
+ return { ...fullBindings, ...toHandle };
199
+ return { ...bindings, ...toHandle };
200
+ };
@@ -1 +1 @@
1
- export { default } from './component';
1
+ export { default } from './component';
@@ -1,32 +1,32 @@
1
- .lunatic-component {
2
- .missing-wrapper {
3
- .missing-buttons {
4
- margin-top: 1em;
5
- .button-lunatic {
6
- width: 4em;
7
- font-size: 1em;
8
- font-weight: normal;
9
- }
10
- .missing-button {
11
- .button-lunatic {
12
- background-color: var(--color-very-very-light);
13
- color: var(--color-primary-dark);
14
- &:hover {
15
- background-color: white;
16
- color: var(--color-primary-main);
17
- }
18
- }
19
- }
20
- .missing-button-active {
21
- .button-lunatic {
22
- background-color: var(--color-primary-dark);
23
- color: var(--color-very-very-light);
24
- &:hover {
25
- background-color: var(--color-primary-main);
26
- color: white;
27
- }
28
- }
29
- }
30
- }
31
- }
32
- }
1
+ .lunatic-component {
2
+ .missing-wrapper {
3
+ .missing-buttons {
4
+ margin-top: 1em;
5
+ .button-lunatic {
6
+ width: 4em;
7
+ font-size: 1em;
8
+ font-weight: normal;
9
+ }
10
+ .missing-button {
11
+ .button-lunatic {
12
+ background-color: var(--color-very-very-light);
13
+ color: var(--color-primary-dark);
14
+ &:hover {
15
+ background-color: white;
16
+ color: var(--color-primary-main);
17
+ }
18
+ }
19
+ }
20
+ .missing-button-active {
21
+ .button-lunatic {
22
+ background-color: var(--color-primary-dark);
23
+ color: var(--color-very-very-light);
24
+ &:hover {
25
+ background-color: var(--color-primary-main);
26
+ color: white;
27
+ }
28
+ }
29
+ }
30
+ }
31
+ }
32
+ }
@@ -1,23 +1,23 @@
1
- import React from 'react';
2
- import Missing from './missing';
3
- import Controls from './controls';
4
-
5
- const componentWrapper = (Component) => (props) => {
6
- const { missing, controls, componentType } = props;
7
- const hasC = hasControls(controls, componentType);
8
- if (missing && !hasC) return <Missing Component={Component} props={props} />;
9
- if (!missing && hasC) return <Controls Component={Component} props={props} />;
10
- if (missing && hasC) {
11
- const ControlComponent = () => (
12
- <Controls Component={Component} props={props} />
13
- );
14
- return <Missing Component={ControlComponent} props={props} />;
15
- }
16
- return <Component {...props} />;
17
- };
18
-
19
- const hasControls = (controls, componentType) =>
20
- (Array.isArray(controls) && controls.length > 0) ||
21
- ['InputNumber', 'Datepicker'].includes(componentType);
22
-
23
- export default componentWrapper;
1
+ import React from 'react';
2
+ import Missing from './missing';
3
+ import Controls from './controls';
4
+
5
+ const componentWrapper = (Component) => (props) => {
6
+ const { missing, controls, componentType } = props;
7
+ const hasC = hasControls(controls, componentType);
8
+ if (missing && !hasC) return <Missing Component={Component} props={props} />;
9
+ if (!missing && hasC) return <Controls Component={Component} props={props} />;
10
+ if (missing && hasC) {
11
+ const ControlComponent = () => (
12
+ <Controls Component={Component} props={props} />
13
+ );
14
+ return <Missing Component={ControlComponent} props={props} />;
15
+ }
16
+ return <Component {...props} />;
17
+ };
18
+
19
+ const hasControls = (controls, componentType) =>
20
+ (Array.isArray(controls) && controls.length > 0) ||
21
+ ['InputNumber', 'Datepicker'].includes(componentType);
22
+
23
+ export default componentWrapper;