@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.
Files changed (219) 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/modal/component.js +36 -0
  56. package/src/components/modal/index.js +1 -0
  57. package/src/components/modal/modal.scss +33 -0
  58. package/src/components/progress-bar/progress-bar.scss +54 -54
  59. package/src/components/radio/component.js +9 -9
  60. package/src/components/radio/radio.scss +59 -59
  61. package/src/components/sequence/component.js +50 -50
  62. package/src/components/sequence/sequence.scss +10 -10
  63. package/src/components/subsequence/component.js +49 -49
  64. package/src/components/suggester/check-store.js +2 -4
  65. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  66. package/src/components/suggester/components/panel/option-container.js +61 -61
  67. package/src/components/suggester/components/panel/panel.js +47 -47
  68. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  69. package/src/components/suggester/components/selection/label.js +35 -35
  70. package/src/components/suggester/components/selection/selection.js +50 -50
  71. package/src/components/suggester/components/suggester-content.js +2 -2
  72. package/src/components/suggester/components/suggester.js +128 -88
  73. package/src/components/suggester/components/suggester.scss +101 -101
  74. package/src/components/suggester/default-style.scss +125 -125
  75. package/src/components/suggester/find-best-label/find-best-label.js +51 -49
  76. package/src/components/suggester/find-best-label/index.js +1 -1
  77. package/src/components/suggester/idb-suggester.js +73 -67
  78. package/src/components/suggester/lunatic-suggester.js +140 -137
  79. package/src/components/suggester/searching/create-searching.js +49 -47
  80. package/src/components/suggester/searching/index.js +1 -1
  81. package/src/components/suggester/state-management/actions.js +38 -38
  82. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  83. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  84. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  85. package/src/components/suggester/suggester-wrapper.js +127 -121
  86. package/src/components/suggester-loader-widget/loader.js +67 -67
  87. package/src/components/suggester-loader-widget/widget.js +123 -123
  88. package/src/components/table/table.js +173 -171
  89. package/src/components/table/table.scss +26 -26
  90. package/src/components/textarea/component.js +11 -11
  91. package/src/components/textarea/textarea.scss +8 -8
  92. package/src/components/tooltip/tooltip.scss +30 -30
  93. package/src/stories/checkbox-boolean/data.json +78 -78
  94. package/src/stories/datepicker/data.json +3 -1
  95. package/src/stories/dropdown/README.md +44 -44
  96. package/src/stories/dropdown/data.json +98 -98
  97. package/src/stories/dropdown/dropdown.stories.js +89 -89
  98. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  99. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  100. package/src/stories/questionnaire/arithmetic.json +247 -247
  101. package/src/stories/questionnaire/kish.json +275 -0
  102. package/src/stories/questionnaire/logement-queen.json +23390 -0
  103. package/src/stories/questionnaire/logement-s2.json +46028 -0
  104. package/src/stories/questionnaire/logement.json +20347 -26087
  105. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  106. package/src/stories/questionnaire/questionnaire.stories.js +236 -138
  107. package/src/stories/questionnaire/update-external/data.json +1 -0
  108. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  109. package/src/stories/suggester/README.md +46 -46
  110. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  111. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  112. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  113. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  114. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  115. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  116. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  117. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  118. package/src/stories/suggester/data-auto.json +232 -231
  119. package/src/stories/suggester/data-vtl.json +82 -82
  120. package/src/stories/suggester/data.json +169 -136
  121. package/src/stories/suggester/naf-rev2/index.js +2 -2
  122. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  123. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  124. package/src/stories/suggester/suggester.stories.js +138 -133
  125. package/src/stories/utils/orchestrator-split.js +119 -0
  126. package/src/stories/utils/orchestrator.js +119 -108
  127. package/src/tests/components/input-number.spec.js +6 -12
  128. package/src/tests/components/missing-wrapper.spec.js +0 -1
  129. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  130. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  131. package/src/utils/components/dragger/dragger.scss +7 -7
  132. package/src/utils/idb-tools/create-db-opener.js +43 -43
  133. package/src/utils/idb-tools/create-open-db.js +25 -25
  134. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  135. package/src/utils/idb-tools/index.js +10 -10
  136. package/src/utils/idb-tools/insert-entity.js +15 -15
  137. package/src/utils/idb-tools/open-db.js +13 -13
  138. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  139. package/src/utils/lib/controls/index.js +1 -0
  140. package/src/utils/lib/controls/utils.js +152 -0
  141. package/src/utils/lib/decorator/title-decorator.js +16 -16
  142. package/src/utils/lib/env.js +2 -2
  143. package/src/utils/lib/index.js +2 -0
  144. package/src/utils/lib/input-number.js +1 -1
  145. package/src/utils/lib/options-positioning.js +9 -9
  146. package/src/utils/lib/pagination/navigation/shared.js +12 -9
  147. package/src/utils/lib/prop-types/lines.js +6 -6
  148. package/src/utils/lib/responses.js +11 -9
  149. package/src/utils/lib/splitting.js +142 -0
  150. package/src/utils/lib/style.js +10 -10
  151. package/src/utils/store-tools/auto-load.js +74 -73
  152. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  153. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  154. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -43
  155. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  156. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  157. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  158. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  159. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  160. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  161. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  162. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  163. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  164. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  165. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  166. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +12 -12
  167. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  168. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +7 -7
  169. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  170. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +13 -13
  171. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  172. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  173. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  174. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  177. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +118 -118
  178. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  179. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  180. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  181. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -9
  182. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  183. package/src/utils/suggester-workers/create-worker.js +56 -0
  184. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  185. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  186. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -33
  187. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  188. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  189. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  190. package/src/utils/suggester-workers/searching/index.js +1 -1
  191. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  192. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  193. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +2 -2
  194. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  195. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +24 -24
  196. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  197. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  198. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  199. package/src/utils/suggester-workers/searching/searching.js +70 -70
  200. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  201. package/src/utils/to-expose/calculated-variables.js +113 -113
  202. package/src/utils/to-expose/handler.js +149 -112
  203. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  204. package/src/utils/to-expose/hooks/index.js +2 -1
  205. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  206. package/src/utils/to-expose/hooks/lunatic.js +284 -187
  207. package/src/utils/to-expose/index.js +1 -1
  208. package/src/utils/to-expose/init-questionnaire.js +164 -164
  209. package/src/utils/to-expose/interpret/vtl.js +18 -18
  210. package/src/utils/to-expose/state.js +66 -58
  211. package/src/components/missing-wrapper/component.js +0 -120
  212. package/src/components/missing-wrapper/wrapper.js +0 -10
  213. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  214. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  215. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  216. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  217. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  218. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  219. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1,137 +1,140 @@
1
- import React, { useCallback, useState, useEffect } from 'react';
2
- import PropTypes from 'prop-types';
3
- import Declarations from '../declarations';
4
- import * as U from '../../utils/lib';
5
- import * as C from '../../constants';
6
- import IDBSuggester from './idb-suggester';
7
- import LabelWrapper from '../../utils/components/label-wrapper';
8
- import FieldWrapper from '../../utils/components/field-wrapper';
9
-
10
- function getSuggestionId(suggestion) {
11
- if (suggestion) {
12
- return suggestion.id;
13
- }
14
- return null;
15
- }
16
-
17
- function Suggester({
18
- id,
19
- label,
20
- preferences,
21
- response,
22
- handleChange,
23
- disabled,
24
- focused,
25
- declarations,
26
- features,
27
- bindings,
28
- management,
29
- labelPosition,
30
- style,
31
- logFunction,
32
- storeName,
33
- optionRenderer,
34
- labelRenderer,
35
- idbVersion,
36
- }) {
37
- const [value, setValue] = useState(() =>
38
- U.getResponseByPreference(preferences)(response)
39
- );
40
- const labelId = `suggester-label-${id}`;
41
- const onSelect = useCallback(
42
- function (suggestion) {
43
- const ids = getSuggestionId(suggestion);
44
- handleChange({
45
- [U.getResponseName(response)]: ids,
46
- });
47
- setValue(ids);
48
- },
49
- [handleChange, response]
50
- );
51
-
52
- return (
53
- <>
54
- <Declarations
55
- id={id}
56
- type={C.BEFORE_QUESTION_TEXT}
57
- declarations={declarations}
58
- features={features}
59
- bindings={bindings}
60
- />
61
- <LabelWrapper
62
- id={labelId}
63
- htmlFor={id}
64
- labelPosition={labelPosition}
65
- bindings={bindings}
66
- label={label}
67
- features={features}
68
- logFunction={logFunction}
69
- >
70
- <Declarations
71
- id={id}
72
- type={C.AFTER_QUESTION_TEXT}
73
- declarations={declarations}
74
- features={features}
75
- bindings={bindings}
76
- />
77
- <FieldWrapper id={id} management={management} response={response}>
78
- <IDBSuggester
79
- storeName={storeName}
80
- optionRenderer={optionRenderer}
81
- labelRenderer={labelRenderer}
82
- labelledBy={labelId}
83
- idbVersion={idbVersion}
84
- onSelect={onSelect}
85
- focused={focused}
86
- disabled={disabled}
87
- response={response}
88
- id={id}
89
- value={value}
90
- />
91
- </FieldWrapper>
92
- </LabelWrapper>
93
- <Declarations
94
- id={id}
95
- type={C.DETACHABLE}
96
- declarations={declarations}
97
- features={features}
98
- bindings={bindings}
99
- />
100
- </>
101
- );
102
- }
103
-
104
- Suggester.defaultProps = {
105
- label: '',
106
- preferences: ['COLLECTED'],
107
- response: {},
108
- disabled: false,
109
- focused: false,
110
- declarations: [],
111
- features: [],
112
- bindings: {},
113
- management: false,
114
- labelPosition: 'DEFAULT',
115
- style: {},
116
- getStoreInfo: undefined,
117
- };
118
-
119
- Suggester.propTypes = {
120
- id: PropTypes.string.isRequired,
121
- label: PropTypes.string,
122
- preferences: PropTypes.arrayOf(U.valueTypePropTypes),
123
- response: U.responsePropTypes,
124
- handleChange: PropTypes.func.isRequired,
125
- disabled: PropTypes.bool,
126
- focused: PropTypes.bool,
127
- declarations: U.declarationsPropTypes,
128
- features: PropTypes.arrayOf(PropTypes.string),
129
- bindings: PropTypes.object,
130
- management: PropTypes.bool,
131
- labelPosition: PropTypes.oneOf(['DEFAULT', 'TOP', 'BOTTOM', 'LEFT', 'RIGHT']),
132
- style: PropTypes.object,
133
- storeInfo: PropTypes.object, //TODO
134
- getStoreInfo: PropTypes.func,
135
- };
136
-
137
- export default React.memo(Suggester, U.areEqual);
1
+ import React, { useCallback, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import componentWrapper from '../component-wrapper';
4
+ import Declarations from '../declarations';
5
+ import * as U from '../../utils/lib';
6
+ import * as C from '../../constants';
7
+ import IDBSuggester from './idb-suggester';
8
+ import LabelWrapper from '../../utils/components/label-wrapper';
9
+ import FieldWrapper from '../../utils/components/field-wrapper';
10
+
11
+ function getSuggestionId(suggestion) {
12
+ if (suggestion) {
13
+ return suggestion.id;
14
+ }
15
+ return null;
16
+ }
17
+
18
+ function Suggester({
19
+ id,
20
+ label,
21
+ preferences,
22
+ response,
23
+ handleChange,
24
+ disabled,
25
+ focused,
26
+ declarations,
27
+ features,
28
+ bindings,
29
+ management,
30
+ labelPosition,
31
+ style,
32
+ logFunction,
33
+ storeName,
34
+ optionRenderer,
35
+ labelRenderer,
36
+ idbVersion,
37
+ }) {
38
+ const [value, setValue] = useState(() =>
39
+ U.getResponseByPreference(preferences)(response)
40
+ );
41
+ const labelId = `suggester-label-${id}`;
42
+ const onSelect = useCallback(
43
+ function (suggestion) {
44
+ const ids = getSuggestionId(suggestion);
45
+ // Delete: null --> empty to handle controls
46
+ handleChange({
47
+ [U.getResponseName(response)]: ids || '',
48
+ });
49
+ setValue(ids);
50
+ },
51
+ [handleChange, response]
52
+ );
53
+
54
+ return (
55
+ <>
56
+ <Declarations
57
+ id={id}
58
+ type={C.BEFORE_QUESTION_TEXT}
59
+ declarations={declarations}
60
+ features={features}
61
+ bindings={bindings}
62
+ />
63
+ <LabelWrapper
64
+ id={labelId}
65
+ htmlFor={id}
66
+ labelPosition={labelPosition}
67
+ bindings={bindings}
68
+ label={label}
69
+ features={features}
70
+ logFunction={logFunction}
71
+ >
72
+ <Declarations
73
+ id={id}
74
+ type={C.AFTER_QUESTION_TEXT}
75
+ declarations={declarations}
76
+ features={features}
77
+ bindings={bindings}
78
+ />
79
+ <FieldWrapper id={id} management={management} response={response}>
80
+ <IDBSuggester
81
+ storeName={storeName}
82
+ optionRenderer={optionRenderer}
83
+ labelRenderer={labelRenderer}
84
+ labelledBy={labelId}
85
+ idbVersion={idbVersion}
86
+ onSelect={onSelect}
87
+ focused={focused}
88
+ disabled={disabled}
89
+ response={response}
90
+ id={id}
91
+ value={value}
92
+ logFunction={logFunction}
93
+ />
94
+ </FieldWrapper>
95
+ </LabelWrapper>
96
+ <Declarations
97
+ id={id}
98
+ type={C.DETACHABLE}
99
+ declarations={declarations}
100
+ features={features}
101
+ bindings={bindings}
102
+ />
103
+ </>
104
+ );
105
+ }
106
+
107
+ Suggester.defaultProps = {
108
+ label: '',
109
+ preferences: ['COLLECTED'],
110
+ response: {},
111
+ disabled: false,
112
+ focused: false,
113
+ declarations: [],
114
+ features: [],
115
+ bindings: {},
116
+ management: false,
117
+ labelPosition: 'DEFAULT',
118
+ style: {},
119
+ getStoreInfo: undefined,
120
+ };
121
+
122
+ Suggester.propTypes = {
123
+ id: PropTypes.string.isRequired,
124
+ label: PropTypes.string,
125
+ preferences: PropTypes.arrayOf(U.valueTypePropTypes),
126
+ response: U.responsePropTypes,
127
+ handleChange: PropTypes.func.isRequired,
128
+ disabled: PropTypes.bool,
129
+ focused: PropTypes.bool,
130
+ declarations: U.declarationsPropTypes,
131
+ features: PropTypes.arrayOf(PropTypes.string),
132
+ bindings: PropTypes.object,
133
+ management: PropTypes.bool,
134
+ labelPosition: PropTypes.oneOf(['DEFAULT', 'TOP', 'BOTTOM', 'LEFT', 'RIGHT']),
135
+ style: PropTypes.object,
136
+ storeInfo: PropTypes.object, //TODO
137
+ getStoreInfo: PropTypes.func,
138
+ };
139
+
140
+ export default componentWrapper(React.memo(Suggester, U.areEqual));
@@ -1,47 +1,49 @@
1
- const WORKER_PATH =
2
- process.env.LUNATIC_SEARCH_WORKER_PATH ||
3
- process.env.REACT_APP_LUNATIC_SEARCH_WORKER_PATH;
4
-
5
- export function isWorkerCompatible() {
6
- if (window.Worker) {
7
- return true;
8
- }
9
- return false;
10
- }
11
-
12
- const searching = (worker) => (search, name, version) => {
13
- if (!WORKER_PATH) {
14
- throw new Error("Worker path is required for suggester's searches.");
15
- }
16
- if (isWorkerCompatible()) {
17
- return new Promise(function (resolve) {
18
- try {
19
- if (worker) {
20
- worker.terminate();
21
- }
22
- worker = new Worker(WORKER_PATH);
23
- worker.postMessage({ search, name, version });
24
- worker.addEventListener('message', function (e) {
25
- const { data } = e;
26
- resolve(data);
27
- worker.terminate();
28
- worker = undefined;
29
- });
30
- } catch (e) {
31
- //TODO
32
- }
33
- });
34
- } else {
35
- // TODO
36
- }
37
- };
38
-
39
- function createSearching(name, version) {
40
- let worker = undefined;
41
- const searching_ = searching(worker);
42
- return async function (search) {
43
- return searching_(search, name, version);
44
- };
45
- }
46
-
47
- export default createSearching;
1
+ import { createWorker } from '../../../utils/suggester-workers/create-worker';
2
+
3
+ const WORKER_PATH =
4
+ process.env.LUNATIC_SEARCH_WORKER_PATH ||
5
+ process.env.REACT_APP_LUNATIC_SEARCH_WORKER_PATH;
6
+
7
+ export function isWorkerCompatible() {
8
+ if (window.Worker) {
9
+ return true;
10
+ }
11
+ return false;
12
+ }
13
+
14
+ const searching = (worker) => (search, name, version) => {
15
+ if (!WORKER_PATH) {
16
+ throw new Error("Worker path is required for suggester's searches.");
17
+ }
18
+ if (isWorkerCompatible()) {
19
+ return new Promise(function (resolve) {
20
+ try {
21
+ if (worker) {
22
+ worker.terminate();
23
+ }
24
+ worker = createWorker(WORKER_PATH);
25
+ worker.postMessage({ search, name, version });
26
+ worker.addEventListener('message', function (e) {
27
+ const { data } = e;
28
+ resolve(data);
29
+ worker.terminate();
30
+ worker = undefined;
31
+ });
32
+ } catch (e) {
33
+ //TODO
34
+ }
35
+ });
36
+ } else {
37
+ // TODO
38
+ }
39
+ };
40
+
41
+ function createSearching(name, version) {
42
+ let worker = undefined;
43
+ const searching_ = searching(worker);
44
+ return async function (search) {
45
+ return searching_(search, name, version);
46
+ };
47
+ }
48
+
49
+ export default createSearching;
@@ -1 +1 @@
1
- export { default } from './create-searching';
1
+ export { default } from './create-searching';
@@ -1,38 +1,38 @@
1
- export const ON_INIT = 'lunatic-suggester/on-init';
2
- export const onInit = ({ id, disabled, value }) => ({
3
- type: ON_INIT,
4
- payload: { id, disabled, value },
5
- });
6
-
7
- export const ON_CHANGE_SEARCH = 'lunatic-suggester/on-change-search';
8
- export const onChangeSearch = (search) => ({
9
- type: ON_CHANGE_SEARCH,
10
- payload: { search },
11
- });
12
-
13
- export const ON_UPDATE_OPTIONS = 'lunatic-suggester/on-update-options';
14
- export const onUpdateOptions = (options, search) => ({
15
- type: ON_UPDATE_OPTIONS,
16
- payload: { options, search },
17
- });
18
-
19
- export const ON_FOCUS = 'lunatic-suggester/on-focus';
20
- export const onFocus = () => ({ type: ON_FOCUS });
21
-
22
- export const ON_BLUR = 'lunatic-suggester/on-blur';
23
- export const onBlur = () => ({ type: ON_BLUR });
24
-
25
- export const ON_CLICK_OPTION = 'lunatic-suggester/on-click-option';
26
- export const onClickOption = (index) => ({
27
- type: ON_CLICK_OPTION,
28
- payload: { index },
29
- });
30
-
31
- export const ON_KEY_DOWN = 'lunatic-suggester/on-key-down';
32
- export const onKeyDown = (key) => ({ type: ON_KEY_DOWN, payload: { key } });
33
-
34
- export const ON_ERROR = 'lunatic-suggester/on-error';
35
- export const onError = (message) => ({ type: ON_ERROR, payload: { message } });
36
-
37
- export const ON_DELETE_SEARCH = 'lunatic-suggester/on-delete-search';
38
- export const onDeleteSearch = () => ({ type: ON_DELETE_SEARCH });
1
+ export const ON_INIT = 'lunatic-suggester/on-init';
2
+ export const onInit = ({ id, disabled, value }) => ({
3
+ type: ON_INIT,
4
+ payload: { id, disabled, value },
5
+ });
6
+
7
+ export const ON_CHANGE_SEARCH = 'lunatic-suggester/on-change-search';
8
+ export const onChangeSearch = (search) => ({
9
+ type: ON_CHANGE_SEARCH,
10
+ payload: { search },
11
+ });
12
+
13
+ export const ON_UPDATE_OPTIONS = 'lunatic-suggester/on-update-options';
14
+ export const onUpdateOptions = (options, search) => ({
15
+ type: ON_UPDATE_OPTIONS,
16
+ payload: { options, search },
17
+ });
18
+
19
+ export const ON_FOCUS = 'lunatic-suggester/on-focus';
20
+ export const onFocus = () => ({ type: ON_FOCUS });
21
+
22
+ export const ON_BLUR = 'lunatic-suggester/on-blur';
23
+ export const onBlur = () => ({ type: ON_BLUR });
24
+
25
+ export const ON_CLICK_OPTION = 'lunatic-suggester/on-click-option';
26
+ export const onClickOption = (index) => ({
27
+ type: ON_CLICK_OPTION,
28
+ payload: { index },
29
+ });
30
+
31
+ export const ON_KEY_DOWN = 'lunatic-suggester/on-key-down';
32
+ export const onKeyDown = (key) => ({ type: ON_KEY_DOWN, payload: { key } });
33
+
34
+ export const ON_ERROR = 'lunatic-suggester/on-error';
35
+ export const onError = (message) => ({ type: ON_ERROR, payload: { message } });
36
+
37
+ export const ON_DELETE_SEARCH = 'lunatic-suggester/on-delete-search';
38
+ export const onDeleteSearch = () => ({ type: ON_DELETE_SEARCH });
@@ -1,11 +1,11 @@
1
- function reduce(state) {
2
- return {
3
- ...state,
4
- search: '',
5
- selectedIndex: undefined,
6
- options: [],
7
- expanded: false,
8
- };
9
- }
10
-
11
- export default reduce;
1
+ function reduce(state) {
2
+ return {
3
+ ...state,
4
+ search: '',
5
+ selectedIndex: undefined,
6
+ options: [],
7
+ expanded: false,
8
+ };
9
+ }
10
+
11
+ export default reduce;
@@ -1,29 +1,29 @@
1
- function getStringValue(value) {
2
- if (value) {
3
- return `${value}`;
4
- }
5
- return '';
6
- }
7
-
8
- function getId() {
9
- return `lunatic-suggester-${new Date().getTime()}`;
10
- }
11
-
12
- function reduce(state, action) {
13
- const { payload } = action;
14
- const { id, disabled, value } = payload;
15
- const { search } = state;
16
-
17
- if (value && search.length === 0) {
18
- return {
19
- ...state,
20
- id: id || getId(),
21
- disabled,
22
- search: getStringValue(value),
23
- };
24
- }
25
-
26
- return { ...state, id: id || getId(), disabled };
27
- }
28
-
29
- export default reduce;
1
+ function getStringValue(value) {
2
+ if (value) {
3
+ return `${value}`;
4
+ }
5
+ return '';
6
+ }
7
+
8
+ function getId() {
9
+ return `lunatic-suggester-${new Date().getTime()}`;
10
+ }
11
+
12
+ function reduce(state, action) {
13
+ const { payload } = action;
14
+ const { id, disabled, value } = payload;
15
+ const { search } = state;
16
+
17
+ if (value && search.length === 0) {
18
+ return {
19
+ ...state,
20
+ id: id || getId(),
21
+ disabled,
22
+ search: getStringValue(value),
23
+ };
24
+ }
25
+
26
+ return { ...state, id: id || getId(), disabled };
27
+ }
28
+
29
+ export default reduce;
@@ -1,38 +1,38 @@
1
- import * as actions from '../actions';
2
- import reduceOnChangeSearch from './reduce-on-change-search';
3
- import reduceOnUpdateOptions from './reduce-on-update-options';
4
- import reduceOnFocus from './reduce-on-focus';
5
- import reduceOnBlur from './reduce-on-blur';
6
- import reduceOnClickOption from './reduce-on-click-option';
7
- import reduceOnKeyDown from './reduce-on-key-down';
8
- import reduceOnInit from './reduce-on-init';
9
- import reduceOnError from './reduce-on-error';
10
- import reduceOnDeleteSearch from './reduce-on-delete-search';
11
-
12
- function reduce(state, action) {
13
- const { type } = action;
14
- switch (type) {
15
- case actions.ON_CHANGE_SEARCH:
16
- return reduceOnChangeSearch(state, action);
17
- case actions.ON_UPDATE_OPTIONS:
18
- return reduceOnUpdateOptions(state, action);
19
- case actions.ON_FOCUS:
20
- return reduceOnFocus(state, action);
21
- case actions.ON_BLUR:
22
- return reduceOnBlur(state, action);
23
- case actions.ON_CLICK_OPTION:
24
- return reduceOnClickOption(state, action);
25
- case actions.ON_KEY_DOWN:
26
- return reduceOnKeyDown(state, action);
27
- case actions.ON_INIT:
28
- return reduceOnInit(state, action);
29
- case actions.ON_ERROR:
30
- return reduceOnError(state, action);
31
- case actions.ON_DELETE_SEARCH:
32
- return reduceOnDeleteSearch(state, action);
33
- default:
34
- return state;
35
- }
36
- }
37
-
38
- export default reduce;
1
+ import * as actions from '../actions';
2
+ import reduceOnChangeSearch from './reduce-on-change-search';
3
+ import reduceOnUpdateOptions from './reduce-on-update-options';
4
+ import reduceOnFocus from './reduce-on-focus';
5
+ import reduceOnBlur from './reduce-on-blur';
6
+ import reduceOnClickOption from './reduce-on-click-option';
7
+ import reduceOnKeyDown from './reduce-on-key-down';
8
+ import reduceOnInit from './reduce-on-init';
9
+ import reduceOnError from './reduce-on-error';
10
+ import reduceOnDeleteSearch from './reduce-on-delete-search';
11
+
12
+ function reduce(state, action) {
13
+ const { type } = action;
14
+ switch (type) {
15
+ case actions.ON_CHANGE_SEARCH:
16
+ return reduceOnChangeSearch(state, action);
17
+ case actions.ON_UPDATE_OPTIONS:
18
+ return reduceOnUpdateOptions(state, action);
19
+ case actions.ON_FOCUS:
20
+ return reduceOnFocus(state, action);
21
+ case actions.ON_BLUR:
22
+ return reduceOnBlur(state, action);
23
+ case actions.ON_CLICK_OPTION:
24
+ return reduceOnClickOption(state, action);
25
+ case actions.ON_KEY_DOWN:
26
+ return reduceOnKeyDown(state, action);
27
+ case actions.ON_INIT:
28
+ return reduceOnInit(state, action);
29
+ case actions.ON_ERROR:
30
+ return reduceOnError(state, action);
31
+ case actions.ON_DELETE_SEARCH:
32
+ return reduceOnDeleteSearch(state, action);
33
+ default:
34
+ return state;
35
+ }
36
+ }
37
+
38
+ export default reduce;