@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.
- 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/loop-constructor/wrapper/component.js +190 -190
- 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/breadcrumb/breadcrumb.stories.js +21 -21
- package/src/stories/checkbox-boolean/data.json +78 -78
- package/src/stories/datepicker/data.json +3 -1
- package/src/stories/declarations/declarations.stories.js +116 -116
- 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/calc-var.json +187 -187
- package/src/stories/questionnaire/data-logement.json +2691 -2691
- 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 -44537
- package/src/stories/questionnaire/logement-sequence.json +26741 -26741
- package/src/stories/questionnaire/logement.json +21073 -26813
- package/src/stories/questionnaire/loop-and-controls.json +481 -0
- package/src/stories/questionnaire/questionnaire.stories.js +236 -154
- package/src/stories/questionnaire/update-external/data.json +1 -0
- package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
- package/src/stories/sequence/sequence.stories.js +32 -32
- package/src/stories/subsequence/subsequence.stories.js +32 -32
- 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/loops/roster-loop.json +71 -71
- 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/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
- package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
- 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 +256 -253
- 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 -188
- 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,18 +1,18 @@
|
|
|
1
|
-
import Snowball from 'snowball';
|
|
2
|
-
|
|
3
|
-
const STEMMERS = {};
|
|
4
|
-
|
|
5
|
-
function getStemmer(language = 'French') {
|
|
6
|
-
if (!(language in STEMMERS)) {
|
|
7
|
-
const stemmer = new Snowball(language);
|
|
8
|
-
STEMMERS[language] = function (token) {
|
|
9
|
-
stemmer.setCurrent(token);
|
|
10
|
-
stemmer.stem();
|
|
11
|
-
return stemmer.getCurrent();
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
return STEMMERS[language];
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export default getStemmer;
|
|
1
|
+
import Snowball from 'snowball';
|
|
2
|
+
|
|
3
|
+
const STEMMERS = {};
|
|
4
|
+
|
|
5
|
+
function getStemmer(language = 'French') {
|
|
6
|
+
if (!(language in STEMMERS)) {
|
|
7
|
+
const stemmer = new Snowball(language);
|
|
8
|
+
STEMMERS[language] = function (token) {
|
|
9
|
+
stemmer.setCurrent(token);
|
|
10
|
+
stemmer.stem();
|
|
11
|
+
return stemmer.getCurrent();
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
return STEMMERS[language];
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export default getStemmer;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
export { default as getStemmer } from './get-stemmer';
|
|
2
|
-
export { default as createTokenizer } from './create-tokenizer';
|
|
3
|
-
export { default as prepareStringIndexation } from './prepare-string-indexation';
|
|
4
|
-
export { default as filterStemmer } from './filter-stemmer';
|
|
5
|
-
export { default as filterLength } from './filter-length';
|
|
6
|
-
export { default as filterDouble } from './filter-double';
|
|
7
|
-
export { default as
|
|
8
|
-
export { default as
|
|
1
|
+
export { default as getStemmer } from './get-stemmer';
|
|
2
|
+
export { default as createTokenizer } from './create-entity-tokenizer';
|
|
3
|
+
export { default as prepareStringIndexation } from './prepare-string-indexation';
|
|
4
|
+
export { default as filterStemmer } from './filters/filter-stemmer';
|
|
5
|
+
export { default as filterLength } from './filters/filter-length';
|
|
6
|
+
export { default as filterDouble } from './filters/filter-double';
|
|
7
|
+
export { default as filterAccents } from './filters/filter-accents';
|
|
8
|
+
export { default as filterToLower } from './filters/filter-to-lower';
|
|
9
|
+
export { default as getRegExpFromPattern } from './get-regexp-from-pattern';
|
|
@@ -1,9 +1,13 @@
|
|
|
1
|
-
import removeAccents from 'remove-accents';
|
|
2
|
-
|
|
3
|
-
function prepare(token = '', replacement = '') {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
import removeAccents from 'remove-accents';
|
|
2
|
+
|
|
3
|
+
function prepare(token = '', replacement = '') {
|
|
4
|
+
if (typeof token === 'string') {
|
|
5
|
+
return removeAccents(token.trim().toLowerCase()).replace(
|
|
6
|
+
/[- ']/g,
|
|
7
|
+
replacement
|
|
8
|
+
);
|
|
9
|
+
}
|
|
10
|
+
return token;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export default prepare;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import prepareStringIndexation from '
|
|
2
|
-
|
|
3
|
-
function softTokenizer(string) {
|
|
4
|
-
return [prepareStringIndexation(string, '-')];
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export default softTokenizer;
|
|
1
|
+
import { prepareStringIndexation } from '../commons-tokenizer';
|
|
2
|
+
|
|
3
|
+
function softTokenizer(string) {
|
|
4
|
+
return [prepareStringIndexation(string, '-')];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export default softTokenizer;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
// Enable cross domain workers
|
|
2
|
+
|
|
3
|
+
const testSameOrigin = (url) => {
|
|
4
|
+
var loc = window.location;
|
|
5
|
+
var a = document.createElement('a');
|
|
6
|
+
a.href = url;
|
|
7
|
+
return (
|
|
8
|
+
a.hostname === loc.hostname &&
|
|
9
|
+
a.port === loc.port &&
|
|
10
|
+
a.protocol === loc.protocol
|
|
11
|
+
);
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const createWorkerFallback = (workerUrl) => {
|
|
15
|
+
console.log('Create worker for MFE');
|
|
16
|
+
var worker = null;
|
|
17
|
+
try {
|
|
18
|
+
var blob;
|
|
19
|
+
try {
|
|
20
|
+
blob = new Blob([`importScripts('${workerUrl}');`], {
|
|
21
|
+
type: 'application/javascript',
|
|
22
|
+
});
|
|
23
|
+
} catch (e) {
|
|
24
|
+
var blobBuilder = new (window.BlobBuilder ||
|
|
25
|
+
window.WebKitBlobBuilder ||
|
|
26
|
+
window.MozBlobBuilder)();
|
|
27
|
+
blobBuilder.append(`importScripts('${workerUrl}');`);
|
|
28
|
+
blob = blobBuilder.getBlob('application/javascript');
|
|
29
|
+
}
|
|
30
|
+
var url = window.URL || window.webkitURL;
|
|
31
|
+
var blobUrl = url.createObjectURL(blob);
|
|
32
|
+
worker = new Worker(blobUrl);
|
|
33
|
+
} catch (e1) {
|
|
34
|
+
console.error(`Lunatic-worker : Failed to load web worker : ${workerUrl}`);
|
|
35
|
+
}
|
|
36
|
+
return worker;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
export const createWorker = (workerUrl) => {
|
|
40
|
+
var worker = null;
|
|
41
|
+
try {
|
|
42
|
+
if (testSameOrigin(workerUrl)) {
|
|
43
|
+
console.log('Trying create classic worker');
|
|
44
|
+
worker = new Worker(workerUrl);
|
|
45
|
+
worker.onerror = (event) => {
|
|
46
|
+
event.preventDefault();
|
|
47
|
+
worker = createWorkerFallback(workerUrl);
|
|
48
|
+
};
|
|
49
|
+
} else {
|
|
50
|
+
worker = createWorkerFallback(workerUrl);
|
|
51
|
+
}
|
|
52
|
+
} catch (e) {
|
|
53
|
+
worker = createWorkerFallback(workerUrl);
|
|
54
|
+
}
|
|
55
|
+
return worker;
|
|
56
|
+
};
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
import distance from 'damerau-levenshtein';
|
|
2
|
-
|
|
3
|
-
function reduceFields(map, fields, similarity) {
|
|
4
|
-
return fields.reduce(function (m, field) {
|
|
5
|
-
if (field in m) {
|
|
6
|
-
return { ...m, [field]: m[field] + similarity };
|
|
7
|
-
}
|
|
8
|
-
return { ...m, [field]: similarity };
|
|
9
|
-
}, map);
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function reduceTokensMap(map, entries, word) {
|
|
13
|
-
return entries.reduce(function (inter, [token, { fields }]) {
|
|
14
|
-
const { similarity } = distance(token, word);
|
|
15
|
-
return reduceFields(inter, fields, similarity);
|
|
16
|
-
}, map);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function findBest(map) {
|
|
20
|
-
let best = -1;
|
|
21
|
-
return Object.entries(map).reduce(function (curr, [field, score]) {
|
|
22
|
-
if (score > best) {
|
|
23
|
-
best = score;
|
|
24
|
-
return field;
|
|
25
|
-
}
|
|
26
|
-
return curr;
|
|
27
|
-
}, undefined);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
function findBestLabel(searchTokens = [], tokensMap = {}) {
|
|
31
|
-
const entries = Object.entries(tokensMap);
|
|
32
|
-
const map = searchTokens.reduce(function (map, word) {
|
|
33
|
-
return reduceTokensMap(map, entries, word);
|
|
34
|
-
}, {});
|
|
35
|
-
const best = findBest(map);
|
|
36
|
-
return best;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export default findBestLabel;
|
|
1
|
+
import distance from 'damerau-levenshtein';
|
|
2
|
+
|
|
3
|
+
function reduceFields(map, fields, similarity) {
|
|
4
|
+
return fields.reduce(function (m, field) {
|
|
5
|
+
if (field in m) {
|
|
6
|
+
return { ...m, [field]: m[field] + similarity };
|
|
7
|
+
}
|
|
8
|
+
return { ...m, [field]: similarity };
|
|
9
|
+
}, map);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function reduceTokensMap(map, entries, word) {
|
|
13
|
+
return entries.reduce(function (inter, [token, { fields }]) {
|
|
14
|
+
const { similarity } = distance(token, word);
|
|
15
|
+
return reduceFields(inter, fields, similarity);
|
|
16
|
+
}, map);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
function findBest(map) {
|
|
20
|
+
let best = -1;
|
|
21
|
+
return Object.entries(map).reduce(function (curr, [field, score]) {
|
|
22
|
+
if (score > best) {
|
|
23
|
+
best = score;
|
|
24
|
+
return field;
|
|
25
|
+
}
|
|
26
|
+
return curr;
|
|
27
|
+
}, undefined);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
function findBestLabel(searchTokens = [], tokensMap = {}) {
|
|
31
|
+
const entries = Object.entries(tokensMap);
|
|
32
|
+
const map = searchTokens.reduce(function (map, word) {
|
|
33
|
+
return reduceTokensMap(map, entries, word);
|
|
34
|
+
}, {});
|
|
35
|
+
const best = findBest(map);
|
|
36
|
+
return best;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export default findBestLabel;
|
|
@@ -1,40 +1,40 @@
|
|
|
1
|
-
/* eslint-disable no-restricted-globals */
|
|
2
|
-
import 'core-js/stable';
|
|
3
|
-
import 'regenerator-runtime/runtime';
|
|
4
|
-
import tokenize from './tokenize';
|
|
5
|
-
import findBestLabel from './find-best-label';
|
|
6
|
-
|
|
7
|
-
const TASKS = [];
|
|
8
|
-
let RUN = false;
|
|
9
|
-
|
|
10
|
-
function executeTask(task) {
|
|
11
|
-
const { option, search, idTask } = task;
|
|
12
|
-
const { tokensMap } = option;
|
|
13
|
-
const { search: st } = tokenize({ search });
|
|
14
|
-
const label = findBestLabel(st, tokensMap);
|
|
15
|
-
|
|
16
|
-
self.postMessage({ response: label, idTask });
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
function appendTask(task) {
|
|
20
|
-
TASKS.push(task);
|
|
21
|
-
if (!RUN) {
|
|
22
|
-
activate();
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
function activate() {
|
|
27
|
-
RUN = true;
|
|
28
|
-
while (TASKS.length) {
|
|
29
|
-
const task = TASKS.pop();
|
|
30
|
-
executeTask(task);
|
|
31
|
-
}
|
|
32
|
-
RUN = false;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
self.onmessage = function (e) {
|
|
36
|
-
const { option, search, idTask } = e.data;
|
|
37
|
-
if (option && search && idTask) {
|
|
38
|
-
appendTask({ option, search, idTask });
|
|
39
|
-
}
|
|
40
|
-
};
|
|
1
|
+
/* eslint-disable no-restricted-globals */
|
|
2
|
+
import 'core-js/stable';
|
|
3
|
+
import 'regenerator-runtime/runtime';
|
|
4
|
+
import tokenize from './tokenize';
|
|
5
|
+
import findBestLabel from './find-best-label';
|
|
6
|
+
|
|
7
|
+
const TASKS = [];
|
|
8
|
+
let RUN = false;
|
|
9
|
+
|
|
10
|
+
function executeTask(task) {
|
|
11
|
+
const { option, search, idTask } = task;
|
|
12
|
+
const { tokensMap } = option;
|
|
13
|
+
const { search: st } = tokenize({ search });
|
|
14
|
+
const label = findBestLabel(st, tokensMap);
|
|
15
|
+
|
|
16
|
+
self.postMessage({ response: label, idTask });
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
function appendTask(task) {
|
|
20
|
+
TASKS.push(task);
|
|
21
|
+
if (!RUN) {
|
|
22
|
+
activate();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function activate() {
|
|
27
|
+
RUN = true;
|
|
28
|
+
while (TASKS.length) {
|
|
29
|
+
const task = TASKS.pop();
|
|
30
|
+
executeTask(task);
|
|
31
|
+
}
|
|
32
|
+
RUN = false;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
self.onmessage = function (e) {
|
|
36
|
+
const { option, search, idTask } = e.data;
|
|
37
|
+
if (option && search && idTask) {
|
|
38
|
+
appendTask({ option, search, idTask });
|
|
39
|
+
}
|
|
40
|
+
};
|
|
@@ -1,33 +1,30 @@
|
|
|
1
|
-
import tokenizer from 'string-tokenizer';
|
|
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
|
-
export default tokenize;
|
|
1
|
+
import tokenizer from 'string-tokenizer';
|
|
2
|
+
|
|
3
|
+
function toArray(tokens) {
|
|
4
|
+
if (Array.isArray(tokens)) {
|
|
5
|
+
return tokens;
|
|
6
|
+
}
|
|
7
|
+
return [tokens];
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
function tokenize(object, pattern = /[\w]+/) {
|
|
11
|
+
if (typeof object === 'object') {
|
|
12
|
+
const map = {};
|
|
13
|
+
Object.entries(object).forEach(function ([key, string]) {
|
|
14
|
+
if (string.length) {
|
|
15
|
+
const { tokens } = tokenizer()
|
|
16
|
+
.input(string)
|
|
17
|
+
.tokens({ tokens: pattern })
|
|
18
|
+
.resolve();
|
|
19
|
+
map[key] = toArray(tokens);
|
|
20
|
+
} else {
|
|
21
|
+
map[key] = [];
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
return map;
|
|
26
|
+
}
|
|
27
|
+
return {};
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export default tokenize;
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import tokenize from './tokenize';
|
|
2
|
-
|
|
3
|
-
describe('tokenize', function () {
|
|
4
|
-
it('simple', function () {
|
|
5
|
-
const results = tokenize({ hello: 'hello world!' });
|
|
6
|
-
const { hello } = results;
|
|
7
|
-
expect(Array.isArray(hello)).toEqual(true);
|
|
8
|
-
expect(hello.length).toEqual(2);
|
|
9
|
-
expect(hello[0]).toEqual('hello');
|
|
10
|
-
expect(hello[1]).toEqual('world');
|
|
11
|
-
});
|
|
12
|
-
|
|
13
|
-
it('undefined', function () {
|
|
14
|
-
const results = tokenize({ hello: '' });
|
|
15
|
-
const { hello } = results;
|
|
16
|
-
expect(Array.isArray(hello)).toEqual(true);
|
|
17
|
-
expect(hello.length).toEqual(0);
|
|
18
|
-
});
|
|
19
|
-
});
|
|
1
|
+
import tokenize from './tokenize';
|
|
2
|
+
|
|
3
|
+
describe('tokenize', function () {
|
|
4
|
+
it('simple', function () {
|
|
5
|
+
const results = tokenize({ hello: 'hello world!' });
|
|
6
|
+
const { hello } = results;
|
|
7
|
+
expect(Array.isArray(hello)).toEqual(true);
|
|
8
|
+
expect(hello.length).toEqual(2);
|
|
9
|
+
expect(hello[0]).toEqual('hello');
|
|
10
|
+
expect(hello[1]).toEqual('world');
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it('undefined', function () {
|
|
14
|
+
const results = tokenize({ hello: '' });
|
|
15
|
+
const { hello } = results;
|
|
16
|
+
expect(Array.isArray(hello)).toEqual(true);
|
|
17
|
+
expect(hello.length).toEqual(0);
|
|
18
|
+
});
|
|
19
|
+
});
|
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
function finalize(withScore, max = 30) {
|
|
2
|
-
return withScore
|
|
3
|
-
.sort(function (a, b) {
|
|
4
|
-
if (a.score > b.score) {
|
|
5
|
-
return -1;
|
|
6
|
-
}
|
|
7
|
-
if (a.score < b.score) {
|
|
8
|
-
return 1;
|
|
9
|
-
}
|
|
10
|
-
return 0;
|
|
11
|
-
})
|
|
12
|
-
.slice(0, max);
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
function compute(results) {
|
|
16
|
-
const listOfDocs = Object.values(results);
|
|
17
|
-
const mapResults = {};
|
|
18
|
-
|
|
19
|
-
listOfDocs.forEach(function (docs, i) {
|
|
20
|
-
docs.forEach(function (doc) {
|
|
21
|
-
const { id } = doc;
|
|
22
|
-
if (id in mapResults) {
|
|
23
|
-
mapResults[id].score++;
|
|
24
|
-
mapResults[id].step = [i, ...mapResults[id].step];
|
|
25
|
-
} else {
|
|
26
|
-
mapResults[id] = { ...doc, score: 1, step: [i] };
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
return finalize(Object.values(mapResults));
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export default compute;
|
|
1
|
+
function finalize(withScore, max = 30) {
|
|
2
|
+
return withScore
|
|
3
|
+
.sort(function (a, b) {
|
|
4
|
+
if (a.score > b.score) {
|
|
5
|
+
return -1;
|
|
6
|
+
}
|
|
7
|
+
if (a.score < b.score) {
|
|
8
|
+
return 1;
|
|
9
|
+
}
|
|
10
|
+
return 0;
|
|
11
|
+
})
|
|
12
|
+
.slice(0, max);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
function compute(results) {
|
|
16
|
+
const listOfDocs = Object.values(results);
|
|
17
|
+
const mapResults = {};
|
|
18
|
+
|
|
19
|
+
listOfDocs.forEach(function (docs, i) {
|
|
20
|
+
docs.forEach(function (doc) {
|
|
21
|
+
const { id } = doc;
|
|
22
|
+
if (id in mapResults) {
|
|
23
|
+
mapResults[id].score++;
|
|
24
|
+
mapResults[id].step = [i, ...mapResults[id].step];
|
|
25
|
+
} else {
|
|
26
|
+
mapResults[id] = { ...doc, score: 1, step: [i] };
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
return finalize(Object.values(mapResults));
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export default compute;
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { openDb } from '../../idb-tools';
|
|
2
|
-
|
|
3
|
-
let STORES = {};
|
|
4
|
-
|
|
5
|
-
async function getDb(name, version) {
|
|
6
|
-
if (name in STORES) {
|
|
7
|
-
return STORES[name];
|
|
8
|
-
}
|
|
9
|
-
try {
|
|
10
|
-
const store = await openDb(name, version);
|
|
11
|
-
STORES[name] = store;
|
|
12
|
-
return store;
|
|
13
|
-
} catch (e) {
|
|
14
|
-
throw new Error(`Can't open store ${name} ${version}`);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export default getDb;
|
|
1
|
+
import { openDb } from '../../idb-tools';
|
|
2
|
+
|
|
3
|
+
let STORES = {};
|
|
4
|
+
|
|
5
|
+
async function getDb(name, version) {
|
|
6
|
+
if (name in STORES) {
|
|
7
|
+
return STORES[name];
|
|
8
|
+
}
|
|
9
|
+
try {
|
|
10
|
+
const store = await openDb(name, version);
|
|
11
|
+
STORES[name] = store;
|
|
12
|
+
return store;
|
|
13
|
+
} catch (e) {
|
|
14
|
+
throw new Error(`Can't open store ${name} ${version}`);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export default getDb;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export { default } from './searching';
|
|
1
|
+
export { default } from './searching';
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
function createAlphanumericOrderer(descending = false) {
|
|
2
|
-
return function ascending(response, order = {}) {
|
|
3
|
-
const { field } = order;
|
|
4
|
-
|
|
5
|
-
if (field && Array.isArray(response)) {
|
|
6
|
-
return response.sort(function (a, b) {
|
|
7
|
-
if (field in a.suggestion && field in b.suggestion) {
|
|
8
|
-
if (a.suggestion[field] > b.suggestion[field]) {
|
|
9
|
-
return descending ? -1 : 1;
|
|
10
|
-
} else if (a.suggestion[field] < b.suggestion[field]) {
|
|
11
|
-
return descending ? 1 : -1;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
return 0;
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
return response;
|
|
18
|
-
};
|
|
19
|
-
}
|
|
20
|
-
export default createAlphanumericOrderer;
|
|
1
|
+
function createAlphanumericOrderer(descending = false) {
|
|
2
|
+
return function ascending(response, order = {}) {
|
|
3
|
+
const { field } = order;
|
|
4
|
+
|
|
5
|
+
if (field && Array.isArray(response)) {
|
|
6
|
+
return response.sort(function (a, b) {
|
|
7
|
+
if (field in a.suggestion && field in b.suggestion) {
|
|
8
|
+
if (a.suggestion[field] > b.suggestion[field]) {
|
|
9
|
+
return descending ? -1 : 1;
|
|
10
|
+
} else if (a.suggestion[field] < b.suggestion[field]) {
|
|
11
|
+
return descending ? 1 : -1;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return 0;
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
return response;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export default createAlphanumericOrderer;
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import createAlphanumericOrderer from './create-alphanumeric-orderer';
|
|
2
|
-
|
|
3
|
-
function identity(response) {
|
|
4
|
-
return response;
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
function getOrderingFunction(order = {}) {
|
|
8
|
-
const { type } = order;
|
|
9
|
-
switch (type) {
|
|
10
|
-
case 'ascending':
|
|
11
|
-
return createAlphanumericOrderer(false);
|
|
12
|
-
case 'descending':
|
|
13
|
-
return createAlphanumericOrderer(true);
|
|
14
|
-
default:
|
|
15
|
-
return identity;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export default getOrderingFunction;
|
|
1
|
+
import createAlphanumericOrderer from './create-alphanumeric-orderer';
|
|
2
|
+
|
|
3
|
+
function identity(response) {
|
|
4
|
+
return response;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
function getOrderingFunction(order = {}) {
|
|
8
|
+
const { type } = order;
|
|
9
|
+
switch (type) {
|
|
10
|
+
case 'ascending':
|
|
11
|
+
return createAlphanumericOrderer(false);
|
|
12
|
+
case 'descending':
|
|
13
|
+
return createAlphanumericOrderer(true);
|
|
14
|
+
default:
|
|
15
|
+
return identity;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export default getOrderingFunction;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { default as queryParserTokenized } from './query-parser-tokenized';
|
|
2
|
-
export { default as queryParserSoft } from './query-parser-soft';
|
|
1
|
+
export { default as queryParserTokenized } from './query-parser-tokenized';
|
|
2
|
+
export { default as queryParserSoft } from './query-parser-soft';
|