intelicoreact 1.5.38 → 1.5.41

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 (519) hide show
  1. package/dist/Atomic/FormElements/ActionAlert/ActionAlert.js +44 -93
  2. package/dist/Atomic/FormElements/ActionAlert/ActionAlert.scss +13 -23
  3. package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.js +38 -43
  4. package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.scss +10 -20
  5. package/dist/Atomic/FormElements/Calendar/Calendar.js +164 -243
  6. package/dist/Atomic/FormElements/Calendar/Calendar.scss +0 -1
  7. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.js +51 -60
  8. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.scss +15 -25
  9. package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.js +39 -47
  10. package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.scss +2 -5
  11. package/dist/Atomic/FormElements/Datepicker/Datepicker.js +308 -410
  12. package/dist/Atomic/FormElements/Datepicker/components/Calendar.js +109 -169
  13. package/dist/Atomic/FormElements/Dropdown/Dropdown.js +527 -680
  14. package/dist/Atomic/FormElements/Dropdown/Dropdown.scss +59 -61
  15. package/dist/Atomic/FormElements/Dropdown/components/DropdownLoader.js +15 -28
  16. package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.js +378 -498
  17. package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.scss +32 -36
  18. package/dist/Atomic/FormElements/FileLoader/FileLoader.js +70 -103
  19. package/dist/Atomic/FormElements/FileLoader/FileLoader.scss +2 -0
  20. package/dist/Atomic/FormElements/FileLoader/partial/LoadZone.js +91 -138
  21. package/dist/Atomic/FormElements/FileLoader/partial/LoadedContent.js +55 -109
  22. package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.js +193 -254
  23. package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.scss +16 -19
  24. package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.js +140 -156
  25. package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.scss +4 -8
  26. package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.js +156 -222
  27. package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.js +114 -158
  28. package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN_old.js +92 -151
  29. package/dist/Atomic/FormElements/Input/Input.js +330 -340
  30. package/dist/Atomic/FormElements/Input/Input.scss +1 -1
  31. package/dist/Atomic/FormElements/InputCalendar/InputCalendar.js +110 -156
  32. package/dist/Atomic/FormElements/InputColor/InputColor.js +58 -57
  33. package/dist/Atomic/FormElements/InputCurrency/InputCurrency.js +145 -188
  34. package/dist/Atomic/FormElements/InputDateRange/InputDateRange.js +228 -294
  35. package/dist/Atomic/FormElements/InputDateRange/InputDateRange.scss +2 -1
  36. package/dist/Atomic/FormElements/InputDateRange/components/DateInput.js +56 -55
  37. package/dist/Atomic/FormElements/InputDateRange/components/Datepicker.js +536 -645
  38. package/dist/Atomic/FormElements/InputDateRange/components/OpenedPart.js +190 -220
  39. package/dist/Atomic/FormElements/InputDateRange/components/SelectItem.js +31 -33
  40. package/dist/Atomic/FormElements/InputDateRange/dependencies.js +169 -247
  41. package/dist/Atomic/FormElements/InputLink/InputLink.js +71 -118
  42. package/dist/Atomic/FormElements/InputMask/InputCarretPosition.js +38 -47
  43. package/dist/Atomic/FormElements/InputMask/InputMask.js +1053 -938
  44. package/dist/Atomic/FormElements/InputMask/config.js +15 -16
  45. package/dist/Atomic/FormElements/InputMask/functions.js +51 -77
  46. package/dist/Atomic/FormElements/InputMask2/InputMask2.js +592 -569
  47. package/dist/Atomic/FormElements/InputMask2/config.js +15 -16
  48. package/dist/Atomic/FormElements/InputMask2/functions.js +51 -77
  49. package/dist/Atomic/FormElements/InputMask3/InputMask3.js +679 -651
  50. package/dist/Atomic/FormElements/InputMask3/config.js +15 -16
  51. package/dist/Atomic/FormElements/InputMask3/functions.js +51 -77
  52. package/dist/Atomic/FormElements/InputWithAction/InputWithAction.js +88 -127
  53. package/dist/Atomic/FormElements/InputWithAction/InputWithAction.scss +1 -1
  54. package/dist/Atomic/FormElements/InputsRow/InputsRow.js +111 -182
  55. package/dist/Atomic/FormElements/Label/Label.js +55 -82
  56. package/dist/Atomic/FormElements/Label/Label.scss +8 -18
  57. package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.js +382 -437
  58. package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.scss +3 -3
  59. package/dist/Atomic/FormElements/MultiSelect/MultiSelect.js +50 -88
  60. package/dist/Atomic/FormElements/NumericInput/NumericInput.js +264 -314
  61. package/dist/Atomic/FormElements/NumericInput/NumericInput.scss +1 -1
  62. package/dist/Atomic/FormElements/RadioGroup/RadioGroup.js +51 -93
  63. package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.js +55 -69
  64. package/dist/Atomic/FormElements/RadioInput/RadioInput.js +45 -51
  65. package/dist/Atomic/FormElements/RadioInput/RadioInput.scss +4 -4
  66. package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.js +40 -53
  67. package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.js +120 -169
  68. package/dist/Atomic/FormElements/RangeInputs/RangeInputs.js +141 -195
  69. package/dist/Atomic/FormElements/RangeList/RangeList.js +140 -199
  70. package/dist/Atomic/FormElements/RangeList/RangeList.scss +2 -2
  71. package/dist/Atomic/FormElements/RangeList/partial/AnyOuterClass.scss +4 -1
  72. package/dist/Atomic/FormElements/RangeList/partial/RangeListRow.js +44 -57
  73. package/dist/Atomic/FormElements/RangeSlider/RangeSlider.js +377 -463
  74. package/dist/Atomic/FormElements/RangeSlider/RangeSlider.scss +1 -1
  75. package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.js +759 -760
  76. package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.scss +9 -9
  77. package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.js +31 -36
  78. package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.scss +2 -0
  79. package/dist/Atomic/FormElements/SwitchableRow/partial/AnyOuterClass.scss +1 -1
  80. package/dist/Atomic/FormElements/Switcher/Switcher.js +44 -52
  81. package/dist/Atomic/FormElements/Switcher/Switcher.scss +3 -3
  82. package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.js +44 -43
  83. package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.scss +2 -0
  84. package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.js +36 -37
  85. package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.scss +2 -0
  86. package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.js +56 -93
  87. package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.scss +2 -0
  88. package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.js +53 -86
  89. package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.scss +2 -0
  90. package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.js +54 -46
  91. package/dist/Atomic/FormElements/SwitcherRangeList/partial/AnyOuterClass.scss +1 -1
  92. package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.js +102 -172
  93. package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.scss +6 -4
  94. package/dist/Atomic/FormElements/SwitcherTagsDropdown/partial/States.js +154 -209
  95. package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.js +56 -59
  96. package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.scss +2 -2
  97. package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.js +112 -140
  98. package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.js +919 -1035
  99. package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.scss +119 -155
  100. package/dist/Atomic/FormElements/Text/Text.js +97 -88
  101. package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.js +35 -44
  102. package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.scss +8 -8
  103. package/dist/Atomic/FormElements/Textarea/Textarea.js +64 -102
  104. package/dist/Atomic/FormElements/Textarea/Textarea.scss +8 -4
  105. package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.js +133 -172
  106. package/dist/Atomic/FormElements/TieredCheckboxes/partial/AccordionWithCheckbox.js +49 -48
  107. package/dist/Atomic/FormElements/TimeRange/TimeRange.js +63 -114
  108. package/dist/Atomic/FormElements/TimeRange/TimeRange.scss +3 -9
  109. package/dist/Atomic/FormElements/UserContacts/UserContacts.js +122 -179
  110. package/dist/Atomic/FormElements/UserContacts/UserContacts.scss +5 -10
  111. package/dist/Atomic/FormElements/UserContacts/partial/AnyOuterClass.scss +1 -1
  112. package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.js +65 -101
  113. package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.scss +12 -4
  114. package/dist/Atomic/FormElements/VariantsListRadio/partials/VariantsListRadioItem.js +71 -80
  115. package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.js +64 -79
  116. package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.scss +3 -1
  117. package/dist/Atomic/FormElements/WidgetPseudoTable/partial/AnyOuterClass.scss +1 -1
  118. package/dist/Atomic/FormElements/WidgetPseudoTable/partial/constructor.js +34 -42
  119. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.js +83 -102
  120. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.scss +3 -1
  121. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/AnyOuterClass.scss +1 -1
  122. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/partial/constructor.js +35 -42
  123. package/dist/Atomic/Layout/Header/Header.js +80 -148
  124. package/dist/Atomic/Layout/Header/Header.scss +1 -1
  125. package/dist/Atomic/Layout/MainMenu/MainMenu.js +133 -213
  126. package/dist/Atomic/Layout/MainMenu/MainMenu.scss +9 -9
  127. package/dist/Atomic/Layout/Spinner/Spinner.js +22 -39
  128. package/dist/Atomic/Layout/Spinner/Spinner.scss +16 -32
  129. package/dist/Atomic/UI/Accordion/Accordion.js +52 -102
  130. package/dist/Atomic/UI/Accordion/Accordion.scss +14 -25
  131. package/dist/Atomic/UI/Accordion/AccordionItem.js +102 -170
  132. package/dist/Atomic/UI/AccordionTable/AccordionTable.js +167 -251
  133. package/dist/Atomic/UI/AccordionText/AccordionText.js +54 -105
  134. package/dist/Atomic/UI/AccordionText/AccordionText.scss +9 -22
  135. package/dist/Atomic/UI/AdvancedTag/AdvTag.js +135 -207
  136. package/dist/Atomic/UI/AdvancedTag/AdvancedTags.js +46 -100
  137. package/dist/Atomic/UI/AdvancedTag/AdvancedTags.scss +2 -2
  138. package/dist/Atomic/UI/Alert/Alert.js +63 -116
  139. package/dist/Atomic/UI/Alert/Alert.scss +2 -2
  140. package/dist/Atomic/UI/Arrow/Arrow.js +110 -163
  141. package/dist/Atomic/UI/Box/Box.js +37 -37
  142. package/dist/Atomic/UI/Box/Box.scss +11 -11
  143. package/dist/Atomic/UI/Button/Button.js +41 -43
  144. package/dist/Atomic/UI/ButtonsBar/ButtonsBar.js +67 -61
  145. package/dist/Atomic/UI/Chart/Chart.js +96 -170
  146. package/dist/Atomic/UI/Chart/partial/Chart.constants.js +74 -142
  147. package/dist/Atomic/UI/Chart/partial/ChartTypeSwitcherIcon/ChartTypeSwitcherIcon.js +77 -91
  148. package/dist/Atomic/UI/Chart/partial/datasetSetters.js +117 -120
  149. package/dist/Atomic/UI/Chart/partial/optionsConstructor.js +292 -314
  150. package/dist/Atomic/UI/Chart/partial/optionsSetters.js +39 -54
  151. package/dist/Atomic/UI/Chart/partial/utils.js +33 -56
  152. package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.js +88 -145
  153. package/dist/Atomic/UI/DateTime/DateTime.js +37 -89
  154. package/dist/Atomic/UI/DateTime/DateTime.scss +2 -2
  155. package/dist/Atomic/UI/DateTime/partial/AnyOuterClass.scss +1 -1
  156. package/dist/Atomic/UI/DebugContainer/DebugContainer.js +31 -93
  157. package/dist/Atomic/UI/DebugContainer/useDebugContainer.js +18 -66
  158. package/dist/Atomic/UI/DoubleString/DoubleString.js +77 -134
  159. package/dist/Atomic/UI/DoubleString/DoubleString.scss +4 -6
  160. package/dist/Atomic/UI/DoubleString/partial/AnyOuterClass.scss +1 -1
  161. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.js +22 -65
  162. package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.js +170 -251
  163. package/dist/Atomic/UI/ExampleChartIntegration/partial/AnyOuterClass.scss +1 -1
  164. package/dist/Atomic/UI/ExampleChartIntegration/partial/utils.js +84 -109
  165. package/dist/Atomic/UI/Hint/Hint.js +202 -243
  166. package/dist/Atomic/UI/Hint/Hint.scss +3 -5
  167. package/dist/Atomic/UI/Hint/partials/_utils.js +42 -54
  168. package/dist/Atomic/UI/Modal/Modal.js +172 -171
  169. package/dist/Atomic/UI/Modal/Modal.scss +69 -91
  170. package/dist/Atomic/UI/Modal/ModalHOC.js +38 -92
  171. package/dist/Atomic/UI/Modal/ModalMobile.scss +14 -24
  172. package/dist/Atomic/UI/Modal/partials/ModalFooter.js +18 -68
  173. package/dist/Atomic/UI/Modal/partials/ModalTitle.js +38 -107
  174. package/dist/Atomic/UI/Modal/partials/useMobileModal.js +153 -130
  175. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.js +62 -118
  176. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.scss +25 -163
  177. package/dist/Atomic/UI/NavLine/NavLine.js +273 -306
  178. package/dist/Atomic/UI/NavLine/NavLine.scss +155 -195
  179. package/dist/Atomic/UI/NavLine/Tabs.js +115 -0
  180. package/dist/Atomic/UI/PageTitle/PageTitle.js +52 -73
  181. package/dist/Atomic/UI/PageTitle/PageTitle.scss +14 -52
  182. package/dist/Atomic/UI/PieChart/PieChart.js +42 -105
  183. package/dist/Atomic/UI/PieChart/PieChart.scss +11 -86
  184. package/dist/Atomic/UI/Price/Price.js +20 -27
  185. package/dist/Atomic/UI/PriceRange/PriceRange.js +18 -40
  186. package/dist/Atomic/UI/ProgressLine/ProgressLine.js +73 -92
  187. package/dist/Atomic/UI/ProgressLine/ProgressLine.scss +71 -85
  188. package/dist/Atomic/UI/Status/Status.js +51 -62
  189. package/dist/Atomic/UI/Status/Status.scss +29 -48
  190. package/dist/Atomic/UI/Table/Partials/TdCell.js +88 -126
  191. package/dist/Atomic/UI/Table/Partials/TdHeader.js +39 -58
  192. package/dist/Atomic/UI/Table/Partials/TdRow.js +73 -124
  193. package/dist/Atomic/UI/Table/Partials/TdTitle.js +45 -113
  194. package/dist/Atomic/UI/Table/Table.js +43 -61
  195. package/dist/Atomic/UI/Table/Table.scss +3 -0
  196. package/dist/Atomic/UI/Table/TdTypes/TdActions.js +64 -108
  197. package/dist/Atomic/UI/Table/TdTypes/TdPriority.js +31 -44
  198. package/dist/Atomic/UI/Table/TdTypes/TdRange.js +10 -24
  199. package/dist/Atomic/UI/Table/TdTypes/TdWeight.js +48 -59
  200. package/dist/Atomic/UI/Tag/Tag.js +113 -157
  201. package/dist/Atomic/UI/Tag/Tag.scss +48 -102
  202. package/dist/Atomic/UI/TagList/TagList.js +179 -223
  203. package/dist/Atomic/UI/TagList/TagList.scss +9 -13
  204. package/dist/Atomic/UI/UserBox/UserBox.js +56 -80
  205. package/dist/Atomic/UI/UserBox/UserBox.scss +21 -45
  206. package/dist/Atomic/UI/WizardStepper/constructor.js +89 -127
  207. package/dist/Atomic/UI/WizardStepper/index.js +6 -14
  208. package/dist/Atomic/UI/WizardStepper/ui/StateIcon/StateIcon.js +51 -53
  209. package/dist/Atomic/UI/WizardStepper/ui/StateIcon/StateIcon.scss +7 -11
  210. package/dist/Atomic/UI/WizardStepper/ui/StateIcon/index.js +5 -9
  211. package/dist/Atomic/UI/WizardStepper/ui/StepRow/StepRow.js +67 -84
  212. package/dist/Atomic/UI/WizardStepper/ui/StepRow/StepRow.scss +7 -13
  213. package/dist/Atomic/UI/WizardStepper/ui/StepRow/index.js +6 -14
  214. package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/StepWrapper.js +45 -50
  215. package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/StepWrapper.scss +18 -24
  216. package/dist/Atomic/UI/WizardStepper/ui/StepWrapper/index.js +6 -14
  217. package/dist/Atomic/UI/WizardStepper/ui/icons.js +106 -138
  218. package/dist/Atomic/UI/WizardStepper/ui/index.js +6 -14
  219. package/dist/Classes/AbortableFetch.js +326 -394
  220. package/dist/Classes/AnimatedHandler.js +44 -31
  221. package/dist/Classes/RESTAPI/index.js +173 -131
  222. package/dist/Classes/RESTAPI/partials/AbortableFetch.js +334 -399
  223. package/dist/Classes/RESTAPI/partials/ApiBase.js +30 -30
  224. package/dist/Classes/RESTAPI/partials/ApiRequestCreators.js +88 -107
  225. package/dist/Classes/RESTAPI/partials/ApiUtils.js +166 -144
  226. package/dist/Classes/RESTAPI/partials/CredentialsProcessing.js +204 -180
  227. package/dist/Classes/RESTAPI/partials/Utils.js +83 -80
  228. package/dist/Classes/RESTAPI/partials/_outerDependencies.js +8 -16
  229. package/dist/Classes/RESTAPI/partials/_utils.js +125 -139
  230. package/dist/Constants/index.constants.js +22 -102
  231. package/dist/Functions/Portal.js +23 -67
  232. package/dist/Functions/animatingFunctions/getAnimatedHandler.js +1 -1
  233. package/dist/Functions/customEventListener.js +50 -48
  234. package/dist/Functions/dateTime.js +177 -130
  235. package/dist/Functions/fieldValueFormatters.js +346 -275
  236. package/dist/Functions/hooks/useFormFieldsChangesManager.js +96 -125
  237. package/dist/Functions/locale/createTranslator.js +27 -29
  238. package/dist/Functions/operations.js +102 -129
  239. package/dist/Functions/presets/inputMaskPresets.js +99 -88
  240. package/dist/Functions/presets/inputPresets.js +35 -41
  241. package/dist/Functions/presets/mobileKeyboardTypesPresets.js +49 -30
  242. package/dist/Functions/schemas.js +20 -78
  243. package/dist/Functions/useBodyScrollLock.js +15 -21
  244. package/dist/Functions/useClickOutside.js +16 -21
  245. package/dist/Functions/useDebounce.js +21 -62
  246. package/dist/Functions/useFieldFocus.js +79 -83
  247. package/dist/Functions/useFormTools/form-drivers/ArrayWithObjects.js +46 -39
  248. package/dist/Functions/useFormTools/form-drivers/ObjectWithIterableObjects.js +137 -132
  249. package/dist/Functions/useFormTools/form-drivers/ObjectWithNamedKeyObjects.js +73 -63
  250. package/dist/Functions/useFormTools/functions/General.js +129 -117
  251. package/dist/Functions/useFormTools/functions/RenderFields.js +85 -75
  252. package/dist/Functions/useFormTools/functions/usePrevious.js +10 -16
  253. package/dist/Functions/useFormTools/index.js +709 -647
  254. package/dist/Functions/useInputHighlightError.js +53 -104
  255. package/dist/Functions/useIsMobile.js +26 -0
  256. package/dist/Functions/useKeyPress/useHandleKeyPress.js +33 -40
  257. package/dist/Functions/useKeyPress/useKeyPress.js +39 -48
  258. package/dist/Functions/useLocalStorage.js +31 -38
  259. package/dist/Functions/useLocationParams.js +24 -31
  260. package/dist/Functions/useMediaQuery.js +10 -14
  261. package/dist/Functions/useMetaInfo.js +35 -45
  262. package/dist/Functions/useMouseUpOutside.js +15 -21
  263. package/dist/Functions/useOnlineStatus.js +21 -25
  264. package/dist/Functions/usePasswordChecker.js +111 -183
  265. package/dist/Functions/usePrevious.js +10 -16
  266. package/dist/Functions/useResize.js +28 -32
  267. package/dist/Functions/useScrollTo.js +16 -26
  268. package/dist/Functions/useToggle.js +16 -20
  269. package/dist/Functions/utils.js +469 -493
  270. package/dist/Molecular/CustomIcons/components/AffiliateNetworks.js +28 -75
  271. package/dist/Molecular/CustomIcons/components/AlertCircle.js +28 -77
  272. package/dist/Molecular/CustomIcons/components/AppStore.js +32 -84
  273. package/dist/Molecular/CustomIcons/components/Arrow.js +38 -93
  274. package/dist/Molecular/CustomIcons/components/ArrowDown.js +20 -63
  275. package/dist/Molecular/CustomIcons/components/ArrowLeft.js +23 -71
  276. package/dist/Molecular/CustomIcons/components/ArrowRight.js +23 -71
  277. package/dist/Molecular/CustomIcons/components/ArrowUp.js +20 -63
  278. package/dist/Molecular/CustomIcons/components/Bell.js +18 -61
  279. package/dist/Molecular/CustomIcons/components/Button.js +18 -61
  280. package/dist/Molecular/CustomIcons/components/Campaigns.js +19 -62
  281. package/dist/Molecular/CustomIcons/components/Check.js +19 -62
  282. package/dist/Molecular/CustomIcons/components/Check2.js +18 -61
  283. package/dist/Molecular/CustomIcons/components/ChevronDown.js +18 -61
  284. package/dist/Molecular/CustomIcons/components/ChevronDownDisabled.js +18 -61
  285. package/dist/Molecular/CustomIcons/components/ChevronLeft.js +18 -61
  286. package/dist/Molecular/CustomIcons/components/ChevronRight.js +18 -61
  287. package/dist/Molecular/CustomIcons/components/ChevronUp.js +18 -61
  288. package/dist/Molecular/CustomIcons/components/ChevronUpDown.js +33 -81
  289. package/dist/Molecular/CustomIcons/components/Close.js +20 -64
  290. package/dist/Molecular/CustomIcons/components/ColumnsOrder.js +45 -95
  291. package/dist/Molecular/CustomIcons/components/Delete.js +19 -62
  292. package/dist/Molecular/CustomIcons/components/Edit.js +18 -61
  293. package/dist/Molecular/CustomIcons/components/Email.js +36 -87
  294. package/dist/Molecular/CustomIcons/components/FinturfLogo.js +26 -82
  295. package/dist/Molecular/CustomIcons/components/FinturfLogo2.js +34 -83
  296. package/dist/Molecular/CustomIcons/components/Flows.js +18 -61
  297. package/dist/Molecular/CustomIcons/components/Gift.js +23 -71
  298. package/dist/Molecular/CustomIcons/components/GoogleAuth.js +32 -84
  299. package/dist/Molecular/CustomIcons/components/GooglePlay.js +32 -84
  300. package/dist/Molecular/CustomIcons/components/HelpCircle.js +21 -67
  301. package/dist/Molecular/CustomIcons/components/HelpCircle2.js +22 -68
  302. package/dist/Molecular/CustomIcons/components/HelpCircleFilled.js +21 -67
  303. package/dist/Molecular/CustomIcons/components/Home.js +21 -67
  304. package/dist/Molecular/CustomIcons/components/Home2.js +24 -70
  305. package/dist/Molecular/CustomIcons/components/Key.js +26 -69
  306. package/dist/Molecular/CustomIcons/components/Landers.js +22 -68
  307. package/dist/Molecular/CustomIcons/components/Lock.js +18 -61
  308. package/dist/Molecular/CustomIcons/components/Mail.js +26 -75
  309. package/dist/Molecular/CustomIcons/components/Mastercard.js +68 -128
  310. package/dist/Molecular/CustomIcons/components/Minus.js +31 -79
  311. package/dist/Molecular/CustomIcons/components/Offers.js +19 -62
  312. package/dist/Molecular/CustomIcons/components/Pause.js +31 -79
  313. package/dist/Molecular/CustomIcons/components/PayPal.js +45 -96
  314. package/dist/Molecular/CustomIcons/components/PayPalLightLarge.js +32 -81
  315. package/dist/Molecular/CustomIcons/components/Phone.js +33 -81
  316. package/dist/Molecular/CustomIcons/components/Play.js +31 -79
  317. package/dist/Molecular/CustomIcons/components/Plus.js +31 -79
  318. package/dist/Molecular/CustomIcons/components/Profile.js +23 -69
  319. package/dist/Molecular/CustomIcons/components/QRCode.js +33 -85
  320. package/dist/Molecular/CustomIcons/components/Rectangle.js +18 -61
  321. package/dist/Molecular/CustomIcons/components/Revert.js +21 -67
  322. package/dist/Molecular/CustomIcons/components/Star.js +17 -60
  323. package/dist/Molecular/CustomIcons/components/Star2.js +19 -62
  324. package/dist/Molecular/CustomIcons/components/TrafficSources.js +21 -68
  325. package/dist/Molecular/CustomIcons/components/Trash.js +18 -61
  326. package/dist/Molecular/CustomIcons/components/TrashRed.js +18 -61
  327. package/dist/Molecular/CustomIcons/components/Triggers.js +18 -61
  328. package/dist/Molecular/CustomIcons/components/User.js +23 -71
  329. package/dist/Molecular/CustomIcons/components/Visa.js +34 -88
  330. package/dist/Molecular/CustomIcons/components/X.js +18 -61
  331. package/dist/Molecular/CustomIcons/index.js +674 -76
  332. package/dist/Molecular/FormElement/FormElement.js +41 -44
  333. package/dist/Molecular/FormWithDependOn/FormWithDependOn.js +161 -179
  334. package/dist/Molecular/FormWithDependOn/partials/_utils.js +56 -49
  335. package/dist/Molecular/InputAddress/InputAddress.js +421 -496
  336. package/dist/Molecular/InputAddress/InputAddress.scss +16 -14
  337. package/dist/Molecular/InputPassword/InputPassword.js +47 -99
  338. package/dist/index.js +8 -11
  339. package/dist/scss/_fonts.scss +60 -48
  340. package/dist/scss/_mixins.scss +2 -2
  341. package/dist/scss/_vars.scss +5 -4
  342. package/dist/scss/main.scss +4 -5
  343. package/package.json +21 -18
  344. package/dist/Atomic/FormElements/ActionAlert/ActionAlert.interface.js +0 -4
  345. package/dist/Atomic/FormElements/ActionAlert/ActionAlert.stories.js +0 -89
  346. package/dist/Atomic/FormElements/ActionAlert/ActionAlert.test.js +0 -130
  347. package/dist/Atomic/FormElements/ActionAlert/index.js +0 -17
  348. package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.interface.js +0 -4
  349. package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.stories.js +0 -81
  350. package/dist/Atomic/FormElements/AdvancedStatus/AdvancedStatus.test.js +0 -104
  351. package/dist/Atomic/FormElements/AdvancedStatus/index.js +0 -17
  352. package/dist/Atomic/FormElements/Calendar/Calendar.props.js +0 -4
  353. package/dist/Atomic/FormElements/Calendar/Calendar.stories.js +0 -108
  354. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.interface.js +0 -4
  355. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.stories.js +0 -100
  356. package/dist/Atomic/FormElements/CheckboxInput/CheckboxInput.test.js +0 -143
  357. package/dist/Atomic/FormElements/CheckboxInput/index.js +0 -17
  358. package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.interface.js +0 -4
  359. package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.stories.js +0 -94
  360. package/dist/Atomic/FormElements/CheckboxesLine/CheckboxesLine.test.js +0 -177
  361. package/dist/Atomic/FormElements/CheckboxesLine/index.js +0 -17
  362. package/dist/Atomic/FormElements/Datepicker/Datepicker.stories.js +0 -51
  363. package/dist/Atomic/FormElements/Dropdown/Dropdown.stories.js +0 -596
  364. package/dist/Atomic/FormElements/DropdownLiveSearch/DropdownLiveSearch.stories.js +0 -272
  365. package/dist/Atomic/FormElements/FileLoader/FileLoader.stories.js +0 -182
  366. package/dist/Atomic/FormElements/FileLoaderDescription/FileLoaderDescription.stories.js +0 -327
  367. package/dist/Atomic/FormElements/FileLoaderLocal/FileLoaderLocal.stories.js +0 -186
  368. package/dist/Atomic/FormElements/FileLoaderLocalGroup/FileLoaderLocalGroup.stories.js +0 -84
  369. package/dist/Atomic/FormElements/FormattedRawSSN/FormattedRawSSN.stories.js +0 -107
  370. package/dist/Atomic/FormElements/Input/Input.stories.js +0 -251
  371. package/dist/Atomic/FormElements/InputCalendar/InputCalendar.stories.js +0 -115
  372. package/dist/Atomic/FormElements/InputColor/InputColor.stories.js +0 -119
  373. package/dist/Atomic/FormElements/InputCurrency/InputCurrency.interface.js +0 -4
  374. package/dist/Atomic/FormElements/InputCurrency/InputCurrency.stories.js +0 -178
  375. package/dist/Atomic/FormElements/InputCurrency/InputCurrency.test.js +0 -129
  376. package/dist/Atomic/FormElements/InputCurrency/index.js +0 -16
  377. package/dist/Atomic/FormElements/InputDateRange/InputDateRange.stories.js +0 -123
  378. package/dist/Atomic/FormElements/InputLink/InputLink.stories.js +0 -140
  379. package/dist/Atomic/FormElements/InputMask/InputMask.stories.js +0 -303
  380. package/dist/Atomic/FormElements/InputMask2/InputMask2.stories.js +0 -314
  381. package/dist/Atomic/FormElements/InputMask3/InputMask3.stories.js +0 -335
  382. package/dist/Atomic/FormElements/InputWithAction/InputWithAction.stories.js +0 -276
  383. package/dist/Atomic/FormElements/InputsRow/InputsRow.stories.js +0 -56
  384. package/dist/Atomic/FormElements/Label/Label.interface.js +0 -4
  385. package/dist/Atomic/FormElements/Label/Label.stories.js +0 -47
  386. package/dist/Atomic/FormElements/Label/Label.test.js +0 -167
  387. package/dist/Atomic/FormElements/Label/index.js +0 -17
  388. package/dist/Atomic/FormElements/MobileCalendar/MobileCalendar.stories.js +0 -172
  389. package/dist/Atomic/FormElements/MultiSelect/MultiSelect.stories.js +0 -121
  390. package/dist/Atomic/FormElements/NumericInput/NumericInput.stories.js +0 -184
  391. package/dist/Atomic/FormElements/RadioGroup/RadioGroup.stories.js +0 -79
  392. package/dist/Atomic/FormElements/RadioGroupWithInput/RadioGroupWithInput.stories.js +0 -151
  393. package/dist/Atomic/FormElements/RadioInput/RadioInput.stories.js +0 -67
  394. package/dist/Atomic/FormElements/RadioRowSwitcher/RadioRowSwitcher.stories.js +0 -116
  395. package/dist/Atomic/FormElements/RangeCalendar/RangeCalendar.stories.js +0 -107
  396. package/dist/Atomic/FormElements/RangeInputs/RangeInputs.stories.js +0 -92
  397. package/dist/Atomic/FormElements/RangeList/RangeList.stories.js +0 -169
  398. package/dist/Atomic/FormElements/RangeSlider/RangeSlider.stories.js +0 -401
  399. package/dist/Atomic/FormElements/RangeSlider2/RangeSlider2.stories.js +0 -314
  400. package/dist/Atomic/FormElements/SwitchableRow/SwitchableRow.stories.js +0 -137
  401. package/dist/Atomic/FormElements/Switcher/Switcher.stories.js +0 -91
  402. package/dist/Atomic/FormElements/SwitcherCheckbox/SwitcherCheckbox.stories.js +0 -104
  403. package/dist/Atomic/FormElements/SwitcherHide/SwitcherHide.stories.js +0 -96
  404. package/dist/Atomic/FormElements/SwitcherRadio/SwitcherRadio.stories.js +0 -140
  405. package/dist/Atomic/FormElements/SwitcherRange/SwitcherRange.stories.js +0 -112
  406. package/dist/Atomic/FormElements/SwitcherRangeList/SwitcherRangeList.stories.js +0 -145
  407. package/dist/Atomic/FormElements/SwitcherTagsDropdown/SwitcherTagsDropdown.stories.js +0 -158
  408. package/dist/Atomic/FormElements/SwitcherTextarea/SwitcherTextarea.stories.js +0 -101
  409. package/dist/Atomic/FormElements/TagListToDropdown/TagListToDropdown.stories.js +0 -131
  410. package/dist/Atomic/FormElements/TagsDropdown/TagsDropdown.stories.js +0 -357
  411. package/dist/Atomic/FormElements/Text/Text.stories.js +0 -80
  412. package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.stories.js +0 -106
  413. package/dist/Atomic/FormElements/TextSwitcher/TextSwitcher.test.js +0 -93
  414. package/dist/Atomic/FormElements/Textarea/Textarea.stories.js +0 -103
  415. package/dist/Atomic/FormElements/TieredCheckboxes/TieredCheckboxes.stories.js +0 -174
  416. package/dist/Atomic/FormElements/TimeRange/TimeRange.interface.js +0 -4
  417. package/dist/Atomic/FormElements/TimeRange/TimeRange.stories.js +0 -40
  418. package/dist/Atomic/FormElements/TimeRange/TimeRange.test.js +0 -163
  419. package/dist/Atomic/FormElements/TimeRange/index.js +0 -17
  420. package/dist/Atomic/FormElements/UserContacts/UserContact.test.js +0 -381
  421. package/dist/Atomic/FormElements/UserContacts/UserContacts.interface.js +0 -4
  422. package/dist/Atomic/FormElements/UserContacts/UserContacts.stories.js +0 -74
  423. package/dist/Atomic/FormElements/UserContacts/index.js +0 -17
  424. package/dist/Atomic/FormElements/VariantsListRadio/VariantsListRadio.stories.js +0 -193
  425. package/dist/Atomic/FormElements/WidgetPseudoTable/WidgetPseudoTable.stories.js +0 -147
  426. package/dist/Atomic/FormElements/WidgetWithSwitchableRows/WidgetWithSwitchableRows.stories.js +0 -151
  427. package/dist/Atomic/Layout/Header/Header.stories.js +0 -71
  428. package/dist/Atomic/Layout/MainMenu/MainMenu.stories.js +0 -115
  429. package/dist/Atomic/Layout/Spinner/Spinner.interface.js +0 -4
  430. package/dist/Atomic/Layout/Spinner/Spinner.stories.js +0 -46
  431. package/dist/Atomic/Layout/Spinner/Spinner.test.js +0 -54
  432. package/dist/Atomic/Layout/Spinner/index.js +0 -17
  433. package/dist/Atomic/UI/Accordion/Accordion.interface.js +0 -4
  434. package/dist/Atomic/UI/Accordion/Accordion.stories.js +0 -168
  435. package/dist/Atomic/UI/Accordion/Accordion.test.js +0 -54
  436. package/dist/Atomic/UI/Accordion/AccordionItem.test.js +0 -50
  437. package/dist/Atomic/UI/Accordion/index.js +0 -17
  438. package/dist/Atomic/UI/AccordionTable/AccordionTable.stories.js +0 -268
  439. package/dist/Atomic/UI/AccordionText/AccordionText.stories.js +0 -125
  440. package/dist/Atomic/UI/AdvancedTag/AdvancedTags.stories.js +0 -115
  441. package/dist/Atomic/UI/Alert/Alert.stories.js +0 -81
  442. package/dist/Atomic/UI/Arrow/Arrow.stories.js +0 -62
  443. package/dist/Atomic/UI/Box/Box.stories.js +0 -114
  444. package/dist/Atomic/UI/Button/Button.stories.js +0 -105
  445. package/dist/Atomic/UI/Button/Button.test.js +0 -147
  446. package/dist/Atomic/UI/ButtonsBar/ButtonsBar.stories.js +0 -129
  447. package/dist/Atomic/UI/Chart/Chart.stories.js +0 -93
  448. package/dist/Atomic/UI/CircleProgressBar/CircleProgressBar.stories.js +0 -85
  449. package/dist/Atomic/UI/DateTime/DateTime.stories.js +0 -50
  450. package/dist/Atomic/UI/DoubleString/DoubleString.stories.js +0 -79
  451. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.interface.js +0 -4
  452. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.stories.js +0 -98
  453. package/dist/Atomic/UI/DynamicIcon/DynamicIcon.test.js +0 -51
  454. package/dist/Atomic/UI/DynamicIcon/index.js +0 -17
  455. package/dist/Atomic/UI/ExampleChartIntegration/ExampleChartIntegration.stories.js +0 -98
  456. package/dist/Atomic/UI/Hint/Hint.stories.js +0 -101
  457. package/dist/Atomic/UI/Hint/index.js +0 -16
  458. package/dist/Atomic/UI/Modal/Modal.interface.js +0 -4
  459. package/dist/Atomic/UI/Modal/Modal.stories.js +0 -370
  460. package/dist/Atomic/UI/Modal/ModalHOC.stories.js +0 -191
  461. package/dist/Atomic/UI/Modal/ModalHOC.test.js +0 -187
  462. package/dist/Atomic/UI/Modal/index.js +0 -26
  463. package/dist/Atomic/UI/Modal/partials/ModalFooter.test.js +0 -118
  464. package/dist/Atomic/UI/Modal/partials/ModalTitle.test.js +0 -126
  465. package/dist/Atomic/UI/Modal/partials/useMobileModal.test.js +0 -133
  466. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.interface.js +0 -4
  467. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.stories.js +0 -513
  468. package/dist/Atomic/UI/MonoAccordion/MonoAccordion.test.js +0 -84
  469. package/dist/Atomic/UI/MonoAccordion/index.js +0 -17
  470. package/dist/Atomic/UI/NavLine/NavLine.interface.js +0 -4
  471. package/dist/Atomic/UI/NavLine/NavLine.stories.js +0 -434
  472. package/dist/Atomic/UI/NavLine/NavLine.test.js +0 -311
  473. package/dist/Atomic/UI/NavLine/index.js +0 -17
  474. package/dist/Atomic/UI/PageTitle/PageTitle.interface.js +0 -4
  475. package/dist/Atomic/UI/PageTitle/PageTitle.stories.js +0 -62
  476. package/dist/Atomic/UI/PageTitle/PageTitle.test.js +0 -181
  477. package/dist/Atomic/UI/PageTitle/index.js +0 -17
  478. package/dist/Atomic/UI/PieChart/PieChar.interface.js +0 -4
  479. package/dist/Atomic/UI/PieChart/PieChart.stories.js +0 -82
  480. package/dist/Atomic/UI/PieChart/PieChart.test.js +0 -142
  481. package/dist/Atomic/UI/PieChart/index.js +0 -26
  482. package/dist/Atomic/UI/Price/Price.interface.js +0 -4
  483. package/dist/Atomic/UI/Price/Price.stories.js +0 -52
  484. package/dist/Atomic/UI/Price/Price.test.js +0 -83
  485. package/dist/Atomic/UI/Price/index.js +0 -17
  486. package/dist/Atomic/UI/PriceRange/PriceRange.interface.js +0 -4
  487. package/dist/Atomic/UI/PriceRange/PriceRange.stories.js +0 -51
  488. package/dist/Atomic/UI/PriceRange/PriceRange.test.js +0 -72
  489. package/dist/Atomic/UI/PriceRange/index.js +0 -17
  490. package/dist/Atomic/UI/ProgressLine/ProgressLine.interface.js +0 -4
  491. package/dist/Atomic/UI/ProgressLine/ProgressLine.stories.js +0 -163
  492. package/dist/Atomic/UI/ProgressLine/ProgressLine.test.js +0 -60
  493. package/dist/Atomic/UI/ProgressLine/index.js +0 -17
  494. package/dist/Atomic/UI/Status/Status.interface.js +0 -4
  495. package/dist/Atomic/UI/Status/Status.stories.js +0 -79
  496. package/dist/Atomic/UI/Status/Status.test.js +0 -103
  497. package/dist/Atomic/UI/Status/index.js +0 -17
  498. package/dist/Atomic/UI/Table/Table.stories.js +0 -250
  499. package/dist/Atomic/UI/Tag/Tag.interface.js +0 -4
  500. package/dist/Atomic/UI/Tag/Tag.stories.js +0 -108
  501. package/dist/Atomic/UI/Tag/Tag.test.js +0 -75
  502. package/dist/Atomic/UI/Tag/index.js +0 -17
  503. package/dist/Atomic/UI/TagList/TagList.stories.js +0 -169
  504. package/dist/Atomic/UI/UserBox/UserBox.interface.js +0 -4
  505. package/dist/Atomic/UI/UserBox/UserBox.stories.js +0 -57
  506. package/dist/Atomic/UI/UserBox/UserBox.test.js +0 -136
  507. package/dist/Atomic/UI/UserBox/index.js +0 -17
  508. package/dist/Atomic/UI/WizardStepper/WizardStepper.stories.js +0 -70
  509. package/dist/Functions/useIsMobile/index.js +0 -17
  510. package/dist/Functions/useIsMobile/useIsMobile.js +0 -33
  511. package/dist/Functions/useIsMobile/useIsMobile.test.js +0 -104
  512. package/dist/Functions/useKeyPress/useHandleKeyPress.test.js +0 -96
  513. package/dist/Functions/useKeyPress/useKeyPress.test.js +0 -87
  514. package/dist/Molecular/FormElement/FormElement.stories.js +0 -92
  515. package/dist/Molecular/FormWithDependOn/FormWithDependOn.stories.js +0 -301
  516. package/dist/Molecular/InputAddress/InputAddress.stories.js +0 -541
  517. package/dist/Molecular/InputPassword/InputPassword.stories.js +0 -86
  518. package/dist/types/base.interface.js +0 -4
  519. package/dist/types/base.types.js +0 -4
@@ -1,518 +1,443 @@
1
1
  "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
2
4
  Object.defineProperty(exports, "__esModule", {
3
- value: true
5
+ value: true
4
6
  });
5
- Object.defineProperty(exports, "default", {
6
- enumerable: true,
7
- get: function() {
8
- return _default;
9
- }
10
- });
11
- const _jsxruntime = require("react/jsx-runtime");
12
- const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
13
- const _classnames = /*#__PURE__*/ _interop_require_default(require("classnames"));
14
- const _reactfeather = require("react-feather");
15
- const _Input = /*#__PURE__*/ _interop_require_default(require("../../Atomic/FormElements/Input/Input"));
16
- const _Spinner = /*#__PURE__*/ _interop_require_default(require("../../Atomic/Layout/Spinner/Spinner"));
17
- const _Hint = /*#__PURE__*/ _interop_require_default(require("../../Atomic/UI/Hint/Hint"));
18
- const _useIsMobile = /*#__PURE__*/ _interop_require_default(require("../../Functions/useIsMobile/useIsMobile"));
19
- const _utils = require("../../Functions/utils");
7
+ exports.default = void 0;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _classnames = _interopRequireDefault(require("classnames"));
10
+ var _reactFeather = require("react-feather");
11
+ var _Input = _interopRequireDefault(require("../../Atomic/FormElements/Input/Input"));
12
+ var _Spinner = _interopRequireDefault(require("../../Atomic/Layout/Spinner/Spinner"));
13
+ var _Hint = _interopRequireDefault(require("../../Atomic/UI/Hint/Hint"));
14
+ var _useIsMobile = _interopRequireDefault(require("../../Functions/useIsMobile"));
15
+ var _utils = require("../../Functions/utils");
20
16
  require("./InputAddress.scss");
21
- function _interop_require_default(obj) {
22
- return obj && obj.__esModule ? obj : {
23
- default: obj
24
- };
25
- }
26
- function _getRequireWildcardCache(nodeInterop) {
27
- if (typeof WeakMap !== "function") return null;
28
- var cacheBabelInterop = new WeakMap();
29
- var cacheNodeInterop = new WeakMap();
30
- return (_getRequireWildcardCache = function(nodeInterop) {
31
- return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
32
- })(nodeInterop);
33
- }
34
- function _interop_require_wildcard(obj, nodeInterop) {
35
- if (!nodeInterop && obj && obj.__esModule) {
36
- return obj;
37
- }
38
- if (obj === null || typeof obj !== "object" && typeof obj !== "function") {
39
- return {
40
- default: obj
41
- };
42
- }
43
- var cache = _getRequireWildcardCache(nodeInterop);
44
- if (cache && cache.has(obj)) {
45
- return cache.get(obj);
46
- }
47
- var newObj = {
48
- __proto__: null
49
- };
50
- var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor;
51
- for(var key in obj){
52
- if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) {
53
- var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null;
54
- if (desc && (desc.get || desc.set)) {
55
- Object.defineProperty(newObj, key, desc);
56
- } else {
57
- newObj[key] = obj[key];
58
- }
59
- }
60
- }
61
- newObj.default = obj;
62
- if (cache) {
63
- cache.set(obj, newObj);
64
- }
65
- return newObj;
66
- }
17
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
18
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
67
19
  const DEFAULT_HINT_MESSAGE = "Select the correct address from the list of suggestions (must contains house number and street name)";
68
20
  const RC = "input-address";
21
+
69
22
  // ? Если равны - true
70
- const compareValues = (val1, val2)=>{
71
- return typeof val1 === typeof val2 && ((0, _utils.getIsOnlyAnObject)(val1) ? (0, _utils.compare)(val1, val2) : val1 === val2);
23
+ const compareValues = (val1, val2) => {
24
+ return typeof val1 === typeof val2 && ((0, _utils.getIsOnlyAnObject)(val1) ? (0, _utils.compare)(val1, val2) : val1 === val2);
72
25
  };
73
- const throttle = (fn, ms)=>{
74
- let id = null;
75
- return (...args)=>{
76
- if (id) clearTimeout(id);
77
- id = setTimeout(()=>{
78
- fn(...args);
79
- }, ms);
80
- };
26
+ const throttle = (fn, ms) => {
27
+ let id = null;
28
+ return function () {
29
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
30
+ args[_key] = arguments[_key];
31
+ }
32
+ if (id) clearTimeout(id);
33
+ id = setTimeout(() => {
34
+ fn(...args);
35
+ }, ms);
36
+ };
81
37
  };
38
+
82
39
  // Отдает true если value валидное НЕ нулевое число
83
- const getIsValidNumber = (value)=>Boolean(value) && typeof value === "number" && !Number.isNaN(value);
84
- const InputAddress = ({ label, className = "", isClearable = true, isKeyboardControlled = true, fieldKey = "", testId = "", throttle: throttleTime = 500, additionalThrottleTimeForListingRequest = 0, loader = "", noItemsMessage = "", error, value = "", onChange = ()=>{}, onChangeValueTransformer, disabled, getListItems = ()=>{}, clarifyAddressInfo, noValidate = false, renderSelectedItem, renderListItem, renderHintMessage, attributesOfNativeInput })=>{
85
- const { isMobile } = (0, _useIsMobile.default)();
86
- const inputRef = (0, _react.useRef)(null);
87
- const listRef = (0, _react.useRef)(null);
88
- const listOverlayRef = (0, _react.useRef)(null);
89
- const listWrapperRef = (0, _react.useRef)(null);
90
- const listHeaderRef = (0, _react.useRef)(null);
91
- const previousValueRef = (0, _react.useRef)(value);
92
- const [isValueInited, setIsValueInited] = (0, _react.useState)(false);
93
- const [isScrollableList, setIsScrollableList] = (0, _react.useState)(null);
94
- const [scrollTop, setScrollTop] = (0, _react.useState)(0);
95
- const [scrollHeight, setScrollHeight] = (0, _react.useState)(1);
96
- const [innerValue, setInnerValue] = (0, _react.useState)(value);
97
- const [tempInnerValue, setTempInnerValue] = (0, _react.useState)(null);
98
- const [tempValue, setTempValue] = (0, _react.useState)(null);
99
- const [listItems, setListItems] = (0, _react.useState)([]);
100
- const [isLoading, setIsLoading] = (0, _react.useState)(false);
101
- const [isListLoading, setIsListLoading] = (0, _react.useState)(false);
102
- const [hightlightedIndex, setHightlightedIndex] = (0, _react.useState)(null);
103
- const [isFocused, setIsFocused] = (0, _react.useState)(false);
104
- const [isListVisible, setIsListVisible] = (0, _react.useState)(false);
105
- const isWrongAddress = (0, _react.useMemo)(()=>{
106
- var _innerValue_street;
107
- if (noValidate) return false;
108
- if (innerValue === "") return false;
109
- // eslint-disable-next-line no-prototype-builtins
110
- if (!(innerValue === null || innerValue === void 0 ? void 0 : innerValue.hasOwnProperty("streetNumber")) || !(innerValue === null || innerValue === void 0 ? void 0 : innerValue.streetNumber)) return true;
111
- // eslint-disable-next-line no-prototype-builtins
112
- if (!(innerValue === null || innerValue === void 0 ? void 0 : innerValue.hasOwnProperty("street")) || !(innerValue === null || innerValue === void 0 ? void 0 : (_innerValue_street = innerValue.street) === null || _innerValue_street === void 0 ? void 0 : _innerValue_street.fullName)) return true;
113
- return false;
114
- }, [
115
- innerValue
116
- ]);
117
- const setItemAsInnerValue = (e, item)=>{
118
- if (e instanceof Event) {
119
- e.preventDefault();
120
- e.stopPropagation();
121
- }
122
- setTimeout(()=>{
123
- setInnerValue(item);
124
- if (isMobile) {
125
- setIsListVisible(false);
126
- }
127
- }, 0);
128
- };
129
- // ? Базовый метод получения списка вариантов адреса
130
- const getAddressVariants = (0, _react.useMemo)(()=>(innerValue)=>{
131
- var _getListItems;
132
- return (_getListItems = getListItems(innerValue)) === null || _getListItems === void 0 ? void 0 : _getListItems.then(setListItems).finally(()=>setIsListLoading(false));
133
- }, [
134
- getListItems
135
- ]);
136
- // ? Метод получения списка вариантов адреса с тротлингом (основным и, если нужно, дополнительным)
137
- // ? Без useMemo работать НЕ будет (т.к. на каждом перерендере будет создаваться новая ф-я и будет теряться замкнутая переменная id из throttle)
138
- const getAddressVariantsWithThrottling = (0, _react.useMemo)(()=>{
139
- const execute = getIsValidNumber(additionalThrottleTimeForListingRequest) ? throttle(getAddressVariants, additionalThrottleTimeForListingRequest) : getAddressVariants;
140
- return getIsValidNumber(throttleTime) ? throttle(execute, throttleTime) : execute;
141
- }, [
142
- getAddressVariants,
143
- additionalThrottleTimeForListingRequest,
144
- throttleTime
145
- ]);
146
- // ? Итоговый "получатель" списка вариантов адресов
147
- const getAddressVariantsList = ()=>{
148
- if (!(innerValue === null || innerValue === void 0 ? void 0 : innerValue.length)) return null;
149
- // ? Вообще с учетом надпись "Loading" в списке вариантов включается в этом месте (т.е. сразу при начале набора),
150
- // ? то, наверное, можно было НЕ мутить с дополнительным тротлингом )).
151
- // ? Наверное, можно было увеличить время первичного тротлинга и, наверное, работало бы так же ))
152
- // ? НО, раз уже сделал )) оставлю, может будет в будущем полезно )
153
- setIsListLoading(true);
154
- getAddressVariantsWithThrottling(innerValue);
155
- return null;
156
- };
157
- const onClearClick = (e)=>{
158
- var _inputRef_current;
159
- e.preventDefault();
160
- e.stopPropagation();
161
- if (!isMobile) {
162
- setIsListVisible(false);
40
+ const getIsValidNumber = value => Boolean(value) && typeof value === "number" && !Number.isNaN(value);
41
+ const InputAddress = _ref => {
42
+ let {
43
+ label,
44
+ className = "",
45
+ isClearable = true,
46
+ isKeyboardControlled = true,
47
+ fieldKey = "",
48
+ testId = "",
49
+ throttle: throttleTime = 500,
50
+ // ms
51
+ additionalThrottleTimeForListingRequest = 0,
52
+ // ms
53
+ loader = "",
54
+ noItemsMessage = "",
55
+ error,
56
+ value = "",
57
+ onChange = () => {},
58
+ onChangeValueTransformer,
59
+ disabled,
60
+ getListItems = () => {},
61
+ clarifyAddressInfo,
62
+ // ! Не делать дефолтного значения! Это и метод и флаг
63
+
64
+ noValidate = false,
65
+ renderSelectedItem,
66
+ renderListItem,
67
+ renderHintMessage,
68
+ attributesOfNativeInput
69
+ } = _ref;
70
+ const {
71
+ isMobile
72
+ } = (0, _useIsMobile.default)();
73
+ const inputRef = (0, _react.useRef)(null);
74
+ const listRef = (0, _react.useRef)(null);
75
+ const listOverlayRef = (0, _react.useRef)(null);
76
+ const listWrapperRef = (0, _react.useRef)(null);
77
+ const listHeaderRef = (0, _react.useRef)(null);
78
+ const previousValueRef = (0, _react.useRef)(value);
79
+ const [isValueInited, setIsValueInited] = (0, _react.useState)(false);
80
+ const [isScrollableList, setIsScrollableList] = (0, _react.useState)(null);
81
+ const [scrollTop, setScrollTop] = (0, _react.useState)(0);
82
+ const [scrollHeight, setScrollHeight] = (0, _react.useState)(1);
83
+ const [innerValue, setInnerValue] = (0, _react.useState)(value);
84
+ const [tempInnerValue, setTempInnerValue] = (0, _react.useState)(null);
85
+ const [tempValue, setTempValue] = (0, _react.useState)(null);
86
+ const [listItems, setListItems] = (0, _react.useState)([]);
87
+ const [isLoading, setIsLoading] = (0, _react.useState)(false);
88
+ const [isListLoading, setIsListLoading] = (0, _react.useState)(false);
89
+ const [hightlightedIndex, setHightlightedIndex] = (0, _react.useState)(null);
90
+ const [isFocused, setIsFocused] = (0, _react.useState)(false);
91
+ const [isListVisible, setIsListVisible] = (0, _react.useState)(false);
92
+ const isWrongAddress = (0, _react.useMemo)(() => {
93
+ if (noValidate) return false;
94
+ if (innerValue === "") return false;
95
+ // eslint-disable-next-line no-prototype-builtins
96
+ if (!innerValue?.hasOwnProperty("streetNumber") || !innerValue?.streetNumber) return true;
97
+
98
+ // eslint-disable-next-line no-prototype-builtins
99
+ if (!innerValue?.hasOwnProperty("street") || !innerValue?.street?.fullName) return true;
100
+ return false;
101
+ }, [innerValue]);
102
+ const setItemAsInnerValue = (e, item) => {
103
+ if (e instanceof Event) {
104
+ e.preventDefault();
105
+ e.stopPropagation();
106
+ }
107
+ setTimeout(() => {
108
+ setInnerValue(item);
109
+ if (isMobile) {
110
+ setIsListVisible(false);
111
+ }
112
+ }, 0);
113
+ };
114
+
115
+ // ? Базовый метод получения списка вариантов адреса
116
+ const getAddressVariants = (0, _react.useMemo)(() => innerValue => getListItems(innerValue)?.then(setListItems).finally(() => setIsListLoading(false)), [getListItems]);
117
+
118
+ // ? Метод получения списка вариантов адреса с тротлингом (основным и, если нужно, дополнительным)
119
+ // ? Без useMemo работать НЕ будет (т.к. на каждом перерендере будет создаваться новая ф-я и будет теряться замкнутая переменная id из throttle)
120
+ const getAddressVariantsWithThrottling = (0, _react.useMemo)(() => {
121
+ const execute = getIsValidNumber(additionalThrottleTimeForListingRequest) ? throttle(getAddressVariants, additionalThrottleTimeForListingRequest) : getAddressVariants;
122
+ return getIsValidNumber(throttleTime) ? throttle(execute, throttleTime) : execute;
123
+ }, [getAddressVariants, additionalThrottleTimeForListingRequest, throttleTime]);
124
+
125
+ // ? Итоговый "получатель" списка вариантов адресов
126
+ const getAddressVariantsList = () => {
127
+ if (!innerValue?.length) return null;
128
+
129
+ // ? Вообще с учетом надпись "Loading" в списке вариантов включается в этом месте (т.е. сразу при начале набора),
130
+ // ? то, наверное, можно было НЕ мутить с дополнительным тротлингом )).
131
+ // ? Наверное, можно было увеличить время первичного тротлинга и, наверное, работало бы так же ))
132
+ // ? НО, раз уже сделал )) оставлю, может будет в будущем полезно )
133
+ setIsListLoading(true);
134
+ getAddressVariantsWithThrottling(innerValue);
135
+ return null;
136
+ };
137
+ const onClearClick = e => {
138
+ e.preventDefault();
139
+ e.stopPropagation();
140
+ if (!isMobile) {
141
+ setIsListVisible(false);
142
+ }
143
+ setInnerValue("");
144
+ inputRef?.current?.focus();
145
+ setTimeout(() => setIsFocused(true), 0);
146
+ };
147
+ const onOverlayClick = e => {
148
+ if (e.target === listOverlayRef?.current) {
149
+ e.stopPropagation();
150
+ e.preventDefault();
151
+ setIsListVisible(false);
152
+ setInnerValue(tempInnerValue);
153
+ onChange(typeof innerValue === "string" || !onChangeValueTransformer || typeof onChangeValueTransformer !== "function" ? innerValue : onChangeValueTransformer(innerValue));
154
+ }
155
+ };
156
+ const onKeyDown = keyCode => {
157
+ if (!isListVisible || !isKeyboardControlled) return false;
158
+ if (keyCode === 13) {
159
+ // Enter Controller
160
+ setItemAsInnerValue(null, listItems[hightlightedIndex]);
161
+ setHightlightedIndex(null);
162
+ inputRef?.current?.blur();
163
+ } else {
164
+ let newHightlightedIndex = null;
165
+ const listItemsElements = document.getElementsByClassName("input-address__list--item");
166
+ const listHeight = listRef?.current?.getBoundingClientRect()?.height;
167
+ const listScrollTop = listRef?.current?.scrollTop || 0;
168
+ const lastItemIndex = parseInt(listItems?.length, 10) - 1;
169
+
170
+ /** Arrows Controllers **/
171
+ if (keyCode === 40) {
172
+ // Down Key Controller
173
+ if (hightlightedIndex === null || hightlightedIndex === lastItemIndex) {
174
+ newHightlightedIndex = 0;
175
+ } else if (hightlightedIndex + 1 < listItems?.length) {
176
+ newHightlightedIndex = hightlightedIndex + 1;
163
177
  }
164
- setInnerValue("");
165
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.focus();
166
- setTimeout(()=>setIsFocused(true), 0);
167
- };
168
- const onOverlayClick = (e)=>{
169
- if (e.target === (listOverlayRef === null || listOverlayRef === void 0 ? void 0 : listOverlayRef.current)) {
170
- e.stopPropagation();
171
- e.preventDefault();
172
- setIsListVisible(false);
173
- setInnerValue(tempInnerValue);
174
- onChange(typeof innerValue === "string" || !onChangeValueTransformer || typeof onChangeValueTransformer !== "function" ? innerValue : onChangeValueTransformer(innerValue));
178
+ } else if (keyCode === 38) {
179
+ // Up Key Controller
180
+ if (hightlightedIndex === null || hightlightedIndex === 0) {
181
+ newHightlightedIndex = lastItemIndex;
182
+ } else if (hightlightedIndex - 1 >= 0) {
183
+ newHightlightedIndex = hightlightedIndex - 1;
175
184
  }
176
- };
177
- const onKeyDown = (keyCode)=>{
178
- if (!isListVisible || !isKeyboardControlled) return false;
179
- if (keyCode === 13) {
180
- var _inputRef_current;
181
- // Enter Controller
182
- setItemAsInnerValue(null, listItems[hightlightedIndex]);
183
- setHightlightedIndex(null);
184
- inputRef === null || inputRef === void 0 ? void 0 : (_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.blur();
185
+ }
186
+
187
+ // Scroll to Element
188
+ const newHightlightedElement = listItemsElements[newHightlightedIndex];
189
+ const newHightlightedElementHeight = newHightlightedElement?.getBoundingClientRect()?.height;
190
+ const newHightlightedElementTopInList = newHightlightedElement?.offsetTop;
191
+ if (newHightlightedElementTopInList + newHightlightedElementHeight > listScrollTop + listHeight) {
192
+ if (Math.abs(newHightlightedElementTopInList + newHightlightedElementHeight - (listScrollTop + listHeight)) <= newHightlightedElementHeight) {
193
+ listRef?.current?.scrollTo(0, listScrollTop + newHightlightedElementHeight);
185
194
  } else {
186
- var _listRef_current_getBoundingClientRect, _listRef_current, _listRef_current1, _newHightlightedElement_getBoundingClientRect;
187
- let newHightlightedIndex = null;
188
- const listItemsElements = document.getElementsByClassName("input-address__list--item");
189
- const listHeight = listRef === null || listRef === void 0 ? void 0 : (_listRef_current = listRef.current) === null || _listRef_current === void 0 ? void 0 : (_listRef_current_getBoundingClientRect = _listRef_current.getBoundingClientRect()) === null || _listRef_current_getBoundingClientRect === void 0 ? void 0 : _listRef_current_getBoundingClientRect.height;
190
- const listScrollTop = (listRef === null || listRef === void 0 ? void 0 : (_listRef_current1 = listRef.current) === null || _listRef_current1 === void 0 ? void 0 : _listRef_current1.scrollTop) || 0;
191
- const lastItemIndex = parseInt(listItems === null || listItems === void 0 ? void 0 : listItems.length, 10) - 1;
192
- /** Arrows Controllers **/ if (keyCode === 40) {
193
- // Down Key Controller
194
- if (hightlightedIndex === null || hightlightedIndex === lastItemIndex) {
195
- newHightlightedIndex = 0;
196
- } else if (hightlightedIndex + 1 < (listItems === null || listItems === void 0 ? void 0 : listItems.length)) {
197
- newHightlightedIndex = hightlightedIndex + 1;
198
- }
199
- } else if (keyCode === 38) {
200
- // Up Key Controller
201
- if (hightlightedIndex === null || hightlightedIndex === 0) {
202
- newHightlightedIndex = lastItemIndex;
203
- } else if (hightlightedIndex - 1 >= 0) {
204
- newHightlightedIndex = hightlightedIndex - 1;
205
- }
206
- }
207
- // Scroll to Element
208
- const newHightlightedElement = listItemsElements[newHightlightedIndex];
209
- const newHightlightedElementHeight = newHightlightedElement === null || newHightlightedElement === void 0 ? void 0 : (_newHightlightedElement_getBoundingClientRect = newHightlightedElement.getBoundingClientRect()) === null || _newHightlightedElement_getBoundingClientRect === void 0 ? void 0 : _newHightlightedElement_getBoundingClientRect.height;
210
- const newHightlightedElementTopInList = newHightlightedElement === null || newHightlightedElement === void 0 ? void 0 : newHightlightedElement.offsetTop;
211
- if (newHightlightedElementTopInList + newHightlightedElementHeight > listScrollTop + listHeight) {
212
- if (Math.abs(newHightlightedElementTopInList + newHightlightedElementHeight - (listScrollTop + listHeight)) <= newHightlightedElementHeight) {
213
- var _listRef_current2;
214
- listRef === null || listRef === void 0 ? void 0 : (_listRef_current2 = listRef.current) === null || _listRef_current2 === void 0 ? void 0 : _listRef_current2.scrollTo(0, listScrollTop + newHightlightedElementHeight);
215
- } else {
216
- var _listRef_current3;
217
- listRef === null || listRef === void 0 ? void 0 : (_listRef_current3 = listRef.current) === null || _listRef_current3 === void 0 ? void 0 : _listRef_current3.scrollTo(0, newHightlightedElementTopInList);
218
- }
219
- } else if (newHightlightedElementTopInList < listScrollTop) {
220
- if (Math.abs(newHightlightedElementTopInList - listScrollTop) < newHightlightedElementHeight) {
221
- var _listRef_current4;
222
- listRef === null || listRef === void 0 ? void 0 : (_listRef_current4 = listRef.current) === null || _listRef_current4 === void 0 ? void 0 : _listRef_current4.scrollTo(0, listScrollTop - newHightlightedElementHeight);
223
- } else {
224
- var _listRef_current5;
225
- listRef === null || listRef === void 0 ? void 0 : (_listRef_current5 = listRef.current) === null || _listRef_current5 === void 0 ? void 0 : _listRef_current5.scrollTo(0, newHightlightedElementTopInList);
226
- }
227
- }
228
- if (!isMobile) setHightlightedIndex(newHightlightedIndex);
195
+ listRef?.current?.scrollTo(0, newHightlightedElementTopInList);
229
196
  }
230
- };
231
- const getHintMessage = ()=>{
232
- if (!renderHintMessage || typeof renderHintMessage !== "function") return DEFAULT_HINT_MESSAGE;
233
- return renderHintMessage(innerValue);
234
- };
235
- const getSelectedItemLabel = (value = innerValue)=>{
236
- var _value_street;
237
- if (!value) return "";
238
- if (typeof value === "string") return value;
239
- if (typeof renderSelectedItem === "function") renderSelectedItem(value);
240
- const label = `${(value === null || value === void 0 ? void 0 : value.streetNumber) || ""} ${(value === null || value === void 0 ? void 0 : (_value_street = value.street) === null || _value_street === void 0 ? void 0 : _value_street.fullName) || ""}`.trim();
241
- return !label && isLoading ? previousValueRef.current : label;
242
- };
243
- const getListItemLabel = (item)=>{
244
- if (typeof item === "string") return item;
245
- if (!renderListItem || typeof renderListItem !== "function") return item === null || item === void 0 ? void 0 : item.fullPrediction;
246
- return renderListItem(item);
247
- };
248
- const setListHeight = ()=>{
249
- if ((listWrapperRef === null || listWrapperRef === void 0 ? void 0 : listWrapperRef.current) && (listHeaderRef === null || listHeaderRef === void 0 ? void 0 : listHeaderRef.current) && listRef.current) {
250
- var _listWrapperRef_current_getBoundingClientRect, _listWrapperRef_current, _listHeaderRef_current_getBoundingClientRect, _listHeaderRef_current;
251
- const listWrapperHeight = listWrapperRef === null || listWrapperRef === void 0 ? void 0 : (_listWrapperRef_current = listWrapperRef.current) === null || _listWrapperRef_current === void 0 ? void 0 : (_listWrapperRef_current_getBoundingClientRect = _listWrapperRef_current.getBoundingClientRect()) === null || _listWrapperRef_current_getBoundingClientRect === void 0 ? void 0 : _listWrapperRef_current_getBoundingClientRect.height;
252
- const listWrapperStyles = getComputedStyle(listWrapperRef === null || listWrapperRef === void 0 ? void 0 : listWrapperRef.current);
253
- const listHeaderHeight = listHeaderRef === null || listHeaderRef === void 0 ? void 0 : (_listHeaderRef_current = listHeaderRef.current) === null || _listHeaderRef_current === void 0 ? void 0 : (_listHeaderRef_current_getBoundingClientRect = _listHeaderRef_current.getBoundingClientRect()) === null || _listHeaderRef_current_getBoundingClientRect === void 0 ? void 0 : _listHeaderRef_current_getBoundingClientRect.height;
254
- const listHeight = listWrapperHeight - listHeaderHeight - parseInt(listWrapperStyles.paddingBottom, 10);
255
- listRef.current.style.maxHeight = `${listHeight}px`;
256
- }
257
- };
258
- const resetListHeight = ()=>{
259
- if (listRef.current) {
260
- listRef.current.style.maxHeight = `initial`;
197
+ } else if (newHightlightedElementTopInList < listScrollTop) {
198
+ if (Math.abs(newHightlightedElementTopInList - listScrollTop) < newHightlightedElementHeight) {
199
+ listRef?.current?.scrollTo(0, listScrollTop - newHightlightedElementHeight);
200
+ } else {
201
+ listRef?.current?.scrollTo(0, newHightlightedElementTopInList);
261
202
  }
262
- };
263
- // ? Основной блок работы со значениями адреса
264
- // ? Не меняйте вызовы setInnerValue и onChange не разобравшись в логике вызовов
265
- (0, _react.useEffect)(()=>{
266
- // ? Исключение инициализации - равны только при первом рендере компонента,
267
- // ? т.к. рефка и стейт инициализируются верхним value
268
- if (!compareValues(innerValue, previousValueRef.current)) {
269
- const isObject = (0, _utils.getIsOnlyAnObject)(innerValue);
270
- // ? innerValue меняется либо от ручного ввода, либо от выбора из списка
271
- // ? Полная информация или нет - напрямую зависит от ответа getListItems
272
- const isFullInfo = isObject && "streetNumber" in innerValue && "street" in innerValue && "city" in innerValue && "state" in innerValue && "country" in innerValue && "zipCode" in innerValue;
273
- // ? Для старого эндпоинта возвращается список с полной информацией, поэтому на проектах ничего не поменяется,
274
- // ? если не менять запросник (getListItems), все будет проходить по этой if-ке или по 3-й (для строчных значений)
275
- if (isFullInfo) {
276
- onChange(innerValue);
277
- setIsLoading(false);
278
- }
279
- // ? Неполная информация может быть только в том случае, когда метод getListItems использует уже новый эндпоинт гугл-апи.
280
- // ? Предполагается, что при этом в компонент будет прокинута ф-я "уточнятель" (clarifyAddressInfo)
281
- if (isObject && !isFullInfo) {
282
- if (typeof clarifyAddressInfo === "function") {
283
- var // ? Предполагается, что clarifyAddressInfo - асинхронная ф-я, запросник уточнения опции
284
- // ? Никаких await-ов НЕ нужно (тем более что в useEffect и нельзя для нового React),
285
- // ? промис "выплюнется в пустоту", но НЕ будет отчищен до резолва, а useEffect (и итерация рендера в целом) при этом будет закончен(а)
286
- _clarifyAddressInfo_then, _clarifyAddressInfo;
287
- setIsLoading(true);
288
- (_clarifyAddressInfo = clarifyAddressInfo(innerValue)) === null || _clarifyAddressInfo === void 0 ? void 0 : (_clarifyAddressInfo_then = _clarifyAddressInfo.then) === null || _clarifyAddressInfo_then === void 0 ? void 0 : _clarifyAddressInfo_then.call(_clarifyAddressInfo, (res)=>{
289
- if (res) setInnerValue(res);
290
- else {
291
- setInnerValue(previousValueRef.current);
292
- setTimeout(()=>{
293
- inputRef.current.focus();
294
- inputRef.current.setSelectionRange(previousValueRef.current.length, previousValueRef.current.length);
295
- }, 0);
296
- }
297
- setIsLoading(false);
298
- return res;
299
- });
300
- } else setInnerValue(getSelectedItemLabel(innerValue));
301
- }
302
- // ? Кейс для строчных значений
303
- if (!isObject) {
304
- // ? Вызываем верхний onChange если innerValue есть или если нету, но это не после логики уточнения
305
- if (innerValue || !isLoading) onChange(innerValue);
306
- // ? Если innerValue есть и еще не открыт листинг - открываем
307
- if (innerValue && !isListVisible) setIsListVisible(true);
308
- // ? Если инпут сфокусирован и значение есть - запрашиваем список вариантов
309
- if (isFocused && Boolean(innerValue)) getAddressVariantsList();
203
+ }
204
+ if (!isMobile) setHightlightedIndex(newHightlightedIndex);
205
+ }
206
+ };
207
+ const getHintMessage = () => {
208
+ if (!renderHintMessage || typeof renderHintMessage !== "function") return DEFAULT_HINT_MESSAGE;
209
+ return renderHintMessage(innerValue);
210
+ };
211
+ const getSelectedItemLabel = function () {
212
+ let value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : innerValue;
213
+ if (!value) return "";
214
+ if (typeof value === "string") return value;
215
+ if (typeof renderSelectedItem === "function") renderSelectedItem(value);
216
+ const label = `${value?.streetNumber || ""} ${value?.street?.fullName || ""}`.trim();
217
+ return !label && isLoading ? previousValueRef.current : label;
218
+ };
219
+ const getListItemLabel = item => {
220
+ if (typeof item === "string") return item;
221
+ if (!renderListItem || typeof renderListItem !== "function") return item?.fullPrediction;
222
+ return renderListItem(item);
223
+ };
224
+ const setListHeight = () => {
225
+ if (listWrapperRef?.current && listHeaderRef?.current && listRef.current) {
226
+ const listWrapperHeight = listWrapperRef?.current?.getBoundingClientRect()?.height;
227
+ const listWrapperStyles = getComputedStyle(listWrapperRef?.current);
228
+ const listHeaderHeight = listHeaderRef?.current?.getBoundingClientRect()?.height;
229
+ const listHeight = listWrapperHeight - listHeaderHeight - parseInt(listWrapperStyles.paddingBottom, 10);
230
+ listRef.current.style.maxHeight = `${listHeight}px`;
231
+ }
232
+ };
233
+ const resetListHeight = () => {
234
+ if (listRef.current) {
235
+ listRef.current.style.maxHeight = `initial`;
236
+ }
237
+ };
238
+
239
+ // ? Основной блок работы со значениями адреса
240
+ // ? Не меняйте вызовы setInnerValue и onChange не разобравшись в логике вызовов
241
+ (0, _react.useEffect)(() => {
242
+ // ? Исключение инициализации - равны только при первом рендере компонента,
243
+ // ? т.к. рефка и стейт инициализируются верхним value
244
+ if (!compareValues(innerValue, previousValueRef.current)) {
245
+ const isObject = (0, _utils.getIsOnlyAnObject)(innerValue);
246
+
247
+ // ? innerValue меняется либо от ручного ввода, либо от выбора из списка
248
+ // ? Полная информация или нет - напрямую зависит от ответа getListItems
249
+ const isFullInfo = isObject && "streetNumber" in innerValue && "street" in innerValue && "city" in innerValue && "state" in innerValue && "country" in innerValue && "zipCode" in innerValue;
250
+
251
+ // ? Для старого эндпоинта возвращается список с полной информацией, поэтому на проектах ничего не поменяется,
252
+ // ? если не менять запросник (getListItems), все будет проходить по этой if-ке или по 3-й (для строчных значений)
253
+ if (isFullInfo) {
254
+ onChange(innerValue);
255
+ setIsLoading(false);
256
+ }
257
+
258
+ // ? Неполная информация может быть только в том случае, когда метод getListItems использует уже новый эндпоинт гугл-апи.
259
+ // ? Предполагается, что при этом в компонент будет прокинута ф-я "уточнятель" (clarifyAddressInfo)
260
+ if (isObject && !isFullInfo) {
261
+ if (typeof clarifyAddressInfo === "function") {
262
+ setIsLoading(true);
263
+ // ? Предполагается, что clarifyAddressInfo - асинхронная ф-я, запросник уточнения опции
264
+ // ? Никаких await-ов НЕ нужно (тем более что в useEffect и нельзя для нового React),
265
+ // ? промис "выплюнется в пустоту", но НЕ будет отчищен до резолва, а useEffect (и итерация рендера в целом) при этом будет закончен(а)
266
+ clarifyAddressInfo(innerValue)?.then?.(res => {
267
+ if (res) setInnerValue(res);else {
268
+ setInnerValue(previousValueRef.current);
269
+ setTimeout(() => {
270
+ inputRef.current.focus();
271
+ inputRef.current.setSelectionRange(previousValueRef.current.length, previousValueRef.current.length);
272
+ }, 0);
310
273
  }
274
+ setIsLoading(false);
275
+ return res;
276
+ });
311
277
  }
312
- }, [
313
- innerValue
314
- ]);
315
- (0, _react.useEffect)(()=>{
316
- if (!isFocused && !isMobile) {
317
- setIsListVisible(false);
318
- setHightlightedIndex(null);
319
- }
320
- }, [
321
- isFocused
322
- ]);
323
- (0, _react.useEffect)(()=>{
324
- if (!isListVisible) {
325
- setListItems([]);
326
- resetListHeight();
327
- }
328
- if (isMobile && isListVisible) {
329
- setTempInnerValue(innerValue);
330
- setListHeight();
331
- }
332
- }, [
333
- isListVisible
334
- ]);
335
- (0, _react.useEffect)(()=>{
336
- // ? учет изменения value сверху (верхние переназначения велью)
337
- if (!compareValues(value, innerValue)) setInnerValue(value);
338
- // ? useEffect должен быть последним, т.к. рефка меняется в рамках текущей итерации
339
- previousValueRef.current = value;
340
- }, [
341
- value
342
- ]);
343
- const renderSearchableInput = ()=>{
344
- const inputValue = getSelectedItemLabel();
345
- return /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
346
- className: (0, _classnames.default)("input-address__input-wrapper"),
347
- children: [
348
- /*#__PURE__*/ (0, _jsxruntime.jsx)(_Input.default, {
349
- ref: inputRef,
350
- testId: `inputAddress--input--key-${testId || fieldKey}`,
351
- className: (0, _classnames.default)("input-address__input", className),
352
- value: inputValue,
353
- onChange: setInnerValue,
354
- onFocus: (e)=>{
355
- setIsFocused(true);
356
- },
357
- onBlur: ()=>setIsFocused(false),
358
- onKeyDown: onKeyDown,
359
- attributesOfNativeInput: attributesOfNativeInput
360
- }),
361
- isWrongAddress && /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
362
- className: (0, _classnames.default)("input-address__alert", {
363
- "input-address__alert--visible": !isFocused
364
- }),
365
- children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Hint.default, {
366
- side: "left",
367
- hint: getHintMessage(),
368
- icon: /*#__PURE__*/ (0, _jsxruntime.jsx)(_reactfeather.AlertTriangle, {}),
369
- handleOpenType: "hover"
370
- })
371
- }),
372
- isClearable && (!isWrongAddress || isFocused) && /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
373
- className: (0, _classnames.default)("input-address__clear-query", {
374
- "input-address__clear-query--input-focused": isFocused
375
- }),
376
- children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_reactfeather.X, {
377
- onClick: onClearClick
378
- })
379
- })
380
- ]
381
- });
278
+ // ! Если сверху поменяли эндпоинт и он выдает "облегченный листинг" (айтемы с неполной инфой),
279
+ // ! и НЕ пробросили clarifyAddressInfo, то на этом кейсе велью инпута будет просто зануляться
280
+ // ! (getSelectedItemLabel вернет пустую строку если вкинуть innerValue без всей инфы)
281
+ else setInnerValue(getSelectedItemLabel(innerValue));
282
+ }
283
+
284
+ // ? Кейс для строчных значений
285
+ if (!isObject) {
286
+ // ? Вызываем верхний onChange если innerValue есть или если нету, но это не после логики уточнения
287
+ if (innerValue || !isLoading) onChange(innerValue);
288
+ // ? Если innerValue есть и еще не открыт листинг - открываем
289
+ if (innerValue && !isListVisible) setIsListVisible(true);
290
+ // ? Если инпут сфокусирован и значение есть - запрашиваем список вариантов
291
+ if (isFocused && Boolean(innerValue)) getAddressVariantsList();
292
+ }
293
+ }
294
+ }, [innerValue]);
295
+ (0, _react.useEffect)(() => {
296
+ if (!isFocused && !isMobile) {
297
+ setIsListVisible(false);
298
+ setHightlightedIndex(null);
299
+ }
300
+ }, [isFocused]);
301
+ (0, _react.useEffect)(() => {
302
+ if (!isListVisible) {
303
+ setListItems([]);
304
+ resetListHeight();
305
+ }
306
+ if (isMobile && isListVisible) {
307
+ setTempInnerValue(innerValue);
308
+ setListHeight();
309
+ }
310
+ }, [isListVisible]);
311
+ (0, _react.useEffect)(() => {
312
+ // ? учет изменения value сверху (верхние переназначения велью)
313
+ if (!compareValues(value, innerValue)) setInnerValue(value);
314
+
315
+ // ? useEffect должен быть последним, т.к. рефка меняется в рамках текущей итерации
316
+ previousValueRef.current = value;
317
+ }, [value]);
318
+ const renderSearchableInput = () => {
319
+ const inputValue = getSelectedItemLabel();
320
+ return /*#__PURE__*/_react.default.createElement("div", {
321
+ className: (0, _classnames.default)("input-address__input-wrapper")
322
+ }, /*#__PURE__*/_react.default.createElement(_Input.default, {
323
+ ref: inputRef,
324
+ testId: `inputAddress--input--key-${testId || fieldKey}`,
325
+ className: (0, _classnames.default)("input-address__input", className),
326
+ value: inputValue,
327
+ onChange: setInnerValue,
328
+ onFocus: e => {
329
+ setIsFocused(true);
330
+ },
331
+ onBlur: () => setIsFocused(false),
332
+ onKeyDown: onKeyDown,
333
+ attributesOfNativeInput: attributesOfNativeInput
334
+ }), isWrongAddress && /*#__PURE__*/_react.default.createElement("div", {
335
+ className: (0, _classnames.default)("input-address__alert", {
336
+ "input-address__alert--visible": !isFocused
337
+ })
338
+ }, /*#__PURE__*/_react.default.createElement(_Hint.default, {
339
+ side: "left",
340
+ hint: getHintMessage(),
341
+ icon: /*#__PURE__*/_react.default.createElement(_reactFeather.AlertTriangle, null),
342
+ handleOpenType: "hover"
343
+ })), isClearable && (!isWrongAddress || isFocused) && /*#__PURE__*/_react.default.createElement("div", {
344
+ className: (0, _classnames.default)("input-address__clear-query", {
345
+ "input-address__clear-query--input-focused": isFocused
346
+ })
347
+ }, /*#__PURE__*/_react.default.createElement(_reactFeather.X, {
348
+ onClick: onClearClick
349
+ })));
350
+ };
351
+ const renderInput = () => {
352
+ const inputValue = getSelectedItemLabel(isListVisible ? tempInnerValue : innerValue);
353
+ return /*#__PURE__*/_react.default.createElement("div", {
354
+ className: (0, _classnames.default)("input-address__input-wrapper")
355
+ }, /*#__PURE__*/_react.default.createElement(_Input.default, {
356
+ testId: `inputAddress--input--key-${testId || fieldKey}`,
357
+ className: (0, _classnames.default)("input-address__input", className),
358
+ value: inputValue,
359
+ onChange: setInnerValue,
360
+ onFocus: e => {
361
+ setIsListVisible(true);
362
+ e?.target?.blur();
363
+ setTimeout(() => inputRef?.current?.focus(), 200);
364
+ }
365
+ }));
366
+ };
367
+ const renderLoader = () => {
368
+ return /*#__PURE__*/_react.default.createElement("div", {
369
+ className: "input-address__list--loader"
370
+ }, loader || "Loading...");
371
+ };
372
+ const renderList = () => {
373
+ const renderListItem = (item, i) => {
374
+ return /*#__PURE__*/_react.default.createElement("div", {
375
+ key: `input-address__list-item${i}`,
376
+ className: (0, _classnames.default)("input-address__list--item", {
377
+ "input-address__list--item-hightlighted": i === hightlightedIndex
378
+ }),
379
+ onMouseDown: e => setItemAsInnerValue(e, item)
380
+ }, getListItemLabel(item));
382
381
  };
383
- const renderInput = ()=>{
384
- const inputValue = getSelectedItemLabel(isListVisible ? tempInnerValue : innerValue);
385
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
386
- className: (0, _classnames.default)("input-address__input-wrapper"),
387
- children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_Input.default, {
388
- testId: `inputAddress--input--key-${testId || fieldKey}`,
389
- className: (0, _classnames.default)("input-address__input", className),
390
- value: inputValue,
391
- onChange: setInnerValue,
392
- onFocus: (e)=>{
393
- var _e_target;
394
- setIsListVisible(true);
395
- e === null || e === void 0 ? void 0 : (_e_target = e.target) === null || _e_target === void 0 ? void 0 : _e_target.blur();
396
- setTimeout(()=>{
397
- var _inputRef_current;
398
- return inputRef === null || inputRef === void 0 ? void 0 : (_inputRef_current = inputRef.current) === null || _inputRef_current === void 0 ? void 0 : _inputRef_current.focus();
399
- }, 200);
400
- }
401
- })
402
- });
382
+ const renderListItemCustom = () => {
383
+ return /*#__PURE__*/_react.default.createElement("div", {
384
+ key: `input-address__list-item--custom`,
385
+ className: (0, _classnames.default)("input-address__list--item", "input-address__list--item-custom"),
386
+ onMouseDown: e => setItemAsInnerValue(e, getSelectedItemLabel())
387
+ }, getSelectedItemLabel(), /*#__PURE__*/_react.default.createElement(_reactFeather.AlertTriangle, null), /*#__PURE__*/_react.default.createElement("span", null, "Choose this only if your address is not listed below"));
403
388
  };
404
- const renderLoader = ()=>{
405
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
406
- className: "input-address__list--loader",
407
- children: loader || "Loading..."
408
- });
389
+ const renderNoItems = () => {
390
+ return /*#__PURE__*/_react.default.createElement("div", {
391
+ className: "input-address__list--no-items"
392
+ }, isMobile && !innerValue?.length ? "Please begin entering your address" : noItemsMessage || "No Items");
409
393
  };
410
- const renderList = ()=>{
411
- const renderListItem = (item, i)=>{
412
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
413
- className: (0, _classnames.default)("input-address__list--item", {
414
- "input-address__list--item-hightlighted": i === hightlightedIndex
415
- }),
416
- onMouseDown: (e)=>setItemAsInnerValue(e, item),
417
- children: getListItemLabel(item)
418
- }, `input-address__list-item${i}`);
419
- };
420
- const renderListItemCustom = ()=>{
421
- return /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
422
- className: (0, _classnames.default)("input-address__list--item", "input-address__list--item-custom"),
423
- onMouseDown: (e)=>setItemAsInnerValue(e, getSelectedItemLabel()),
424
- children: [
425
- getSelectedItemLabel(),
426
- /*#__PURE__*/ (0, _jsxruntime.jsx)(_reactfeather.AlertTriangle, {}),
427
- /*#__PURE__*/ (0, _jsxruntime.jsx)("span", {
428
- children: "Choose this only if your address is not listed below"
429
- })
430
- ]
431
- }, `input-address__list-item--custom`);
432
- };
433
- const renderNoItems = ()=>{
434
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
435
- className: "input-address__list--no-items",
436
- children: isMobile && !(innerValue === null || innerValue === void 0 ? void 0 : innerValue.length) ? "Please begin entering your address" : noItemsMessage || "No Items"
437
- });
438
- };
439
- const renderListDesktop = ()=>{
440
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
441
- className: "input-address__list-wrapper",
442
- ref: listWrapperRef,
443
- children: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
444
- className: "input-address__list",
445
- ref: listRef,
446
- children: isListLoading ? renderLoader() : (listItems === null || listItems === void 0 ? void 0 : listItems.length) ? listItems === null || listItems === void 0 ? void 0 : listItems.map(renderListItem) : renderNoItems()
447
- })
448
- });
449
- };
450
- const renderListMobile = ()=>{
451
- return /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
452
- className: "input-address__list-overlay",
453
- ref: listOverlayRef,
454
- onClick: onOverlayClick,
455
- children: /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
456
- className: "input-address__list-wrapper",
457
- ref: listWrapperRef,
458
- children: [
459
- isMobile && /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
460
- ref: listHeaderRef,
461
- className: (0, _classnames.default)(`${RC}__list-header`, {
462
- [`${RC}__list-header-with-shadow`]: isScrollableList && isMobile,
463
- [`${RC}__list-header-with-shadow-hidden`]: scrollTop === 0
464
- }),
465
- children: [
466
- /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
467
- className: (0, _classnames.default)(`${RC}__list-header-row`),
468
- children: [
469
- /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
470
- className: (0, _classnames.default)(`${RC}__list-label`),
471
- children: label || "Address"
472
- }),
473
- /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
474
- className: (0, _classnames.default)(`${RC}__list-close-icon`),
475
- onClick: ()=>setIsListVisible(false),
476
- children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_reactfeather.X, {
477
- onClick: ()=>setIsListVisible(false)
478
- })
479
- })
480
- ]
481
- }),
482
- /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
483
- className: (0, _classnames.default)(`${RC}__list-header-row`),
484
- children: renderSearchableInput()
485
- })
486
- ]
487
- }),
488
- /*#__PURE__*/ (0, _jsxruntime.jsx)("div", {
489
- className: "input-address__list",
490
- ref: listRef,
491
- children: isListLoading ? renderLoader() : /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {
492
- children: [
493
- getSelectedItemLabel() && renderListItemCustom(),
494
- listItems === null || listItems === void 0 ? void 0 : listItems.map(renderListItem),
495
- !(listItems === null || listItems === void 0 ? void 0 : listItems.length) && !getSelectedItemLabel() && renderNoItems()
496
- ]
497
- })
498
- })
499
- ]
500
- })
501
- });
502
- };
503
- return isMobile ? renderListMobile() : renderListDesktop();
394
+ const renderListDesktop = () => {
395
+ return /*#__PURE__*/_react.default.createElement("div", {
396
+ className: "input-address__list-wrapper",
397
+ ref: listWrapperRef
398
+ }, /*#__PURE__*/_react.default.createElement("div", {
399
+ className: "input-address__list",
400
+ ref: listRef
401
+ }, isListLoading ? renderLoader() : listItems?.length ? listItems?.map(renderListItem) : renderNoItems()));
504
402
  };
505
- return /*#__PURE__*/ (0, _jsxruntime.jsxs)("div", {
506
- className: (0, _classnames.default)("input-address", {
507
- "input-address--error": error || isWrongAddress && !isFocused
508
- }),
509
- children: [
510
- isLoading && /*#__PURE__*/ (0, _jsxruntime.jsx)(_Spinner.default, {
511
- size: "small"
512
- }),
513
- isMobile ? renderInput() : renderSearchableInput(),
514
- isListVisible && renderList()
515
- ]
516
- });
403
+ const renderListMobile = () => {
404
+ return /*#__PURE__*/_react.default.createElement("div", {
405
+ className: "input-address__list-overlay",
406
+ ref: listOverlayRef,
407
+ onClick: onOverlayClick
408
+ }, /*#__PURE__*/_react.default.createElement("div", {
409
+ className: "input-address__list-wrapper",
410
+ ref: listWrapperRef
411
+ }, isMobile && /*#__PURE__*/_react.default.createElement("div", {
412
+ ref: listHeaderRef,
413
+ className: (0, _classnames.default)(`${RC}__list-header`, {
414
+ [`${RC}__list-header-with-shadow`]: isScrollableList && isMobile,
415
+ [`${RC}__list-header-with-shadow-hidden`]: scrollTop === 0
416
+ })
417
+ }, /*#__PURE__*/_react.default.createElement("div", {
418
+ className: (0, _classnames.default)(`${RC}__list-header-row`)
419
+ }, /*#__PURE__*/_react.default.createElement("div", {
420
+ className: (0, _classnames.default)(`${RC}__list-label`)
421
+ }, label || "Address"), /*#__PURE__*/_react.default.createElement("div", {
422
+ className: (0, _classnames.default)(`${RC}__list-close-icon`),
423
+ onClick: () => setIsListVisible(false)
424
+ }, /*#__PURE__*/_react.default.createElement(_reactFeather.X, {
425
+ onClick: () => setIsListVisible(false)
426
+ }))), /*#__PURE__*/_react.default.createElement("div", {
427
+ className: (0, _classnames.default)(`${RC}__list-header-row`)
428
+ }, renderSearchableInput())), /*#__PURE__*/_react.default.createElement("div", {
429
+ className: "input-address__list",
430
+ ref: listRef
431
+ }, isListLoading ? renderLoader() : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, getSelectedItemLabel() && renderListItemCustom(), listItems?.map(renderListItem), !listItems?.length && !getSelectedItemLabel() && renderNoItems()))));
432
+ };
433
+ return isMobile ? renderListMobile() : renderListDesktop();
434
+ };
435
+ return /*#__PURE__*/_react.default.createElement("div", {
436
+ className: (0, _classnames.default)("input-address", {
437
+ "input-address--error": error || isWrongAddress && !isFocused
438
+ })
439
+ }, isLoading && /*#__PURE__*/_react.default.createElement(_Spinner.default, {
440
+ size: "small"
441
+ }), isMobile ? renderInput() : renderSearchableInput(), isListVisible && renderList());
517
442
  };
518
- const _default = InputAddress;
443
+ var _default = exports.default = InputAddress;