@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,38 +1,38 @@
1
- export const ON_INIT = 'lunatic-suggester/on-init';
2
- export const onInit = ({ id, disabled, value }) => ({
3
- type: ON_INIT,
4
- payload: { id, disabled, value },
5
- });
6
-
7
- export const ON_CHANGE_SEARCH = 'lunatic-suggester/on-change-search';
8
- export const onChangeSearch = (search) => ({
9
- type: ON_CHANGE_SEARCH,
10
- payload: { search },
11
- });
12
-
13
- export const ON_UPDATE_OPTIONS = 'lunatic-suggester/on-update-options';
14
- export const onUpdateOptions = (options, search) => ({
15
- type: ON_UPDATE_OPTIONS,
16
- payload: { options, search },
17
- });
18
-
19
- export const ON_FOCUS = 'lunatic-suggester/on-focus';
20
- export const onFocus = () => ({ type: ON_FOCUS });
21
-
22
- export const ON_BLUR = 'lunatic-suggester/on-blur';
23
- export const onBlur = () => ({ type: ON_BLUR });
24
-
25
- export const ON_CLICK_OPTION = 'lunatic-suggester/on-click-option';
26
- export const onClickOption = (index) => ({
27
- type: ON_CLICK_OPTION,
28
- payload: { index },
29
- });
30
-
31
- export const ON_KEY_DOWN = 'lunatic-suggester/on-key-down';
32
- export const onKeyDown = (key) => ({ type: ON_KEY_DOWN, payload: { key } });
33
-
34
- export const ON_ERROR = 'lunatic-suggester/on-error';
35
- export const onError = (message) => ({ type: ON_ERROR, payload: { message } });
36
-
37
- export const ON_DELETE_SEARCH = 'lunatic-suggester/on-delete-search';
38
- export const onDeleteSearch = () => ({ type: ON_DELETE_SEARCH });
1
+ export const ON_INIT = 'lunatic-suggester/on-init';
2
+ export const onInit = ({ id, disabled, value }) => ({
3
+ type: ON_INIT,
4
+ payload: { id, disabled, value },
5
+ });
6
+
7
+ export const ON_CHANGE_SEARCH = 'lunatic-suggester/on-change-search';
8
+ export const onChangeSearch = (search) => ({
9
+ type: ON_CHANGE_SEARCH,
10
+ payload: { search },
11
+ });
12
+
13
+ export const ON_UPDATE_OPTIONS = 'lunatic-suggester/on-update-options';
14
+ export const onUpdateOptions = (options, search) => ({
15
+ type: ON_UPDATE_OPTIONS,
16
+ payload: { options, search },
17
+ });
18
+
19
+ export const ON_FOCUS = 'lunatic-suggester/on-focus';
20
+ export const onFocus = () => ({ type: ON_FOCUS });
21
+
22
+ export const ON_BLUR = 'lunatic-suggester/on-blur';
23
+ export const onBlur = () => ({ type: ON_BLUR });
24
+
25
+ export const ON_CLICK_OPTION = 'lunatic-suggester/on-click-option';
26
+ export const onClickOption = (index) => ({
27
+ type: ON_CLICK_OPTION,
28
+ payload: { index },
29
+ });
30
+
31
+ export const ON_KEY_DOWN = 'lunatic-suggester/on-key-down';
32
+ export const onKeyDown = (key) => ({ type: ON_KEY_DOWN, payload: { key } });
33
+
34
+ export const ON_ERROR = 'lunatic-suggester/on-error';
35
+ export const onError = (message) => ({ type: ON_ERROR, payload: { message } });
36
+
37
+ export const ON_DELETE_SEARCH = 'lunatic-suggester/on-delete-search';
38
+ export const onDeleteSearch = () => ({ type: ON_DELETE_SEARCH });
@@ -1,11 +1,11 @@
1
- function reduce(state) {
2
- return {
3
- ...state,
4
- search: '',
5
- selectedIndex: undefined,
6
- options: [],
7
- expanded: false,
8
- };
9
- }
10
-
11
- export default reduce;
1
+ function reduce(state) {
2
+ return {
3
+ ...state,
4
+ search: '',
5
+ selectedIndex: undefined,
6
+ options: [],
7
+ expanded: false,
8
+ };
9
+ }
10
+
11
+ export default reduce;
@@ -1,29 +1,29 @@
1
- function getStringValue(value) {
2
- if (value) {
3
- return `${value}`;
4
- }
5
- return '';
6
- }
7
-
8
- function getId() {
9
- return `lunatic-suggester-${new Date().getTime()}`;
10
- }
11
-
12
- function reduce(state, action) {
13
- const { payload } = action;
14
- const { id, disabled, value } = payload;
15
- const { search } = state;
16
-
17
- if (value && search.length === 0) {
18
- return {
19
- ...state,
20
- id: id || getId(),
21
- disabled,
22
- search: getStringValue(value),
23
- };
24
- }
25
-
26
- return { ...state, id: id || getId(), disabled };
27
- }
28
-
29
- export default reduce;
1
+ function getStringValue(value) {
2
+ if (value) {
3
+ return `${value}`;
4
+ }
5
+ return '';
6
+ }
7
+
8
+ function getId() {
9
+ return `lunatic-suggester-${new Date().getTime()}`;
10
+ }
11
+
12
+ function reduce(state, action) {
13
+ const { payload } = action;
14
+ const { id, disabled, value } = payload;
15
+ const { search } = state;
16
+
17
+ if (value && search.length === 0) {
18
+ return {
19
+ ...state,
20
+ id: id || getId(),
21
+ disabled,
22
+ search: getStringValue(value),
23
+ };
24
+ }
25
+
26
+ return { ...state, id: id || getId(), disabled };
27
+ }
28
+
29
+ export default reduce;
@@ -1,38 +1,38 @@
1
- import * as actions from '../actions';
2
- import reduceOnChangeSearch from './reduce-on-change-search';
3
- import reduceOnUpdateOptions from './reduce-on-update-options';
4
- import reduceOnFocus from './reduce-on-focus';
5
- import reduceOnBlur from './reduce-on-blur';
6
- import reduceOnClickOption from './reduce-on-click-option';
7
- import reduceOnKeyDown from './reduce-on-key-down';
8
- import reduceOnInit from './reduce-on-init';
9
- import reduceOnError from './reduce-on-error';
10
- import reduceOnDeleteSearch from './reduce-on-delete-search';
11
-
12
- function reduce(state, action) {
13
- const { type } = action;
14
- switch (type) {
15
- case actions.ON_CHANGE_SEARCH:
16
- return reduceOnChangeSearch(state, action);
17
- case actions.ON_UPDATE_OPTIONS:
18
- return reduceOnUpdateOptions(state, action);
19
- case actions.ON_FOCUS:
20
- return reduceOnFocus(state, action);
21
- case actions.ON_BLUR:
22
- return reduceOnBlur(state, action);
23
- case actions.ON_CLICK_OPTION:
24
- return reduceOnClickOption(state, action);
25
- case actions.ON_KEY_DOWN:
26
- return reduceOnKeyDown(state, action);
27
- case actions.ON_INIT:
28
- return reduceOnInit(state, action);
29
- case actions.ON_ERROR:
30
- return reduceOnError(state, action);
31
- case actions.ON_DELETE_SEARCH:
32
- return reduceOnDeleteSearch(state, action);
33
- default:
34
- return state;
35
- }
36
- }
37
-
38
- export default reduce;
1
+ import * as actions from '../actions';
2
+ import reduceOnChangeSearch from './reduce-on-change-search';
3
+ import reduceOnUpdateOptions from './reduce-on-update-options';
4
+ import reduceOnFocus from './reduce-on-focus';
5
+ import reduceOnBlur from './reduce-on-blur';
6
+ import reduceOnClickOption from './reduce-on-click-option';
7
+ import reduceOnKeyDown from './reduce-on-key-down';
8
+ import reduceOnInit from './reduce-on-init';
9
+ import reduceOnError from './reduce-on-error';
10
+ import reduceOnDeleteSearch from './reduce-on-delete-search';
11
+
12
+ function reduce(state, action) {
13
+ const { type } = action;
14
+ switch (type) {
15
+ case actions.ON_CHANGE_SEARCH:
16
+ return reduceOnChangeSearch(state, action);
17
+ case actions.ON_UPDATE_OPTIONS:
18
+ return reduceOnUpdateOptions(state, action);
19
+ case actions.ON_FOCUS:
20
+ return reduceOnFocus(state, action);
21
+ case actions.ON_BLUR:
22
+ return reduceOnBlur(state, action);
23
+ case actions.ON_CLICK_OPTION:
24
+ return reduceOnClickOption(state, action);
25
+ case actions.ON_KEY_DOWN:
26
+ return reduceOnKeyDown(state, action);
27
+ case actions.ON_INIT:
28
+ return reduceOnInit(state, action);
29
+ case actions.ON_ERROR:
30
+ return reduceOnError(state, action);
31
+ case actions.ON_DELETE_SEARCH:
32
+ return reduceOnDeleteSearch(state, action);
33
+ default:
34
+ return state;
35
+ }
36
+ }
37
+
38
+ export default reduce;
@@ -1,121 +1,127 @@
1
- import React, { useReducer, useEffect } from 'react';
2
- import PropTypes from 'prop-types';
3
- import {
4
- reducer,
5
- INITIAL_STATE,
6
- SuggesterContext,
7
- actions,
8
- } from './state-management';
9
- import { Suggester } from './components';
10
- import DefaultLabelRenderer from './components/selection/default-label-renderer';
11
- import { DefaultOptionRenderer } from './components';
12
- import './default-style.scss';
13
-
14
- function getSearch(search, value) {
15
- if (search && search.length) {
16
- return search;
17
- }
18
- return value;
19
- }
20
-
21
- function SuggesterWrapper({
22
- id,
23
- className,
24
- version,
25
- labelledBy,
26
- placeholderList,
27
- optionRenderer,
28
- onSelect,
29
- searching,
30
- labelRenderer,
31
- disabled,
32
- value,
33
- }) {
34
- const [state, dispatch] = useReducer(reducer, INITIAL_STATE);
35
- const { search, selectedIndex, options } = state;
36
-
37
- useEffect(
38
- function () {
39
- async function doIt() {
40
- try {
41
- const what = getSearch(search, value);
42
- if (what && typeof searching === 'function') {
43
- const { results, search: old } = await searching(what);
44
- dispatch(actions.onUpdateOptions(results, old));
45
- } else {
46
- dispatch(actions.onDeleteSearch());
47
- }
48
- } catch (e) {
49
- console.error(e);
50
- dispatch(actions.onError('Une erreur est survenue.'));
51
- }
52
- }
53
- doIt();
54
- },
55
- [search, searching, value]
56
- );
57
-
58
- useEffect(
59
- function () {
60
- if (selectedIndex !== undefined) {
61
- onSelect(options[selectedIndex], selectedIndex);
62
- }
63
- },
64
- [selectedIndex, onSelect, options]
65
- );
66
-
67
- useEffect(
68
- function () {
69
- dispatch(actions.onInit({ id, disabled, value }));
70
- },
71
- [id, disabled, value]
72
- );
73
-
74
- return (
75
- <SuggesterContext.Provider value={[state, dispatch]}>
76
- <Suggester
77
- className={className}
78
- placeholderList={placeholderList}
79
- version={version}
80
- labelledBy={labelledBy}
81
- optionRenderer={optionRenderer}
82
- labelRenderer={labelRenderer}
83
- onSelect={onSelect}
84
- value={value}
85
- />
86
- </SuggesterContext.Provider>
87
- );
88
- }
89
-
90
- SuggesterWrapper.propTypes = {
91
- id: PropTypes.string,
92
- className: PropTypes.string,
93
- placeholderList: PropTypes.string,
94
- labelledBy: PropTypes.string,
95
- optionRenderer: PropTypes.func,
96
- labelRenderer: PropTypes.func,
97
- onSelect: PropTypes.func,
98
- storeInfo: PropTypes.object,
99
- value: PropTypes.oneOfType([
100
- PropTypes.string,
101
- PropTypes.number,
102
- PropTypes.bool,
103
- PropTypes.object,
104
- ]),
105
- searching: PropTypes.func,
106
- };
107
-
108
- SuggesterWrapper.defaultProps = {
109
- id: undefined,
110
- className: 'lunatic-suggester-default-style',
111
- labelledBy: undefined,
112
- placeholderList: 'Veuillez...',
113
- optionRenderer: DefaultOptionRenderer,
114
- labelRenderer: DefaultLabelRenderer,
115
- language: 'French',
116
- onSelect: () => null,
117
- value: undefined,
118
- searching: undefined,
119
- };
120
-
121
- export default SuggesterWrapper;
1
+ import React, { useReducer, useEffect } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import {
4
+ reducer,
5
+ INITIAL_STATE,
6
+ SuggesterContext,
7
+ actions,
8
+ } from './state-management';
9
+ import { Suggester } from './components';
10
+ import DefaultLabelRenderer from './components/selection/default-label-renderer';
11
+ import { DefaultOptionRenderer } from './components';
12
+ import './default-style.scss';
13
+
14
+ function getSearch(search, value) {
15
+ if (search && search.length) {
16
+ return search;
17
+ }
18
+ return value;
19
+ }
20
+
21
+ function SuggesterWrapper({
22
+ id,
23
+ className,
24
+ version,
25
+ labelledBy,
26
+ placeholderList,
27
+ optionRenderer,
28
+ onSelect,
29
+ searching,
30
+ labelRenderer,
31
+ disabled,
32
+ value,
33
+ focused,
34
+ response,
35
+ logFunction,
36
+ }) {
37
+ const [state, dispatch] = useReducer(reducer, INITIAL_STATE);
38
+ const { search, selectedIndex, options, expended } = state;
39
+
40
+ useEffect(
41
+ function () {
42
+ async function doIt() {
43
+ try {
44
+ const what = getSearch(search, value);
45
+ if (what && typeof searching === 'function') {
46
+ const { results, search: old } = await searching(what);
47
+ dispatch(actions.onUpdateOptions(results, old));
48
+ } else {
49
+ dispatch(actions.onDeleteSearch());
50
+ }
51
+ } catch (e) {
52
+ console.error(e);
53
+ dispatch(actions.onError('Une erreur est survenue.'));
54
+ }
55
+ }
56
+ doIt();
57
+ },
58
+ [search, searching, value]
59
+ );
60
+
61
+ useEffect(
62
+ function () {
63
+ if (selectedIndex !== undefined && !expended) {
64
+ onSelect(options[selectedIndex], selectedIndex);
65
+ }
66
+ },
67
+ [selectedIndex, onSelect, options, expended]
68
+ );
69
+
70
+ useEffect(
71
+ function () {
72
+ dispatch(actions.onInit({ id, disabled, value }));
73
+ },
74
+ [id, disabled, value]
75
+ );
76
+
77
+ return (
78
+ <SuggesterContext.Provider value={[state, dispatch]}>
79
+ <Suggester
80
+ className={className}
81
+ placeholderList={placeholderList}
82
+ version={version}
83
+ labelledBy={labelledBy}
84
+ optionRenderer={optionRenderer}
85
+ labelRenderer={labelRenderer}
86
+ onSelect={onSelect}
87
+ value={value}
88
+ focused={focused}
89
+ response={response}
90
+ logFunction={logFunction}
91
+ />
92
+ </SuggesterContext.Provider>
93
+ );
94
+ }
95
+
96
+ SuggesterWrapper.propTypes = {
97
+ id: PropTypes.string,
98
+ className: PropTypes.string,
99
+ placeholderList: PropTypes.string,
100
+ labelledBy: PropTypes.string,
101
+ optionRenderer: PropTypes.func,
102
+ labelRenderer: PropTypes.func,
103
+ onSelect: PropTypes.func,
104
+ storeInfo: PropTypes.object,
105
+ value: PropTypes.oneOfType([
106
+ PropTypes.string,
107
+ PropTypes.number,
108
+ PropTypes.bool,
109
+ PropTypes.object,
110
+ ]),
111
+ searching: PropTypes.func,
112
+ };
113
+
114
+ SuggesterWrapper.defaultProps = {
115
+ id: undefined,
116
+ className: 'lunatic-suggester-default-style',
117
+ labelledBy: undefined,
118
+ placeholderList: 'Veuillez...',
119
+ optionRenderer: DefaultOptionRenderer,
120
+ labelRenderer: DefaultLabelRenderer,
121
+ language: 'French',
122
+ onSelect: () => null,
123
+ value: undefined,
124
+ searching: undefined,
125
+ };
126
+
127
+ export default SuggesterWrapper;
@@ -1,67 +1,67 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { createAppendTask } from '../../utils/suggester-workers/append-to-index';
3
- import Progress from './progress';
4
- import { clearStoreData } from '../../utils/store-tools';
5
-
6
- function empty() {}
7
-
8
- function Loader({ start, db, store, idbVersion, fetch, post, handleClick }) {
9
- const [progress, setProgress] = useState(0);
10
- const [entities, setEntities] = useState(undefined);
11
-
12
- useEffect(
13
- function () {
14
- async function load() {
15
- if (typeof fetch === 'function' && start) {
16
- const e = await fetch();
17
- setEntities(e);
18
- }
19
- }
20
- load();
21
- },
22
- [fetch, start]
23
- );
24
-
25
- function log({ message }) {
26
- const { type, percent } = message;
27
- if (type === 'bulk-insert/complete') {
28
- setProgress(percent);
29
- }
30
- }
31
-
32
- useEffect(
33
- function () {
34
- let abort;
35
- async function go() {
36
- try {
37
- if (entities && db && idbVersion && store) {
38
- const [startT, abort_] = createAppendTask(store, idbVersion, log);
39
- abort = abort_;
40
- clearStoreData(db);
41
- await startT(entities);
42
- post(store.name, entities.length);
43
- }
44
- } catch (e) {
45
- console.warn(e);
46
- }
47
- }
48
-
49
- go();
50
-
51
- return function () {
52
- if (abort) {
53
- abort();
54
- }
55
- };
56
- },
57
- [store, db, entities, idbVersion, post]
58
- );
59
-
60
- return (
61
- <Progress percent={progress} display={true} handleClick={handleClick} />
62
- );
63
- }
64
-
65
- Loader.defaultProps = { idbVersion: '1', post: empty, handleClick: empty };
66
-
67
- export default Loader;
1
+ import React, { useEffect, useState } from 'react';
2
+ import { createAppendTask } from '../../utils/suggester-workers/append-to-index';
3
+ import Progress from './progress';
4
+ import { clearStoreData } from '../../utils/store-tools';
5
+
6
+ function empty() {}
7
+
8
+ function Loader({ start, db, store, idbVersion, fetch, post, handleClick }) {
9
+ const [progress, setProgress] = useState(0);
10
+ const [entities, setEntities] = useState(undefined);
11
+
12
+ useEffect(
13
+ function () {
14
+ async function load() {
15
+ if (typeof fetch === 'function' && start) {
16
+ const e = await fetch();
17
+ setEntities(e);
18
+ }
19
+ }
20
+ load();
21
+ },
22
+ [fetch, start]
23
+ );
24
+
25
+ function log({ message }) {
26
+ const { type, percent } = message;
27
+ if (type === 'bulk-insert/complete') {
28
+ setProgress(percent);
29
+ }
30
+ }
31
+
32
+ useEffect(
33
+ function () {
34
+ let abort;
35
+ async function go() {
36
+ try {
37
+ if (entities && db && idbVersion && store) {
38
+ const [startT, abort_] = createAppendTask(store, idbVersion, log);
39
+ abort = abort_;
40
+ clearStoreData(db);
41
+ await startT(entities);
42
+ post(store.name, entities.length);
43
+ }
44
+ } catch (e) {
45
+ console.warn(e);
46
+ }
47
+ }
48
+
49
+ go();
50
+
51
+ return function () {
52
+ if (abort) {
53
+ abort();
54
+ }
55
+ };
56
+ },
57
+ [store, db, entities, idbVersion, post]
58
+ );
59
+
60
+ return (
61
+ <Progress percent={progress} display={true} handleClick={handleClick} />
62
+ );
63
+ }
64
+
65
+ Loader.defaultProps = { idbVersion: '1', post: empty, handleClick: empty };
66
+
67
+ export default Loader;