@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
@@ -0,0 +1,142 @@
1
+ const getBindingsDependenciesCalculated = (variables) => {
2
+ if (!variables) return {};
3
+ return variables.reduce((acc, { name, bindingDependencies, shapeFrom }) => {
4
+ if (shapeFrom && bindingDependencies)
5
+ return { ...acc, [name]: [...bindingDependencies, shapeFrom] };
6
+ if (bindingDependencies) return { ...acc, [name]: bindingDependencies };
7
+ if (shapeFrom) return { ...acc, [name]: [shapeFrom] };
8
+ return acc;
9
+ }, {});
10
+ };
11
+
12
+ const getAllDeps = (deps) => (variablesCalcDeps) => {
13
+ if (!deps || !variablesCalcDeps) return [];
14
+ return deps.reduce((acc, dep) => {
15
+ const depsOfDep = variablesCalcDeps[dep];
16
+ if (Array.isArray(depsOfDep)) {
17
+ return [...acc, dep, ...getAllDeps(depsOfDep)(variablesCalcDeps)];
18
+ }
19
+ return [...acc, dep];
20
+ }, []);
21
+ };
22
+
23
+ const getNestedVarsInFilterOrControl = (element) => {
24
+ if (element && Array.isArray(element?.bindingDependencies))
25
+ return element?.bindingDependencies;
26
+ return [];
27
+ };
28
+
29
+ const getNestedVarsInComponent = (component) => {
30
+ const {
31
+ componentType,
32
+ bindingDependencies = [],
33
+ conditionFilter,
34
+ controls = [],
35
+ } = component;
36
+ var bindings = [
37
+ ...bindingDependencies, // bindingDependencies of Component
38
+ ...getNestedVarsInFilterOrControl(conditionFilter), // bindingDependencies of its conditionFilter
39
+ ...controls.reduce(
40
+ (acc, c) => [...acc, ...getNestedVarsInFilterOrControl(c)],
41
+ []
42
+ ), // bindingDependencies of its controls
43
+ ];
44
+
45
+ if (componentType === 'Loop') {
46
+ const { components, loopDependencies } = component;
47
+ if (Array.isArray(loopDependencies))
48
+ bindings = [...bindings, ...loopDependencies];
49
+ if (Array.isArray(components)) {
50
+ bindings = components.reduce(
51
+ (acc, c) => [...acc, ...getNestedVarsInComponent(c)],
52
+ [...bindings]
53
+ );
54
+ }
55
+ }
56
+
57
+ return bindings;
58
+ };
59
+
60
+ const getNestedVars =
61
+ (components = []) =>
62
+ (variables) => {
63
+ const variableCalculatedDependencies =
64
+ getBindingsDependenciesCalculated(variables);
65
+ const depsVarsTemp = components
66
+ .reduce((acc, c) => {
67
+ return [...acc, ...getNestedVarsInComponent(c)];
68
+ }, [])
69
+ .filter((v, i, a) => a.indexOf(v) === i);
70
+ return getAllDeps(depsVarsTemp)(variableCalculatedDependencies).filter(
71
+ (v, i, a) => a.indexOf(v) === i
72
+ );
73
+ };
74
+
75
+ const getUsefullVariablesFromSource = (variables) => (nestedVars) => {
76
+ return variables.filter(({ variableType, name }) => {
77
+ if (variableType === 'CALCULATED' && !nestedVars.includes(name))
78
+ return false;
79
+ if (variableType === 'COLLECTED' && !nestedVars.includes(name))
80
+ return false;
81
+ return true;
82
+ });
83
+ };
84
+
85
+ export const getSplitQuestionnaireSource = (source) => {
86
+ const { components, variables, ...rest } = source;
87
+ var split = [];
88
+ var currentComponents = [];
89
+ var previousPage = null;
90
+ components.map((c) => {
91
+ const { componentType, page } = c;
92
+ // splitting by Sequence or Loop
93
+ if (
94
+ (componentType === 'Sequence' || componentType === 'Loop') &&
95
+ previousPage !== page
96
+ ) {
97
+ if (currentComponents.length > 0) split.push(currentComponents);
98
+ currentComponents = [c];
99
+ } else {
100
+ currentComponents.push(c);
101
+ }
102
+ previousPage = page;
103
+ return null;
104
+ });
105
+ if (currentComponents.length > 0) split.push(currentComponents);
106
+
107
+ return split.reduce((prev, currentSource) => {
108
+ const firstPage = currentSource[0].page;
109
+ const maxPage = currentSource[currentSource.length - 1].page;
110
+ const nestedVars = getNestedVars(currentSource)(variables);
111
+ const newVariables = getUsefullVariablesFromSource(variables)(nestedVars);
112
+
113
+ return [
114
+ ...prev,
115
+ {
116
+ ...rest,
117
+ variables: newVariables,
118
+ firstPage,
119
+ maxPage,
120
+ components: currentSource,
121
+ },
122
+ ];
123
+ }, []);
124
+ };
125
+
126
+ export const getRootPageInSources = (sources) => {
127
+ return sources.map((source) => {
128
+ const { components } = source;
129
+ return components.reduce((acc, { page }) => {
130
+ if (page) return [...acc, page];
131
+ return acc;
132
+ }, []);
133
+ });
134
+ };
135
+
136
+ export const mergeStateData = (oldData, newData) => {
137
+ return {
138
+ COLLECTED: { ...oldData.COLLECTED, ...newData.COLLECTED },
139
+ CALCULATED: { ...oldData.CALCULATED, ...newData.CALCULATED },
140
+ EXTERNAL: { ...oldData.EXTERNAL, ...newData.EXTERNAL },
141
+ };
142
+ };
@@ -1,10 +1,10 @@
1
- import camelCase from 'lodash.camelcase';
2
-
3
- export const buildStyleObject = obj =>
4
- obj
5
- ? Object.entries(obj).reduce((_, [key, value]) => {
6
- if (key.startsWith(':')) _[key] = buildStyleObject(value);
7
- else _[camelCase(key)] = value;
8
- return _;
9
- }, {})
10
- : {};
1
+ import camelCase from 'lodash.camelcase';
2
+
3
+ export const buildStyleObject = obj =>
4
+ obj
5
+ ? Object.entries(obj).reduce((_, [key, value]) => {
6
+ if (key.startsWith(':')) _[key] = buildStyleObject(value);
7
+ else _[camelCase(key)] = value;
8
+ return _;
9
+ }, {})
10
+ : {};
@@ -1,73 +1,74 @@
1
- import openStorage from './open-or-create-store';
2
- import updateStoreInfo from './create/update-store-info';
3
- import cleanStorage from './clear-store-data';
4
- import cleanInfoStorage from './clear-store-info';
5
-
6
- const workerPath =
7
- process.env.LUNATIC_LOADER_WORKER_PATH ||
8
- process.env.REACT_APP_LUNATIC_LOADER_WORKER_PATH ||
9
- 'workers/lunatic-loader-worker-0.1.0.js';
10
-
11
- export const loadSuggesters = (suggesterFetcher) => async (suggesters) => {
12
- Object.entries(suggesters).forEach(async ([name, attrs]) => {
13
- const { version } = attrs;
14
- const db = await openStorage(name, version);
15
- if (db) {
16
- await cleanStorage(db);
17
- await cleanInfoStorage(db);
18
- await updateStoreInfo(db, attrs);
19
- }
20
- });
21
- Object.entries(suggesters).forEach(([name, attrs]) => {
22
- const { url, version, fields, stopWords } = attrs;
23
- const f = suggesterFetcher || fetch;
24
- f(url).then(async (res) => {
25
- const data = await res.json();
26
- const [launch, terminate] = task({ name, fields, stopWords }, version);
27
- await launch(data);
28
- terminate();
29
- });
30
- });
31
- };
32
-
33
- /**
34
- * Only with Worker
35
- */
36
- function task({ name, fields, stopWords }, version, log = () => null) {
37
- const worker = new Worker(workerPath);
38
- let start = false;
39
- let stop = false;
40
-
41
- function launch(entities, post = () => null) {
42
- return new Promise(function (resolve) {
43
- start = true;
44
- worker.postMessage({
45
- name,
46
- version,
47
- fields,
48
- entities,
49
- stopWords,
50
- });
51
- worker.addEventListener('message', function (e) {
52
- const { data } = e;
53
- if (data === 'success') {
54
- if (!stop) {
55
- post();
56
- }
57
- resolve(data);
58
- } else {
59
- log(data);
60
- }
61
- });
62
- });
63
- }
64
-
65
- function terminate() {
66
- if (start) {
67
- stop = true;
68
- worker.terminate();
69
- }
70
- }
71
-
72
- return [launch, terminate];
73
- }
1
+ import openStorage from './open-or-create-store';
2
+ import updateStoreInfo from './create/update-store-info';
3
+ import cleanStorage from './clear-store-data';
4
+ import cleanInfoStorage from './clear-store-info';
5
+ import { createWorker } from '../suggester-workers/create-worker';
6
+
7
+ const workerPath =
8
+ process.env.LUNATIC_LOADER_WORKER_PATH ||
9
+ process.env.REACT_APP_LUNATIC_LOADER_WORKER_PATH ||
10
+ 'workers/lunatic-loader-worker-0.1.0.js';
11
+
12
+ export const loadSuggesters = (suggesterFetcher) => async (suggesters) => {
13
+ Object.entries(suggesters).forEach(async ([name, attrs]) => {
14
+ const { version } = attrs;
15
+ const db = await openStorage(name, version);
16
+ if (db) {
17
+ await cleanStorage(db);
18
+ await cleanInfoStorage(db);
19
+ await updateStoreInfo(db, attrs);
20
+ }
21
+ });
22
+ Object.entries(suggesters).forEach(([name, attrs]) => {
23
+ const { url, version, fields, stopWords } = attrs;
24
+ const f = suggesterFetcher || fetch;
25
+ f(url).then(async (res) => {
26
+ const data = await res.json();
27
+ const [launch, terminate] = task({ name, fields, stopWords }, version);
28
+ await launch(data);
29
+ terminate();
30
+ });
31
+ });
32
+ };
33
+
34
+ /**
35
+ * Only with Worker
36
+ */
37
+ function task({ name, fields, stopWords }, version, log = () => null) {
38
+ const worker = createWorker(workerPath);
39
+ let start = false;
40
+ let stop = false;
41
+
42
+ function launch(entities, post = () => null) {
43
+ return new Promise(function (resolve) {
44
+ start = true;
45
+ worker.postMessage({
46
+ name,
47
+ version,
48
+ fields,
49
+ entities,
50
+ stopWords,
51
+ });
52
+ worker.addEventListener('message', function (e) {
53
+ const { data } = e;
54
+ if (data === 'success') {
55
+ if (!stop) {
56
+ post();
57
+ }
58
+ resolve(data);
59
+ } else {
60
+ log(data);
61
+ }
62
+ });
63
+ });
64
+ }
65
+
66
+ function terminate() {
67
+ if (start) {
68
+ stop = true;
69
+ worker.terminate();
70
+ }
71
+ }
72
+
73
+ return [launch, terminate];
74
+ }
@@ -1,25 +1,25 @@
1
- import { CONSTANTES } from '../../store-tools';
2
- import { openDb, idbBulkInsert } from '../../idb-tools';
3
- import MESSAGES from './store-messages';
4
- import prepareEntities from './prepare-entities';
5
-
6
- async function append(storeInfo, version, entities, log = () => null) {
7
- try {
8
- const { name, stopWords, fields } = storeInfo;
9
- const prepared = prepareEntities(entities, { fields, stopWords }, log);
10
- const db = await openDb(name, version);
11
- log({ message: MESSAGES.startInsertBatch });
12
- await idbBulkInsert(db, CONSTANTES.STORE_DATA_NAME, function (args) {
13
- const { message } = args;
14
- log({ message });
15
- })(prepared);
16
- log({ message: MESSAGES.insertBatchDone });
17
- log({ message: MESSAGES.done });
18
- return 'success';
19
- } catch (e) {
20
- log({ message: 'Errors occurred when trying to append data.' });
21
- console.error(e);
22
- }
23
- }
24
-
25
- export default append;
1
+ import { CONSTANTES } from '../../store-tools';
2
+ import { openDb, idbBulkInsert } from '../../idb-tools';
3
+ import MESSAGES from './store-messages';
4
+ import prepareEntities from './prepare-entities';
5
+
6
+ async function append(storeInfo, version, entities, log = () => null) {
7
+ try {
8
+ const { name, stopWords, fields } = storeInfo;
9
+ const prepared = prepareEntities(entities, { fields, stopWords }, log);
10
+ const db = await openDb(name, version);
11
+ log({ message: MESSAGES.startInsertBatch });
12
+ await idbBulkInsert(db, CONSTANTES.STORE_DATA_NAME, function (args) {
13
+ const { message } = args;
14
+ log({ message });
15
+ })(prepared);
16
+ log({ message: MESSAGES.insertBatchDone });
17
+ log({ message: MESSAGES.done });
18
+ return 'success';
19
+ } catch (e) {
20
+ log({ message: 'Errors occurred when trying to append data.' });
21
+ console.error(e);
22
+ }
23
+ }
24
+
25
+ export default append;
@@ -1,16 +1,16 @@
1
- /* eslint-disable no-restricted-globals */
2
- import 'core-js/stable';
3
- import 'regenerator-runtime/runtime';
4
- import append from './append';
5
-
6
- self.onmessage = function (e) {
7
- function log(message) {
8
- self.postMessage(message);
9
- }
10
- const { name, version, stopWords, fields, entities } = e.data;
11
- append({ name, version, stopWords, fields }, version, entities, log).then(
12
- function () {
13
- self.postMessage('success');
14
- }
15
- );
16
- };
1
+ /* eslint-disable no-restricted-globals */
2
+ import 'core-js/stable';
3
+ import 'regenerator-runtime/runtime';
4
+ import append from './append';
5
+
6
+ self.onmessage = function (e) {
7
+ function log(message) {
8
+ self.postMessage(message);
9
+ }
10
+ const { name, version, stopWords, fields, entities } = e.data;
11
+ append({ name, version, stopWords, fields }, version, entities, log).then(
12
+ function () {
13
+ self.postMessage('success');
14
+ }
15
+ );
16
+ };
@@ -1,43 +1,45 @@
1
- const workerPath =
2
- process.env.LUNATIC_LOADER_WORKER_PATH ||
3
- process.env.REACT_APP_LUNATIC_LOADER_WORKER_PATH ||
4
- 'workers/lunatic-loader-worker-0.1.0.js';
5
-
6
- /**
7
- * Only with Worker
8
- */
9
- function task(info, version, log = () => null) {
10
- const { name, fields, stopWords } = info;
11
- const worker = new Worker(workerPath);
12
- let start = false;
13
- let stop = false;
14
-
15
- function launch(entities, post = () => null) {
16
- return new Promise(function (resolve) {
17
- start = true;
18
- worker.addEventListener('message', function (e) {
19
- const { data } = e;
20
- if (data === 'success') {
21
- if (!stop) {
22
- post();
23
- }
24
- resolve(data);
25
- } else {
26
- log(data);
27
- }
28
- });
29
- worker.postMessage({ name, version, fields, stopWords, entities });
30
- });
31
- }
32
-
33
- function terminate() {
34
- if (start) {
35
- stop = true;
36
- worker.terminate();
37
- }
38
- }
39
-
40
- return [launch, terminate];
41
- }
42
-
43
- export default task;
1
+ import { createWorker } from '../create-worker';
2
+
3
+ const workerPath =
4
+ process.env.LUNATIC_LOADER_WORKER_PATH ||
5
+ process.env.REACT_APP_LUNATIC_LOADER_WORKER_PATH ||
6
+ 'workers/lunatic-loader-worker-0.1.0.js';
7
+
8
+ /**
9
+ * Only with Worker
10
+ */
11
+ function task(info, version, log = () => null) {
12
+ const { name, fields, stopWords } = info;
13
+ const worker = createWorker(workerPath);
14
+ let start = false;
15
+ let stop = false;
16
+
17
+ function launch(entities, post = () => null) {
18
+ return new Promise(function (resolve) {
19
+ start = true;
20
+ worker.addEventListener('message', function (e) {
21
+ const { data } = e;
22
+ if (data === 'success') {
23
+ if (!stop) {
24
+ post();
25
+ }
26
+ resolve(data);
27
+ } else {
28
+ log(data);
29
+ }
30
+ });
31
+ worker.postMessage({ name, version, fields, stopWords, entities });
32
+ });
33
+ }
34
+
35
+ function terminate() {
36
+ if (start) {
37
+ stop = true;
38
+ worker.terminate();
39
+ }
40
+ }
41
+
42
+ return [launch, terminate];
43
+ }
44
+
45
+ export default task;
@@ -1,2 +1,2 @@
1
- export { default } from './append';
2
- export { default as createAppendTask } from './create-append-task';
1
+ export { default } from './append';
2
+ export { default as createAppendTask } from './create-append-task';
@@ -1,61 +1,61 @@
1
- import { createTokenizer } from '../commons-tokenizer';
2
- import MESSAGES from './store-messages';
3
-
4
- const DEFAULT_BATCH_SIZE = 1000;
5
-
6
- function appendField(fields, field) {
7
- if (fields.indexOf(field) !== -1) {
8
- return fields;
9
- }
10
- return [...fields, field];
11
- }
12
-
13
- function createTokensMap(tokensFields) {
14
- return Object.entries(tokensFields).reduce(function (map, [field, tokens]) {
15
- return tokens.reduce(function (map2, token) {
16
- if (token in map2) {
17
- const entry = map2[token];
18
- const { fields, count } = entry;
19
- return {
20
- ...map2,
21
- [token]: {
22
- count: count + 1,
23
- fields: appendField(fields, field),
24
- },
25
- };
26
- }
27
- return { ...map2, [token]: { count: 1, fields: [field] } };
28
- }, map);
29
- }, {});
30
- }
31
-
32
- function prepareEntities(entities, { fields, stopWords }, log) {
33
- const tokenizer = createTokenizer(fields, stopWords);
34
-
35
- let done = 0;
36
- const size = DEFAULT_BATCH_SIZE;
37
- const { length: max } = entities || [];
38
-
39
- return entities.map(function (suggestion) {
40
- const { id } = suggestion;
41
- if (id) {
42
- const tokensFields = tokenizer(suggestion);
43
- const tokensMap = createTokensMap(tokensFields);
44
-
45
- done++;
46
- if (done % size === 0 || done === max) {
47
- log({
48
- message: {
49
- ...MESSAGES.indexBatch,
50
- max,
51
- done,
52
- percent: (done / max) * 100,
53
- },
54
- });
55
- }
56
- return { id, suggestion, tokens: Object.keys(tokensMap), tokensMap };
57
- } else throw new Error(`Missing id on entity.`);
58
- }, []);
59
- }
60
-
61
- export default prepareEntities;
1
+ import { createTokenizer } from '../commons-tokenizer';
2
+ import MESSAGES from './store-messages';
3
+
4
+ const DEFAULT_BATCH_SIZE = 1000;
5
+
6
+ function appendField(fields, field) {
7
+ if (fields.indexOf(field) !== -1) {
8
+ return fields;
9
+ }
10
+ return [...fields, field];
11
+ }
12
+
13
+ function createTokensMap(tokensFields) {
14
+ return Object.entries(tokensFields).reduce(function (map, [field, tokens]) {
15
+ return tokens.reduce(function (map2, token) {
16
+ if (token in map2) {
17
+ const entry = map2[token];
18
+ const { fields, count } = entry;
19
+ return {
20
+ ...map2,
21
+ [token]: {
22
+ count: count + 1,
23
+ fields: appendField(fields, field),
24
+ },
25
+ };
26
+ }
27
+ return { ...map2, [token]: { count: 1, fields: [field] } };
28
+ }, map);
29
+ }, {});
30
+ }
31
+
32
+ function prepareEntities(entities, { fields, stopWords }, log) {
33
+ const tokenizer = createTokenizer(fields, stopWords);
34
+
35
+ let done = 0;
36
+ const size = DEFAULT_BATCH_SIZE;
37
+ const { length: max } = entities || [];
38
+
39
+ return entities.map(function (suggestion) {
40
+ const { id } = suggestion;
41
+ if (id) {
42
+ const tokensFields = tokenizer(suggestion);
43
+ const tokensMap = createTokensMap(tokensFields);
44
+
45
+ done++;
46
+ if (done % size === 0 || done === max) {
47
+ log({
48
+ message: {
49
+ ...MESSAGES.indexBatch,
50
+ max,
51
+ done,
52
+ percent: (done / max) * 100,
53
+ },
54
+ });
55
+ }
56
+ return { id, suggestion, tokens: Object.keys(tokensMap), tokensMap };
57
+ } else throw new Error(`Missing id on entity.`);
58
+ }, []);
59
+ }
60
+
61
+ export default prepareEntities;
@@ -1,21 +1,21 @@
1
- import { BULK_INSERT_MESSAGES } from '../../idb-tools';
2
-
3
- const MESSAGES = {
4
- ...BULK_INSERT_MESSAGES,
5
- startCreateIndex: { type: 'fill-store/start-create-index' },
6
- indexBatch: {
7
- type: 'fill-store/index-batch',
8
- max: undefined,
9
- done: undefined,
10
- percent: undefined,
11
- },
12
- createIndexDone: { type: 'fill-store/create-index-done' },
13
- //
14
- storeClear: { type: 'fill-store/clear-store' },
15
- startInsertBatch: { type: 'fill-store/start-insert-bacth' },
16
- insertBatchDone: { type: 'fill-store/insert-done' },
17
- done: { type: 'fill-store/done' },
18
- error: { type: 'fill-store/error' },
19
- };
20
-
21
- export default MESSAGES;
1
+ import { BULK_INSERT_MESSAGES } from '../../idb-tools';
2
+
3
+ const MESSAGES = {
4
+ ...BULK_INSERT_MESSAGES,
5
+ startCreateIndex: { type: 'fill-store/start-create-index' },
6
+ indexBatch: {
7
+ type: 'fill-store/index-batch',
8
+ max: undefined,
9
+ done: undefined,
10
+ percent: undefined,
11
+ },
12
+ createIndexDone: { type: 'fill-store/create-index-done' },
13
+ //
14
+ storeClear: { type: 'fill-store/clear-store' },
15
+ startInsertBatch: { type: 'fill-store/start-insert-bacth' },
16
+ insertBatchDone: { type: 'fill-store/insert-done' },
17
+ done: { type: 'fill-store/done' },
18
+ error: { type: 'fill-store/error' },
19
+ };
20
+
21
+ export default MESSAGES;