@inseefr/lunatic 0.2.3-experimental → 0.2.3-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 (230) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +25 -23
  3. package/lib/index.js +1191 -475
  4. package/lib/index.js.map +1 -1
  5. package/package.json +174 -172
  6. package/src/components/breadcrumb/breadcrumb.scss +22 -22
  7. package/src/components/checkbox/boolean.js +172 -172
  8. package/src/components/checkbox/checkbox.scss +73 -73
  9. package/src/components/checkbox/group.js +231 -231
  10. package/src/components/checkbox/one.js +11 -11
  11. package/src/components/component-wrapper/controls/component.js +70 -0
  12. package/src/components/component-wrapper/controls/controls.scss +6 -0
  13. package/src/components/component-wrapper/controls/index.js +1 -0
  14. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -0
  15. package/src/components/component-wrapper/controls/validators/index.js +16 -0
  16. package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
  17. package/src/components/{missing-wrapper → component-wrapper}/index.js +0 -0
  18. package/src/components/component-wrapper/missing/component.js +200 -0
  19. package/src/components/component-wrapper/missing/index.js +1 -0
  20. package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +32 -32
  21. package/src/components/component-wrapper/wrapper.js +23 -0
  22. package/src/components/components.js +1 -0
  23. package/src/components/datepicker/component.js +26 -11
  24. package/src/components/declarations/component.js +46 -46
  25. package/src/components/declarations/declarations.scss +40 -40
  26. package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -274
  27. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
  28. package/src/components/dropdown/commons/actions.js +65 -56
  29. package/src/components/dropdown/commons/children-to-option.js +9 -9
  30. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
  31. package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
  32. package/src/components/dropdown/commons/components/dropdown.js +204 -183
  33. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
  34. package/src/components/dropdown/commons/reducer.js +3 -0
  35. package/src/components/dropdown/commons/tools/index.js +17 -17
  36. package/src/components/dropdown/component.js +135 -135
  37. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -185
  38. package/src/components/dropdown/dropdown-edit/index.js +11 -11
  39. package/src/components/dropdown/dropdown-simple/dropdown.js +173 -164
  40. package/src/components/dropdown/dropdown-simple/index.js +20 -20
  41. package/src/components/dropdown/dropdown.scss +178 -178
  42. package/src/components/icon/icon.scss +15 -15
  43. package/src/components/index.js +2 -0
  44. package/src/components/index.scss +177 -175
  45. package/src/components/input/input-number.js +30 -54
  46. package/src/components/input/input.js +11 -11
  47. package/src/components/input/input.scss +31 -37
  48. package/src/components/loop/component.js +170 -169
  49. package/src/components/loop/loop.scss +13 -13
  50. package/src/components/loop/wrapper.js +1 -1
  51. package/src/components/loop-constructor/block/block.scss +10 -10
  52. package/src/components/loop-constructor/block/component.js +9 -9
  53. package/src/components/loop-constructor/roster/component.js +8 -8
  54. package/src/components/loop-constructor/wrapper/body-component.js +146 -125
  55. package/src/components/loop-constructor/wrapper/component.js +190 -190
  56. package/src/components/modal/component.js +36 -0
  57. package/src/components/modal/index.js +1 -0
  58. package/src/components/modal/modal.scss +33 -0
  59. package/src/components/progress-bar/progress-bar.scss +54 -54
  60. package/src/components/radio/component.js +9 -9
  61. package/src/components/radio/radio.scss +59 -59
  62. package/src/components/sequence/component.js +50 -50
  63. package/src/components/sequence/sequence.scss +10 -10
  64. package/src/components/subsequence/component.js +49 -49
  65. package/src/components/suggester/check-store.js +2 -4
  66. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  67. package/src/components/suggester/components/panel/option-container.js +61 -61
  68. package/src/components/suggester/components/panel/panel.js +47 -47
  69. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  70. package/src/components/suggester/components/selection/label.js +35 -35
  71. package/src/components/suggester/components/selection/selection.js +50 -50
  72. package/src/components/suggester/components/suggester-content.js +2 -2
  73. package/src/components/suggester/components/suggester.js +128 -88
  74. package/src/components/suggester/components/suggester.scss +101 -101
  75. package/src/components/suggester/default-style.scss +125 -125
  76. package/src/components/suggester/find-best-label/find-best-label.js +51 -49
  77. package/src/components/suggester/find-best-label/index.js +1 -1
  78. package/src/components/suggester/idb-suggester.js +73 -67
  79. package/src/components/suggester/lunatic-suggester.js +140 -137
  80. package/src/components/suggester/searching/create-searching.js +49 -47
  81. package/src/components/suggester/searching/index.js +1 -1
  82. package/src/components/suggester/state-management/actions.js +38 -38
  83. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  84. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  85. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  86. package/src/components/suggester/suggester-wrapper.js +127 -121
  87. package/src/components/suggester-loader-widget/loader.js +67 -67
  88. package/src/components/suggester-loader-widget/widget.js +123 -123
  89. package/src/components/table/table.js +173 -171
  90. package/src/components/table/table.scss +26 -26
  91. package/src/components/textarea/component.js +11 -11
  92. package/src/components/textarea/textarea.scss +8 -8
  93. package/src/components/tooltip/tooltip.scss +30 -30
  94. package/src/stories/breadcrumb/breadcrumb.stories.js +21 -21
  95. package/src/stories/checkbox-boolean/data.json +78 -78
  96. package/src/stories/datepicker/data.json +3 -1
  97. package/src/stories/declarations/declarations.stories.js +116 -116
  98. package/src/stories/dropdown/README.md +44 -44
  99. package/src/stories/dropdown/data.json +98 -98
  100. package/src/stories/dropdown/dropdown.stories.js +89 -89
  101. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  102. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  103. package/src/stories/questionnaire/arithmetic.json +247 -247
  104. package/src/stories/questionnaire/calc-var.json +187 -187
  105. package/src/stories/questionnaire/data-logement.json +2691 -2691
  106. package/src/stories/questionnaire/kish.json +275 -0
  107. package/src/stories/questionnaire/logement-queen.json +23390 -0
  108. package/src/stories/questionnaire/logement-s2.json +46028 -44537
  109. package/src/stories/questionnaire/logement-sequence.json +26741 -26741
  110. package/src/stories/questionnaire/logement.json +21073 -26813
  111. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  112. package/src/stories/questionnaire/questionnaire.stories.js +236 -154
  113. package/src/stories/questionnaire/update-external/data.json +1 -0
  114. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  115. package/src/stories/sequence/sequence.stories.js +32 -32
  116. package/src/stories/subsequence/subsequence.stories.js +32 -32
  117. package/src/stories/suggester/README.md +46 -46
  118. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  119. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  120. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  121. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  122. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  123. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  124. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  125. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  126. package/src/stories/suggester/data-auto.json +232 -231
  127. package/src/stories/suggester/data-vtl.json +82 -82
  128. package/src/stories/suggester/data.json +169 -136
  129. package/src/stories/suggester/naf-rev2/index.js +2 -2
  130. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  131. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  132. package/src/stories/suggester/suggester.stories.js +138 -133
  133. package/src/stories/utils/orchestrator-split.js +119 -0
  134. package/src/stories/utils/orchestrator.js +119 -108
  135. package/src/tests/components/input-number.spec.js +6 -12
  136. package/src/tests/components/loops/roster-loop.json +71 -71
  137. package/src/tests/components/missing-wrapper.spec.js +0 -1
  138. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  139. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  140. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
  141. package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
  142. package/src/utils/components/dragger/dragger.scss +7 -7
  143. package/src/utils/idb-tools/create-db-opener.js +43 -43
  144. package/src/utils/idb-tools/create-open-db.js +25 -25
  145. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  146. package/src/utils/idb-tools/index.js +10 -10
  147. package/src/utils/idb-tools/insert-entity.js +15 -15
  148. package/src/utils/idb-tools/open-db.js +13 -13
  149. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  150. package/src/utils/lib/controls/index.js +1 -0
  151. package/src/utils/lib/controls/utils.js +152 -0
  152. package/src/utils/lib/decorator/title-decorator.js +16 -16
  153. package/src/utils/lib/env.js +2 -2
  154. package/src/utils/lib/index.js +2 -0
  155. package/src/utils/lib/input-number.js +1 -1
  156. package/src/utils/lib/options-positioning.js +9 -9
  157. package/src/utils/lib/pagination/navigation/shared.js +256 -253
  158. package/src/utils/lib/prop-types/lines.js +6 -6
  159. package/src/utils/lib/responses.js +11 -9
  160. package/src/utils/lib/splitting.js +142 -0
  161. package/src/utils/lib/style.js +10 -10
  162. package/src/utils/store-tools/auto-load.js +74 -73
  163. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  164. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  165. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -43
  166. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  167. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  168. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  169. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  170. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  171. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  172. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  173. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  174. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  177. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +12 -12
  178. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  179. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +7 -7
  180. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  181. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +13 -13
  182. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  183. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  184. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  185. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  186. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  187. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  188. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +118 -118
  189. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  190. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  191. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  192. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -9
  193. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  194. package/src/utils/suggester-workers/create-worker.js +56 -0
  195. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  196. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  197. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -33
  198. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  199. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  200. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  201. package/src/utils/suggester-workers/searching/index.js +1 -1
  202. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  203. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  204. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +2 -2
  205. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  206. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +24 -24
  207. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  208. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  209. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  210. package/src/utils/suggester-workers/searching/searching.js +70 -70
  211. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  212. package/src/utils/to-expose/calculated-variables.js +113 -113
  213. package/src/utils/to-expose/handler.js +149 -112
  214. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  215. package/src/utils/to-expose/hooks/index.js +2 -1
  216. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  217. package/src/utils/to-expose/hooks/lunatic.js +284 -188
  218. package/src/utils/to-expose/index.js +1 -1
  219. package/src/utils/to-expose/init-questionnaire.js +164 -164
  220. package/src/utils/to-expose/interpret/vtl.js +18 -18
  221. package/src/utils/to-expose/state.js +66 -58
  222. package/src/components/missing-wrapper/component.js +0 -120
  223. package/src/components/missing-wrapper/wrapper.js +0 -10
  224. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  225. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  226. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  227. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  228. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  229. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  230. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1,8 +1,8 @@
1
- // see input.scss
2
-
3
- .lunatic-component {
4
- .textarea-lunatic {
5
- height: 3em;
6
- width: 100%;
7
- }
8
- }
1
+ // see input.scss
2
+
3
+ .lunatic-component {
4
+ .textarea-lunatic {
5
+ height: 3em;
6
+ width: 100%;
7
+ }
8
+ }
@@ -1,30 +1,30 @@
1
- // Import index once for bundle
2
- @import 'src/components/index.scss';
3
-
4
- .lunatic-component {
5
- /* Tooltip container */
6
- .tooltip-lunatic {
7
- position: relative;
8
- display: inline-block;
9
- align-items: center;
10
- }
11
-
12
- /* Tooltip text */
13
- .tooltip-lunatic .tooltip-text {
14
- min-width: 10em;
15
- max-width: 20em;
16
- background-color: var(--color-primary-dark);
17
- color: #fff;
18
- padding: 0.5em;
19
- border-radius: 6px;
20
- font-size: 1em;
21
- &.place-left {
22
- &::before {
23
- border-left: 10px solid var(--color-primary-dark);
24
- }
25
- &::after {
26
- content: none;
27
- }
28
- }
29
- }
30
- }
1
+ // Import index once for bundle
2
+ @import 'src/components/index.scss';
3
+
4
+ .lunatic-component {
5
+ /* Tooltip container */
6
+ .tooltip-lunatic {
7
+ position: relative;
8
+ display: inline-block;
9
+ align-items: center;
10
+ }
11
+
12
+ /* Tooltip text */
13
+ .tooltip-lunatic .tooltip-text {
14
+ min-width: 10em;
15
+ max-width: 20em;
16
+ background-color: var(--color-primary-dark);
17
+ color: #fff;
18
+ padding: 0.5em;
19
+ border-radius: 6px;
20
+ font-size: 1em;
21
+ &.place-left {
22
+ &::before {
23
+ border-left: 10px solid var(--color-primary-dark);
24
+ }
25
+ &::after {
26
+ content: none;
27
+ }
28
+ }
29
+ }
30
+ }
@@ -1,21 +1,21 @@
1
- import React from 'react';
2
- import { storiesOf } from '@storybook/react';
3
- import { Breadcrumb } from 'components';
4
- import { withReadme } from 'storybook-readme';
5
- import readme from './README.md';
6
- import { titleDecorator } from 'utils/lib';
7
-
8
- const elements = ['Sequence', 'Sub-sequence', 'Question'];
9
-
10
- const stories = storiesOf('Breadcrumb', module)
11
- .addDecorator(withReadme(readme))
12
- .addDecorator((Component) => {
13
- const WrappedComponent = titleDecorator(Component);
14
- return <WrappedComponent title="<Breadcrumb />" />;
15
- });
16
-
17
- stories.addWithJSX('Default', () => (
18
- <div className="lunatic-component">
19
- <Breadcrumb id="default" elements={elements} />
20
- </div>
21
- ));
1
+ import React from 'react';
2
+ import { storiesOf } from '@storybook/react';
3
+ import { Breadcrumb } from 'components';
4
+ import { withReadme } from 'storybook-readme';
5
+ import readme from './README.md';
6
+ import { titleDecorator } from 'utils/lib';
7
+
8
+ const elements = ['Sequence', 'Sub-sequence', 'Question'];
9
+
10
+ const stories = storiesOf('Breadcrumb', module)
11
+ .addDecorator(withReadme(readme))
12
+ .addDecorator((Component) => {
13
+ const WrappedComponent = titleDecorator(Component);
14
+ return <WrappedComponent title="<Breadcrumb />" />;
15
+ });
16
+
17
+ stories.addWithJSX('Default', () => (
18
+ <div className="lunatic-component">
19
+ <Breadcrumb id="default" elements={elements} />
20
+ </div>
21
+ ));
@@ -1,78 +1,78 @@
1
- {
2
- "components": [
3
- {
4
- "id": "1",
5
- "componentType": "CheckboxBoolean",
6
- "mandatory": false,
7
- "label": "➡ 1. Are you ready?",
8
- "response": {
9
- "name": "READY"
10
- },
11
- "missingResponse": {
12
- "name": "READY_MISSING"
13
- }
14
- },
15
- {
16
- "id": "2",
17
- "componentType": "CheckboxBoolean",
18
- "mandatory": false,
19
- "label": "➡ 2. Are you always ready?",
20
- "response": {
21
- "name": "READY2"
22
- },
23
- "missingResponse": {
24
- "name": "READY2_MISSING"
25
- }
26
- }
27
- ],
28
- "variables": [
29
- {
30
- "variableType": "COLLECTED",
31
- "name": "READY",
32
- "componentRef": "1",
33
- "values": {
34
- "PREVIOUS": null,
35
- "COLLECTED": null,
36
- "FORCED": null,
37
- "EDITED": null,
38
- "INPUTED": null
39
- }
40
- },
41
- {
42
- "variableType": "COLLECTED",
43
- "name": "READY_MISSING",
44
- "componentRef": "1",
45
- "values": {
46
- "PREVIOUS": null,
47
- "COLLECTED": null,
48
- "FORCED": null,
49
- "EDITED": null,
50
- "INPUTED": null
51
- }
52
- },
53
- {
54
- "variableType": "COLLECTED",
55
- "name": "READY2",
56
- "componentRef": "2",
57
- "values": {
58
- "PREVIOUS": null,
59
- "COLLECTED": true,
60
- "FORCED": null,
61
- "EDITED": null,
62
- "INPUTED": null
63
- }
64
- },
65
- {
66
- "variableType": "COLLECTED",
67
- "name": "READY2_MISSING",
68
- "componentRef": "2",
69
- "values": {
70
- "PREVIOUS": null,
71
- "COLLECTED": null,
72
- "FORCED": null,
73
- "EDITED": null,
74
- "INPUTED": null
75
- }
76
- }
77
- ]
78
- }
1
+ {
2
+ "components": [
3
+ {
4
+ "id": "1",
5
+ "componentType": "CheckboxBoolean",
6
+ "mandatory": false,
7
+ "label": "➡ 1. Are you ready?",
8
+ "response": {
9
+ "name": "READY"
10
+ },
11
+ "missingResponse": {
12
+ "name": "READY_MISSING"
13
+ }
14
+ },
15
+ {
16
+ "id": "2",
17
+ "componentType": "CheckboxBoolean",
18
+ "mandatory": false,
19
+ "label": "➡ 2. Are you always ready?",
20
+ "response": {
21
+ "name": "READY2"
22
+ },
23
+ "missingResponse": {
24
+ "name": "READY2_MISSING"
25
+ }
26
+ }
27
+ ],
28
+ "variables": [
29
+ {
30
+ "variableType": "COLLECTED",
31
+ "name": "READY",
32
+ "componentRef": "1",
33
+ "values": {
34
+ "PREVIOUS": null,
35
+ "COLLECTED": null,
36
+ "FORCED": null,
37
+ "EDITED": null,
38
+ "INPUTED": null
39
+ }
40
+ },
41
+ {
42
+ "variableType": "COLLECTED",
43
+ "name": "READY_MISSING",
44
+ "componentRef": "1",
45
+ "values": {
46
+ "PREVIOUS": null,
47
+ "COLLECTED": null,
48
+ "FORCED": null,
49
+ "EDITED": null,
50
+ "INPUTED": null
51
+ }
52
+ },
53
+ {
54
+ "variableType": "COLLECTED",
55
+ "name": "READY2",
56
+ "componentRef": "2",
57
+ "values": {
58
+ "PREVIOUS": null,
59
+ "COLLECTED": true,
60
+ "FORCED": null,
61
+ "EDITED": null,
62
+ "INPUTED": null
63
+ }
64
+ },
65
+ {
66
+ "variableType": "COLLECTED",
67
+ "name": "READY2_MISSING",
68
+ "componentRef": "2",
69
+ "values": {
70
+ "PREVIOUS": null,
71
+ "COLLECTED": null,
72
+ "FORCED": null,
73
+ "EDITED": null,
74
+ "INPUTED": null
75
+ }
76
+ }
77
+ ]
78
+ }
@@ -11,7 +11,9 @@
11
11
  "dateFormat": "jj/mm/aaaa",
12
12
  "missingResponse": {
13
13
  "name": "DATEFIRST_MISSING"
14
- }
14
+ },
15
+ "min": "1900-01-01",
16
+ "max": "2099-12-31"
15
17
  }
16
18
  ],
17
19
  "variables": [
@@ -1,116 +1,116 @@
1
- import React from 'react';
2
- import { storiesOf } from '@storybook/react';
3
- import { withReadme } from 'storybook-readme';
4
- import { Declarations } from 'components';
5
- import readme from './README.md';
6
- import { titleDecorator } from 'utils/lib';
7
- import * as C from '../../constants';
8
- import { featuresOptions } from '../utils/options';
9
- import { object, select } from '@storybook/addon-knobs/react';
10
-
11
- const stories = storiesOf('Declarations', module)
12
- .addDecorator(withReadme(readme))
13
- .addDecorator((Component) => {
14
- const WrappedComponent = titleDecorator(Component);
15
- return <WrappedComponent title="<Declarations />" />;
16
- });
17
-
18
- stories.addWithJSX('Default', () => (
19
- <div className="lunatic-component">
20
- <Declarations
21
- id="default"
22
- type={C.BEFORE_QUESTION_TEXT}
23
- declarations={declarations}
24
- />
25
- </div>
26
- ));
27
-
28
- stories.addWithJSX('Props', () => (
29
- <div className="lunatic-component">
30
- <Declarations
31
- id="default"
32
- type={C.BEFORE_QUESTION_TEXT}
33
- declarations={declarationsVtl}
34
- features={select('Features', featuresOptions, ['VTL', 'MD'])}
35
- bindings={object('Bindings', { test: 'test' })}
36
- />
37
- </div>
38
- ));
39
-
40
- const declarations = [
41
- {
42
- id: '1',
43
- label: "I'm the label of the instruction declaration",
44
- position: C.BEFORE_QUESTION_TEXT,
45
- declarationType: C.INSTRUCTION,
46
- },
47
- {
48
- id: '2',
49
- label: "I'm the label of the comment declaration",
50
- position: C.BEFORE_QUESTION_TEXT,
51
- declarationType: C.COMMENT,
52
- },
53
- {
54
- id: '3',
55
- label: "I'm the label of the help declaration",
56
- position: C.BEFORE_QUESTION_TEXT,
57
- declarationType: C.HELP,
58
- },
59
- {
60
- id: '4',
61
- label: "I'm the label of the warning declaration",
62
- position: C.BEFORE_QUESTION_TEXT,
63
- declarationType: C.WARNING,
64
- },
65
- {
66
- id: '5',
67
- label: "I'm the label of the message filter declaration",
68
- position: C.BEFORE_QUESTION_TEXT,
69
- declarationType: C.MESSAGE_FILTER,
70
- },
71
- {
72
- id: '6',
73
- label: "I'm the label of the statement declaration",
74
- position: C.BEFORE_QUESTION_TEXT,
75
- declarationType: C.STATEMENT,
76
- },
77
- ];
78
-
79
- const declarationsVtl = [
80
- {
81
- id: '1',
82
- label: '"I\'m the label of the instruction declaration"',
83
- position: C.BEFORE_QUESTION_TEXT,
84
- declarationType: C.INSTRUCTION,
85
- },
86
- {
87
- id: '2',
88
- label: '"I\'m the label of the comment declaration"',
89
- position: C.BEFORE_QUESTION_TEXT,
90
- declarationType: C.COMMENT,
91
- },
92
- {
93
- id: '3',
94
- label: '"I\'m the label of the help declaration"',
95
- position: C.BEFORE_QUESTION_TEXT,
96
- declarationType: C.HELP,
97
- },
98
- {
99
- id: '4',
100
- label: '"I\'m the label of the warning declaration"',
101
- position: C.BEFORE_QUESTION_TEXT,
102
- declarationType: C.WARNING,
103
- },
104
- {
105
- id: '5',
106
- label: '"I\'m the label of the message filter declaration"',
107
- position: C.BEFORE_QUESTION_TEXT,
108
- declarationType: C.MESSAGE_FILTER,
109
- },
110
- {
111
- id: '6',
112
- label: '"I\'m the label of the statement declaration"',
113
- position: C.BEFORE_QUESTION_TEXT,
114
- declarationType: C.STATEMENT,
115
- },
116
- ];
1
+ import React from 'react';
2
+ import { storiesOf } from '@storybook/react';
3
+ import { withReadme } from 'storybook-readme';
4
+ import { Declarations } from 'components';
5
+ import readme from './README.md';
6
+ import { titleDecorator } from 'utils/lib';
7
+ import * as C from '../../constants';
8
+ import { featuresOptions } from '../utils/options';
9
+ import { object, select } from '@storybook/addon-knobs/react';
10
+
11
+ const stories = storiesOf('Declarations', module)
12
+ .addDecorator(withReadme(readme))
13
+ .addDecorator((Component) => {
14
+ const WrappedComponent = titleDecorator(Component);
15
+ return <WrappedComponent title="<Declarations />" />;
16
+ });
17
+
18
+ stories.addWithJSX('Default', () => (
19
+ <div className="lunatic-component">
20
+ <Declarations
21
+ id="default"
22
+ type={C.BEFORE_QUESTION_TEXT}
23
+ declarations={declarations}
24
+ />
25
+ </div>
26
+ ));
27
+
28
+ stories.addWithJSX('Props', () => (
29
+ <div className="lunatic-component">
30
+ <Declarations
31
+ id="default"
32
+ type={C.BEFORE_QUESTION_TEXT}
33
+ declarations={declarationsVtl}
34
+ features={select('Features', featuresOptions, ['VTL', 'MD'])}
35
+ bindings={object('Bindings', { test: 'test' })}
36
+ />
37
+ </div>
38
+ ));
39
+
40
+ const declarations = [
41
+ {
42
+ id: '1',
43
+ label: "I'm the label of the instruction declaration",
44
+ position: C.BEFORE_QUESTION_TEXT,
45
+ declarationType: C.INSTRUCTION,
46
+ },
47
+ {
48
+ id: '2',
49
+ label: "I'm the label of the comment declaration",
50
+ position: C.BEFORE_QUESTION_TEXT,
51
+ declarationType: C.COMMENT,
52
+ },
53
+ {
54
+ id: '3',
55
+ label: "I'm the label of the help declaration",
56
+ position: C.BEFORE_QUESTION_TEXT,
57
+ declarationType: C.HELP,
58
+ },
59
+ {
60
+ id: '4',
61
+ label: "I'm the label of the warning declaration",
62
+ position: C.BEFORE_QUESTION_TEXT,
63
+ declarationType: C.WARNING,
64
+ },
65
+ {
66
+ id: '5',
67
+ label: "I'm the label of the message filter declaration",
68
+ position: C.BEFORE_QUESTION_TEXT,
69
+ declarationType: C.MESSAGE_FILTER,
70
+ },
71
+ {
72
+ id: '6',
73
+ label: "I'm the label of the statement declaration",
74
+ position: C.BEFORE_QUESTION_TEXT,
75
+ declarationType: C.STATEMENT,
76
+ },
77
+ ];
78
+
79
+ const declarationsVtl = [
80
+ {
81
+ id: '1',
82
+ label: '"I\'m the label of the instruction declaration"',
83
+ position: C.BEFORE_QUESTION_TEXT,
84
+ declarationType: C.INSTRUCTION,
85
+ },
86
+ {
87
+ id: '2',
88
+ label: '"I\'m the label of the comment declaration"',
89
+ position: C.BEFORE_QUESTION_TEXT,
90
+ declarationType: C.COMMENT,
91
+ },
92
+ {
93
+ id: '3',
94
+ label: '"I\'m the label of the help declaration"',
95
+ position: C.BEFORE_QUESTION_TEXT,
96
+ declarationType: C.HELP,
97
+ },
98
+ {
99
+ id: '4',
100
+ label: '"I\'m the label of the warning declaration"',
101
+ position: C.BEFORE_QUESTION_TEXT,
102
+ declarationType: C.WARNING,
103
+ },
104
+ {
105
+ id: '5',
106
+ label: '"I\'m the label of the message filter declaration"',
107
+ position: C.BEFORE_QUESTION_TEXT,
108
+ declarationType: C.MESSAGE_FILTER,
109
+ },
110
+ {
111
+ id: '6',
112
+ label: '"I\'m the label of the statement declaration"',
113
+ position: C.BEFORE_QUESTION_TEXT,
114
+ declarationType: C.STATEMENT,
115
+ },
116
+ ];
@@ -1,44 +1,44 @@
1
- # Dropdown component
2
-
3
- ## Props
4
-
5
- | Props | Type | Default value | Required | Description |
6
- | :--------------: | :----: | :-----------: | :------: | ---------------------------------------------------- |
7
- | id | string | - | ✓ | Id of the dropdown |
8
- | label | string | "" | | Label of the dropdown |
9
- | preferences \* | array | ["COLLECTED"] | | Preferences to manage dropdown response |
10
- | response \* | object | {} | | Response concerned by the component |
11
- | options \* | array | - | ✓ | Options of the dropdown |
12
- | handleChange | func | - | ✓ | Handler of the dropdown |
13
- | placeholderList | string | "" | | Placeholder of the dropdown |
14
- | disabled | bool | false | | Is the dropdown disabled |
15
- | writable | bool | false | | Is the dropdown writable |
16
- | mandatory | bool | false | | Is the dropdown mandatory |
17
- | widthAuto | bool | false | | Add the width-auto props for options of the Dropdown |
18
- | labelPosition \* | string | "DEFAULT" | | Position of the dropdown label |
19
- | declarations \* | array | [] | | Declarations of the dropdown |
20
- | features | array | [ ] | | Component features for labels |
21
- | bindings | object | [ ] | | Questionnaire bindings |
22
- | management | bool | false | | Management mode of the dropdown |
23
- | zIndex | number | 0 | | z-index of the dropdown |
24
- | style | object | {} | | Style of the dropdown |
25
-
26
- - `preferences` props has to be an ordered array of `COLLECTED`, `FORCED` or `EDITED`
27
- - `response` props has to be a shape of `{name: string, values: object}`
28
- - `options` props has to be an array made by objects with a shape of `{label: string, value: string}`
29
- - `labelPosition` props has to be one of `DEFAULT`, `TOP`, `BOTTOM`, `RIGHT` or `LEFT`
30
- - `declarations` are documented in the `Declarations` component
31
-
32
- ## Styles
33
-
34
- **Dropdown** component has cascade classes:
35
-
36
- - `lunatic-dropdown`
37
- - `lunatic-dropdown-container`
38
- - `lunatic-dropdown-content`
39
- - `lunatic-dropdown-input`
40
- - `lunatic-icon`
41
- - `lunatic-transition`
42
- - `lunatic-dropdown-panel`
43
- - `lunatic-dropdown-option`
44
- - `lunatic-prefix`
1
+ # Dropdown component
2
+
3
+ ## Props
4
+
5
+ | Props | Type | Default value | Required | Description |
6
+ | :--------------: | :----: | :-----------: | :------: | ---------------------------------------------------- |
7
+ | id | string | - | ✓ | Id of the dropdown |
8
+ | label | string | "" | | Label of the dropdown |
9
+ | preferences \* | array | ["COLLECTED"] | | Preferences to manage dropdown response |
10
+ | response \* | object | {} | | Response concerned by the component |
11
+ | options \* | array | - | ✓ | Options of the dropdown |
12
+ | handleChange | func | - | ✓ | Handler of the dropdown |
13
+ | placeholderList | string | "" | | Placeholder of the dropdown |
14
+ | disabled | bool | false | | Is the dropdown disabled |
15
+ | writable | bool | false | | Is the dropdown writable |
16
+ | mandatory | bool | false | | Is the dropdown mandatory |
17
+ | widthAuto | bool | false | | Add the width-auto props for options of the Dropdown |
18
+ | labelPosition \* | string | "DEFAULT" | | Position of the dropdown label |
19
+ | declarations \* | array | [] | | Declarations of the dropdown |
20
+ | features | array | [ ] | | Component features for labels |
21
+ | bindings | object | [ ] | | Questionnaire bindings |
22
+ | management | bool | false | | Management mode of the dropdown |
23
+ | zIndex | number | 0 | | z-index of the dropdown |
24
+ | style | object | {} | | Style of the dropdown |
25
+
26
+ - `preferences` props has to be an ordered array of `COLLECTED`, `FORCED` or `EDITED`
27
+ - `response` props has to be a shape of `{name: string, values: object}`
28
+ - `options` props has to be an array made by objects with a shape of `{label: string, value: string}`
29
+ - `labelPosition` props has to be one of `DEFAULT`, `TOP`, `BOTTOM`, `RIGHT` or `LEFT`
30
+ - `declarations` are documented in the `Declarations` component
31
+
32
+ ## Styles
33
+
34
+ **Dropdown** component has cascade classes:
35
+
36
+ - `lunatic-dropdown`
37
+ - `lunatic-dropdown-container`
38
+ - `lunatic-dropdown-content`
39
+ - `lunatic-dropdown-input`
40
+ - `lunatic-icon`
41
+ - `lunatic-transition`
42
+ - `lunatic-dropdown-panel`
43
+ - `lunatic-dropdown-option`
44
+ - `lunatic-prefix`