@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,49 +1,51 @@
1
- const WORKER_PATH =
2
- process.env.LUNATIC_LABEL_WORKER_PATH ||
3
- process.env.REACT_APP_LUNATIC_LABEL_WORKER_PATH;
4
-
5
- let WORKER;
6
- const TASKS = new Map();
7
-
8
- function getIdTask() {
9
- const id = `${Date.now()}`;
10
- if (id in TASKS) {
11
- return getIdTask();
12
- }
13
- return id;
14
- }
15
-
16
- function getWorker() {
17
- if (!WORKER) {
18
- WORKER = new Worker(WORKER_PATH);
19
- WORKER.addEventListener('message', function (e) {
20
- const { data } = e;
21
- const { response, idTask } = data;
22
- if (idTask in TASKS) {
23
- TASKS[idTask](response);
24
- }
25
- });
26
- }
27
- return WORKER;
28
- }
29
-
30
- /**
31
- *
32
- * @param {*} option
33
- * @param {*} search
34
- * @returns
35
- */
36
- function findBestLabel(option, search) {
37
- return new Promise(function (resolve) {
38
- const idTask = getIdTask();
39
- const worker = getWorker();
40
-
41
- TASKS[idTask] = function (response) {
42
- resolve(response);
43
- delete TASKS[idTask];
44
- };
45
- worker.postMessage({ option, search, idTask });
46
- });
47
- }
48
-
49
- export default findBestLabel;
1
+ import { createWorker } from '../../../utils/suggester-workers/create-worker';
2
+
3
+ const WORKER_PATH =
4
+ process.env.LUNATIC_LABEL_WORKER_PATH ||
5
+ process.env.REACT_APP_LUNATIC_LABEL_WORKER_PATH;
6
+
7
+ let WORKER;
8
+ const TASKS = new Map();
9
+
10
+ function getIdTask() {
11
+ const id = `${Date.now()}`;
12
+ if (id in TASKS) {
13
+ return getIdTask();
14
+ }
15
+ return id;
16
+ }
17
+
18
+ function getWorker() {
19
+ if (!WORKER) {
20
+ WORKER = createWorker(WORKER_PATH);
21
+ WORKER.addEventListener('message', function (e) {
22
+ const { data } = e;
23
+ const { response, idTask } = data;
24
+ if (idTask in TASKS) {
25
+ TASKS[idTask](response);
26
+ }
27
+ });
28
+ }
29
+ return WORKER;
30
+ }
31
+
32
+ /**
33
+ *
34
+ * @param {*} option
35
+ * @param {*} search
36
+ * @returns
37
+ */
38
+ function findBestLabel(option, search) {
39
+ return new Promise(function (resolve) {
40
+ const idTask = getIdTask();
41
+ const worker = getWorker();
42
+
43
+ TASKS[idTask] = function (response) {
44
+ resolve(response);
45
+ delete TASKS[idTask];
46
+ };
47
+ worker.postMessage({ option, search, idTask });
48
+ });
49
+ }
50
+
51
+ export default findBestLabel;
@@ -1 +1 @@
1
- export { default } from './find-best-label';
1
+ export { default } from './find-best-label';
@@ -1,67 +1,73 @@
1
- import React, { useEffect, useMemo, useState } from 'react';
2
- import PropTypes from 'prop-types';
3
- import SuggesterWrapper from './suggester-wrapper';
4
- import createSearching from './searching';
5
- import CheckStore from './check-store';
6
-
7
- function IDBSuggester({
8
- storeName,
9
- idbVersion,
10
- id,
11
- className,
12
- labelledBy,
13
- optionRenderer,
14
- labelRenderer,
15
- onSelect,
16
- disabled,
17
- value,
18
- }) {
19
- const [store, setStore] = useState(undefined);
20
- const searching = useMemo(
21
- function () {
22
- if (store) {
23
- return createSearching(storeName, idbVersion);
24
- }
25
- return undefined;
26
- },
27
- [storeName, idbVersion, store]
28
- );
29
-
30
- return (
31
- <CheckStore
32
- storeName={storeName}
33
- idbVersion={idbVersion}
34
- setStore={setStore}
35
- >
36
- <SuggesterWrapper
37
- id={id}
38
- className={className}
39
- labelledBy={labelledBy}
40
- optionRenderer={optionRenderer}
41
- labelRenderer={labelRenderer}
42
- onSelect={onSelect}
43
- searching={searching}
44
- storeName={storeName}
45
- disabled={disabled}
46
- value={value}
47
- />
48
- </CheckStore>
49
- );
50
- }
51
-
52
- IDBSuggester.defaultProps = {
53
- idbVersion: '1',
54
- };
55
-
56
- IDBSuggester.propTypes = {
57
- storeName: PropTypes.string.isRequired,
58
- idbVersion: PropTypes.string,
59
- id: PropTypes.string,
60
- className: PropTypes.string,
61
- labelledBy: PropTypes.string,
62
- optionRenderer: PropTypes.func,
63
- labelRenderer: PropTypes.func,
64
- onSelect: PropTypes.func,
65
- };
66
-
67
- export default IDBSuggester;
1
+ import React, { useMemo, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import SuggesterWrapper from './suggester-wrapper';
4
+ import createSearching from './searching';
5
+ import CheckStore from './check-store';
6
+
7
+ function IDBSuggester({
8
+ storeName,
9
+ idbVersion,
10
+ id,
11
+ className,
12
+ labelledBy,
13
+ optionRenderer,
14
+ labelRenderer,
15
+ onSelect,
16
+ disabled,
17
+ value,
18
+ focused,
19
+ response,
20
+ logFunction,
21
+ }) {
22
+ const [store, setStore] = useState(undefined);
23
+ const searching = useMemo(
24
+ function () {
25
+ if (store) {
26
+ return createSearching(storeName, idbVersion);
27
+ }
28
+ return undefined;
29
+ },
30
+ [storeName, idbVersion, store]
31
+ );
32
+
33
+ return (
34
+ <CheckStore
35
+ storeName={storeName}
36
+ idbVersion={idbVersion}
37
+ setStore={setStore}
38
+ >
39
+ <SuggesterWrapper
40
+ id={id}
41
+ className={className}
42
+ labelledBy={labelledBy}
43
+ optionRenderer={optionRenderer}
44
+ labelRenderer={labelRenderer}
45
+ onSelect={onSelect}
46
+ searching={searching}
47
+ storeName={storeName}
48
+ disabled={disabled}
49
+ value={value}
50
+ focused={focused}
51
+ response={response}
52
+ logFunction={logFunction}
53
+ />
54
+ </CheckStore>
55
+ );
56
+ }
57
+
58
+ IDBSuggester.defaultProps = {
59
+ idbVersion: '1',
60
+ };
61
+
62
+ IDBSuggester.propTypes = {
63
+ storeName: PropTypes.string.isRequired,
64
+ idbVersion: PropTypes.string,
65
+ id: PropTypes.string,
66
+ className: PropTypes.string,
67
+ labelledBy: PropTypes.string,
68
+ optionRenderer: PropTypes.func,
69
+ labelRenderer: PropTypes.func,
70
+ onSelect: PropTypes.func,
71
+ };
72
+
73
+ export default IDBSuggester;
@@ -1,137 +1,140 @@
1
- import React, { useCallback, useState, useEffect } from 'react';
2
- import PropTypes from 'prop-types';
3
- import Declarations from '../declarations';
4
- import * as U from '../../utils/lib';
5
- import * as C from '../../constants';
6
- import IDBSuggester from './idb-suggester';
7
- import LabelWrapper from '../../utils/components/label-wrapper';
8
- import FieldWrapper from '../../utils/components/field-wrapper';
9
-
10
- function getSuggestionId(suggestion) {
11
- if (suggestion) {
12
- return suggestion.id;
13
- }
14
- return null;
15
- }
16
-
17
- function Suggester({
18
- id,
19
- label,
20
- preferences,
21
- response,
22
- handleChange,
23
- disabled,
24
- focused,
25
- declarations,
26
- features,
27
- bindings,
28
- management,
29
- labelPosition,
30
- style,
31
- logFunction,
32
- storeName,
33
- optionRenderer,
34
- labelRenderer,
35
- idbVersion,
36
- }) {
37
- const [value, setValue] = useState(() =>
38
- U.getResponseByPreference(preferences)(response)
39
- );
40
- const labelId = `suggester-label-${id}`;
41
- const onSelect = useCallback(
42
- function (suggestion) {
43
- const ids = getSuggestionId(suggestion);
44
- handleChange({
45
- [U.getResponseName(response)]: ids,
46
- });
47
- setValue(ids);
48
- },
49
- [handleChange, response]
50
- );
51
-
52
- return (
53
- <>
54
- <Declarations
55
- id={id}
56
- type={C.BEFORE_QUESTION_TEXT}
57
- declarations={declarations}
58
- features={features}
59
- bindings={bindings}
60
- />
61
- <LabelWrapper
62
- id={labelId}
63
- htmlFor={id}
64
- labelPosition={labelPosition}
65
- bindings={bindings}
66
- label={label}
67
- features={features}
68
- logFunction={logFunction}
69
- >
70
- <Declarations
71
- id={id}
72
- type={C.AFTER_QUESTION_TEXT}
73
- declarations={declarations}
74
- features={features}
75
- bindings={bindings}
76
- />
77
- <FieldWrapper id={id} management={management} response={response}>
78
- <IDBSuggester
79
- storeName={storeName}
80
- optionRenderer={optionRenderer}
81
- labelRenderer={labelRenderer}
82
- labelledBy={labelId}
83
- idbVersion={idbVersion}
84
- onSelect={onSelect}
85
- focused={focused}
86
- disabled={disabled}
87
- response={response}
88
- id={id}
89
- value={value}
90
- />
91
- </FieldWrapper>
92
- </LabelWrapper>
93
- <Declarations
94
- id={id}
95
- type={C.DETACHABLE}
96
- declarations={declarations}
97
- features={features}
98
- bindings={bindings}
99
- />
100
- </>
101
- );
102
- }
103
-
104
- Suggester.defaultProps = {
105
- label: '',
106
- preferences: ['COLLECTED'],
107
- response: {},
108
- disabled: false,
109
- focused: false,
110
- declarations: [],
111
- features: [],
112
- bindings: {},
113
- management: false,
114
- labelPosition: 'DEFAULT',
115
- style: {},
116
- getStoreInfo: undefined,
117
- };
118
-
119
- Suggester.propTypes = {
120
- id: PropTypes.string.isRequired,
121
- label: PropTypes.string,
122
- preferences: PropTypes.arrayOf(U.valueTypePropTypes),
123
- response: U.responsePropTypes,
124
- handleChange: PropTypes.func.isRequired,
125
- disabled: PropTypes.bool,
126
- focused: PropTypes.bool,
127
- declarations: U.declarationsPropTypes,
128
- features: PropTypes.arrayOf(PropTypes.string),
129
- bindings: PropTypes.object,
130
- management: PropTypes.bool,
131
- labelPosition: PropTypes.oneOf(['DEFAULT', 'TOP', 'BOTTOM', 'LEFT', 'RIGHT']),
132
- style: PropTypes.object,
133
- storeInfo: PropTypes.object, //TODO
134
- getStoreInfo: PropTypes.func,
135
- };
136
-
137
- export default React.memo(Suggester, U.areEqual);
1
+ import React, { useCallback, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import componentWrapper from '../component-wrapper';
4
+ import Declarations from '../declarations';
5
+ import * as U from '../../utils/lib';
6
+ import * as C from '../../constants';
7
+ import IDBSuggester from './idb-suggester';
8
+ import LabelWrapper from '../../utils/components/label-wrapper';
9
+ import FieldWrapper from '../../utils/components/field-wrapper';
10
+
11
+ function getSuggestionId(suggestion) {
12
+ if (suggestion) {
13
+ return suggestion.id;
14
+ }
15
+ return null;
16
+ }
17
+
18
+ function Suggester({
19
+ id,
20
+ label,
21
+ preferences,
22
+ response,
23
+ handleChange,
24
+ disabled,
25
+ focused,
26
+ declarations,
27
+ features,
28
+ bindings,
29
+ management,
30
+ labelPosition,
31
+ style,
32
+ logFunction,
33
+ storeName,
34
+ optionRenderer,
35
+ labelRenderer,
36
+ idbVersion,
37
+ }) {
38
+ const [value, setValue] = useState(() =>
39
+ U.getResponseByPreference(preferences)(response)
40
+ );
41
+ const labelId = `suggester-label-${id}`;
42
+ const onSelect = useCallback(
43
+ function (suggestion) {
44
+ const ids = getSuggestionId(suggestion);
45
+ // Delete: null --> empty to handle controls
46
+ handleChange({
47
+ [U.getResponseName(response)]: ids || '',
48
+ });
49
+ setValue(ids);
50
+ },
51
+ [handleChange, response]
52
+ );
53
+
54
+ return (
55
+ <>
56
+ <Declarations
57
+ id={id}
58
+ type={C.BEFORE_QUESTION_TEXT}
59
+ declarations={declarations}
60
+ features={features}
61
+ bindings={bindings}
62
+ />
63
+ <LabelWrapper
64
+ id={labelId}
65
+ htmlFor={id}
66
+ labelPosition={labelPosition}
67
+ bindings={bindings}
68
+ label={label}
69
+ features={features}
70
+ logFunction={logFunction}
71
+ >
72
+ <Declarations
73
+ id={id}
74
+ type={C.AFTER_QUESTION_TEXT}
75
+ declarations={declarations}
76
+ features={features}
77
+ bindings={bindings}
78
+ />
79
+ <FieldWrapper id={id} management={management} response={response}>
80
+ <IDBSuggester
81
+ storeName={storeName}
82
+ optionRenderer={optionRenderer}
83
+ labelRenderer={labelRenderer}
84
+ labelledBy={labelId}
85
+ idbVersion={idbVersion}
86
+ onSelect={onSelect}
87
+ focused={focused}
88
+ disabled={disabled}
89
+ response={response}
90
+ id={id}
91
+ value={value}
92
+ logFunction={logFunction}
93
+ />
94
+ </FieldWrapper>
95
+ </LabelWrapper>
96
+ <Declarations
97
+ id={id}
98
+ type={C.DETACHABLE}
99
+ declarations={declarations}
100
+ features={features}
101
+ bindings={bindings}
102
+ />
103
+ </>
104
+ );
105
+ }
106
+
107
+ Suggester.defaultProps = {
108
+ label: '',
109
+ preferences: ['COLLECTED'],
110
+ response: {},
111
+ disabled: false,
112
+ focused: false,
113
+ declarations: [],
114
+ features: [],
115
+ bindings: {},
116
+ management: false,
117
+ labelPosition: 'DEFAULT',
118
+ style: {},
119
+ getStoreInfo: undefined,
120
+ };
121
+
122
+ Suggester.propTypes = {
123
+ id: PropTypes.string.isRequired,
124
+ label: PropTypes.string,
125
+ preferences: PropTypes.arrayOf(U.valueTypePropTypes),
126
+ response: U.responsePropTypes,
127
+ handleChange: PropTypes.func.isRequired,
128
+ disabled: PropTypes.bool,
129
+ focused: PropTypes.bool,
130
+ declarations: U.declarationsPropTypes,
131
+ features: PropTypes.arrayOf(PropTypes.string),
132
+ bindings: PropTypes.object,
133
+ management: PropTypes.bool,
134
+ labelPosition: PropTypes.oneOf(['DEFAULT', 'TOP', 'BOTTOM', 'LEFT', 'RIGHT']),
135
+ style: PropTypes.object,
136
+ storeInfo: PropTypes.object, //TODO
137
+ getStoreInfo: PropTypes.func,
138
+ };
139
+
140
+ export default componentWrapper(React.memo(Suggester, U.areEqual));
@@ -1,47 +1,49 @@
1
- const WORKER_PATH =
2
- process.env.LUNATIC_SEARCH_WORKER_PATH ||
3
- process.env.REACT_APP_LUNATIC_SEARCH_WORKER_PATH;
4
-
5
- export function isWorkerCompatible() {
6
- if (window.Worker) {
7
- return true;
8
- }
9
- return false;
10
- }
11
-
12
- const searching = (worker) => (search, name, version) => {
13
- if (!WORKER_PATH) {
14
- throw new Error("Worker path is required for suggester's searches.");
15
- }
16
- if (isWorkerCompatible()) {
17
- return new Promise(function (resolve) {
18
- try {
19
- if (worker) {
20
- worker.terminate();
21
- }
22
- worker = new Worker(WORKER_PATH);
23
- worker.postMessage({ search, name, version });
24
- worker.addEventListener('message', function (e) {
25
- const { data } = e;
26
- resolve(data);
27
- worker.terminate();
28
- worker = undefined;
29
- });
30
- } catch (e) {
31
- //TODO
32
- }
33
- });
34
- } else {
35
- // TODO
36
- }
37
- };
38
-
39
- function createSearching(name, version) {
40
- let worker = undefined;
41
- const searching_ = searching(worker);
42
- return async function (search) {
43
- return searching_(search, name, version);
44
- };
45
- }
46
-
47
- export default createSearching;
1
+ import { createWorker } from '../../../utils/suggester-workers/create-worker';
2
+
3
+ const WORKER_PATH =
4
+ process.env.LUNATIC_SEARCH_WORKER_PATH ||
5
+ process.env.REACT_APP_LUNATIC_SEARCH_WORKER_PATH;
6
+
7
+ export function isWorkerCompatible() {
8
+ if (window.Worker) {
9
+ return true;
10
+ }
11
+ return false;
12
+ }
13
+
14
+ const searching = (worker) => (search, name, version) => {
15
+ if (!WORKER_PATH) {
16
+ throw new Error("Worker path is required for suggester's searches.");
17
+ }
18
+ if (isWorkerCompatible()) {
19
+ return new Promise(function (resolve) {
20
+ try {
21
+ if (worker) {
22
+ worker.terminate();
23
+ }
24
+ worker = createWorker(WORKER_PATH);
25
+ worker.postMessage({ search, name, version });
26
+ worker.addEventListener('message', function (e) {
27
+ const { data } = e;
28
+ resolve(data);
29
+ worker.terminate();
30
+ worker = undefined;
31
+ });
32
+ } catch (e) {
33
+ //TODO
34
+ }
35
+ });
36
+ } else {
37
+ // TODO
38
+ }
39
+ };
40
+
41
+ function createSearching(name, version) {
42
+ let worker = undefined;
43
+ const searching_ = searching(worker);
44
+ return async function (search) {
45
+ return searching_(search, name, version);
46
+ };
47
+ }
48
+
49
+ export default createSearching;
@@ -1 +1 @@
1
- export { default } from './create-searching';
1
+ export { default } from './create-searching';