@inseefr/lunatic 0.2.2-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.
- package/LICENSE +21 -21
- package/README.md +25 -23
- package/lib/index.js +1191 -475
- package/lib/index.js.map +1 -1
- package/package.json +174 -172
- package/src/components/breadcrumb/breadcrumb.scss +22 -22
- package/src/components/checkbox/boolean.js +172 -172
- package/src/components/checkbox/checkbox.scss +73 -73
- package/src/components/checkbox/group.js +231 -231
- package/src/components/checkbox/one.js +11 -11
- package/src/components/component-wrapper/controls/component.js +70 -0
- package/src/components/component-wrapper/controls/controls.scss +6 -0
- package/src/components/component-wrapper/controls/index.js +1 -0
- package/src/components/component-wrapper/controls/validators/datepicker.js +44 -0
- package/src/components/component-wrapper/controls/validators/index.js +16 -0
- package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
- package/src/components/{missing-wrapper → component-wrapper}/index.js +0 -0
- package/src/components/component-wrapper/missing/component.js +200 -0
- package/src/components/component-wrapper/missing/index.js +1 -0
- package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +32 -32
- package/src/components/component-wrapper/wrapper.js +23 -0
- package/src/components/components.js +1 -0
- package/src/components/datepicker/component.js +26 -11
- package/src/components/declarations/component.js +46 -46
- package/src/components/declarations/declarations.scss +40 -40
- package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -274
- package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
- package/src/components/dropdown/commons/actions.js +65 -56
- package/src/components/dropdown/commons/children-to-option.js +9 -9
- package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
- package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
- package/src/components/dropdown/commons/components/dropdown.js +204 -183
- package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
- package/src/components/dropdown/commons/reducer.js +3 -0
- package/src/components/dropdown/commons/tools/index.js +17 -17
- package/src/components/dropdown/component.js +135 -135
- package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -185
- package/src/components/dropdown/dropdown-edit/index.js +11 -11
- package/src/components/dropdown/dropdown-simple/dropdown.js +173 -164
- package/src/components/dropdown/dropdown-simple/index.js +20 -20
- package/src/components/dropdown/dropdown.scss +178 -178
- package/src/components/icon/icon.scss +15 -15
- package/src/components/index.js +2 -0
- package/src/components/index.scss +177 -175
- package/src/components/input/input-number.js +30 -54
- package/src/components/input/input.js +11 -11
- package/src/components/input/input.scss +31 -37
- package/src/components/loop/component.js +170 -169
- package/src/components/loop/loop.scss +13 -13
- package/src/components/loop/wrapper.js +1 -1
- package/src/components/loop-constructor/block/block.scss +10 -10
- package/src/components/loop-constructor/block/component.js +9 -9
- package/src/components/loop-constructor/roster/component.js +8 -8
- package/src/components/loop-constructor/wrapper/body-component.js +146 -125
- package/src/components/modal/component.js +36 -0
- package/src/components/modal/index.js +1 -0
- package/src/components/modal/modal.scss +33 -0
- package/src/components/progress-bar/progress-bar.scss +54 -54
- package/src/components/radio/component.js +9 -9
- package/src/components/radio/radio.scss +59 -59
- package/src/components/sequence/component.js +50 -50
- package/src/components/sequence/sequence.scss +10 -10
- package/src/components/subsequence/component.js +49 -49
- package/src/components/suggester/check-store.js +2 -4
- package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
- package/src/components/suggester/components/panel/option-container.js +61 -61
- package/src/components/suggester/components/panel/panel.js +47 -47
- package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
- package/src/components/suggester/components/selection/label.js +35 -35
- package/src/components/suggester/components/selection/selection.js +50 -50
- package/src/components/suggester/components/suggester-content.js +2 -2
- package/src/components/suggester/components/suggester.js +128 -88
- package/src/components/suggester/components/suggester.scss +101 -101
- package/src/components/suggester/default-style.scss +125 -125
- package/src/components/suggester/find-best-label/find-best-label.js +51 -49
- package/src/components/suggester/find-best-label/index.js +1 -1
- package/src/components/suggester/idb-suggester.js +73 -67
- package/src/components/suggester/lunatic-suggester.js +140 -137
- package/src/components/suggester/searching/create-searching.js +49 -47
- package/src/components/suggester/searching/index.js +1 -1
- package/src/components/suggester/state-management/actions.js +38 -38
- package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
- package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
- package/src/components/suggester/state-management/reducer/reducer.js +38 -38
- package/src/components/suggester/suggester-wrapper.js +127 -121
- package/src/components/suggester-loader-widget/loader.js +67 -67
- package/src/components/suggester-loader-widget/widget.js +123 -123
- package/src/components/table/table.js +173 -171
- package/src/components/table/table.scss +26 -26
- package/src/components/textarea/component.js +11 -11
- package/src/components/textarea/textarea.scss +8 -8
- package/src/components/tooltip/tooltip.scss +30 -30
- package/src/stories/checkbox-boolean/data.json +78 -78
- package/src/stories/datepicker/data.json +3 -1
- package/src/stories/dropdown/README.md +44 -44
- package/src/stories/dropdown/data.json +98 -98
- package/src/stories/dropdown/dropdown.stories.js +89 -89
- package/src/stories/progress-bar/progress-bar.stories.js +24 -24
- package/src/stories/questionnaire/arithmetic-management.json +47 -0
- package/src/stories/questionnaire/arithmetic.json +247 -247
- package/src/stories/questionnaire/kish.json +275 -0
- package/src/stories/questionnaire/logement-queen.json +23390 -0
- package/src/stories/questionnaire/logement-s2.json +46028 -0
- package/src/stories/questionnaire/logement.json +20347 -26087
- package/src/stories/questionnaire/loop-and-controls.json +481 -0
- package/src/stories/questionnaire/questionnaire.stories.js +236 -138
- package/src/stories/questionnaire/update-external/data.json +1 -0
- package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
- package/src/stories/suggester/README.md +46 -46
- package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
- package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
- package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
- package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
- package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
- package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
- package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
- package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
- package/src/stories/suggester/data-auto.json +232 -231
- package/src/stories/suggester/data-vtl.json +82 -82
- package/src/stories/suggester/data.json +169 -136
- package/src/stories/suggester/naf-rev2/index.js +2 -2
- package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
- package/src/stories/suggester/suggester-workers.stories.js +226 -179
- package/src/stories/suggester/suggester.stories.js +138 -133
- package/src/stories/utils/orchestrator-split.js +119 -0
- package/src/stories/utils/orchestrator.js +119 -108
- package/src/tests/components/input-number.spec.js +6 -12
- package/src/tests/components/missing-wrapper.spec.js +0 -1
- package/src/tests/utils/lib/table/roster.spec.js +25 -25
- package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
- package/src/utils/components/dragger/dragger.scss +7 -7
- package/src/utils/idb-tools/create-db-opener.js +43 -43
- package/src/utils/idb-tools/create-open-db.js +25 -25
- package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
- package/src/utils/idb-tools/index.js +10 -10
- package/src/utils/idb-tools/insert-entity.js +15 -15
- package/src/utils/idb-tools/open-db.js +13 -13
- package/src/utils/idb-tools/open-or-create-db.js +34 -34
- package/src/utils/lib/controls/index.js +1 -0
- package/src/utils/lib/controls/utils.js +152 -0
- package/src/utils/lib/decorator/title-decorator.js +16 -16
- package/src/utils/lib/env.js +2 -2
- package/src/utils/lib/index.js +2 -0
- package/src/utils/lib/input-number.js +1 -1
- package/src/utils/lib/options-positioning.js +9 -9
- package/src/utils/lib/pagination/navigation/shared.js +12 -9
- package/src/utils/lib/prop-types/lines.js +6 -6
- package/src/utils/lib/responses.js +11 -9
- package/src/utils/lib/splitting.js +142 -0
- package/src/utils/lib/style.js +10 -10
- package/src/utils/store-tools/auto-load.js +74 -73
- package/src/utils/suggester-workers/append-to-index/append.js +25 -25
- package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
- package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -43
- package/src/utils/suggester-workers/append-to-index/index.js +2 -2
- package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
- package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
- package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
- package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
- package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
- package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
- package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +12 -12
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
- package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +7 -7
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
- package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +13 -13
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
- package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
- package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +118 -118
- package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
- package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
- package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
- package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -9
- package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
- package/src/utils/suggester-workers/create-worker.js +56 -0
- package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
- package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
- package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -33
- package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
- package/src/utils/suggester-workers/searching/compute-score.js +33 -33
- package/src/utils/suggester-workers/searching/get-db.js +18 -18
- package/src/utils/suggester-workers/searching/index.js +1 -1
- package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
- package/src/utils/suggester-workers/searching/order/index.js +19 -19
- package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +2 -2
- package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
- package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +24 -24
- package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
- package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
- package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
- package/src/utils/suggester-workers/searching/searching.js +70 -70
- package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
- package/src/utils/to-expose/calculated-variables.js +113 -113
- package/src/utils/to-expose/handler.js +149 -112
- package/src/utils/to-expose/hooks/filter-components.js +27 -12
- package/src/utils/to-expose/hooks/index.js +2 -1
- package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
- package/src/utils/to-expose/hooks/lunatic.js +284 -187
- package/src/utils/to-expose/index.js +1 -1
- package/src/utils/to-expose/init-questionnaire.js +164 -164
- package/src/utils/to-expose/interpret/vtl.js +18 -18
- package/src/utils/to-expose/state.js +66 -58
- package/src/components/missing-wrapper/component.js +0 -120
- package/src/components/missing-wrapper/wrapper.js +0 -10
- package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
- package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
- package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
- package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
- package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
- package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
- package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
|
@@ -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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
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;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import createFieldsTokenizer from './create-fields-tokenizer';
|
|
2
|
+
import { composeFilters, createFilterStopWords } from './filters';
|
|
3
|
+
import filterStemmer from './filters/filter-stemmer';
|
|
4
|
+
import filterLength from './filters/filter-length';
|
|
5
|
+
import filterSynonyms from './filters/filter-synonyms';
|
|
6
|
+
import filterAccents from './filters/filter-accents';
|
|
7
|
+
import filterToLower from './filters/filter-to-lower';
|
|
8
|
+
import filterDouble from './filters/filter-double';
|
|
9
|
+
|
|
10
|
+
function createMapFieldsTokenizer(fields, filters) {
|
|
11
|
+
return fields.reduce(function (mapFieldTokenizers, field) {
|
|
12
|
+
const { name } = field;
|
|
13
|
+
return {
|
|
14
|
+
...mapFieldTokenizers,
|
|
15
|
+
[name]: createFieldsTokenizer(field, filters),
|
|
16
|
+
};
|
|
17
|
+
}, {});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
function createFilterTokens(fields, stopWords) {
|
|
21
|
+
const filterStopWords = createFilterStopWords(stopWords);
|
|
22
|
+
const getFilters = composeFilters(
|
|
23
|
+
filterDouble,
|
|
24
|
+
filterAccents,
|
|
25
|
+
filterStemmer,
|
|
26
|
+
filterSynonyms,
|
|
27
|
+
filterToLower,
|
|
28
|
+
filterStopWords,
|
|
29
|
+
filterLength
|
|
30
|
+
);
|
|
31
|
+
const FIELDS_TOKENIZER_MAP = createMapFieldsTokenizer(
|
|
32
|
+
fields || [],
|
|
33
|
+
getFilters
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
return function (field, entity) {
|
|
37
|
+
const { name } = field;
|
|
38
|
+
const tokenizeIt = FIELDS_TOKENIZER_MAP[name];
|
|
39
|
+
if (name in entity) {
|
|
40
|
+
return tokenizeIt(`${entity[name]}`);
|
|
41
|
+
}
|
|
42
|
+
return [];
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function createEntityTokenizer(fields, stopWords) {
|
|
47
|
+
const tokenizeAll = createFilterTokens(fields, stopWords);
|
|
48
|
+
return function (entity) {
|
|
49
|
+
return fields.reduce(function (a, field) {
|
|
50
|
+
const { name } = field;
|
|
51
|
+
return { ...a, [name]: tokenizeAll(field, entity) };
|
|
52
|
+
}, {});
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export default createEntityTokenizer;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import prepareStringIndexation from './prepare-string-indexation';
|
|
2
|
+
import softTokenizer from './soft-tokenizer';
|
|
3
|
+
import tokenizer from 'string-tokenizer';
|
|
4
|
+
import getRegExpFromPattern from './get-regexp-from-pattern';
|
|
5
|
+
|
|
6
|
+
function defaultTokenizeIt(string) {
|
|
7
|
+
return [prepareStringIndexation(string)];
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
function toArray(content) {
|
|
11
|
+
return Array.isArray(content) ? content : [content];
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
function tokensToArray(tokenized) {
|
|
15
|
+
return Object.entries(tokenized).reduce(function (a, [k, values]) {
|
|
16
|
+
if (k.startsWith('pattern')) {
|
|
17
|
+
return [...a, ...toArray(values)];
|
|
18
|
+
}
|
|
19
|
+
return a;
|
|
20
|
+
}, []);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function createFieldsTokenizer(field, filtersStack) {
|
|
24
|
+
const {
|
|
25
|
+
name,
|
|
26
|
+
rules = [],
|
|
27
|
+
min,
|
|
28
|
+
language = 'French',
|
|
29
|
+
stemmer = true,
|
|
30
|
+
synonyms = {},
|
|
31
|
+
} = field;
|
|
32
|
+
if (rules === 'soft') {
|
|
33
|
+
return softTokenizer;
|
|
34
|
+
}
|
|
35
|
+
if (rules.length) {
|
|
36
|
+
const tokenRules = rules.reduce(function (rulesMap, pattern, index) {
|
|
37
|
+
return {
|
|
38
|
+
...rulesMap,
|
|
39
|
+
[`pattern${name}${index}`]: getRegExpFromPattern(pattern),
|
|
40
|
+
};
|
|
41
|
+
}, {});
|
|
42
|
+
|
|
43
|
+
return function (string) {
|
|
44
|
+
const what = tokenizer().input(string).tokens(tokenRules).resolve();
|
|
45
|
+
return filtersStack(tokensToArray(what), {
|
|
46
|
+
min,
|
|
47
|
+
language,
|
|
48
|
+
stemmer,
|
|
49
|
+
synonyms,
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
return defaultTokenizeIt;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export default createFieldsTokenizer;
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import defaultStopWords from './stop-words';
|
|
2
|
-
|
|
3
|
-
function createFilterStopWords(stops = defaultStopWords) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
export default createFilterStopWords;
|
|
1
|
+
import defaultStopWords from './stop-words';
|
|
2
|
+
|
|
3
|
+
function createFilterStopWords(stops = defaultStopWords) {
|
|
4
|
+
const mapSW = stops.reduce(function (a, w) {
|
|
5
|
+
return { ...a, [w]: undefined };
|
|
6
|
+
}, {});
|
|
7
|
+
return function filter(tokens) {
|
|
8
|
+
return tokens.reduce(function (a, t) {
|
|
9
|
+
if (t in mapSW) {
|
|
10
|
+
return a;
|
|
11
|
+
}
|
|
12
|
+
return [...a, t];
|
|
13
|
+
}, []);
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export default createFilterStopWords;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import defaultStopWords from './stop-words';
|
|
2
|
+
|
|
3
|
+
function createFilterStopWords(stops = defaultStopWords) {
|
|
4
|
+
const mapSW = stops.reduce(function (a, w) {
|
|
5
|
+
return { ...a, [w]: undefined };
|
|
6
|
+
}, {});
|
|
7
|
+
return function filter(tokens) {
|
|
8
|
+
return tokens.reduce(function (a, t) {
|
|
9
|
+
if (t in mapSW) {
|
|
10
|
+
return a;
|
|
11
|
+
}
|
|
12
|
+
return [...a, t];
|
|
13
|
+
}, []);
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export default createFilterStopWords;
|
package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import createFilterSW from './create-filter-stop-words';
|
|
2
|
+
|
|
3
|
+
describe('create-filter-stop-words', function () {
|
|
4
|
+
it('only last ', function () {
|
|
5
|
+
const sw = ['un', 'de'];
|
|
6
|
+
const tokens = ['un', 'de', 'trois'];
|
|
7
|
+
|
|
8
|
+
const filter = createFilterSW(sw);
|
|
9
|
+
|
|
10
|
+
const results = filter(tokens);
|
|
11
|
+
expect(Array.isArray(results)).toBe(true);
|
|
12
|
+
expect(results.length).toBe(1);
|
|
13
|
+
});
|
|
14
|
+
});
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import removeAccents from 'remove-accents';
|
|
2
|
+
|
|
3
|
+
function filterAccents(tokens = []) {
|
|
4
|
+
return tokens.map(function (token) {
|
|
5
|
+
if (typeof token === 'string') {
|
|
6
|
+
return removeAccents(token).toLowerCase();
|
|
7
|
+
}
|
|
8
|
+
return token;
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export default filterAccents;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import filterATL from './filter-accents';
|
|
2
|
+
|
|
3
|
+
describe('filter-length', function () {
|
|
4
|
+
it('maj accent', function () {
|
|
5
|
+
const tokens = ['UN', 'éà ù'];
|
|
6
|
+
const results = filterATL(tokens, { min: 3 });
|
|
7
|
+
expect(Array.isArray(results)).toBe(true);
|
|
8
|
+
expect(results.length).toBe(2);
|
|
9
|
+
expect(results[0]).toBe('un');
|
|
10
|
+
expect(results[1]).toBe('ea u');
|
|
11
|
+
});
|
|
12
|
+
});
|
package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js}
RENAMED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
function filterDouble(tokens = []) {
|
|
2
|
-
const map = {};
|
|
3
|
-
return tokens.reduce(function (a, token) {
|
|
4
|
-
if (token in map) {
|
|
5
|
-
return a;
|
|
6
|
-
}
|
|
7
|
-
map[token] = true;
|
|
8
|
-
return [...a, token];
|
|
9
|
-
}, []);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export default filterDouble;
|
|
1
|
+
function filterDouble(tokens = []) {
|
|
2
|
+
const map = {};
|
|
3
|
+
return tokens.reduce(function (a, token) {
|
|
4
|
+
if (token in map) {
|
|
5
|
+
return a;
|
|
6
|
+
}
|
|
7
|
+
map[token] = true;
|
|
8
|
+
return [...a, token];
|
|
9
|
+
}, []);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export default filterDouble;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import filterDouble from './filter-double';
|
|
2
|
+
|
|
3
|
+
describe('filter-double', function () {
|
|
4
|
+
it('empty', function () {
|
|
5
|
+
const tokens = ['un', 'un'];
|
|
6
|
+
const results = filterDouble(tokens);
|
|
7
|
+
expect(Array.isArray(results)).toBe(true);
|
|
8
|
+
expect(results.length).toBe(1);
|
|
9
|
+
expect(results[0]).toBe('un');
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
it('remove one', function () {
|
|
13
|
+
const tokens = ['un', 'un', 'long'];
|
|
14
|
+
const results = filterDouble(tokens, { min: 3 });
|
|
15
|
+
expect(Array.isArray(results)).toBe(true);
|
|
16
|
+
expect(results.length).toBe(2);
|
|
17
|
+
expect(results[0]).toBe('un');
|
|
18
|
+
expect(results[1]).toBe('long');
|
|
19
|
+
});
|
|
20
|
+
});
|
package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
function filterLength(tokens, { min = 2 }) {
|
|
2
|
-
return tokens.filter(function (token) {
|
|
3
|
-
return token.length >= min;
|
|
4
|
-
});
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export default filterLength;
|
|
1
|
+
function filterLength(tokens, { min = 2 }) {
|
|
2
|
+
return tokens.filter(function (token) {
|
|
3
|
+
return token.length >= min;
|
|
4
|
+
});
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export default filterLength;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import filterLength from './filter-length';
|
|
2
|
+
|
|
3
|
+
describe('filter-length', function () {
|
|
4
|
+
it('empty', function () {
|
|
5
|
+
const tokens = ['un', 'no'];
|
|
6
|
+
const results = filterLength(tokens, { min: 3 });
|
|
7
|
+
expect(Array.isArray(results)).toBe(true);
|
|
8
|
+
expect(results.length).toBe(0);
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
it('remove one', function () {
|
|
12
|
+
const tokens = ['un', 'long'];
|
|
13
|
+
const results = filterLength(tokens, { min: 3 });
|
|
14
|
+
expect(Array.isArray(results)).toBe(true);
|
|
15
|
+
expect(results.length).toBe(1);
|
|
16
|
+
expect(results[0]).toBe('long');
|
|
17
|
+
});
|
|
18
|
+
});
|