@inseefr/lunatic 0.2.3-experimental → 0.2.3-prisme

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (230) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +25 -23
  3. package/lib/index.js +1191 -475
  4. package/lib/index.js.map +1 -1
  5. package/package.json +174 -172
  6. package/src/components/breadcrumb/breadcrumb.scss +22 -22
  7. package/src/components/checkbox/boolean.js +172 -172
  8. package/src/components/checkbox/checkbox.scss +73 -73
  9. package/src/components/checkbox/group.js +231 -231
  10. package/src/components/checkbox/one.js +11 -11
  11. package/src/components/component-wrapper/controls/component.js +70 -0
  12. package/src/components/component-wrapper/controls/controls.scss +6 -0
  13. package/src/components/component-wrapper/controls/index.js +1 -0
  14. package/src/components/component-wrapper/controls/validators/datepicker.js +44 -0
  15. package/src/components/component-wrapper/controls/validators/index.js +16 -0
  16. package/src/components/component-wrapper/controls/validators/input-number.js +23 -0
  17. package/src/components/{missing-wrapper → component-wrapper}/index.js +0 -0
  18. package/src/components/component-wrapper/missing/component.js +200 -0
  19. package/src/components/component-wrapper/missing/index.js +1 -0
  20. package/src/components/{missing-wrapper → component-wrapper/missing}/missing.scss +32 -32
  21. package/src/components/component-wrapper/wrapper.js +23 -0
  22. package/src/components/components.js +1 -0
  23. package/src/components/datepicker/component.js +26 -11
  24. package/src/components/declarations/component.js +46 -46
  25. package/src/components/declarations/declarations.scss +40 -40
  26. package/src/components/declarations/wrappers/input-declarations-wrapper.js +328 -274
  27. package/src/components/declarations/wrappers/simple-declarations-wrapper.js +54 -54
  28. package/src/components/dropdown/commons/actions.js +65 -56
  29. package/src/components/dropdown/commons/children-to-option.js +9 -9
  30. package/src/components/dropdown/commons/cleaner-callbacks.js +58 -58
  31. package/src/components/dropdown/commons/components/dropdown-container.js +29 -29
  32. package/src/components/dropdown/commons/components/dropdown.js +204 -183
  33. package/src/components/dropdown/commons/event-callbacks/on-mousedown-callback.js +15 -15
  34. package/src/components/dropdown/commons/reducer.js +3 -0
  35. package/src/components/dropdown/commons/tools/index.js +17 -17
  36. package/src/components/dropdown/component.js +135 -135
  37. package/src/components/dropdown/dropdown-edit/dropdown-edit.js +194 -185
  38. package/src/components/dropdown/dropdown-edit/index.js +11 -11
  39. package/src/components/dropdown/dropdown-simple/dropdown.js +173 -164
  40. package/src/components/dropdown/dropdown-simple/index.js +20 -20
  41. package/src/components/dropdown/dropdown.scss +178 -178
  42. package/src/components/icon/icon.scss +15 -15
  43. package/src/components/index.js +2 -0
  44. package/src/components/index.scss +177 -175
  45. package/src/components/input/input-number.js +30 -54
  46. package/src/components/input/input.js +11 -11
  47. package/src/components/input/input.scss +31 -37
  48. package/src/components/loop/component.js +170 -169
  49. package/src/components/loop/loop.scss +13 -13
  50. package/src/components/loop/wrapper.js +1 -1
  51. package/src/components/loop-constructor/block/block.scss +10 -10
  52. package/src/components/loop-constructor/block/component.js +9 -9
  53. package/src/components/loop-constructor/roster/component.js +8 -8
  54. package/src/components/loop-constructor/wrapper/body-component.js +146 -125
  55. package/src/components/loop-constructor/wrapper/component.js +190 -190
  56. package/src/components/modal/component.js +36 -0
  57. package/src/components/modal/index.js +1 -0
  58. package/src/components/modal/modal.scss +33 -0
  59. package/src/components/progress-bar/progress-bar.scss +54 -54
  60. package/src/components/radio/component.js +9 -9
  61. package/src/components/radio/radio.scss +59 -59
  62. package/src/components/sequence/component.js +50 -50
  63. package/src/components/sequence/sequence.scss +10 -10
  64. package/src/components/subsequence/component.js +49 -49
  65. package/src/components/suggester/check-store.js +2 -4
  66. package/src/components/suggester/components/panel/default-option-renderer.js +27 -27
  67. package/src/components/suggester/components/panel/option-container.js +61 -61
  68. package/src/components/suggester/components/panel/panel.js +47 -47
  69. package/src/components/suggester/components/selection/default-label-renderer.js +31 -31
  70. package/src/components/suggester/components/selection/label.js +35 -35
  71. package/src/components/suggester/components/selection/selection.js +50 -50
  72. package/src/components/suggester/components/suggester-content.js +2 -2
  73. package/src/components/suggester/components/suggester.js +128 -88
  74. package/src/components/suggester/components/suggester.scss +101 -101
  75. package/src/components/suggester/default-style.scss +125 -125
  76. package/src/components/suggester/find-best-label/find-best-label.js +51 -49
  77. package/src/components/suggester/find-best-label/index.js +1 -1
  78. package/src/components/suggester/idb-suggester.js +73 -67
  79. package/src/components/suggester/lunatic-suggester.js +140 -137
  80. package/src/components/suggester/searching/create-searching.js +49 -47
  81. package/src/components/suggester/searching/index.js +1 -1
  82. package/src/components/suggester/state-management/actions.js +38 -38
  83. package/src/components/suggester/state-management/reducer/reduce-on-delete-search.js +11 -11
  84. package/src/components/suggester/state-management/reducer/reduce-on-init.js +29 -29
  85. package/src/components/suggester/state-management/reducer/reducer.js +38 -38
  86. package/src/components/suggester/suggester-wrapper.js +127 -121
  87. package/src/components/suggester-loader-widget/loader.js +67 -67
  88. package/src/components/suggester-loader-widget/widget.js +123 -123
  89. package/src/components/table/table.js +173 -171
  90. package/src/components/table/table.scss +26 -26
  91. package/src/components/textarea/component.js +11 -11
  92. package/src/components/textarea/textarea.scss +8 -8
  93. package/src/components/tooltip/tooltip.scss +30 -30
  94. package/src/stories/breadcrumb/breadcrumb.stories.js +21 -21
  95. package/src/stories/checkbox-boolean/data.json +78 -78
  96. package/src/stories/datepicker/data.json +3 -1
  97. package/src/stories/declarations/declarations.stories.js +116 -116
  98. package/src/stories/dropdown/README.md +44 -44
  99. package/src/stories/dropdown/data.json +98 -98
  100. package/src/stories/dropdown/dropdown.stories.js +89 -89
  101. package/src/stories/progress-bar/progress-bar.stories.js +24 -24
  102. package/src/stories/questionnaire/arithmetic-management.json +47 -0
  103. package/src/stories/questionnaire/arithmetic.json +247 -247
  104. package/src/stories/questionnaire/calc-var.json +187 -187
  105. package/src/stories/questionnaire/data-logement.json +2691 -2691
  106. package/src/stories/questionnaire/kish.json +275 -0
  107. package/src/stories/questionnaire/logement-queen.json +23390 -0
  108. package/src/stories/questionnaire/logement-s2.json +46028 -44537
  109. package/src/stories/questionnaire/logement-sequence.json +26741 -26741
  110. package/src/stories/questionnaire/logement.json +21073 -26813
  111. package/src/stories/questionnaire/loop-and-controls.json +481 -0
  112. package/src/stories/questionnaire/questionnaire.stories.js +236 -154
  113. package/src/stories/questionnaire/update-external/data.json +1 -0
  114. package/src/stories/questionnaire/update-external/questionnaire.json +75 -0
  115. package/src/stories/sequence/sequence.stories.js +32 -32
  116. package/src/stories/subsequence/subsequence.stories.js +32 -32
  117. package/src/stories/suggester/README.md +46 -46
  118. package/src/stories/suggester/bailleurs-sociaux/fetch-bailleurs.js +15 -15
  119. package/src/stories/suggester/bailleurs-sociaux/index.js +2 -2
  120. package/src/stories/suggester/bailleurs-sociaux/option-bailleur-renderer.js +58 -58
  121. package/src/stories/suggester/bailleurs-sociaux/preloader.svg +51 -51
  122. package/src/stories/suggester/bailleurs-sociaux/theme.scss +22 -22
  123. package/src/stories/suggester/bailleurs-sociaux-2021/fetch-bailleurs.js +12 -0
  124. package/src/stories/suggester/bailleurs-sociaux-2021/index.js +1 -0
  125. package/src/stories/suggester/cog-communes/fetch-cog.js +15 -15
  126. package/src/stories/suggester/data-auto.json +232 -231
  127. package/src/stories/suggester/data-vtl.json +82 -82
  128. package/src/stories/suggester/data.json +169 -136
  129. package/src/stories/suggester/naf-rev2/index.js +2 -2
  130. package/src/stories/suggester/naf-rev2/option-naf-renderer.js +17 -17
  131. package/src/stories/suggester/suggester-workers.stories.js +226 -179
  132. package/src/stories/suggester/suggester.stories.js +138 -133
  133. package/src/stories/utils/orchestrator-split.js +119 -0
  134. package/src/stories/utils/orchestrator.js +119 -108
  135. package/src/tests/components/input-number.spec.js +6 -12
  136. package/src/tests/components/loops/roster-loop.json +71 -71
  137. package/src/tests/components/missing-wrapper.spec.js +0 -1
  138. package/src/tests/utils/lib/table/roster.spec.js +25 -25
  139. package/src/tests/utils/to-expose/handler/results/res-input-edited.json +1 -1
  140. package/src/tests/utils/to-expose/init-questionnaire/questionnaire.json +148 -148
  141. package/src/tests/utils/to-expose/init-questionnaire/result.json +181 -181
  142. package/src/utils/components/dragger/dragger.scss +7 -7
  143. package/src/utils/idb-tools/create-db-opener.js +43 -43
  144. package/src/utils/idb-tools/create-open-db.js +25 -25
  145. package/src/utils/idb-tools/idb-bulk-insert.js +96 -96
  146. package/src/utils/idb-tools/index.js +10 -10
  147. package/src/utils/idb-tools/insert-entity.js +15 -15
  148. package/src/utils/idb-tools/open-db.js +13 -13
  149. package/src/utils/idb-tools/open-or-create-db.js +34 -34
  150. package/src/utils/lib/controls/index.js +1 -0
  151. package/src/utils/lib/controls/utils.js +152 -0
  152. package/src/utils/lib/decorator/title-decorator.js +16 -16
  153. package/src/utils/lib/env.js +2 -2
  154. package/src/utils/lib/index.js +2 -0
  155. package/src/utils/lib/input-number.js +1 -1
  156. package/src/utils/lib/options-positioning.js +9 -9
  157. package/src/utils/lib/pagination/navigation/shared.js +256 -253
  158. package/src/utils/lib/prop-types/lines.js +6 -6
  159. package/src/utils/lib/responses.js +11 -9
  160. package/src/utils/lib/splitting.js +142 -0
  161. package/src/utils/lib/style.js +10 -10
  162. package/src/utils/store-tools/auto-load.js +74 -73
  163. package/src/utils/suggester-workers/append-to-index/append.js +25 -25
  164. package/src/utils/suggester-workers/append-to-index/append.worker.js +16 -16
  165. package/src/utils/suggester-workers/append-to-index/create-append-task.js +45 -43
  166. package/src/utils/suggester-workers/append-to-index/index.js +2 -2
  167. package/src/utils/suggester-workers/append-to-index/prepare-entities.js +61 -61
  168. package/src/utils/suggester-workers/append-to-index/store-messages.js +21 -21
  169. package/src/utils/suggester-workers/commons-tokenizer/create-entity-tokenizer.js +56 -0
  170. package/src/utils/suggester-workers/commons-tokenizer/create-fields-tokenizer.js +56 -0
  171. package/src/utils/suggester-workers/commons-tokenizer/create-filter-stop-words.js +17 -17
  172. package/src/utils/suggester-workers/commons-tokenizer/filters/compose-filters.js +10 -0
  173. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.js +17 -0
  174. package/src/utils/suggester-workers/commons-tokenizer/filters/create-filter-stop-words.spec.js +14 -0
  175. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.js +12 -0
  176. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-accents.spec.js +12 -0
  177. package/src/utils/suggester-workers/commons-tokenizer/{filter-double.js → filters/filter-double.js} +12 -12
  178. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-double.spec.js +20 -0
  179. package/src/utils/suggester-workers/commons-tokenizer/{filter-length.js → filters/filter-length.js} +7 -7
  180. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-length.spec.js +18 -0
  181. package/src/utils/suggester-workers/commons-tokenizer/{filter-stemmer.js → filters/filter-stemmer.js} +13 -13
  182. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-stemmer.spec.js +12 -0
  183. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.js +36 -0
  184. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-synonyms.spec.js +12 -0
  185. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.js +10 -0
  186. package/src/utils/suggester-workers/commons-tokenizer/filters/filter-to-lower.spec.js +12 -0
  187. package/src/utils/suggester-workers/commons-tokenizer/filters/index.js +2 -0
  188. package/src/utils/suggester-workers/commons-tokenizer/{stop-words.js → filters/stop-words.js} +118 -118
  189. package/src/utils/suggester-workers/commons-tokenizer/get-regexp-from-pattern.js +8 -8
  190. package/src/utils/suggester-workers/commons-tokenizer/get-stemmer.js +18 -18
  191. package/src/utils/suggester-workers/commons-tokenizer/index.js +9 -8
  192. package/src/utils/suggester-workers/commons-tokenizer/prepare-string-indexation.js +13 -9
  193. package/src/utils/suggester-workers/commons-tokenizer/soft-tokenizer.js +7 -7
  194. package/src/utils/suggester-workers/create-worker.js +56 -0
  195. package/src/utils/suggester-workers/find-best-label/find-best-label.js +39 -39
  196. package/src/utils/suggester-workers/find-best-label/find-best-label.worker.js +40 -40
  197. package/src/utils/suggester-workers/find-best-label/tokenize.js +30 -33
  198. package/src/utils/suggester-workers/find-best-label/tokenize.spec.js +19 -19
  199. package/src/utils/suggester-workers/searching/compute-score.js +33 -33
  200. package/src/utils/suggester-workers/searching/get-db.js +18 -18
  201. package/src/utils/suggester-workers/searching/index.js +1 -1
  202. package/src/utils/suggester-workers/searching/order/create-alphanumeric-orderer.js +20 -20
  203. package/src/utils/suggester-workers/searching/order/index.js +19 -19
  204. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/index.js +2 -2
  205. package/src/utils/suggester-workers/searching/query-parser/query-parser-soft.js +7 -0
  206. package/src/utils/suggester-workers/{query-parser → searching/query-parser}/query-parser-soft.spec.js +24 -24
  207. package/src/utils/suggester-workers/searching/query-parser/query-parser-tokenized.js +34 -0
  208. package/src/utils/suggester-workers/searching/resolve-query-parser.js +27 -27
  209. package/src/utils/suggester-workers/searching/search-in-index.js +17 -17
  210. package/src/utils/suggester-workers/searching/searching.js +70 -70
  211. package/src/utils/suggester-workers/searching/searching.worker.js +11 -11
  212. package/src/utils/to-expose/calculated-variables.js +113 -113
  213. package/src/utils/to-expose/handler.js +149 -112
  214. package/src/utils/to-expose/hooks/filter-components.js +27 -12
  215. package/src/utils/to-expose/hooks/index.js +2 -1
  216. package/src/utils/to-expose/hooks/lunatic-split.js +428 -0
  217. package/src/utils/to-expose/hooks/lunatic.js +284 -188
  218. package/src/utils/to-expose/index.js +1 -1
  219. package/src/utils/to-expose/init-questionnaire.js +164 -164
  220. package/src/utils/to-expose/interpret/vtl.js +18 -18
  221. package/src/utils/to-expose/state.js +66 -58
  222. package/src/components/missing-wrapper/component.js +0 -120
  223. package/src/components/missing-wrapper/wrapper.js +0 -10
  224. package/src/tests/utils/to-expose/hooks/use-lunatic.spec.js +0 -46
  225. package/src/utils/suggester-workers/commons-tokenizer/create-tokenizer.js +0 -103
  226. package/src/utils/suggester-workers/commons-tokenizer/filter-accents-to-lower.js +0 -9
  227. package/src/utils/suggester-workers/commons-tokenizer/filter-synonyms.js +0 -10
  228. package/src/utils/suggester-workers/query-parser/query-parser-soft.js +0 -7
  229. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.js +0 -31
  230. package/src/utils/suggester-workers/query-parser/query-parser-tokenized.spec.js +0 -32
@@ -1,46 +1,46 @@
1
- # Suggester component
2
-
3
- ## Props
4
-
5
- | Props | Type | Default value | Required | Description |
6
- | :--------------: | :----: | :--------------------------------------: | :------: | ---------------------------------------- |
7
- | id | string | - | ✓ | Id of the suggester |
8
- | label | string | "" | | Fieldset label of the suggester |
9
- | preferences \* | array | ["COLLECTED"] | | Preferences to manage suggester response |
10
- | response \* | object | {} | | Response concerned by the component |
11
- | placeholderList | string | "" | | Placeholder of the suggester |
12
- | handleChange | func | - | ✓ | Handler of the suggester |
13
- | disabled | bool | false | | Is the suggester options disabled |
14
- | focused | bool | false | | Is the suggester options focused |
15
- | declarations \* | array | [] | | Declarations of the suggester |
16
- | features | array | [ ] | | Component features for labels |
17
- | bindings | object | [ ] | | Questionnaire bindings |
18
- | management | bool | false | | Management mode of the suggester |
19
- | labelPosition \* | string | "DEFAULT" | | Position of the input label |
20
- | path | string | - | ✓ | Path to data into indexdb |
21
- | style \* | object | { fieldsetStyle: {}, modalityStyle: {} } | | Style of the suggester |
22
-
23
- - `preferences` props has to be an ordered array of `COLLECTED`, `FORCED` or `EDITED`
24
- - `response` props has to be a shape of `{name: string, values: object}`
25
- - `labelPosition` props has to be one of `DEFAULT`, `TOP`, `BOTTOM`, `RIGHT` or `LEFT`
26
- - `declarations` are documented in the `Declarations` component
27
-
28
- ## Styles
29
-
30
- **Suggester** component has for classes XXX.
31
-
32
- ## Json-lunatic store-info
33
-
34
- {
35
- suggester: { [name] : {
36
- name,
37
- fields: [{ name: string, rules: [regexp]|'soft'|undefined, language: string|undefined, stemmer: boolean, min: integer }],
38
- queryParser:
39
- {type: 'soft'}|
40
- {type:'tokenized', params: { language: string, rules: [regexp]|undefined, stemmer: boolean|undefined },
41
- stopWords: [string]|undefined,
42
- order: { type: 'ascending'|'descending', field: string }|undefined,
43
- version: string
44
- }
45
- } , ...
46
- }
1
+ # Suggester component
2
+
3
+ ## Props
4
+
5
+ | Props | Type | Default value | Required | Description |
6
+ | :--------------: | :----: | :--------------------------------------: | :------: | ---------------------------------------- |
7
+ | id | string | - | ✓ | Id of the suggester |
8
+ | label | string | "" | | Fieldset label of the suggester |
9
+ | preferences \* | array | ["COLLECTED"] | | Preferences to manage suggester response |
10
+ | response \* | object | {} | | Response concerned by the component |
11
+ | placeholderList | string | "" | | Placeholder of the suggester |
12
+ | handleChange | func | - | ✓ | Handler of the suggester |
13
+ | disabled | bool | false | | Is the suggester options disabled |
14
+ | focused | bool | false | | Is the suggester options focused |
15
+ | declarations \* | array | [] | | Declarations of the suggester |
16
+ | features | array | [ ] | | Component features for labels |
17
+ | bindings | object | [ ] | | Questionnaire bindings |
18
+ | management | bool | false | | Management mode of the suggester |
19
+ | labelPosition \* | string | "DEFAULT" | | Position of the input label |
20
+ | path | string | - | ✓ | Path to data into indexdb |
21
+ | style \* | object | { fieldsetStyle: {}, modalityStyle: {} } | | Style of the suggester |
22
+
23
+ - `preferences` props has to be an ordered array of `COLLECTED`, `FORCED` or `EDITED`
24
+ - `response` props has to be a shape of `{name: string, values: object}`
25
+ - `labelPosition` props has to be one of `DEFAULT`, `TOP`, `BOTTOM`, `RIGHT` or `LEFT`
26
+ - `declarations` are documented in the `Declarations` component
27
+
28
+ ## Styles
29
+
30
+ **Suggester** component has for classes XXX.
31
+
32
+ ## Json-lunatic store-info
33
+
34
+ {
35
+ suggester: { [name] : {
36
+ name,
37
+ fields: [{ name: string, rules: [regexp]|'soft'|undefined, language: string|undefined, stemmer: boolean, min: integer }],
38
+ queryParser:
39
+ {type: 'soft'}|
40
+ {type:'tokenized', params: { language: string, rules: [regexp]|undefined, stemmer: boolean|undefined },
41
+ stopWords: [string]|undefined,
42
+ order: { type: 'ascending'|'descending', field: string }|undefined,
43
+ version: string
44
+ }
45
+ } , ...
46
+ }
@@ -1,15 +1,15 @@
1
- async function fetchBailleurs(path = '') {
2
- const sbPath =
3
- process.env.NODE_ENV === 'development'
4
- ? `${path}/bailleurs-sociaux.json`
5
- : `/Lunatic/storybook/bailleurs-sociaux.json`;
6
- const response = await fetch(sbPath);
7
- const naf = await response.json();
8
- return naf.map(function (bailleur) {
9
- const { code, libelle1 } = bailleur;
10
-
11
- return { ...bailleur, id: code, label: libelle1, value: code };
12
- });
13
- }
14
-
15
- export default fetchBailleurs;
1
+ async function fetchBailleurs(path = '') {
2
+ const sbPath =
3
+ process.env.NODE_ENV === 'development'
4
+ ? `${path}/bailleurs-sociaux.json`
5
+ : `/Lunatic/storybook/bailleurs-sociaux.json`;
6
+ const response = await fetch(sbPath);
7
+ const naf = await response.json();
8
+ return naf.map(function (bailleur) {
9
+ const { code, libelle1 } = bailleur;
10
+
11
+ return { ...bailleur, id: code, label: libelle1, value: code };
12
+ });
13
+ }
14
+
15
+ export default fetchBailleurs;
@@ -1,2 +1,2 @@
1
- export { default as fetch } from './fetch-bailleurs';
2
- export { default as OptionRenderer } from './option-bailleur-renderer';
1
+ export { default as fetch } from './fetch-bailleurs';
2
+ export { default as OptionRenderer } from './option-bailleur-renderer';
@@ -1,58 +1,58 @@
1
- import React, { useEffect, useState } from 'react';
2
- import classnames from 'classnames';
3
- import findBestLabel from '../../../components/suggester/find-best-label';
4
- import './theme.scss';
5
-
6
- function getLabel(option, attribut) {
7
- const { libelle1, libelle2, code } = option;
8
- switch (attribut) {
9
- case 'libelle2':
10
- return `${code} - ${libelle2}`;
11
- case 'libelle1':
12
- case 'code':
13
- return `${code} - ${libelle1}`;
14
- default:
15
- return ``;
16
- }
17
- }
18
-
19
- function OptionBailleurRenderer({ option, selected, search }) {
20
- const { typorg } = option;
21
- const [computed, setComputed] = useState(false);
22
- const [attribut, setAttribut] = useState(undefined);
23
-
24
- useEffect(
25
- function () {
26
- let unmount = false;
27
- async function doIt() {
28
- const best = await findBestLabel(option, search);
29
- if (!unmount) {
30
- setAttribut(best);
31
- setComputed(true);
32
- }
33
- }
34
-
35
- doIt();
36
-
37
- return function () {
38
- unmount = true;
39
- };
40
- },
41
- [option, search]
42
- );
43
-
44
- return (
45
- <div
46
- className={classnames('option-bailleur', `type-${typorg}`, {
47
- selected,
48
- computed,
49
- })}
50
- >
51
- <span className={classnames('bailleur-label', {})} title={attribut}>
52
- {getLabel(option, attribut)}
53
- </span>
54
- </div>
55
- );
56
- }
57
-
58
- export default OptionBailleurRenderer;
1
+ import React, { useEffect, useState } from 'react';
2
+ import classnames from 'classnames';
3
+ import findBestLabel from '../../../components/suggester/find-best-label';
4
+ import './theme.scss';
5
+
6
+ function getLabel(option, attribut) {
7
+ const { libelle1, libelle2, code } = option;
8
+ switch (attribut) {
9
+ case 'libelle2':
10
+ return `${code} - ${libelle2}`;
11
+ case 'libelle1':
12
+ case 'code':
13
+ return `${code} - ${libelle1}`;
14
+ default:
15
+ return ``;
16
+ }
17
+ }
18
+
19
+ function OptionBailleurRenderer({ option, selected, search }) {
20
+ const { typorg } = option;
21
+ const [computed, setComputed] = useState(false);
22
+ const [attribut, setAttribut] = useState(undefined);
23
+
24
+ useEffect(
25
+ function () {
26
+ let unmount = false;
27
+ async function doIt() {
28
+ const best = await findBestLabel(option, search);
29
+ if (!unmount) {
30
+ setAttribut(best);
31
+ setComputed(true);
32
+ }
33
+ }
34
+
35
+ doIt();
36
+
37
+ return function () {
38
+ unmount = true;
39
+ };
40
+ },
41
+ [option, search]
42
+ );
43
+
44
+ return (
45
+ <div
46
+ className={classnames('option-bailleur', `type-${typorg}`, {
47
+ selected,
48
+ computed,
49
+ })}
50
+ >
51
+ <span className={classnames('bailleur-label', {})} title={attribut}>
52
+ {getLabel(option, attribut)}
53
+ </span>
54
+ </div>
55
+ );
56
+ }
57
+
58
+ export default OptionBailleurRenderer;
@@ -1,52 +1,52 @@
1
- <?xml version="1.0" encoding="utf-8"?>
2
- <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin: auto; background: none; display: block; shape-rendering: auto;" width="200px" height="200px" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid">
3
- <g transform="rotate(0 50 50)">
4
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
5
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.9166666666666666s" repeatCount="indefinite"></animate>
6
- </rect>
7
- </g><g transform="rotate(30 50 50)">
8
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
9
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.8333333333333334s" repeatCount="indefinite"></animate>
10
- </rect>
11
- </g><g transform="rotate(60 50 50)">
12
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
13
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.75s" repeatCount="indefinite"></animate>
14
- </rect>
15
- </g><g transform="rotate(90 50 50)">
16
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
17
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.6666666666666666s" repeatCount="indefinite"></animate>
18
- </rect>
19
- </g><g transform="rotate(120 50 50)">
20
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
21
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5833333333333334s" repeatCount="indefinite"></animate>
22
- </rect>
23
- </g><g transform="rotate(150 50 50)">
24
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
25
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5s" repeatCount="indefinite"></animate>
26
- </rect>
27
- </g><g transform="rotate(180 50 50)">
28
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
29
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.4166666666666667s" repeatCount="indefinite"></animate>
30
- </rect>
31
- </g><g transform="rotate(210 50 50)">
32
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
33
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.3333333333333333s" repeatCount="indefinite"></animate>
34
- </rect>
35
- </g><g transform="rotate(240 50 50)">
36
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
37
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.25s" repeatCount="indefinite"></animate>
38
- </rect>
39
- </g><g transform="rotate(270 50 50)">
40
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
41
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.16666666666666666s" repeatCount="indefinite"></animate>
42
- </rect>
43
- </g><g transform="rotate(300 50 50)">
44
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
45
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.08333333333333333s" repeatCount="indefinite"></animate>
46
- </rect>
47
- </g><g transform="rotate(330 50 50)">
48
- <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
49
- <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="0s" repeatCount="indefinite"></animate>
50
- </rect>
51
- </g>
1
+ <?xml version="1.0" encoding="utf-8"?>
2
+ <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin: auto; background: none; display: block; shape-rendering: auto;" width="200px" height="200px" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid">
3
+ <g transform="rotate(0 50 50)">
4
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
5
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.9166666666666666s" repeatCount="indefinite"></animate>
6
+ </rect>
7
+ </g><g transform="rotate(30 50 50)">
8
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
9
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.8333333333333334s" repeatCount="indefinite"></animate>
10
+ </rect>
11
+ </g><g transform="rotate(60 50 50)">
12
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
13
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.75s" repeatCount="indefinite"></animate>
14
+ </rect>
15
+ </g><g transform="rotate(90 50 50)">
16
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
17
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.6666666666666666s" repeatCount="indefinite"></animate>
18
+ </rect>
19
+ </g><g transform="rotate(120 50 50)">
20
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
21
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5833333333333334s" repeatCount="indefinite"></animate>
22
+ </rect>
23
+ </g><g transform="rotate(150 50 50)">
24
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
25
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5s" repeatCount="indefinite"></animate>
26
+ </rect>
27
+ </g><g transform="rotate(180 50 50)">
28
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
29
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.4166666666666667s" repeatCount="indefinite"></animate>
30
+ </rect>
31
+ </g><g transform="rotate(210 50 50)">
32
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
33
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.3333333333333333s" repeatCount="indefinite"></animate>
34
+ </rect>
35
+ </g><g transform="rotate(240 50 50)">
36
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
37
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.25s" repeatCount="indefinite"></animate>
38
+ </rect>
39
+ </g><g transform="rotate(270 50 50)">
40
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
41
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.16666666666666666s" repeatCount="indefinite"></animate>
42
+ </rect>
43
+ </g><g transform="rotate(300 50 50)">
44
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
45
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.08333333333333333s" repeatCount="indefinite"></animate>
46
+ </rect>
47
+ </g><g transform="rotate(330 50 50)">
48
+ <rect x="47" y="24" rx="3" ry="6" width="6" height="12" fill="#fe718d">
49
+ <animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="0s" repeatCount="indefinite"></animate>
50
+ </rect>
51
+ </g>
52
52
  <!-- [ldio] generated by https://loading.io/ --></svg>
@@ -1,22 +1,22 @@
1
- .option-bailleur {
2
- white-space: nowrap;
3
- overflow: hidden;
4
- background-image: url('./preloader.svg');
5
- background-repeat: no-repeat;
6
- background-size: 16px 16px;
7
- background-color: gray;
8
- color: snow;
9
-
10
- &.computed {
11
- background-color: transparent;
12
- background-image:none;
13
- color: black;
14
-
15
- }
16
-
17
- &.selected {
18
- .bailleur-label {
19
- color: goldenrod;
20
- }
21
- }
22
- }
1
+ .option-bailleur {
2
+ white-space: nowrap;
3
+ overflow: hidden;
4
+ background-image: url('./preloader.svg');
5
+ background-repeat: no-repeat;
6
+ background-size: 16px 16px;
7
+ background-color: gray;
8
+ color: snow;
9
+
10
+ &.computed {
11
+ background-color: transparent;
12
+ background-image:none;
13
+ color: black;
14
+
15
+ }
16
+
17
+ &.selected {
18
+ .bailleur-label {
19
+ color: goldenrod;
20
+ }
21
+ }
22
+ }
@@ -0,0 +1,12 @@
1
+ const FILE_NAME = 'bailleurs-sociaux-2021.json';
2
+
3
+ async function fetchBailleurs(path = '') {
4
+ const sbPath =
5
+ process.env.NODE_ENV === 'development'
6
+ ? `${path}/${FILE_NAME}`
7
+ : `/Lunatic/storybook/${FILE_NAME}`;
8
+ const response = await fetch(sbPath);
9
+ return response.json();
10
+ }
11
+
12
+ export default fetchBailleurs;
@@ -0,0 +1 @@
1
+ export { default as fetch } from './fetch-bailleurs';
@@ -1,15 +1,15 @@
1
- async function fetchCOG(path = '') {
2
- const sbPath =
3
- process.env.NODE_ENV === 'development'
4
- ? `${path}/communes-2019.json`
5
- : `/Lunatic/storybook/communes-2019.json`;
6
- const response = await fetch(sbPath);
7
- const cog = await response.json();
8
-
9
- return cog.map(({ label, ...rest }) => ({
10
- label,
11
- ...rest,
12
- }));
13
- }
14
-
15
- export default fetchCOG;
1
+ async function fetchCOG(path = '') {
2
+ const sbPath =
3
+ process.env.NODE_ENV === 'development'
4
+ ? `${path}/communes-2019.json`
5
+ : `/Lunatic/storybook/communes-2019.json`;
6
+ const response = await fetch(sbPath);
7
+ const cog = await response.json();
8
+
9
+ return cog.map(({ label, ...rest }) => ({
10
+ label,
11
+ ...rest,
12
+ }));
13
+ }
14
+
15
+ export default fetchCOG;