@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,24 +1,24 @@
1
- import queryParserSoft from './query-parser-soft';
2
-
3
- describe('query-parser-soft', function () {
4
- it('empty query', function () {
5
- const result = queryParserSoft('');
6
- expect(result.length).toBe(1);
7
- expect(result).toContain('');
8
- });
9
- it('to lower case', function () {
10
- const result = queryParserSoft('HELLO');
11
- expect(result.length).toBe(1);
12
- expect(result).toContain('hello');
13
- });
14
- it('trim accent', function () {
15
- const result = queryParserSoft('ïéèû');
16
- expect(result.length).toBe(1);
17
- expect(result).toContain('ieeu');
18
- });
19
- it('white spaces', function () {
20
- const result = queryParserSoft('HELLO WORLD!');
21
- expect(result.length).toBe(1);
22
- expect(result).toContain('hello-world!');
23
- });
24
- });
1
+ import queryParserSoft from './query-parser-soft';
2
+
3
+ describe('query-parser-soft', function () {
4
+ it('empty query', function () {
5
+ const result = queryParserSoft('');
6
+ expect(result.length).toBe(1);
7
+ expect(result).toContain('');
8
+ });
9
+ it('to lower case', function () {
10
+ const result = queryParserSoft('HELLO');
11
+ expect(result.length).toBe(1);
12
+ expect(result).toContain('hello');
13
+ });
14
+ it('trim accent', function () {
15
+ const result = queryParserSoft('ïéèû');
16
+ expect(result.length).toBe(1);
17
+ expect(result).toContain('ieeu');
18
+ });
19
+ it('white spaces', function () {
20
+ const result = queryParserSoft('HELLO WORLD!');
21
+ expect(result.length).toBe(1);
22
+ expect(result).toContain('hello-world!');
23
+ });
24
+ });
@@ -0,0 +1,34 @@
1
+ import tokenizer from 'string-tokenizer';
2
+ import {
3
+ filterStemmer,
4
+ filterLength,
5
+ filterDouble,
6
+ getRegExpFromPattern,
7
+ filterToLower,
8
+ } from '../../commons-tokenizer';
9
+ import { composeFilters } from '../../commons-tokenizer/filters';
10
+
11
+ const filterTokens = composeFilters(
12
+ filterDouble,
13
+ filterStemmer,
14
+ filterToLower,
15
+ filterLength
16
+ );
17
+
18
+ function toArray(tokens) {
19
+ if (tokens) {
20
+ return Array.isArray(tokens) ? tokens : [tokens];
21
+ }
22
+ return [];
23
+ }
24
+
25
+ function queryParserTokenized(query = '', { pattern, ...args } = {}) {
26
+ const patternForTokens = { tokens: getRegExpFromPattern(pattern) };
27
+ const { tokens } = tokenizer()
28
+ .input(query)
29
+ .tokens(patternForTokens)
30
+ .resolve();
31
+ return filterTokens(toArray(tokens), args);
32
+ }
33
+
34
+ export default queryParserTokenized;
@@ -1,27 +1,27 @@
1
- import { queryParserTokenized, queryParserSoft } from '../query-parser';
2
-
3
- async function resolve(name, queryParser) {
4
- try {
5
- const { type } = queryParser;
6
- switch (type) {
7
- case 'tokenized':
8
- const { params } = queryParser;
9
- const { language, pattern, min, stemmer } = params;
10
- return (query) =>
11
- queryParserTokenized(query, {
12
- language,
13
- pattern,
14
- min,
15
- stemmer,
16
- });
17
- case 'soft':
18
- return queryParserSoft;
19
- default:
20
- throw new Error(`Unknown parser type ${type}`);
21
- }
22
- } catch (e) {
23
- throw new Error(e);
24
- }
25
- }
26
-
27
- export default resolve;
1
+ import { queryParserTokenized, queryParserSoft } from './query-parser';
2
+
3
+ async function resolve(queryParser) {
4
+ try {
5
+ const { type } = queryParser;
6
+ switch (type) {
7
+ case 'tokenized':
8
+ const { params } = queryParser;
9
+ const { language, pattern, min, stemmer } = params;
10
+ return (query) =>
11
+ queryParserTokenized(query, {
12
+ language,
13
+ pattern,
14
+ min,
15
+ stemmer,
16
+ });
17
+ case 'soft':
18
+ return queryParserSoft;
19
+ default:
20
+ throw new Error(`Unknown parser type ${type}`);
21
+ }
22
+ } catch (e) {
23
+ throw new Error(e);
24
+ }
25
+ }
26
+
27
+ export default resolve;
@@ -1,17 +1,17 @@
1
- import { CONSTANTES } from '../../store-tools';
2
-
3
- function search(token, index) {
4
- const range = IDBKeyRange.bound(token, `${token}${CONSTANTES.MAX_STRING}`);
5
- return new Promise(function (resolve, reject) {
6
- try {
7
- index.getAll(range).onsuccess = function (req) {
8
- const results = req.target.result;
9
- resolve(results);
10
- };
11
- } catch (e) {
12
- reject(e);
13
- }
14
- });
15
- }
16
-
17
- export default search;
1
+ import { CONSTANTES } from '../../store-tools';
2
+
3
+ function search(token, index) {
4
+ const range = IDBKeyRange.bound(token, `${token}${CONSTANTES.MAX_STRING}`);
5
+ return new Promise(function (resolve, reject) {
6
+ try {
7
+ index.getAll(range).onsuccess = function (req) {
8
+ const results = req.target.result;
9
+ resolve(results);
10
+ };
11
+ } catch (e) {
12
+ reject(e);
13
+ }
14
+ });
15
+ }
16
+
17
+ export default search;
@@ -1,70 +1,70 @@
1
- import getDb from './get-db';
2
- import { CONSTANTES } from '../../store-tools';
3
- import { getEntity } from '../../idb-tools';
4
- import searchInIndex from './search-in-index';
5
- import resolveQueryParser from './resolve-query-parser';
6
- import computeScore from './compute-score';
7
- import getOrderingFunction from './order';
8
-
9
- function prepare(response) {
10
- return response.map(({ suggestion, tokensMap }) => ({
11
- ...suggestion,
12
- tokensMap,
13
- }));
14
- }
15
-
16
- async function searchTokens(tokens, index) {
17
- const results = await Promise.all(
18
- tokens.map((token) => searchInIndex(token, index))
19
- );
20
-
21
- return results.reduce(function (a, step, i) {
22
- return { ...a, [tokens[i]]: step };
23
- }, {});
24
- }
25
-
26
- function isValideSearch(search) {
27
- if (typeof search === 'string' && search.trim().length) {
28
- return true;
29
- }
30
- return false;
31
- }
32
-
33
- function filterSize(response, max) {
34
- if (max && max < response.length) {
35
- return response.slice(0, max);
36
- }
37
- return response;
38
- }
39
-
40
- async function searching(search, { name, version = '1' }) {
41
- try {
42
- if (isValideSearch(search)) {
43
- const db = await getDb(name, version);
44
- const info = await getEntity(db, CONSTANTES.STORE_INFO_NAME, name);
45
- const { queryParser, max, order } = info;
46
- const parser = await resolveQueryParser(name, queryParser);
47
- const transaction = db.transaction(
48
- CONSTANTES.STORE_DATA_NAME,
49
- 'readonly'
50
- );
51
- const store = transaction.objectStore(CONSTANTES.STORE_DATA_NAME);
52
- const index = store.index(CONSTANTES.STORE_INDEX_NAME);
53
- const tokens = parser(search);
54
- const tokensSuggestions = await searchTokens(tokens, index);
55
- const response = computeScore(tokensSuggestions);
56
- return {
57
- results: prepare(
58
- getOrderingFunction(order)(filterSize(response, max), order)
59
- ),
60
- search,
61
- };
62
- }
63
- return { results: [], search };
64
- } catch (e) {
65
- console.err(e);
66
- throw e;
67
- }
68
- }
69
-
70
- export default searching;
1
+ import getDb from './get-db';
2
+ import { CONSTANTES } from '../../store-tools';
3
+ import { getEntity } from '../../idb-tools';
4
+ import searchInIndex from './search-in-index';
5
+ import resolveQueryParser from './resolve-query-parser';
6
+ import computeScore from './compute-score';
7
+ import getOrderingFunction from './order';
8
+
9
+ function prepare(response) {
10
+ return response.map(({ suggestion, tokensMap }) => ({
11
+ ...suggestion,
12
+ tokensMap,
13
+ }));
14
+ }
15
+
16
+ async function searchTokens(tokens, index) {
17
+ const results = await Promise.all(
18
+ tokens.map((token) => searchInIndex(token, index))
19
+ );
20
+
21
+ return results.reduce(function (a, step, i) {
22
+ return { ...a, [tokens[i]]: step };
23
+ }, {});
24
+ }
25
+
26
+ function isValideSearch(search) {
27
+ if (typeof search === 'string' && search.trim().length) {
28
+ return true;
29
+ }
30
+ return false;
31
+ }
32
+
33
+ function filterSize(response, max) {
34
+ if (max && max < response.length) {
35
+ return response.slice(0, max);
36
+ }
37
+ return response;
38
+ }
39
+
40
+ async function searching(search, { name, version = '1' }) {
41
+ try {
42
+ if (isValideSearch(search)) {
43
+ const db = await getDb(name, version);
44
+ const info = await getEntity(db, CONSTANTES.STORE_INFO_NAME, name);
45
+ const { queryParser, max, order } = info;
46
+ const parser = await resolveQueryParser(queryParser);
47
+ const transaction = db.transaction(
48
+ CONSTANTES.STORE_DATA_NAME,
49
+ 'readonly'
50
+ );
51
+ const store = transaction.objectStore(CONSTANTES.STORE_DATA_NAME);
52
+ const index = store.index(CONSTANTES.STORE_INDEX_NAME);
53
+ const tokens = parser(search);
54
+ const tokensSuggestions = await searchTokens(tokens, index);
55
+ const response = computeScore(tokensSuggestions);
56
+ return {
57
+ results: prepare(
58
+ getOrderingFunction(order)(filterSize(response, max), order)
59
+ ),
60
+ search,
61
+ };
62
+ }
63
+ return { results: [], search };
64
+ } catch (e) {
65
+ console.error(e);
66
+ throw e;
67
+ }
68
+ }
69
+
70
+ export default searching;
@@ -1,11 +1,11 @@
1
- /* eslint-disable no-restricted-globals */
2
- import 'core-js/stable';
3
- import 'regenerator-runtime/runtime';
4
- import searching from './searching';
5
-
6
- self.onmessage = function (e) {
7
- const { search, name, version } = e.data;
8
- searching(search, { name, version }).then(function (result) {
9
- self.postMessage(result);
10
- });
11
- };
1
+ /* eslint-disable no-restricted-globals */
2
+ import 'core-js/stable';
3
+ import 'regenerator-runtime/runtime';
4
+ import searching from './searching';
5
+
6
+ self.onmessage = function (e) {
7
+ const { search, name, version } = e.data;
8
+ searching(search, { name, version }).then(function (result) {
9
+ self.postMessage(result);
10
+ });
11
+ };
@@ -1,113 +1,113 @@
1
- import { interpret } from './interpret';
2
- import {
3
- buildVectorialBindings,
4
- buildBindingsForDeeperComponents,
5
- } from '../lib/loops/bindings';
6
- import { isFunction } from '../lib';
7
- import {
8
- CALCULATED_VAR_CATEGORY,
9
- EVENT_VALUE_CHANGE,
10
- } from '../../constants/event-types';
11
-
12
- export const getCalculatedVariables =
13
- (variables) =>
14
- ({ bindings, updatedVars, logFunction, init = false }) => {
15
- let wip = {};
16
- return Object.entries(variables).reduce((acc, [name, v]) => {
17
- const value = getCalculatedVariable(v, name)(variables)({
18
- bindings,
19
- wip,
20
- updatedVars,
21
- logFunction,
22
- init,
23
- });
24
- return {
25
- ...acc,
26
- [name]: value,
27
- };
28
- }, {});
29
- };
30
-
31
- const getCalculatedVariable =
32
- (v, name) =>
33
- (variables) =>
34
- ({ bindings, wip, updatedVars, logFunction, init }) => {
35
- const { bindingDependencies } = v;
36
- if (!init && !Array.isArray(bindingDependencies)) return v;
37
- if (
38
- Array.isArray(updatedVars) &&
39
- updatedVars.length > 0 &&
40
- Array.isArray(bindingDependencies) &&
41
- !updatedVars.some((ai) => bindingDependencies.includes(ai))
42
- )
43
- return v;
44
- const exactBindings = (bindingDependencies || []).reduce((acc, b) => {
45
- if (bindings[b] !== undefined) return { ...acc, [b]: bindings[b] };
46
- if (wip[b] !== undefined) return { ...acc, [b]: wip[b] };
47
- const varToCalc = variables[b];
48
- if (!varToCalc) return acc;
49
- const newValue = getCalculatedVariable(varToCalc)(variables)({
50
- bindings,
51
- wip,
52
- updatedVars,
53
- init,
54
- });
55
- wip[b] = newValue.value;
56
- return { ...acc, [b]: newValue.value };
57
- }, {});
58
- const { expression, shapeFrom } = v;
59
- const value =
60
- wip[name] !== undefined
61
- ? wip[name]
62
- : getValue(bindings, exactBindings, expression, shapeFrom);
63
- const handleTempMomentValue =
64
- value && value._isAMomentObject ? value.format('DD-MM-YYYY') : value;
65
-
66
- if (
67
- isFunction(logFunction) &&
68
- // Filter only filterResult vars : name.startsWith('FILTER_RESULT_') &&
69
- JSON.stringify(value) !== JSON.stringify(variables[name].value)
70
- ) {
71
- logFunction({
72
- idParadataObject: `${name}`,
73
- typeParadataObject: CALCULATED_VAR_CATEGORY,
74
- type: EVENT_VALUE_CHANGE,
75
- oldValue: value,
76
- newValue: variables[name]?.value,
77
- });
78
- }
79
-
80
- if (shapeFrom)
81
- return {
82
- expression,
83
- bindingDependencies,
84
- value: handleTempMomentValue,
85
- shapeFrom,
86
- };
87
- return {
88
- expression,
89
- bindingDependencies,
90
- value: handleTempMomentValue,
91
- };
92
- };
93
-
94
- const getValue = (bindings, exactBindings, expression, shapeFrom) => {
95
- if (!shapeFrom) {
96
- const vectorialBindings = buildVectorialBindings(exactBindings);
97
- const res = interpret(['VTL'])(vectorialBindings)(expression);
98
- return Array.isArray(res) ? res[0] : res;
99
- }
100
- const shape = bindings[shapeFrom];
101
- return buildShape(exactBindings, expression)(shape);
102
- };
103
-
104
- const buildShape = (exactBindings, expression) => (array) =>
105
- array.map((a, i) => {
106
- const loopBindings = buildBindingsForDeeperComponents(i)(exactBindings);
107
- if (Array.isArray(a)) {
108
- return buildShape(loopBindings, expression)(a);
109
- }
110
- const vectorialBindings = buildVectorialBindings(loopBindings);
111
- const res = interpret(['VTL'])(vectorialBindings)(expression);
112
- return Array.isArray(res) ? res[0] : res;
113
- });
1
+ import { interpret } from './interpret';
2
+ import {
3
+ buildVectorialBindings,
4
+ buildBindingsForDeeperComponents,
5
+ } from '../lib/loops/bindings';
6
+ import { isFunction } from '../lib';
7
+ import {
8
+ CALCULATED_VAR_CATEGORY,
9
+ EVENT_VALUE_CHANGE,
10
+ } from '../../constants/event-types';
11
+
12
+ export const getCalculatedVariables =
13
+ (variables) =>
14
+ ({ bindings, updatedVars, logFunction, init = false }) => {
15
+ let wip = {};
16
+ return Object.entries(variables).reduce((acc, [name, v]) => {
17
+ const value = getCalculatedVariable(v, name)(variables)({
18
+ bindings,
19
+ wip,
20
+ updatedVars,
21
+ logFunction,
22
+ init,
23
+ });
24
+ return {
25
+ ...acc,
26
+ [name]: value,
27
+ };
28
+ }, {});
29
+ };
30
+
31
+ const getCalculatedVariable =
32
+ (v, name) =>
33
+ (variables) =>
34
+ ({ bindings, wip, updatedVars, logFunction, init }) => {
35
+ const { bindingDependencies } = v;
36
+ if (!init && !Array.isArray(bindingDependencies)) return v;
37
+ if (
38
+ Array.isArray(updatedVars) &&
39
+ updatedVars.length > 0 &&
40
+ Array.isArray(bindingDependencies) &&
41
+ !updatedVars.some((ai) => bindingDependencies.includes(ai))
42
+ )
43
+ return v;
44
+ const exactBindings = (bindingDependencies || []).reduce((acc, b) => {
45
+ if (bindings[b] !== undefined) return { ...acc, [b]: bindings[b] };
46
+ if (wip[b] !== undefined) return { ...acc, [b]: wip[b] };
47
+ const varToCalc = variables[b];
48
+ if (!varToCalc) return acc;
49
+ const newValue = getCalculatedVariable(varToCalc)(variables)({
50
+ bindings,
51
+ wip,
52
+ updatedVars,
53
+ init,
54
+ });
55
+ wip[b] = newValue.value;
56
+ return { ...acc, [b]: newValue.value };
57
+ }, {});
58
+ const { expression, shapeFrom } = v;
59
+ const value =
60
+ wip[name] !== undefined
61
+ ? wip[name]
62
+ : getValue(bindings, exactBindings, expression, shapeFrom);
63
+ const handleTempMomentValue =
64
+ value && value._isAMomentObject ? value.format('DD-MM-YYYY') : value;
65
+
66
+ if (
67
+ isFunction(logFunction) &&
68
+ // Filter only filterResult vars : name.startsWith('FILTER_RESULT_') &&
69
+ JSON.stringify(value) !== JSON.stringify(variables[name].value)
70
+ ) {
71
+ logFunction({
72
+ idParadataObject: `${name}`,
73
+ typeParadataObject: CALCULATED_VAR_CATEGORY,
74
+ type: EVENT_VALUE_CHANGE,
75
+ oldValue: value,
76
+ newValue: variables[name]?.value,
77
+ });
78
+ }
79
+
80
+ if (shapeFrom)
81
+ return {
82
+ expression,
83
+ bindingDependencies,
84
+ value: handleTempMomentValue,
85
+ shapeFrom,
86
+ };
87
+ return {
88
+ expression,
89
+ bindingDependencies,
90
+ value: handleTempMomentValue,
91
+ };
92
+ };
93
+
94
+ const getValue = (bindings, exactBindings, expression, shapeFrom) => {
95
+ if (!shapeFrom) {
96
+ const vectorialBindings = buildVectorialBindings(exactBindings);
97
+ const res = interpret(['VTL'])(vectorialBindings)(expression);
98
+ return Array.isArray(res) ? res[0] : res;
99
+ }
100
+ const shape = bindings[shapeFrom];
101
+ return buildShape(exactBindings, expression)(shape);
102
+ };
103
+
104
+ const buildShape = (exactBindings, expression) => (array) =>
105
+ array.map((a, i) => {
106
+ const loopBindings = buildBindingsForDeeperComponents(i)(exactBindings);
107
+ if (Array.isArray(a)) {
108
+ return buildShape(loopBindings, expression)(a);
109
+ }
110
+ const vectorialBindings = buildVectorialBindings(loopBindings);
111
+ const res = interpret(['VTL'])(vectorialBindings)(expression);
112
+ return Array.isArray(res) ? res[0] : res;
113
+ });