@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,183 +1,204 @@
1
- import React, { useEffect, useCallback, useMemo } from 'react';
2
- import PropTypes from 'prop-types';
3
- import classnames from 'classnames';
4
- import Label from './label';
5
- import * as U from '../../../../utils/lib';
6
- import * as CLEAN from '../cleaner-callbacks';
7
- import * as actions from '../actions';
8
- import DropdownField from './dropdown-field';
9
- import DropdownContainer from './dropdown-container';
10
- import {
11
- createOnKeyDownCallback,
12
- createOnMouseDownCallback,
13
- BINDED_KEYS,
14
- } from '../event-callbacks';
15
-
16
- /** */
17
- function stopAndPrevent(e) {
18
- e.preventDefault();
19
- e.stopPropagation();
20
- }
21
-
22
- /** */
23
- function prepareOptions(options, valueFromProps) {
24
- return options.reduce(
25
- (a, o, i) =>
26
- o.value === valueFromProps && a.index === -1
27
- ? { index: i, option: o }
28
- : a,
29
- { index: -1, option: {} }
30
- );
31
- }
32
-
33
- /** */
34
- function onKeyDownCallbackProxy(state, dispatch, onSelect) {
35
- const callback = createOnKeyDownCallback(state, dispatch, onSelect);
36
- return function (e) {
37
- switch (e.key) {
38
- case BINDED_KEYS.enter:
39
- case BINDED_KEYS.arrowUp:
40
- case BINDED_KEYS.arrowDown:
41
- stopAndPrevent(e);
42
- callback(e.key);
43
- break;
44
- case BINDED_KEYS.tab:
45
- callback(e.key);
46
- break;
47
- default:
48
- return;
49
- }
50
- return false;
51
- };
52
- }
53
-
54
- function Dropdown({
55
- options,
56
- children,
57
- onSelect,
58
- response,
59
- className,
60
- label,
61
- labelPosition,
62
- mandatory,
63
- value: valueFromProps,
64
- management,
65
- state,
66
- dispatch,
67
- refs,
68
- }) {
69
- const { visible, focused, id, disabled } = state;
70
-
71
- CLEAN.add(id, function () {
72
- dispatch(actions.hidePanel());
73
- dispatch(actions.setFocused(false));
74
- });
75
- useEffect(
76
- function () {
77
- const hook = function () {
78
- dispatch(actions.hidePanel());
79
- dispatch(actions.setFocused(false));
80
- };
81
- window.addEventListener('mousedown', hook);
82
-
83
- return function () {
84
- window.removeEventListener('mousedown', hook);
85
- CLEAN.clear(id);
86
- };
87
- },
88
- [id, dispatch]
89
- );
90
-
91
- useEffect(
92
- function () {
93
- dispatch(actions.setOptions(options));
94
- },
95
- [options, dispatch]
96
- );
97
-
98
- useEffect(
99
- function () {
100
- if (valueFromProps) {
101
- const { option, index } = prepareOptions(options, valueFromProps);
102
- dispatch(actions.setSelectedOption(option));
103
- dispatch(actions.setActiveOption(index));
104
- }
105
- },
106
- [valueFromProps, options, dispatch]
107
- );
108
-
109
- const onFocus = useCallback(
110
- function () {
111
- dispatch(actions.setFocused(true && !disabled));
112
- },
113
- [dispatch, disabled]
114
- );
115
-
116
- const onBlur = useCallback(
117
- function () {
118
- dispatch(actions.setFocused(false));
119
- },
120
- [dispatch]
121
- );
122
-
123
- const onMouseDownCallback = useMemo(
124
- () => createOnMouseDownCallback(state, dispatch),
125
- [state, dispatch]
126
- );
127
-
128
- const onKeyDownCallback = useMemo(
129
- () => onKeyDownCallbackProxy(state, dispatch, onSelect),
130
- [state, dispatch, onSelect]
131
- );
132
-
133
- return (
134
- <DropdownContainer
135
- className={classnames(className, U.getLabelPositionClass(labelPosition), {
136
- focused,
137
- disabled,
138
- })}
139
- id={id}
140
- onMouseDown={onMouseDownCallback}
141
- onKeyDown={onKeyDownCallback}
142
- onFocus={onFocus}
143
- onBlur={onBlur}
144
- ref={refs}
145
- >
146
- <Label content={label} focused={focused} mandatory={mandatory} />
147
- <DropdownField
148
- id={id}
149
- response={response}
150
- options={options}
151
- management={management}
152
- focused={focused}
153
- visible={visible}
154
- disabled={disabled}
155
- >
156
- {children}
157
- </DropdownField>
158
- </DropdownContainer>
159
- );
160
- }
161
-
162
- Dropdown.propTypes = {
163
- zIndex: PropTypes.number,
164
- className: PropTypes.string,
165
- id: PropTypes.string,
166
- options: PropTypes.array.isRequired,
167
- onSelect: PropTypes.func,
168
- value: PropTypes.oneOfType([
169
- PropTypes.string,
170
- PropTypes.number,
171
- PropTypes.object,
172
- PropTypes.bool,
173
- ]),
174
- };
175
-
176
- Dropdown.defaultProps = {
177
- options: [],
178
- onSelect: () => null,
179
- };
180
-
181
- export default React.forwardRef((props, ref) => (
182
- <Dropdown {...props} refs={ref} />
183
- ));
1
+ import React, { useEffect, useCallback, useMemo } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import classnames from 'classnames';
4
+ import Label from './label';
5
+ import * as U from '../../../../utils/lib';
6
+ import * as C from '../../../../constants';
7
+ import * as CLEAN from '../cleaner-callbacks';
8
+ import * as actions from '../actions';
9
+ import DropdownField from './dropdown-field';
10
+ import DropdownContainer from './dropdown-container';
11
+ import {
12
+ createOnKeyDownCallback,
13
+ createOnMouseDownCallback,
14
+ BINDED_KEYS,
15
+ } from '../event-callbacks';
16
+
17
+ /** */
18
+ function stopAndPrevent(e) {
19
+ e.preventDefault();
20
+ e.stopPropagation();
21
+ }
22
+
23
+ /** */
24
+ function prepareOptions(options, valueFromProps) {
25
+ return options.reduce(
26
+ (a, o, i) =>
27
+ o.value === valueFromProps && a.index === -1
28
+ ? { index: i, option: o }
29
+ : a,
30
+ { index: -1, option: {} }
31
+ );
32
+ }
33
+
34
+ /** */
35
+ function onKeyDownCallbackProxy(state, dispatch, onSelect) {
36
+ const callback = createOnKeyDownCallback(state, dispatch, onSelect);
37
+ return function (e) {
38
+ switch (e.key) {
39
+ case BINDED_KEYS.enter:
40
+ case BINDED_KEYS.arrowUp:
41
+ case BINDED_KEYS.arrowDown:
42
+ stopAndPrevent(e);
43
+ callback(e.key);
44
+ break;
45
+ case BINDED_KEYS.tab:
46
+ callback(e.key);
47
+ break;
48
+ default:
49
+ return;
50
+ }
51
+ return false;
52
+ };
53
+ }
54
+
55
+ function Dropdown({
56
+ options,
57
+ children,
58
+ onSelect,
59
+ response,
60
+ className,
61
+ label,
62
+ labelPosition,
63
+ mandatory,
64
+ value: valueFromProps,
65
+ management,
66
+ state,
67
+ dispatch,
68
+ refs,
69
+ logFunction,
70
+ }) {
71
+ const { visible, focused, id, disabled } = state;
72
+
73
+ const createEventFocus = (focusIn = true) =>
74
+ U.createObjectEvent(
75
+ id,
76
+ C.INPUT_CATEGORY,
77
+ focusIn ? C.EVENT_FOCUS_IN : C.EVENT_FOCUS_OUT,
78
+ U.getResponseName(response),
79
+ valueFromProps
80
+ );
81
+
82
+ CLEAN.add(id, function () {
83
+ dispatch(actions.hidePanel());
84
+ dispatch(actions.setFocused(false));
85
+ });
86
+ useEffect(
87
+ function () {
88
+ const hook = function () {
89
+ dispatch(actions.hidePanel());
90
+ dispatch(actions.setFocused(false));
91
+ };
92
+ window.addEventListener('mousedown', hook);
93
+
94
+ return function () {
95
+ window.removeEventListener('mousedown', hook);
96
+ CLEAN.clear(id);
97
+ };
98
+ },
99
+ [id, dispatch]
100
+ );
101
+
102
+ useEffect(
103
+ function () {
104
+ dispatch(actions.setOptions(options));
105
+ },
106
+ [options, dispatch]
107
+ );
108
+
109
+ useEffect(
110
+ function () {
111
+ if (valueFromProps) {
112
+ const { option, index } = prepareOptions(options, valueFromProps);
113
+ dispatch(actions.setSelectedOption(option));
114
+ dispatch(actions.setActiveOption(index));
115
+ }
116
+ },
117
+ [valueFromProps, options, dispatch]
118
+ );
119
+
120
+ const onFocus = useCallback(
121
+ function () {
122
+ dispatch(actions.setFocused(true && !disabled));
123
+ },
124
+ [dispatch, disabled]
125
+ );
126
+
127
+ const onBlur = useCallback(
128
+ function () {
129
+ dispatch(actions.setFocused(false));
130
+ },
131
+ [dispatch]
132
+ );
133
+
134
+ const onMouseDownCallback = useMemo(
135
+ () => createOnMouseDownCallback(state, dispatch),
136
+ [state, dispatch]
137
+ );
138
+
139
+ const onKeyDownCallback = useMemo(
140
+ () => onKeyDownCallbackProxy(state, dispatch, onSelect),
141
+ [state, dispatch, onSelect]
142
+ );
143
+
144
+ // log info when focus change
145
+ useEffect(() => {
146
+ if (id && focused && U.isFunction(logFunction))
147
+ logFunction(createEventFocus());
148
+ if (id && !focused && U.isFunction(logFunction))
149
+ logFunction(createEventFocus(false));
150
+
151
+ // eslint-disable-next-line react-hooks/exhaustive-deps
152
+ }, [focused, id]);
153
+
154
+ return (
155
+ <DropdownContainer
156
+ className={classnames(className, U.getLabelPositionClass(labelPosition), {
157
+ focused,
158
+ disabled,
159
+ })}
160
+ id={id}
161
+ onMouseDown={onMouseDownCallback}
162
+ onKeyDown={onKeyDownCallback}
163
+ onFocus={onFocus}
164
+ onBlur={onBlur}
165
+ ref={refs}
166
+ >
167
+ <Label content={label} focused={focused} mandatory={mandatory} />
168
+ <DropdownField
169
+ id={id}
170
+ response={response}
171
+ options={options}
172
+ management={management}
173
+ focused={focused}
174
+ visible={visible}
175
+ disabled={disabled}
176
+ >
177
+ {children}
178
+ </DropdownField>
179
+ </DropdownContainer>
180
+ );
181
+ }
182
+
183
+ Dropdown.propTypes = {
184
+ zIndex: PropTypes.number,
185
+ className: PropTypes.string,
186
+ id: PropTypes.string,
187
+ options: PropTypes.array.isRequired,
188
+ onSelect: PropTypes.func,
189
+ value: PropTypes.oneOfType([
190
+ PropTypes.string,
191
+ PropTypes.number,
192
+ PropTypes.object,
193
+ PropTypes.bool,
194
+ ]),
195
+ };
196
+
197
+ Dropdown.defaultProps = {
198
+ options: [],
199
+ onSelect: () => null,
200
+ };
201
+
202
+ export default React.forwardRef((props, ref) => (
203
+ <Dropdown {...props} refs={ref} />
204
+ ));
@@ -1,15 +1,15 @@
1
- import * as CLEAN from '../cleaner-callbacks';
2
- import * as actions from '../actions';
3
-
4
- /** */
5
- const onMouseDownCallback =
6
- ({ visible, id, disabled }, dispatch) =>
7
- (e) => {
8
- e.stopPropagation();
9
- if (!visible && !disabled) {
10
- CLEAN.applyAll(id);
11
- dispatch(actions.showPanel());
12
- }
13
- };
14
-
15
- export default onMouseDownCallback;
1
+ import * as CLEAN from '../cleaner-callbacks';
2
+ import * as actions from '../actions';
3
+
4
+ /** */
5
+ const onMouseDownCallback =
6
+ ({ visible, id, disabled }, dispatch) =>
7
+ (e) => {
8
+ e.stopPropagation();
9
+ if (!visible && !disabled) {
10
+ CLEAN.applyAll(id);
11
+ dispatch(actions.showPanel());
12
+ }
13
+ };
14
+
15
+ export default onMouseDownCallback;
@@ -141,6 +141,9 @@ const reducer = (state, action) => {
141
141
  const { callback } = payload;
142
142
  return reduceEnterPressed(state, callback);
143
143
  }
144
+ case actions.INIT_ACTIVE_INDEX: {
145
+ return { ...state, activeIndex: 0 };
146
+ }
144
147
  default:
145
148
  return state;
146
149
  }
@@ -1,17 +1,17 @@
1
- /** */
2
- export const scrollTo = id => {
3
- const li = document.getElementById(id);
4
- if (li) {
5
- const parent = li.parentNode;
6
- const pr = parent.getBoundingClientRect();
7
- const lr = li.getBoundingClientRect();
8
- const top = lr.top - pr.top + parent.scrollTop;
9
- const bottom = lr.bottom - pr.top + parent.scrollTop;
10
-
11
- if (bottom > parent.scrollTop + pr.height) {
12
- parent.scrollTo(0, bottom - pr.height);
13
- } else if (top < parent.scrollTop) {
14
- parent.scrollTo(0, top);
15
- }
16
- }
17
- };
1
+ /** */
2
+ export const scrollTo = id => {
3
+ const li = document.getElementById(id);
4
+ if (li) {
5
+ const parent = li.parentNode;
6
+ const pr = parent.getBoundingClientRect();
7
+ const lr = li.getBoundingClientRect();
8
+ const top = lr.top - pr.top + parent.scrollTop;
9
+ const bottom = lr.bottom - pr.top + parent.scrollTop;
10
+
11
+ if (bottom > parent.scrollTop + pr.height) {
12
+ parent.scrollTo(0, bottom - pr.height);
13
+ } else if (top < parent.scrollTop) {
14
+ parent.scrollTo(0, top);
15
+ }
16
+ }
17
+ };