@skbkontur/react-ui 0.0.0-8824ede9eb → 0.0.0-8ea1692541

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 (708) hide show
  1. package/CHANGELOG.md +58 -0
  2. package/cjs/components/Autocomplete/Autocomplete.d.ts +9 -17
  3. package/cjs/components/Autocomplete/Autocomplete.js +13 -7
  4. package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
  5. package/cjs/components/Button/Button.d.ts +4 -5
  6. package/cjs/components/Button/Button.js +8 -3
  7. package/cjs/components/Button/Button.js.map +1 -1
  8. package/cjs/components/Button/Button.mixins.js +1 -1
  9. package/cjs/components/Button/Button.mixins.js.map +1 -1
  10. package/cjs/components/Button/Button.styles.js +18 -18
  11. package/cjs/components/Button/Button.styles.js.map +1 -1
  12. package/cjs/components/Center/Center.d.ts +4 -3
  13. package/cjs/components/Center/Center.js +9 -3
  14. package/cjs/components/Center/Center.js.map +1 -1
  15. package/cjs/components/Checkbox/Checkbox.js +4 -2
  16. package/cjs/components/Checkbox/Checkbox.js.map +1 -1
  17. package/cjs/components/Checkbox/Checkbox.md +48 -0
  18. package/cjs/components/Checkbox/Checkbox.styles.d.ts +1 -1
  19. package/cjs/components/Checkbox/Checkbox.styles.js +1 -1
  20. package/cjs/components/Checkbox/Checkbox.styles.js.map +1 -1
  21. package/cjs/components/ComboBox/ComboBox.d.ts +8 -13
  22. package/cjs/components/ComboBox/ComboBox.js +12 -2
  23. package/cjs/components/ComboBox/ComboBox.js.map +1 -1
  24. package/cjs/components/CurrencyInput/CurrencyInput.d.ts +6 -9
  25. package/cjs/components/CurrencyInput/CurrencyInput.js +25 -10
  26. package/cjs/components/CurrencyInput/CurrencyInput.js.map +1 -1
  27. package/cjs/components/CurrencyInput/CurrencyInputKeyboardActions.d.ts +3 -1
  28. package/cjs/components/CurrencyInput/CurrencyInputKeyboardActions.js +14 -2
  29. package/cjs/components/CurrencyInput/CurrencyInputKeyboardActions.js.map +1 -1
  30. package/cjs/components/CurrencyLabel/CurrencyLabel.d.ts +3 -9
  31. package/cjs/components/CurrencyLabel/CurrencyLabel.js +15 -15
  32. package/cjs/components/CurrencyLabel/CurrencyLabel.js.map +1 -1
  33. package/cjs/components/DateInput/DateFragmentsView.d.ts +1 -1
  34. package/cjs/components/DateInput/DateFragmentsView.js +10 -1
  35. package/cjs/components/DateInput/DateFragmentsView.js.map +1 -1
  36. package/cjs/components/DateInput/DateInput.d.ts +9 -12
  37. package/cjs/components/DateInput/DateInput.js +11 -3
  38. package/cjs/components/DateInput/DateInput.js.map +1 -1
  39. package/cjs/components/DateInput/helpers/DateInputKeyboardActions.js +1 -2
  40. package/cjs/components/DateInput/helpers/DateInputKeyboardActions.js.map +1 -1
  41. package/cjs/components/DateInput/helpers/SelectionHelpers.js +2 -2
  42. package/cjs/components/DateInput/helpers/SelectionHelpers.js.map +1 -1
  43. package/cjs/components/DatePicker/DatePicker.d.ts +7 -9
  44. package/cjs/components/DatePicker/DatePicker.js +23 -9
  45. package/cjs/components/DatePicker/DatePicker.js.map +1 -1
  46. package/cjs/components/DatePicker/Picker.js +5 -1
  47. package/cjs/components/DatePicker/Picker.js.map +1 -1
  48. package/cjs/components/DropdownMenu/DropdownMenu.d.ts +5 -5
  49. package/cjs/components/DropdownMenu/DropdownMenu.js +9 -3
  50. package/cjs/components/DropdownMenu/DropdownMenu.js.map +1 -1
  51. package/cjs/components/FileUploader/FileUploader.js +2 -2
  52. package/cjs/components/FileUploader/FileUploader.js.map +1 -1
  53. package/cjs/components/FileUploader/FileUploader.md +8 -1
  54. package/cjs/components/FxInput/FxInput.d.ts +6 -6
  55. package/cjs/components/FxInput/FxInput.js +16 -11
  56. package/cjs/components/FxInput/FxInput.js.map +1 -1
  57. package/cjs/components/Gapped/Gapped.d.ts +7 -8
  58. package/cjs/components/Gapped/Gapped.js +12 -6
  59. package/cjs/components/Gapped/Gapped.js.map +1 -1
  60. package/cjs/components/GlobalLoader/GlobalLoader.d.ts +7 -14
  61. package/cjs/components/GlobalLoader/GlobalLoader.js +13 -9
  62. package/cjs/components/GlobalLoader/GlobalLoader.js.map +1 -1
  63. package/cjs/components/GlobalLoader/GlobalLoaderView.d.ts +2 -2
  64. package/cjs/components/GlobalLoader/GlobalLoaderView.js.map +1 -1
  65. package/cjs/components/Hint/Hint.d.ts +8 -12
  66. package/cjs/components/Hint/Hint.js +15 -5
  67. package/cjs/components/Hint/Hint.js.map +1 -1
  68. package/cjs/components/Hint/Hint.md +14 -0
  69. package/cjs/components/Input/Input.d.ts +4 -3
  70. package/cjs/components/Input/Input.js +10 -5
  71. package/cjs/components/Input/Input.js.map +1 -1
  72. package/cjs/components/Input/Input.md +5 -1
  73. package/cjs/components/Kebab/Kebab.d.ts +8 -15
  74. package/cjs/components/Kebab/Kebab.js +14 -5
  75. package/cjs/components/Kebab/Kebab.js.map +1 -1
  76. package/cjs/components/Link/Link.d.ts +5 -7
  77. package/cjs/components/Link/Link.js +12 -5
  78. package/cjs/components/Link/Link.js.map +1 -1
  79. package/cjs/components/Loader/Loader.d.ts +9 -5
  80. package/cjs/components/Loader/Loader.js +15 -4
  81. package/cjs/components/Loader/Loader.js.map +1 -1
  82. package/cjs/components/Loader/__stories__/LoaderAndButton.js +6 -0
  83. package/cjs/components/Loader/__stories__/LoaderAndButton.js.map +1 -1
  84. package/cjs/components/MenuItem/MenuItem.js +3 -1
  85. package/cjs/components/MenuItem/MenuItem.js.map +1 -1
  86. package/cjs/components/Modal/Modal.d.ts +4 -3
  87. package/cjs/components/Modal/Modal.js +9 -4
  88. package/cjs/components/Modal/Modal.js.map +1 -1
  89. package/cjs/components/Modal/Modal.styles.d.ts +2 -2
  90. package/cjs/components/Modal/Modal.styles.js +2 -2
  91. package/cjs/components/Modal/Modal.styles.js.map +1 -1
  92. package/cjs/components/Modal/ModalBody.js +2 -2
  93. package/cjs/components/Modal/ModalBody.js.map +1 -1
  94. package/cjs/components/Modal/ModalFooter.js +1 -1
  95. package/cjs/components/Modal/ModalFooter.js.map +1 -1
  96. package/cjs/components/Modal/ModalHeader.js +1 -1
  97. package/cjs/components/Modal/ModalHeader.js.map +1 -1
  98. package/cjs/components/Paging/Paging.d.ts +7 -10
  99. package/cjs/components/Paging/Paging.js +16 -6
  100. package/cjs/components/Paging/Paging.js.map +1 -1
  101. package/cjs/components/Paging/PagingDefaultComponent.d.ts +3 -3
  102. package/cjs/components/Paging/PagingDefaultComponent.js.map +1 -1
  103. package/cjs/components/PasswordInput/PasswordInput.d.ts +4 -3
  104. package/cjs/components/PasswordInput/PasswordInput.js +14 -7
  105. package/cjs/components/PasswordInput/PasswordInput.js.map +1 -1
  106. package/cjs/components/Radio/Radio.d.ts +4 -3
  107. package/cjs/components/Radio/Radio.js +11 -4
  108. package/cjs/components/Radio/Radio.js.map +1 -1
  109. package/cjs/components/RadioGroup/RadioGroup.d.ts +2 -4
  110. package/cjs/components/RadioGroup/RadioGroup.js +4 -2
  111. package/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  112. package/cjs/components/ResponsiveLayout/ResponsiveLayoutEvents.js +2 -2
  113. package/cjs/components/ResponsiveLayout/ResponsiveLayoutEvents.js.map +1 -1
  114. package/cjs/components/ScrollContainer/ScrollContainer.d.ts +7 -8
  115. package/cjs/components/ScrollContainer/ScrollContainer.helpers.js +4 -4
  116. package/cjs/components/ScrollContainer/ScrollContainer.helpers.js.map +1 -1
  117. package/cjs/components/ScrollContainer/ScrollContainer.js +12 -6
  118. package/cjs/components/ScrollContainer/ScrollContainer.js.map +1 -1
  119. package/cjs/components/Select/Item.d.ts +4 -2
  120. package/cjs/components/Select/Item.js +3 -0
  121. package/cjs/components/Select/Item.js.map +1 -1
  122. package/cjs/components/Select/Select.d.ts +3 -12
  123. package/cjs/components/Select/Select.js +8 -1
  124. package/cjs/components/Select/Select.js.map +1 -1
  125. package/cjs/components/Select/Select.styles.js +4 -4
  126. package/cjs/components/Select/Select.styles.js.map +1 -1
  127. package/cjs/components/SidePage/SidePage.d.ts +5 -6
  128. package/cjs/components/SidePage/SidePage.js +8 -1
  129. package/cjs/components/SidePage/SidePage.js.map +1 -1
  130. package/cjs/components/SidePage/SidePageFooter.d.ts +6 -4
  131. package/cjs/components/SidePage/SidePageFooter.js +4 -0
  132. package/cjs/components/SidePage/SidePageFooter.js.map +1 -1
  133. package/cjs/components/Spinner/Spinner.d.ts +4 -2
  134. package/cjs/components/Spinner/Spinner.js +10 -4
  135. package/cjs/components/Spinner/Spinner.js.map +1 -1
  136. package/cjs/components/Spinner/Spinner.styles.d.ts +1 -1
  137. package/cjs/components/Spinner/Spinner.styles.js +7 -7
  138. package/cjs/components/Spinner/Spinner.styles.js.map +1 -1
  139. package/cjs/components/Sticky/Sticky.d.ts +5 -4
  140. package/cjs/components/Sticky/Sticky.js +9 -2
  141. package/cjs/components/Sticky/Sticky.js.map +1 -1
  142. package/cjs/components/Tabs/Indicator.d.ts +1 -1
  143. package/cjs/components/Tabs/Indicator.js +1 -1
  144. package/cjs/components/Tabs/Indicator.js.map +1 -1
  145. package/cjs/components/Tabs/Tab.d.ts +4 -4
  146. package/cjs/components/Tabs/Tab.js +11 -13
  147. package/cjs/components/Tabs/Tab.js.map +1 -1
  148. package/cjs/components/Tabs/Tabs.d.ts +4 -4
  149. package/cjs/components/Tabs/Tabs.js +12 -3
  150. package/cjs/components/Tabs/Tabs.js.map +1 -1
  151. package/cjs/components/Textarea/Textarea.d.ts +8 -10
  152. package/cjs/components/Textarea/Textarea.js +13 -7
  153. package/cjs/components/Textarea/Textarea.js.map +1 -1
  154. package/cjs/components/Textarea/TextareaCounter.d.ts +2 -2
  155. package/cjs/components/Textarea/TextareaCounter.js.map +1 -1
  156. package/cjs/components/Toast/Toast.js +1 -1
  157. package/cjs/components/Toast/Toast.js.map +1 -1
  158. package/cjs/components/Toggle/Toggle.d.ts +5 -6
  159. package/cjs/components/Toggle/Toggle.js +10 -4
  160. package/cjs/components/Toggle/Toggle.js.map +1 -1
  161. package/cjs/components/TokenInput/TokenInput.d.ts +19 -16
  162. package/cjs/components/TokenInput/TokenInput.js +76 -59
  163. package/cjs/components/TokenInput/TokenInput.js.map +1 -1
  164. package/cjs/components/TokenInput/TokenInputMenu.d.ts +2 -1
  165. package/cjs/components/TokenInput/TokenInputMenu.js +1 -1
  166. package/cjs/components/TokenInput/TokenInputMenu.js.map +1 -1
  167. package/cjs/components/Tooltip/Tooltip.d.ts +13 -19
  168. package/cjs/components/Tooltip/Tooltip.js +27 -24
  169. package/cjs/components/Tooltip/Tooltip.js.map +1 -1
  170. package/cjs/components/TooltipMenu/TooltipMenu.d.ts +6 -5
  171. package/cjs/components/TooltipMenu/TooltipMenu.js +11 -5
  172. package/cjs/components/TooltipMenu/TooltipMenu.js.map +1 -1
  173. package/cjs/hooks/useEffectWithoutInitCall.d.ts +2 -2
  174. package/cjs/hooks/useEffectWithoutInitCall.js +2 -2
  175. package/cjs/hooks/useEffectWithoutInitCall.js.map +1 -1
  176. package/cjs/hooks/useMemoObject.d.ts +2 -1
  177. package/cjs/hooks/useMemoObject.js +2 -0
  178. package/cjs/hooks/useMemoObject.js.map +1 -1
  179. package/cjs/internal/BGRuler.d.ts +13 -15
  180. package/cjs/internal/BGRuler.js +16 -8
  181. package/cjs/internal/BGRuler.js.map +1 -1
  182. package/cjs/internal/Calendar/Calendar.d.ts +4 -13
  183. package/cjs/internal/Calendar/Calendar.js +10 -5
  184. package/cjs/internal/Calendar/Calendar.js.map +1 -1
  185. package/cjs/internal/Calendar/DayCellView.styles.js +1 -1
  186. package/cjs/internal/Calendar/DayCellView.styles.js.map +1 -1
  187. package/cjs/internal/Calendar/Month.js +16 -11
  188. package/cjs/internal/Calendar/Month.js.map +1 -1
  189. package/cjs/internal/Calendar/MonthViewModel.d.ts +1 -1
  190. package/cjs/internal/Calendar/config.d.ts +1 -8
  191. package/cjs/internal/CommonWrapper/CommonWrapper.d.ts +1 -1
  192. package/cjs/internal/CommonWrapper/CommonWrapper.js +5 -4
  193. package/cjs/internal/CommonWrapper/CommonWrapper.js.map +1 -1
  194. package/cjs/internal/ComponentCombinator.d.ts +6 -8
  195. package/cjs/internal/ComponentCombinator.js +6 -2
  196. package/cjs/internal/ComponentCombinator.js.map +1 -1
  197. package/cjs/internal/ComponentTable.d.ts +7 -8
  198. package/cjs/internal/ComponentTable.js +14 -3
  199. package/cjs/internal/ComponentTable.js.map +1 -1
  200. package/cjs/internal/CustomComboBox/ComboBoxMenu.d.ts +6 -6
  201. package/cjs/internal/CustomComboBox/ComboBoxMenu.js +14 -8
  202. package/cjs/internal/CustomComboBox/ComboBoxMenu.js.map +1 -1
  203. package/cjs/internal/CustomComboBox/ComboBoxView.d.ts +4 -12
  204. package/cjs/internal/CustomComboBox/ComboBoxView.js +18 -10
  205. package/cjs/internal/CustomComboBox/ComboBoxView.js.map +1 -1
  206. package/cjs/internal/CustomComboBox/CustomComboBoxReducer.js +4 -5
  207. package/cjs/internal/CustomComboBox/CustomComboBoxReducer.js.map +1 -1
  208. package/cjs/internal/DataTids/DataTids.d.ts +5 -5
  209. package/cjs/internal/DataTids/DataTids.js +4 -0
  210. package/cjs/internal/DataTids/DataTids.js.map +1 -1
  211. package/cjs/internal/DateSelect/DateSelect.d.ts +4 -6
  212. package/cjs/internal/DateSelect/DateSelect.js +16 -10
  213. package/cjs/internal/DateSelect/DateSelect.js.map +1 -1
  214. package/cjs/internal/DropdownContainer/DropdownContainer.d.ts +4 -7
  215. package/cjs/internal/DropdownContainer/DropdownContainer.js +8 -5
  216. package/cjs/internal/DropdownContainer/DropdownContainer.js.map +1 -1
  217. package/cjs/internal/FileUploaderControl/withFileUploaderControlProvider.d.ts +1 -1
  218. package/cjs/internal/FileUploaderControl/withFileUploaderControlProvider.js.map +1 -1
  219. package/cjs/internal/HideBodyVerticalScroll/HideBodyVerticalScroll.js +2 -1
  220. package/cjs/internal/HideBodyVerticalScroll/HideBodyVerticalScroll.js.map +1 -1
  221. package/cjs/internal/InputLikeText/InputLikeText.d.ts +4 -3
  222. package/cjs/internal/InputLikeText/InputLikeText.js +11 -4
  223. package/cjs/internal/InputLikeText/InputLikeText.js.map +1 -1
  224. package/cjs/internal/InternalMenu/InternalMenu.d.ts +3 -9
  225. package/cjs/internal/InternalMenu/InternalMenu.js +36 -14
  226. package/cjs/internal/InternalMenu/InternalMenu.js.map +1 -1
  227. package/cjs/internal/InternalMenu/InternalMenu.styles.js +2 -1
  228. package/cjs/internal/InternalMenu/InternalMenu.styles.js.map +1 -1
  229. package/cjs/internal/MaskedInput/MaskedInput.d.ts +5 -2
  230. package/cjs/internal/MaskedInput/MaskedInput.js +20 -7
  231. package/cjs/internal/MaskedInput/MaskedInput.js.map +1 -1
  232. package/cjs/internal/Menu/Menu.d.ts +4 -7
  233. package/cjs/internal/Menu/Menu.js +14 -4
  234. package/cjs/internal/Menu/Menu.js.map +1 -1
  235. package/cjs/internal/MobilePopup/MobilePopup.js +1 -1
  236. package/cjs/internal/MobilePopup/MobilePopup.js.map +1 -1
  237. package/cjs/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.js +1 -1
  238. package/cjs/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.js.map +1 -1
  239. package/cjs/internal/PerformanceMetrics/PerformanceMetrics.js.map +1 -1
  240. package/cjs/internal/Popup/Popup.d.ts +11 -17
  241. package/cjs/internal/Popup/Popup.js +38 -19
  242. package/cjs/internal/Popup/Popup.js.map +1 -1
  243. package/cjs/internal/Popup/PopupHelper.d.ts +1 -1
  244. package/cjs/internal/Popup/PopupHelper.js.map +1 -1
  245. package/cjs/internal/Popup/PopupPin.d.ts +1 -1
  246. package/cjs/internal/Popup/PopupPin.js.map +1 -1
  247. package/cjs/internal/PopupMenu/PopupMenu.d.ts +8 -11
  248. package/cjs/internal/PopupMenu/PopupMenu.js +8 -1
  249. package/cjs/internal/PopupMenu/PopupMenu.js.map +1 -1
  250. package/cjs/internal/RenderLayer/RenderLayer.d.ts +6 -4
  251. package/cjs/internal/RenderLayer/RenderLayer.js +15 -4
  252. package/cjs/internal/RenderLayer/RenderLayer.js.map +1 -1
  253. package/cjs/internal/ThemePlayground/AnotherInputsPlayground.d.ts +11 -6
  254. package/cjs/internal/ThemePlayground/AnotherInputsPlayground.js +7 -0
  255. package/cjs/internal/ThemePlayground/AnotherInputsPlayground.js.map +1 -1
  256. package/cjs/internal/ThemePlayground/CurrencyInputPlayground.d.ts +7 -6
  257. package/cjs/internal/ThemePlayground/CurrencyInputPlayground.js +2 -3
  258. package/cjs/internal/ThemePlayground/CurrencyInputPlayground.js.map +1 -1
  259. package/cjs/internal/ThemePlayground/FxInputPlayground.d.ts +6 -4
  260. package/cjs/internal/ThemePlayground/FxInputPlayground.js +5 -5
  261. package/cjs/internal/ThemePlayground/FxInputPlayground.js.map +1 -1
  262. package/cjs/internal/ThemePlayground/HintPlayground.d.ts +1 -1
  263. package/cjs/internal/ThemePlayground/HintPlayground.js.map +1 -1
  264. package/cjs/internal/ThemePlayground/PagingPlayground.d.ts +6 -6
  265. package/cjs/internal/ThemePlayground/PagingPlayground.js +5 -2
  266. package/cjs/internal/ThemePlayground/PagingPlayground.js.map +1 -1
  267. package/cjs/internal/ThemePlayground/Playground.d.ts +1 -1
  268. package/cjs/internal/ThemePlayground/Playground.js.map +1 -1
  269. package/cjs/internal/ThemePlayground/SelectPlayground.d.ts +9 -6
  270. package/cjs/internal/ThemePlayground/SelectPlayground.js +6 -0
  271. package/cjs/internal/ThemePlayground/SelectPlayground.js.map +1 -1
  272. package/cjs/internal/ThemePlayground/SizesGroup.d.ts +2 -2
  273. package/cjs/internal/ThemePlayground/SizesGroup.js +2 -0
  274. package/cjs/internal/ThemePlayground/SizesGroup.js.map +1 -1
  275. package/cjs/internal/ThemePlayground/SwitcherPlayground.d.ts +9 -8
  276. package/cjs/internal/ThemePlayground/SwitcherPlayground.js +6 -1
  277. package/cjs/internal/ThemePlayground/SwitcherPlayground.js.map +1 -1
  278. package/cjs/internal/ThemePlayground/ThemeContextPlayground.js +14 -4
  279. package/cjs/internal/ThemePlayground/ThemeContextPlayground.js.map +1 -1
  280. package/cjs/internal/ThemePlayground/ThemeEditor.d.ts +1 -4
  281. package/cjs/internal/ThemePlayground/ThemeEditor.js.map +1 -1
  282. package/cjs/internal/ThemePlayground/TogglePlayground.d.ts +2 -7
  283. package/cjs/internal/ThemePlayground/TogglePlayground.js +4 -10
  284. package/cjs/internal/ThemePlayground/TogglePlayground.js.map +1 -1
  285. package/cjs/internal/ThemePlayground/TokenInputPlayground.d.ts +6 -4
  286. package/cjs/internal/ThemePlayground/TokenInputPlayground.js +3 -0
  287. package/cjs/internal/ThemePlayground/TokenInputPlayground.js.map +1 -1
  288. package/cjs/internal/ThemePlayground/VariableValue.d.ts +6 -8
  289. package/cjs/internal/ThemePlayground/VariableValue.js +6 -1
  290. package/cjs/internal/ThemePlayground/VariableValue.js.map +1 -1
  291. package/cjs/internal/ThemePlayground/helpers.d.ts +1 -1
  292. package/cjs/internal/ThemePlayground/helpers.js +4 -2
  293. package/cjs/internal/ThemePlayground/helpers.js.map +1 -1
  294. package/cjs/internal/ThemeShowcase/ThemeShowcase.js.map +1 -1
  295. package/cjs/internal/ZIndex/ZIndex.d.ts +7 -11
  296. package/cjs/internal/ZIndex/ZIndex.js +7 -7
  297. package/cjs/internal/ZIndex/ZIndex.js.map +1 -1
  298. package/cjs/internal/themes/DefaultTheme.js +1 -1
  299. package/cjs/internal/themes/DefaultTheme.js.map +1 -1
  300. package/cjs/lib/ConditionalHandler.js.map +1 -1
  301. package/cjs/lib/InstanceWithAnchorElement.d.ts +1 -1
  302. package/cjs/lib/InstanceWithAnchorElement.js.map +1 -1
  303. package/cjs/lib/ModalStack.js +2 -2
  304. package/cjs/lib/ModalStack.js.map +1 -1
  305. package/cjs/lib/SSRSafe.d.ts +2 -1
  306. package/cjs/lib/SSRSafe.js +9 -1
  307. package/cjs/lib/SSRSafe.js.map +1 -1
  308. package/cjs/lib/animation/index.js +1 -0
  309. package/cjs/lib/animation/index.js.map +1 -1
  310. package/cjs/lib/callChildRef/callChildRef.js +1 -1
  311. package/cjs/lib/callChildRef/callChildRef.js.map +1 -1
  312. package/cjs/lib/createPropsGetter.d.ts +2 -1
  313. package/cjs/lib/createPropsGetter.js +3 -0
  314. package/cjs/lib/createPropsGetter.js.map +1 -1
  315. package/cjs/lib/date/InternalDateCalculator.d.ts +1 -1
  316. package/cjs/lib/date/InternalDateCalculator.js +1 -1
  317. package/cjs/lib/date/InternalDateCalculator.js.map +1 -1
  318. package/cjs/lib/date/InternalDateValidator.d.ts +1 -1
  319. package/cjs/lib/date/InternalDateValidator.js +9 -2
  320. package/cjs/lib/date/InternalDateValidator.js.map +1 -1
  321. package/cjs/lib/extractKeyboardAction.d.ts +1 -1
  322. package/cjs/lib/extractKeyboardAction.js.map +1 -1
  323. package/cjs/lib/filterProps.js +0 -1
  324. package/cjs/lib/filterProps.js.map +1 -1
  325. package/cjs/lib/listenFocusOutside.d.ts +1 -1
  326. package/cjs/lib/listenFocusOutside.js.map +1 -1
  327. package/cjs/lib/locale/useLocaleForControl.d.ts +1 -1
  328. package/cjs/lib/locale/useLocaleForControl.js.map +1 -1
  329. package/cjs/lib/memo.d.ts +3 -1
  330. package/cjs/lib/memo.js +3 -3
  331. package/cjs/lib/memo.js.map +1 -1
  332. package/cjs/lib/net/fetch.js +2 -2
  333. package/cjs/lib/net/fetch.js.map +1 -1
  334. package/cjs/lib/reactGetTextContent.js +0 -1
  335. package/cjs/lib/reactGetTextContent.js.map +1 -1
  336. package/cjs/lib/rootNode/getRootNode.d.ts +3 -3
  337. package/cjs/lib/rootNode/getRootNode.js +7 -7
  338. package/cjs/lib/rootNode/getRootNode.js.map +1 -1
  339. package/cjs/lib/rootNode/rootNodeDecorator.d.ts +9 -9
  340. package/cjs/lib/rootNode/rootNodeDecorator.js.map +1 -1
  341. package/cjs/lib/styles/ColorFactory.js +2 -2
  342. package/cjs/lib/styles/ColorFactory.js.map +1 -1
  343. package/cjs/lib/styles/ColorFunctions.js.map +1 -1
  344. package/cjs/lib/theming/AnimationKeyframes.d.ts +3 -5
  345. package/cjs/lib/theming/AnimationKeyframes.js +8 -22
  346. package/cjs/lib/theming/AnimationKeyframes.js.map +1 -1
  347. package/cjs/lib/theming/Emotion.js +1 -0
  348. package/cjs/lib/theming/Emotion.js.map +1 -1
  349. package/cjs/lib/theming/ThemeFactory.d.ts +1 -1
  350. package/cjs/lib/theming/ThemeFactory.js +3 -1
  351. package/cjs/lib/theming/ThemeFactory.js.map +1 -1
  352. package/cjs/lib/theming/ThemeHelpers.d.ts +2 -2
  353. package/cjs/lib/theming/ThemeHelpers.js +1 -1
  354. package/cjs/lib/theming/ThemeHelpers.js.map +1 -1
  355. package/cjs/lib/utils.d.ts +3 -1
  356. package/cjs/lib/utils.js +5 -2
  357. package/cjs/lib/utils.js.map +1 -1
  358. package/cjs/lib/withClassWrapper.js +1 -4
  359. package/cjs/lib/withClassWrapper.js.map +1 -1
  360. package/cjs/typings/event-types.d.ts +2 -2
  361. package/components/Autocomplete/Autocomplete/Autocomplete.js +26 -13
  362. package/components/Autocomplete/Autocomplete/Autocomplete.js.map +1 -1
  363. package/components/Autocomplete/Autocomplete.d.ts +9 -17
  364. package/components/Button/Button/Button.js +11 -5
  365. package/components/Button/Button/Button.js.map +1 -1
  366. package/components/Button/Button.d.ts +4 -5
  367. package/components/Button/Button.mixins/Button.mixins.js +1 -1
  368. package/components/Button/Button.mixins/Button.mixins.js.map +1 -1
  369. package/components/Button/Button.styles/Button.styles.js +18 -18
  370. package/components/Button/Button.styles/Button.styles.js.map +1 -1
  371. package/components/Center/Center/Center.js +7 -5
  372. package/components/Center/Center/Center.js.map +1 -1
  373. package/components/Center/Center.d.ts +4 -3
  374. package/components/Checkbox/Checkbox/Checkbox.js +5 -2
  375. package/components/Checkbox/Checkbox/Checkbox.js.map +1 -1
  376. package/components/Checkbox/Checkbox.md +48 -0
  377. package/components/Checkbox/Checkbox.styles/Checkbox.styles.js +1 -1
  378. package/components/Checkbox/Checkbox.styles/Checkbox.styles.js.map +1 -1
  379. package/components/Checkbox/Checkbox.styles.d.ts +1 -1
  380. package/components/ComboBox/ComboBox/ComboBox.js +3 -1
  381. package/components/ComboBox/ComboBox/ComboBox.js.map +1 -1
  382. package/components/ComboBox/ComboBox.d.ts +8 -13
  383. package/components/CurrencyInput/CurrencyInput/CurrencyInput.js +36 -21
  384. package/components/CurrencyInput/CurrencyInput/CurrencyInput.js.map +1 -1
  385. package/components/CurrencyInput/CurrencyInput.d.ts +6 -9
  386. package/components/CurrencyInput/CurrencyInputKeyboardActions/CurrencyInputKeyboardActions.js +4 -2
  387. package/components/CurrencyInput/CurrencyInputKeyboardActions/CurrencyInputKeyboardActions.js.map +1 -1
  388. package/components/CurrencyInput/CurrencyInputKeyboardActions.d.ts +3 -1
  389. package/components/CurrencyLabel/CurrencyLabel/CurrencyLabel.js +21 -15
  390. package/components/CurrencyLabel/CurrencyLabel/CurrencyLabel.js.map +1 -1
  391. package/components/CurrencyLabel/CurrencyLabel.d.ts +3 -9
  392. package/components/DateInput/DateFragmentsView/DateFragmentsView.js +11 -1
  393. package/components/DateInput/DateFragmentsView/DateFragmentsView.js.map +1 -1
  394. package/components/DateInput/DateFragmentsView.d.ts +1 -1
  395. package/components/DateInput/DateInput/DateInput.js +18 -5
  396. package/components/DateInput/DateInput/DateInput.js.map +1 -1
  397. package/components/DateInput/DateInput.d.ts +9 -12
  398. package/components/DateInput/helpers/DateInputKeyboardActions/DateInputKeyboardActions.js +0 -1
  399. package/components/DateInput/helpers/DateInputKeyboardActions/DateInputKeyboardActions.js.map +1 -1
  400. package/components/DateInput/helpers/SelectionHelpers/SelectionHelpers.js +2 -2
  401. package/components/DateInput/helpers/SelectionHelpers/SelectionHelpers.js.map +1 -1
  402. package/components/DatePicker/DatePicker/DatePicker.js +25 -21
  403. package/components/DatePicker/DatePicker/DatePicker.js.map +1 -1
  404. package/components/DatePicker/DatePicker.d.ts +7 -9
  405. package/components/DatePicker/Picker/Picker.js +5 -1
  406. package/components/DatePicker/Picker/Picker.js.map +1 -1
  407. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js +8 -2
  408. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js.map +1 -1
  409. package/components/DropdownMenu/DropdownMenu.d.ts +5 -5
  410. package/components/FileUploader/FileUploader/FileUploader.js +2 -2
  411. package/components/FileUploader/FileUploader/FileUploader.js.map +1 -1
  412. package/components/FileUploader/FileUploader.md +8 -1
  413. package/components/FxInput/FxInput/FxInput.js +15 -10
  414. package/components/FxInput/FxInput/FxInput.js.map +1 -1
  415. package/components/FxInput/FxInput.d.ts +6 -6
  416. package/components/Gapped/Gapped/Gapped.js +17 -8
  417. package/components/Gapped/Gapped/Gapped.js.map +1 -1
  418. package/components/Gapped/Gapped.d.ts +7 -8
  419. package/components/GlobalLoader/GlobalLoader/GlobalLoader.js +35 -16
  420. package/components/GlobalLoader/GlobalLoader/GlobalLoader.js.map +1 -1
  421. package/components/GlobalLoader/GlobalLoader.d.ts +7 -14
  422. package/components/GlobalLoader/GlobalLoaderView/GlobalLoaderView.js.map +1 -1
  423. package/components/GlobalLoader/GlobalLoaderView.d.ts +2 -2
  424. package/components/Hint/Hint/Hint.js +30 -18
  425. package/components/Hint/Hint/Hint.js.map +1 -1
  426. package/components/Hint/Hint.d.ts +8 -12
  427. package/components/Hint/Hint.md +14 -0
  428. package/components/Input/Input/Input.js +13 -8
  429. package/components/Input/Input/Input.js.map +1 -1
  430. package/components/Input/Input.d.ts +4 -3
  431. package/components/Input/Input.md +5 -1
  432. package/components/Kebab/Kebab/Kebab.js +19 -8
  433. package/components/Kebab/Kebab/Kebab.js.map +1 -1
  434. package/components/Kebab/Kebab.d.ts +8 -15
  435. package/components/Link/Link/Link.js +10 -7
  436. package/components/Link/Link/Link.js.map +1 -1
  437. package/components/Link/Link.d.ts +5 -7
  438. package/components/Loader/Loader/Loader.js +22 -17
  439. package/components/Loader/Loader/Loader.js.map +1 -1
  440. package/components/Loader/Loader.d.ts +9 -5
  441. package/components/Loader/__stories__/LoaderAndButton/LoaderAndButton.js.map +1 -1
  442. package/components/MenuItem/MenuItem/MenuItem.js +4 -1
  443. package/components/MenuItem/MenuItem/MenuItem.js.map +1 -1
  444. package/components/Modal/Modal/Modal.js +5 -3
  445. package/components/Modal/Modal/Modal.js.map +1 -1
  446. package/components/Modal/Modal.d.ts +4 -3
  447. package/components/Modal/Modal.styles/Modal.styles.js +2 -2
  448. package/components/Modal/Modal.styles/Modal.styles.js.map +1 -1
  449. package/components/Modal/Modal.styles.d.ts +2 -2
  450. package/components/Modal/ModalBody/ModalBody.js +2 -2
  451. package/components/Modal/ModalBody/ModalBody.js.map +1 -1
  452. package/components/Modal/ModalFooter/ModalFooter.js +2 -2
  453. package/components/Modal/ModalFooter/ModalFooter.js.map +1 -1
  454. package/components/Modal/ModalHeader/ModalHeader.js +2 -2
  455. package/components/Modal/ModalHeader/ModalHeader.js.map +1 -1
  456. package/components/Paging/Paging/Paging.js +25 -15
  457. package/components/Paging/Paging/Paging.js.map +1 -1
  458. package/components/Paging/Paging.d.ts +7 -10
  459. package/components/Paging/PagingDefaultComponent/PagingDefaultComponent.js.map +1 -1
  460. package/components/Paging/PagingDefaultComponent.d.ts +3 -3
  461. package/components/PasswordInput/PasswordInput/PasswordInput.js +14 -13
  462. package/components/PasswordInput/PasswordInput/PasswordInput.js.map +1 -1
  463. package/components/PasswordInput/PasswordInput.d.ts +4 -3
  464. package/components/Radio/Radio/Radio.js +11 -6
  465. package/components/Radio/Radio/Radio.js.map +1 -1
  466. package/components/Radio/Radio.d.ts +4 -3
  467. package/components/RadioGroup/RadioGroup/RadioGroup.js +10 -10
  468. package/components/RadioGroup/RadioGroup/RadioGroup.js.map +1 -1
  469. package/components/RadioGroup/RadioGroup.d.ts +2 -4
  470. package/components/ResponsiveLayout/ResponsiveLayoutEvents/ResponsiveLayoutEvents.js +3 -1
  471. package/components/ResponsiveLayout/ResponsiveLayoutEvents/ResponsiveLayoutEvents.js.map +1 -1
  472. package/components/ScrollContainer/ScrollContainer/ScrollContainer.js +11 -7
  473. package/components/ScrollContainer/ScrollContainer/ScrollContainer.js.map +1 -1
  474. package/components/ScrollContainer/ScrollContainer.d.ts +7 -8
  475. package/components/ScrollContainer/ScrollContainer.helpers/ScrollContainer.helpers.js +4 -4
  476. package/components/ScrollContainer/ScrollContainer.helpers/ScrollContainer.helpers.js.map +1 -1
  477. package/components/Select/Item/Item.js.map +1 -1
  478. package/components/Select/Item.d.ts +4 -2
  479. package/components/Select/Select/Select.js +4 -3
  480. package/components/Select/Select/Select.js.map +1 -1
  481. package/components/Select/Select.d.ts +3 -12
  482. package/components/Select/Select.styles/Select.styles.js +4 -4
  483. package/components/Select/Select.styles/Select.styles.js.map +1 -1
  484. package/components/SidePage/SidePage/SidePage.js +14 -9
  485. package/components/SidePage/SidePage/SidePage.js.map +1 -1
  486. package/components/SidePage/SidePage.d.ts +5 -6
  487. package/components/SidePage/SidePageFooter/SidePageFooter.js.map +1 -1
  488. package/components/SidePage/SidePageFooter.d.ts +6 -4
  489. package/components/Spinner/Spinner/Spinner.js +8 -6
  490. package/components/Spinner/Spinner/Spinner.js.map +1 -1
  491. package/components/Spinner/Spinner.d.ts +4 -2
  492. package/components/Spinner/Spinner.styles/Spinner.styles.js +3 -3
  493. package/components/Spinner/Spinner.styles/Spinner.styles.js.map +1 -1
  494. package/components/Spinner/Spinner.styles.d.ts +1 -1
  495. package/components/Sticky/Sticky/Sticky.js +7 -4
  496. package/components/Sticky/Sticky/Sticky.js.map +1 -1
  497. package/components/Sticky/Sticky.d.ts +5 -4
  498. package/components/Tabs/Indicator/Indicator.js +1 -1
  499. package/components/Tabs/Indicator/Indicator.js.map +1 -1
  500. package/components/Tabs/Indicator.d.ts +1 -1
  501. package/components/Tabs/Tab/Tab.js +15 -7
  502. package/components/Tabs/Tab/Tab.js.map +1 -1
  503. package/components/Tabs/Tab.d.ts +4 -4
  504. package/components/Tabs/Tabs/Tabs.js +10 -8
  505. package/components/Tabs/Tabs/Tabs.js.map +1 -1
  506. package/components/Tabs/Tabs.d.ts +4 -4
  507. package/components/Textarea/Textarea/Textarea.js +23 -15
  508. package/components/Textarea/Textarea/Textarea.js.map +1 -1
  509. package/components/Textarea/Textarea.d.ts +8 -10
  510. package/components/Textarea/TextareaCounter/TextareaCounter.js.map +1 -1
  511. package/components/Textarea/TextareaCounter.d.ts +2 -2
  512. package/components/Toast/Toast/Toast.js +1 -1
  513. package/components/Toast/Toast/Toast.js.map +1 -1
  514. package/components/Toggle/Toggle/Toggle.js +12 -7
  515. package/components/Toggle/Toggle/Toggle.js.map +1 -1
  516. package/components/Toggle/Toggle.d.ts +5 -6
  517. package/components/TokenInput/TokenInput/TokenInput.js +107 -77
  518. package/components/TokenInput/TokenInput/TokenInput.js.map +1 -1
  519. package/components/TokenInput/TokenInput.d.ts +19 -16
  520. package/components/TokenInput/TokenInputMenu/TokenInputMenu.js +1 -1
  521. package/components/TokenInput/TokenInputMenu/TokenInputMenu.js.map +1 -1
  522. package/components/TokenInput/TokenInputMenu.d.ts +2 -1
  523. package/components/Tooltip/Tooltip/Tooltip.js +60 -47
  524. package/components/Tooltip/Tooltip/Tooltip.js.map +1 -1
  525. package/components/Tooltip/Tooltip.d.ts +13 -19
  526. package/components/TooltipMenu/TooltipMenu/TooltipMenu.js +15 -13
  527. package/components/TooltipMenu/TooltipMenu/TooltipMenu.js.map +1 -1
  528. package/components/TooltipMenu/TooltipMenu.d.ts +6 -5
  529. package/hooks/useEffectWithoutInitCall/useEffectWithoutInitCall.js +2 -2
  530. package/hooks/useEffectWithoutInitCall/useEffectWithoutInitCall.js.map +1 -1
  531. package/hooks/useEffectWithoutInitCall.d.ts +2 -2
  532. package/hooks/useMemoObject/useMemoObject.js.map +1 -1
  533. package/hooks/useMemoObject.d.ts +2 -1
  534. package/internal/BGRuler/BGRuler.js +11 -6
  535. package/internal/BGRuler/BGRuler.js.map +1 -1
  536. package/internal/BGRuler.d.ts +13 -15
  537. package/internal/Calendar/Calendar/Calendar.js +11 -5
  538. package/internal/Calendar/Calendar/Calendar.js.map +1 -1
  539. package/internal/Calendar/Calendar.d.ts +4 -13
  540. package/internal/Calendar/DayCellView.styles/DayCellView.styles.js +1 -1
  541. package/internal/Calendar/DayCellView.styles/DayCellView.styles.js.map +1 -1
  542. package/internal/Calendar/Month/Month.js +20 -11
  543. package/internal/Calendar/Month/Month.js.map +1 -1
  544. package/internal/Calendar/MonthViewModel.d.ts +1 -1
  545. package/internal/Calendar/config.d.ts +1 -8
  546. package/internal/CommonWrapper/CommonWrapper/CommonWrapper.js +3 -2
  547. package/internal/CommonWrapper/CommonWrapper/CommonWrapper.js.map +1 -1
  548. package/internal/CommonWrapper/CommonWrapper.d.ts +1 -1
  549. package/internal/ComponentCombinator/ComponentCombinator.js +8 -5
  550. package/internal/ComponentCombinator/ComponentCombinator.js.map +1 -1
  551. package/internal/ComponentCombinator.d.ts +6 -8
  552. package/internal/ComponentTable/ComponentTable.js +16 -4
  553. package/internal/ComponentTable/ComponentTable.js.map +1 -1
  554. package/internal/ComponentTable.d.ts +7 -8
  555. package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js +18 -19
  556. package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js.map +1 -1
  557. package/internal/CustomComboBox/ComboBoxMenu.d.ts +6 -6
  558. package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js +21 -10
  559. package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js.map +1 -1
  560. package/internal/CustomComboBox/ComboBoxView.d.ts +4 -12
  561. package/internal/CustomComboBox/CustomComboBoxReducer/CustomComboBoxReducer.js +4 -5
  562. package/internal/CustomComboBox/CustomComboBoxReducer/CustomComboBoxReducer.js.map +1 -1
  563. package/internal/DataTids/DataTids/DataTids.js.map +1 -1
  564. package/internal/DataTids/DataTids.d.ts +5 -5
  565. package/internal/DateSelect/DateSelect/DateSelect.js +15 -12
  566. package/internal/DateSelect/DateSelect/DateSelect.js.map +1 -1
  567. package/internal/DateSelect/DateSelect.d.ts +4 -6
  568. package/internal/DropdownContainer/DropdownContainer/DropdownContainer.js +6 -10
  569. package/internal/DropdownContainer/DropdownContainer/DropdownContainer.js.map +1 -1
  570. package/internal/DropdownContainer/DropdownContainer.d.ts +4 -7
  571. package/internal/FileUploaderControl/withFileUploaderControlProvider/withFileUploaderControlProvider.js.map +1 -1
  572. package/internal/FileUploaderControl/withFileUploaderControlProvider.d.ts +1 -1
  573. package/internal/HideBodyVerticalScroll/HideBodyVerticalScroll/HideBodyVerticalScroll.js +2 -1
  574. package/internal/HideBodyVerticalScroll/HideBodyVerticalScroll/HideBodyVerticalScroll.js.map +1 -1
  575. package/internal/InputLikeText/InputLikeText/InputLikeText.js +9 -4
  576. package/internal/InputLikeText/InputLikeText/InputLikeText.js.map +1 -1
  577. package/internal/InputLikeText/InputLikeText.d.ts +4 -3
  578. package/internal/InternalMenu/InternalMenu/InternalMenu.js +38 -17
  579. package/internal/InternalMenu/InternalMenu/InternalMenu.js.map +1 -1
  580. package/internal/InternalMenu/InternalMenu.d.ts +3 -9
  581. package/internal/InternalMenu/InternalMenu.styles/InternalMenu.styles.js +1 -1
  582. package/internal/InternalMenu/InternalMenu.styles/InternalMenu.styles.js.map +1 -1
  583. package/internal/MaskedInput/MaskedInput/MaskedInput.js +16 -7
  584. package/internal/MaskedInput/MaskedInput/MaskedInput.js.map +1 -1
  585. package/internal/MaskedInput/MaskedInput.d.ts +5 -2
  586. package/internal/Menu/Menu/Menu.js +16 -4
  587. package/internal/Menu/Menu/Menu.js.map +1 -1
  588. package/internal/Menu/Menu.d.ts +4 -7
  589. package/internal/MobilePopup/MobilePopup/MobilePopup.js +1 -1
  590. package/internal/MobilePopup/MobilePopup/MobilePopup.js.map +1 -1
  591. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader/MobilePopupHeader.js +1 -1
  592. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader/MobilePopupHeader.js.map +1 -1
  593. package/internal/PerformanceMetrics/PerformanceMetrics/PerformanceMetrics.js.map +1 -1
  594. package/internal/Popup/Popup/Popup.js +52 -35
  595. package/internal/Popup/Popup/Popup.js.map +1 -1
  596. package/internal/Popup/Popup.d.ts +11 -17
  597. package/internal/Popup/PopupHelper/PopupHelper.js.map +1 -1
  598. package/internal/Popup/PopupHelper.d.ts +1 -1
  599. package/internal/Popup/PopupPin/PopupPin.js.map +1 -1
  600. package/internal/Popup/PopupPin.d.ts +1 -1
  601. package/internal/PopupMenu/PopupMenu/PopupMenu.js +12 -4
  602. package/internal/PopupMenu/PopupMenu/PopupMenu.js.map +1 -1
  603. package/internal/PopupMenu/PopupMenu.d.ts +8 -11
  604. package/internal/RenderLayer/RenderLayer/RenderLayer.js +18 -11
  605. package/internal/RenderLayer/RenderLayer/RenderLayer.js.map +1 -1
  606. package/internal/RenderLayer/RenderLayer.d.ts +6 -4
  607. package/internal/ThemePlayground/AnotherInputsPlayground/AnotherInputsPlayground.js.map +1 -1
  608. package/internal/ThemePlayground/AnotherInputsPlayground.d.ts +11 -6
  609. package/internal/ThemePlayground/CurrencyInputPlayground/CurrencyInputPlayground.js.map +1 -1
  610. package/internal/ThemePlayground/CurrencyInputPlayground.d.ts +7 -6
  611. package/internal/ThemePlayground/FxInputPlayground/FxInputPlayground.js +10 -6
  612. package/internal/ThemePlayground/FxInputPlayground/FxInputPlayground.js.map +1 -1
  613. package/internal/ThemePlayground/FxInputPlayground.d.ts +6 -4
  614. package/internal/ThemePlayground/HintPlayground/HintPlayground.js.map +1 -1
  615. package/internal/ThemePlayground/HintPlayground.d.ts +1 -1
  616. package/internal/ThemePlayground/PagingPlayground/PagingPlayground.js +2 -2
  617. package/internal/ThemePlayground/PagingPlayground/PagingPlayground.js.map +1 -1
  618. package/internal/ThemePlayground/PagingPlayground.d.ts +6 -6
  619. package/internal/ThemePlayground/Playground/Playground.js.map +1 -1
  620. package/internal/ThemePlayground/Playground.d.ts +1 -1
  621. package/internal/ThemePlayground/SelectPlayground/SelectPlayground.js.map +1 -1
  622. package/internal/ThemePlayground/SelectPlayground.d.ts +9 -6
  623. package/internal/ThemePlayground/SizesGroup/SizesGroup.js.map +1 -1
  624. package/internal/ThemePlayground/SizesGroup.d.ts +2 -2
  625. package/internal/ThemePlayground/SwitcherPlayground/SwitcherPlayground.js.map +1 -1
  626. package/internal/ThemePlayground/SwitcherPlayground.d.ts +9 -8
  627. package/internal/ThemePlayground/ThemeContextPlayground/ThemeContextPlayground.js +13 -3
  628. package/internal/ThemePlayground/ThemeContextPlayground/ThemeContextPlayground.js.map +1 -1
  629. package/internal/ThemePlayground/ThemeEditor/ThemeEditor.js.map +1 -1
  630. package/internal/ThemePlayground/ThemeEditor.d.ts +1 -4
  631. package/internal/ThemePlayground/TogglePlayground/TogglePlayground.js +5 -17
  632. package/internal/ThemePlayground/TogglePlayground/TogglePlayground.js.map +1 -1
  633. package/internal/ThemePlayground/TogglePlayground.d.ts +2 -7
  634. package/internal/ThemePlayground/TokenInputPlayground/TokenInputPlayground.js.map +1 -1
  635. package/internal/ThemePlayground/TokenInputPlayground.d.ts +6 -4
  636. package/internal/ThemePlayground/VariableValue/VariableValue.js +4 -2
  637. package/internal/ThemePlayground/VariableValue/VariableValue.js.map +1 -1
  638. package/internal/ThemePlayground/VariableValue.d.ts +6 -8
  639. package/internal/ThemePlayground/helpers/helpers.js +0 -1
  640. package/internal/ThemePlayground/helpers/helpers.js.map +1 -1
  641. package/internal/ThemePlayground/helpers.d.ts +1 -1
  642. package/internal/ThemeShowcase/ThemeShowcase/ThemeShowcase.js.map +1 -1
  643. package/internal/ZIndex/ZIndex/ZIndex.js +21 -16
  644. package/internal/ZIndex/ZIndex/ZIndex.js.map +1 -1
  645. package/internal/ZIndex/ZIndex.d.ts +7 -11
  646. package/internal/themes/DefaultTheme/DefaultTheme.js +6 -6
  647. package/internal/themes/DefaultTheme/DefaultTheme.js.map +1 -1
  648. package/lib/ConditionalHandler/ConditionalHandler.js.map +1 -1
  649. package/lib/InstanceWithAnchorElement/InstanceWithAnchorElement.js.map +1 -1
  650. package/lib/InstanceWithAnchorElement.d.ts +1 -1
  651. package/lib/ModalStack/ModalStack.js +2 -2
  652. package/lib/ModalStack/ModalStack.js.map +1 -1
  653. package/lib/SSRSafe/SSRSafe.js +7 -0
  654. package/lib/SSRSafe/SSRSafe.js.map +1 -1
  655. package/lib/SSRSafe.d.ts +2 -1
  656. package/lib/animation/index/index.js +1 -1
  657. package/lib/animation/index/index.js.map +1 -1
  658. package/lib/callChildRef/callChildRef/callChildRef.js +1 -1
  659. package/lib/callChildRef/callChildRef/callChildRef.js.map +1 -1
  660. package/lib/createPropsGetter/createPropsGetter.js +1 -0
  661. package/lib/createPropsGetter/createPropsGetter.js.map +1 -1
  662. package/lib/createPropsGetter.d.ts +2 -1
  663. package/lib/date/InternalDateCalculator/InternalDateCalculator.js +1 -2
  664. package/lib/date/InternalDateCalculator/InternalDateCalculator.js.map +1 -1
  665. package/lib/date/InternalDateCalculator.d.ts +1 -1
  666. package/lib/date/InternalDateValidator/InternalDateValidator.js +8 -2
  667. package/lib/date/InternalDateValidator/InternalDateValidator.js.map +1 -1
  668. package/lib/date/InternalDateValidator.d.ts +1 -1
  669. package/lib/extractKeyboardAction/extractKeyboardAction.js.map +1 -1
  670. package/lib/extractKeyboardAction.d.ts +1 -1
  671. package/lib/filterProps/filterProps.js +0 -1
  672. package/lib/filterProps/filterProps.js.map +1 -1
  673. package/lib/listenFocusOutside/listenFocusOutside.js.map +1 -1
  674. package/lib/listenFocusOutside.d.ts +1 -1
  675. package/lib/locale/useLocaleForControl/useLocaleForControl.js.map +1 -1
  676. package/lib/locale/useLocaleForControl.d.ts +1 -1
  677. package/lib/memo/memo.js +2 -4
  678. package/lib/memo/memo.js.map +1 -1
  679. package/lib/memo.d.ts +3 -1
  680. package/lib/net/fetch/fetch.js +2 -2
  681. package/lib/net/fetch/fetch.js.map +1 -1
  682. package/lib/reactGetTextContent/reactGetTextContent.js +0 -1
  683. package/lib/reactGetTextContent/reactGetTextContent.js.map +1 -1
  684. package/lib/rootNode/getRootNode/getRootNode.js +8 -8
  685. package/lib/rootNode/getRootNode/getRootNode.js.map +1 -1
  686. package/lib/rootNode/getRootNode.d.ts +3 -3
  687. package/lib/rootNode/rootNodeDecorator/rootNodeDecorator.js.map +1 -1
  688. package/lib/rootNode/rootNodeDecorator.d.ts +9 -9
  689. package/lib/styles/ColorFactory/ColorFactory.js +3 -1
  690. package/lib/styles/ColorFactory/ColorFactory.js.map +1 -1
  691. package/lib/styles/ColorFunctions/ColorFunctions.js.map +1 -1
  692. package/lib/theming/AnimationKeyframes/AnimationKeyframes.js +8 -14
  693. package/lib/theming/AnimationKeyframes/AnimationKeyframes.js.map +1 -1
  694. package/lib/theming/AnimationKeyframes.d.ts +3 -5
  695. package/lib/theming/Emotion/Emotion.js.map +1 -1
  696. package/lib/theming/ThemeFactory/ThemeFactory.js +4 -1
  697. package/lib/theming/ThemeFactory/ThemeFactory.js.map +1 -1
  698. package/lib/theming/ThemeFactory.d.ts +1 -1
  699. package/lib/theming/ThemeHelpers/ThemeHelpers.js +1 -1
  700. package/lib/theming/ThemeHelpers/ThemeHelpers.js.map +1 -1
  701. package/lib/theming/ThemeHelpers.d.ts +2 -2
  702. package/lib/utils/utils.js +2 -2
  703. package/lib/utils/utils.js.map +1 -1
  704. package/lib/utils.d.ts +3 -1
  705. package/lib/withClassWrapper/withClassWrapper.js +1 -4
  706. package/lib/withClassWrapper/withClassWrapper.js.map +1 -1
  707. package/package.json +3 -3
  708. package/typings/event-types.d.ts +2 -2
@@ -1 +1 @@
1
- {"version":3,"sources":["Kebab.tsx"],"names":["React","PropTypes","isKeyArrowVertical","isKeyEnter","isKeySpace","someKeys","LayoutEvents","keyListener","PopupMenu","ThemeContext","MenuKebabIcon","isTestEnv","ThemeFactory","CommonWrapper","cx","rootNode","styles","Kebab","state","focusedByTab","anchor","listener","remove","undefined","renderCaption","captionProps","disabled","props","handleCaptionKeyDown","event","openMenu","handleCaptionClick","toggleMenu","handleFocus","handleBlur","kebab","theme","opened","focused","renderIcon","e","preventDefault","handleChangeMenuState","isOpened","restoreFocus","setState","requestAnimationFrame","isTabPressed","componentDidMount","addListener","componentWillUnmount","render","create","popupPinOffset","kebabPinOffset","popupMargin","kebabMargin","popupPinSize","kebabPinSize","renderMain","positions","setRootNode","disableAnimations","menuMaxHeight","onOpen","onClose","children","icon","iconsmall","size","iconmedium","iconlarge","Component","__KONTUR_REACT_UI__","propTypes","defaultProps","node","bool","oneOfType","string","number","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { isKeyArrowVertical, isKeyEnter, isKeySpace, someKeys } from '../../lib/events/keyboard/identifiers';\nimport * as LayoutEvents from '../../lib/LayoutEvents';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { PopupMenu, PopupMenuCaptionProps, PopupMenuProps } from '../../internal/PopupMenu';\nimport { Nullable } from '../../typings/utility-types';\nimport { PopupPositionsType } from '../../internal/Popup';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { MenuKebabIcon } from '../../internal/icons/16px';\nimport { isTestEnv } from '../../lib/currentEnvironment';\nimport { ThemeFactory } from '../../lib/theming/ThemeFactory';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\n\nimport { styles } from './Kebab.styles';\n\nexport interface KebabProps extends CommonProps, Pick<PopupMenuProps, 'onOpen' | 'onClose'> {\n disabled?: boolean;\n size: 'small' | 'medium' | 'large';\n /**\n * Список позиций доступных для расположения выпадашки.\n *\n * Если во всех позициях выпадашка вылезает за пределы `viewport`, будет использована первая из этого списка.\n *\n * **Возможные значения**: `top left`, `top center`, `top right`, `right top`, `right middle`, `right bottom`, `bottom left`, `bottom center`, `bottom right`, `left top`, `left middle`, `left bottom`\n * @default ['bottom left', 'bottom right', 'top left', 'top right']\n */\n positions: PopupPositionsType[];\n menuMaxHeight?: number | string;\n /**\n * Не показывать анимацию\n */\n disableAnimations: boolean;\n /**\n * Кастомная иконка\n */\n icon?: React.ReactNode;\n}\n\nexport interface KebabState {\n anchor: Nullable<HTMLElement>;\n focusedByTab: boolean;\n}\n\n@rootNode\nexport class Kebab extends React.Component<KebabProps, KebabState> {\n public static __KONTUR_REACT_UI__ = 'Kebab';\n\n public static propTypes = {};\n\n public static defaultProps = {\n onOpen: () => undefined,\n onClose: () => undefined,\n positions: ['bottom left', 'bottom right', 'top left', 'top right'],\n size: 'small',\n disableAnimations: isTestEnv,\n icon: <MenuKebabIcon />,\n };\n\n public state = {\n focusedByTab: false,\n anchor: null,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n\n private listener: {\n remove: () => void;\n } = {\n remove: () => undefined,\n };\n\n public componentDidMount() {\n /** addListener'у нужен колбэк в аргумент */\n this.listener = LayoutEvents.addListener(() => undefined);\n }\n\n public componentWillUnmount() {\n this.listener.remove();\n }\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return (\n <ThemeContext.Provider\n value={ThemeFactory.create(\n {\n popupPinOffset: theme.kebabPinOffset,\n popupMargin: theme.kebabMargin,\n popupPinSize: theme.kebabPinSize,\n },\n theme,\n )}\n >\n {this.renderMain()}\n </ThemeContext.Provider>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { disabled, positions } = this.props;\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <PopupMenu\n popupHasPin\n positions={positions}\n onChangeMenuState={this.handleChangeMenuState}\n caption={this.renderCaption}\n disableAnimations={this.props.disableAnimations}\n menuMaxHeight={this.props.menuMaxHeight}\n onOpen={this.props.onOpen}\n onClose={this.props.onClose}\n >\n {!disabled && this.props.children}\n </PopupMenu>\n </CommonWrapper>\n );\n }\n\n private renderCaption = (captionProps: PopupMenuCaptionProps) => {\n const { disabled } = this.props;\n const handleCaptionKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (!disabled) {\n this.handleCaptionKeyDown(event, captionProps.openMenu);\n }\n };\n\n const handleCaptionClick = () => {\n if (!disabled) {\n captionProps.toggleMenu();\n }\n };\n\n return (\n <span\n tabIndex={disabled ? -1 : 0}\n onClick={handleCaptionClick}\n onKeyDown={handleCaptionKeyDown}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n className={cx({\n [styles.kebab(this.theme)]: true,\n [styles.opened(this.theme)]: captionProps.opened,\n [styles.disabled()]: disabled,\n [styles.focused(this.theme)]: this.state.focusedByTab,\n })}\n >\n {this.renderIcon()}\n </span>\n );\n };\n\n private handleCaptionKeyDown = (\n e: React.KeyboardEvent<HTMLDivElement>,\n openMenu: PopupMenuCaptionProps['openMenu'],\n ) => {\n if (someKeys(isKeyEnter, isKeySpace, isKeyArrowVertical)(e)) {\n e.preventDefault();\n openMenu(true);\n }\n };\n\n private handleChangeMenuState = (isOpened: boolean, restoreFocus: boolean): void => {\n this.setState({\n focusedByTab: !isOpened && restoreFocus,\n });\n };\n\n private handleFocus = () => {\n if (!this.props.disabled) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n }\n };\n\n private handleBlur = () => {\n this.setState({\n focusedByTab: false,\n });\n };\n\n private renderIcon() {\n return (\n <div\n className={cx({\n [styles.icon()]: true,\n [styles.iconsmall()]: this.props.size === 'small',\n [styles.iconmedium()]: this.props.size === 'medium',\n [styles.iconlarge()]: this.props.size === 'large',\n })}\n >\n {this.props.icon}\n </div>\n );\n }\n}\n\nKebab.propTypes = {\n children: PropTypes.node,\n disabled: PropTypes.bool,\n menuMaxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Размер кебаба small 14px | large 20px\n */\n size: PropTypes.string,\n\n /**\n * Коллбек, вызывающийся перед закрытием кебаба\n */\n onClose: PropTypes.func,\n\n /**\n * Коллбек, вызывающийся перед открытием кебаба\n */\n onOpen: PropTypes.func,\n};\n"]}
1
+ {"version":3,"sources":["Kebab.tsx"],"names":["React","PropTypes","isKeyArrowVertical","isKeyEnter","isKeySpace","someKeys","LayoutEvents","keyListener","PopupMenu","ThemeContext","MenuKebabIcon","isTestEnv","ThemeFactory","CommonWrapper","cx","rootNode","createPropsGetter","styles","Kebab","getProps","defaultProps","state","focusedByTab","anchor","listener","remove","undefined","renderCaption","captionProps","disabled","props","handleCaptionKeyDown","event","openMenu","handleCaptionClick","toggleMenu","handleFocus","handleBlur","kebab","theme","opened","focused","renderIcon","e","preventDefault","handleChangeMenuState","isOpened","restoreFocus","setState","requestAnimationFrame","isTabPressed","componentDidMount","addListener","componentWillUnmount","render","create","popupPinOffset","kebabPinOffset","popupMargin","kebabMargin","popupPinSize","kebabPinSize","renderMain","positions","disableAnimations","onOpen","onClose","setRootNode","menuMaxHeight","children","size","icon","iconsmall","iconmedium","iconlarge","Component","__KONTUR_REACT_UI__","propTypes","node","bool","oneOfType","string","number","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { isKeyArrowVertical, isKeyEnter, isKeySpace, someKeys } from '../../lib/events/keyboard/identifiers';\nimport * as LayoutEvents from '../../lib/LayoutEvents';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { PopupMenu, PopupMenuCaptionProps, PopupMenuProps } from '../../internal/PopupMenu';\nimport { Nullable } from '../../typings/utility-types';\nimport { PopupPositionsType } from '../../internal/Popup';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { MenuKebabIcon } from '../../internal/icons/16px';\nimport { isTestEnv } from '../../lib/currentEnvironment';\nimport { ThemeFactory } from '../../lib/theming/ThemeFactory';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\n\nimport { styles } from './Kebab.styles';\n\nexport interface KebabProps extends CommonProps, Pick<PopupMenuProps, 'onOpen' | 'onClose'> {\n disabled?: boolean;\n size?: 'small' | 'medium' | 'large';\n /**\n * Список позиций доступных для расположения выпадашки.\n *\n * Если во всех позициях выпадашка вылезает за пределы `viewport`, будет использована первая из этого списка.\n *\n * **Возможные значения**: `top left`, `top center`, `top right`, `right top`, `right middle`, `right bottom`, `bottom left`, `bottom center`, `bottom right`, `left top`, `left middle`, `left bottom`\n * @default ['bottom left', 'bottom right', 'top left', 'top right']\n */\n positions?: PopupPositionsType[];\n menuMaxHeight?: number | string;\n /**\n * Не показывать анимацию\n */\n disableAnimations?: boolean;\n /**\n * Кастомная иконка\n */\n icon?: React.ReactNode;\n}\n\nexport interface KebabState {\n anchor: Nullable<HTMLElement>;\n focusedByTab: boolean;\n}\n\ntype DefaultProps = Required<\n Pick<KebabProps, 'onOpen' | 'onClose' | 'positions' | 'size' | 'disableAnimations' | 'icon'>\n>;\n\n@rootNode\nexport class Kebab extends React.Component<KebabProps, KebabState> {\n public static __KONTUR_REACT_UI__ = 'Kebab';\n\n public static propTypes = {};\n\n public static defaultProps: DefaultProps = {\n onOpen: () => undefined,\n onClose: () => undefined,\n positions: ['bottom left', 'bottom right', 'top left', 'top right'],\n size: 'small',\n disableAnimations: isTestEnv,\n icon: <MenuKebabIcon />,\n };\n\n private getProps = createPropsGetter(Kebab.defaultProps);\n\n public state: KebabState = {\n focusedByTab: false,\n anchor: null,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n\n private listener: {\n remove: () => void;\n } = {\n remove: () => undefined,\n };\n\n public componentDidMount() {\n /** addListener'у нужен колбэк в аргумент */\n this.listener = LayoutEvents.addListener(() => undefined);\n }\n\n public componentWillUnmount() {\n this.listener.remove();\n }\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return (\n <ThemeContext.Provider\n value={ThemeFactory.create(\n {\n popupPinOffset: theme.kebabPinOffset,\n popupMargin: theme.kebabMargin,\n popupPinSize: theme.kebabPinSize,\n },\n theme,\n )}\n >\n {this.renderMain()}\n </ThemeContext.Provider>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { disabled } = this.props;\n const { positions, disableAnimations, onOpen, onClose } = this.getProps();\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <PopupMenu\n popupHasPin\n positions={positions}\n onChangeMenuState={this.handleChangeMenuState}\n caption={this.renderCaption}\n disableAnimations={disableAnimations}\n menuMaxHeight={this.props.menuMaxHeight}\n onOpen={onOpen}\n onClose={onClose}\n >\n {!disabled && this.props.children}\n </PopupMenu>\n </CommonWrapper>\n );\n }\n\n private renderCaption = (captionProps: PopupMenuCaptionProps) => {\n const { disabled } = this.props;\n const handleCaptionKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (!disabled) {\n this.handleCaptionKeyDown(event, captionProps.openMenu);\n }\n };\n\n const handleCaptionClick = () => {\n if (!disabled) {\n captionProps.toggleMenu();\n }\n };\n\n return (\n <span\n tabIndex={disabled ? -1 : 0}\n onClick={handleCaptionClick}\n onKeyDown={handleCaptionKeyDown}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n className={cx({\n [styles.kebab(this.theme)]: true,\n [styles.opened(this.theme)]: captionProps.opened,\n [styles.disabled()]: disabled,\n [styles.focused(this.theme)]: this.state.focusedByTab,\n })}\n >\n {this.renderIcon()}\n </span>\n );\n };\n\n private handleCaptionKeyDown = (\n e: React.KeyboardEvent<HTMLDivElement>,\n openMenu: PopupMenuCaptionProps['openMenu'],\n ) => {\n if (someKeys(isKeyEnter, isKeySpace, isKeyArrowVertical)(e)) {\n e.preventDefault();\n openMenu(true);\n }\n };\n\n private handleChangeMenuState = (isOpened: boolean, restoreFocus: boolean): void => {\n this.setState({\n focusedByTab: !isOpened && restoreFocus,\n });\n };\n\n private handleFocus = () => {\n if (!this.props.disabled) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n }\n };\n\n private handleBlur = () => {\n this.setState({\n focusedByTab: false,\n });\n };\n\n private renderIcon() {\n const { size, icon } = this.getProps();\n return (\n <div\n className={cx({\n [styles.icon()]: true,\n [styles.iconsmall()]: size === 'small',\n [styles.iconmedium()]: size === 'medium',\n [styles.iconlarge()]: size === 'large',\n })}\n >\n {icon}\n </div>\n );\n }\n}\n\nKebab.propTypes = {\n children: PropTypes.node,\n disabled: PropTypes.bool,\n menuMaxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /**\n * Размер кебаба small 14px | large 20px\n */\n size: PropTypes.string,\n\n /**\n * Коллбек, вызывающийся перед закрытием кебаба\n */\n onClose: PropTypes.func,\n\n /**\n * Коллбек, вызывающийся перед открытием кебаба\n */\n onOpen: PropTypes.func,\n};\n"]}
@@ -5,7 +5,7 @@ import { PopupPositionsType } from '../../internal/Popup';
5
5
  import { CommonProps } from '../../internal/CommonWrapper';
6
6
  export interface KebabProps extends CommonProps, Pick<PopupMenuProps, 'onOpen' | 'onClose'> {
7
7
  disabled?: boolean;
8
- size: 'small' | 'medium' | 'large';
8
+ size?: 'small' | 'medium' | 'large';
9
9
  /**
10
10
  * Список позиций доступных для расположения выпадашки.
11
11
  *
@@ -14,12 +14,12 @@ export interface KebabProps extends CommonProps, Pick<PopupMenuProps, 'onOpen' |
14
14
  * **Возможные значения**: `top left`, `top center`, `top right`, `right top`, `right middle`, `right bottom`, `bottom left`, `bottom center`, `bottom right`, `left top`, `left middle`, `left bottom`
15
15
  * @default ['bottom left', 'bottom right', 'top left', 'top right']
16
16
  */
17
- positions: PopupPositionsType[];
17
+ positions?: PopupPositionsType[];
18
18
  menuMaxHeight?: number | string;
19
19
  /**
20
20
  * Не показывать анимацию
21
21
  */
22
- disableAnimations: boolean;
22
+ disableAnimations?: boolean;
23
23
  /**
24
24
  * Кастомная иконка
25
25
  */
@@ -29,21 +29,13 @@ export interface KebabState {
29
29
  anchor: Nullable<HTMLElement>;
30
30
  focusedByTab: boolean;
31
31
  }
32
+ declare type DefaultProps = Required<Pick<KebabProps, 'onOpen' | 'onClose' | 'positions' | 'size' | 'disableAnimations' | 'icon'>>;
32
33
  export declare class Kebab extends React.Component<KebabProps, KebabState> {
33
34
  static __KONTUR_REACT_UI__: string;
34
35
  static propTypes: {};
35
- static defaultProps: {
36
- onOpen: () => undefined;
37
- onClose: () => undefined;
38
- positions: string[];
39
- size: string;
40
- disableAnimations: boolean;
41
- icon: JSX.Element;
42
- };
43
- state: {
44
- focusedByTab: boolean;
45
- anchor: null;
46
- };
36
+ static defaultProps: DefaultProps;
37
+ private getProps;
38
+ state: KebabState;
47
39
  private theme;
48
40
  private setRootNode;
49
41
  private listener;
@@ -58,3 +50,4 @@ export declare class Kebab extends React.Component<KebabProps, KebabState> {
58
50
  private handleBlur;
59
51
  private renderIcon;
60
52
  }
53
+ export {};
@@ -14,15 +14,16 @@ import { Spinner } from "../../Spinner";
14
14
  import { CommonWrapper } from "../../../internal/CommonWrapper";
15
15
  import { cx } from "../../../lib/theming/Emotion";
16
16
  import { rootNode } from "../../../lib/rootNode/rootNodeDecorator";
17
+ import { createPropsGetter } from "../../../lib/createPropsGetter";
17
18
  import { styles } from "../Link.styles";
18
19
  export var LinkDataTids = {
19
20
  root: 'Link__root'
20
21
  };
22
+ export
21
23
  /**
22
- * Элемент ссылки из HTML.
23
- */
24
-
25
- export var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_React$Component) {
24
+ * Элемент ссылки из HTML.
25
+ */
26
+ var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_React$Component) {
26
27
  _inheritsLoose(Link, _React$Component);
27
28
 
28
29
  function Link() {
@@ -33,6 +34,7 @@ export var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_R
33
34
  }
34
35
 
35
36
  _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;
37
+ _this.getProps = createPropsGetter(Link.defaultProps);
36
38
  _this.state = {
37
39
  focusedByTab: false
38
40
  };
@@ -91,7 +93,7 @@ export var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_R
91
93
  }, rest, linkProps), iconElement, _this.props.children, arrow);
92
94
  };
93
95
 
94
- _this._handleFocus = function (event) {
96
+ _this._handleFocus = function () {
95
97
  if (!_this.props.disabled) {
96
98
  // focus event fires before keyDown eventlistener
97
99
  // so we should check tabPressed in async way
@@ -113,11 +115,12 @@ export var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_R
113
115
 
114
116
  _this._handleClick = function (event) {
115
117
  var _this$props = _this.props,
116
- href = _this$props.href,
117
118
  onClick = _this$props.onClick,
118
119
  disabled = _this$props.disabled,
119
120
  loading = _this$props.loading;
120
121
 
122
+ var href = _this.getProps().href;
123
+
121
124
  if (!href) {
122
125
  event.preventDefault();
123
126
  }
@@ -139,7 +142,7 @@ export var Link = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_R
139
142
  _this2.theme = theme;
140
143
  return /*#__PURE__*/React.createElement(CommonWrapper, _extends({
141
144
  rootNodeRef: _this2.setRootNode
142
- }, _this2.props), _this2.renderMain);
145
+ }, _this2.getProps()), _this2.renderMain);
143
146
  });
144
147
  };
145
148
 
@@ -1 +1 @@
1
- {"version":3,"sources":["Link.tsx"],"names":["React","PropTypes","keyListener","ThemeContext","isExternalLink","Spinner","CommonWrapper","cx","rootNode","styles","LinkDataTids","root","Link","state","focusedByTab","renderMain","props","disabled","href","icon","use","loading","_button","_buttonOpened","relOrigin","rel","rest","iconElement","theme","arrow","focused","linkProps","className","button","buttonOpened","useDefault","useSuccess","useDanger","useGrayed","useGrayedFocus","focus","onClick","_handleClick","onFocus","_handleFocus","onBlur","_handleBlur","tabIndex","children","event","requestAnimationFrame","isTabPressed","setState","preventDefault","render","setRootNode","Component","__KONTUR_REACT_UI__","propTypes","bool","string","node","oneOf","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { Override } from '../../typings/utility-types';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { isExternalLink } from '../../lib/utils';\nimport { Spinner } from '../Spinner';\nimport { CommonWrapper, CommonProps, CommonWrapperRestProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode/rootNodeDecorator';\n\nimport { styles } from './Link.styles';\n\nexport interface LinkProps\n extends CommonProps,\n Override<\n React.AnchorHTMLAttributes<HTMLAnchorElement>,\n {\n /**\n * Отключенное состояние.\n */\n disabled?: boolean;\n /**\n * HTML-атрибут `href`.\n */\n href?: string;\n /**\n * Добавляет ссылке иконку.\n */\n icon?: React.ReactElement<any>;\n /**\n * Тема ссылки.\n */\n use?: 'default' | 'success' | 'danger' | 'grayed';\n /**\n * @ignore\n */\n _button?: boolean;\n /**\n * @ignore\n */\n _buttonOpened?: boolean;\n /**\n * HTML-атрибут `tabindex`.\n */\n tabIndex?: number;\n /**\n * Переводит ссылку в состояние загрузки.\n */\n loading?: boolean;\n /**\n * HTML-событие `onclick`.\n */\n onClick?: (event: React.MouseEvent<HTMLAnchorElement>) => void;\n }\n > {}\n\nexport interface LinkState {\n focusedByTab: boolean;\n}\n\nexport const LinkDataTids = {\n root: 'Link__root',\n} as const;\n\n/**\n * Элемент ссылки из HTML.\n */\n@rootNode\nexport class Link extends React.Component<LinkProps, LinkState> {\n public static __KONTUR_REACT_UI__ = 'Link';\n\n public static propTypes = {\n disabled: PropTypes.bool,\n\n href: PropTypes.string,\n\n icon: PropTypes.node,\n\n use: PropTypes.oneOf(['default', 'success', 'danger', 'grayed']),\n };\n\n public static defaultProps = {\n href: '',\n use: 'default',\n };\n\n public state = {\n focusedByTab: false,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n {this.renderMain}\n </CommonWrapper>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain = (props: CommonWrapperRestProps<LinkProps>) => {\n const { disabled, href, icon, use, loading, _button, _buttonOpened, rel: relOrigin, ...rest } = props;\n\n let iconElement = null;\n if (icon) {\n iconElement = (\n <span className={styles.icon(this.theme)}>{loading ? <Spinner caption={null} dimmed inline /> : icon}</span>\n );\n }\n\n let arrow = null;\n if (_button) {\n arrow = <span className={styles.arrow()} />;\n }\n\n let rel = relOrigin;\n if (typeof rel === 'undefined' && href) {\n rel = `noopener${isExternalLink(href) ? ' noreferrer' : ''}`;\n }\n\n const focused = !disabled && this.state.focusedByTab;\n\n const linkProps = {\n className: cx({\n [styles.root(this.theme)]: true,\n [styles.button(this.theme)]: !!_button,\n [styles.buttonOpened(this.theme)]: !!_buttonOpened,\n [styles.useDefault(this.theme)]: use === 'default',\n [styles.useSuccess(this.theme)]: use === 'success',\n [styles.useDanger(this.theme)]: use === 'danger',\n [styles.useGrayed(this.theme)]: use === 'grayed',\n [styles.useGrayedFocus(this.theme)]: use === 'grayed' && focused,\n [styles.focus(this.theme)]: focused,\n [styles.disabled(this.theme)]: !!disabled || !!loading,\n }),\n href,\n rel,\n onClick: this._handleClick,\n onFocus: this._handleFocus,\n onBlur: this._handleBlur,\n tabIndex: disabled || loading ? -1 : this.props.tabIndex,\n };\n\n return (\n <a data-tid={LinkDataTids.root} {...rest} {...linkProps}>\n {iconElement}\n {this.props.children}\n {arrow}\n </a>\n );\n };\n\n private _handleFocus = (event: React.FocusEvent<HTMLAnchorElement>) => {\n if (!this.props.disabled) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n }\n };\n\n private _handleBlur = () => {\n this.setState({ focusedByTab: false });\n };\n\n private _handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {\n const { href, onClick, disabled, loading } = this.props;\n if (!href) {\n event.preventDefault();\n }\n if (onClick && !disabled && !loading) {\n onClick(event);\n }\n };\n}\n"]}
1
+ {"version":3,"sources":["Link.tsx"],"names":["React","PropTypes","keyListener","ThemeContext","isExternalLink","Spinner","CommonWrapper","cx","rootNode","createPropsGetter","styles","LinkDataTids","root","Link","getProps","defaultProps","state","focusedByTab","renderMain","props","disabled","href","icon","use","loading","_button","_buttonOpened","relOrigin","rel","rest","iconElement","theme","arrow","focused","linkProps","className","button","buttonOpened","useDefault","useSuccess","useDanger","useGrayed","useGrayedFocus","focus","onClick","_handleClick","onFocus","_handleFocus","onBlur","_handleBlur","tabIndex","children","requestAnimationFrame","isTabPressed","setState","event","preventDefault","render","setRootNode","Component","__KONTUR_REACT_UI__","propTypes","bool","string","node","oneOf"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { Override } from '../../typings/utility-types';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { isExternalLink } from '../../lib/utils';\nimport { Spinner } from '../Spinner';\nimport { CommonWrapper, CommonProps, CommonWrapperRestProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode/rootNodeDecorator';\nimport { createPropsGetter, DefaultizedProps } from '../../lib/createPropsGetter';\n\nimport { styles } from './Link.styles';\n\nexport interface LinkProps\n extends CommonProps,\n Override<\n React.AnchorHTMLAttributes<HTMLAnchorElement>,\n {\n /**\n * Отключенное состояние.\n */\n disabled?: boolean;\n /**\n * HTML-атрибут `href`.\n */\n href?: string;\n /**\n * Добавляет ссылке иконку.\n */\n icon?: React.ReactElement<any>;\n /**\n * Тема ссылки.\n */\n use?: 'default' | 'success' | 'danger' | 'grayed';\n /**\n * @ignore\n */\n _button?: boolean;\n /**\n * @ignore\n */\n _buttonOpened?: boolean;\n /**\n * HTML-атрибут `tabindex`.\n */\n tabIndex?: number;\n /**\n * Переводит ссылку в состояние загрузки.\n */\n loading?: boolean;\n /**\n * HTML-событие `onclick`.\n */\n onClick?: (event: React.MouseEvent<HTMLAnchorElement>) => void;\n }\n > {}\n\nexport interface LinkState {\n focusedByTab: boolean;\n}\n\nexport const LinkDataTids = {\n root: 'Link__root',\n} as const;\n\ntype DefaultProps = Required<Pick<LinkProps, 'href' | 'use'>>;\ntype DefaultizedLinkProps = DefaultizedProps<LinkProps, DefaultProps>;\n\n/**\n * Элемент ссылки из HTML.\n */\n@rootNode\nexport class Link extends React.Component<LinkProps, LinkState> {\n public static __KONTUR_REACT_UI__ = 'Link';\n\n public static propTypes = {\n disabled: PropTypes.bool,\n\n href: PropTypes.string,\n\n icon: PropTypes.node,\n\n use: PropTypes.oneOf(['default', 'success', 'danger', 'grayed']),\n };\n\n public static defaultProps: DefaultProps = {\n href: '',\n use: 'default',\n };\n\n private getProps = createPropsGetter(Link.defaultProps);\n\n public state: LinkState = {\n focusedByTab: false,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.getProps()}>\n {this.renderMain}\n </CommonWrapper>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain = (props: CommonWrapperRestProps<DefaultizedLinkProps>) => {\n const { disabled, href, icon, use, loading, _button, _buttonOpened, rel: relOrigin, ...rest } = props;\n\n let iconElement = null;\n if (icon) {\n iconElement = (\n <span className={styles.icon(this.theme)}>{loading ? <Spinner caption={null} dimmed inline /> : icon}</span>\n );\n }\n\n let arrow = null;\n if (_button) {\n arrow = <span className={styles.arrow()} />;\n }\n\n let rel = relOrigin;\n if (typeof rel === 'undefined' && href) {\n rel = `noopener${isExternalLink(href) ? ' noreferrer' : ''}`;\n }\n\n const focused = !disabled && this.state.focusedByTab;\n\n const linkProps = {\n className: cx({\n [styles.root(this.theme)]: true,\n [styles.button(this.theme)]: !!_button,\n [styles.buttonOpened(this.theme)]: !!_buttonOpened,\n [styles.useDefault(this.theme)]: use === 'default',\n [styles.useSuccess(this.theme)]: use === 'success',\n [styles.useDanger(this.theme)]: use === 'danger',\n [styles.useGrayed(this.theme)]: use === 'grayed',\n [styles.useGrayedFocus(this.theme)]: use === 'grayed' && focused,\n [styles.focus(this.theme)]: focused,\n [styles.disabled(this.theme)]: !!disabled || !!loading,\n }),\n href,\n rel,\n onClick: this._handleClick,\n onFocus: this._handleFocus,\n onBlur: this._handleBlur,\n tabIndex: disabled || loading ? -1 : this.props.tabIndex,\n };\n\n return (\n <a data-tid={LinkDataTids.root} {...rest} {...linkProps}>\n {iconElement}\n {this.props.children}\n {arrow}\n </a>\n );\n };\n\n private _handleFocus = () => {\n if (!this.props.disabled) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n }\n };\n\n private _handleBlur = () => {\n this.setState({ focusedByTab: false });\n };\n\n private _handleClick = (event: React.MouseEvent<HTMLAnchorElement>) => {\n const { onClick, disabled, loading } = this.props;\n const href = this.getProps().href;\n if (!href) {\n event.preventDefault();\n }\n if (onClick && !disabled && !loading) {\n onClick(event);\n }\n };\n}\n"]}
@@ -47,6 +47,7 @@ export interface LinkState {
47
47
  export declare const LinkDataTids: {
48
48
  readonly root: "Link__root";
49
49
  };
50
+ declare type DefaultProps = Required<Pick<LinkProps, 'href' | 'use'>>;
50
51
  /**
51
52
  * Элемент ссылки из HTML.
52
53
  */
@@ -58,13 +59,9 @@ export declare class Link extends React.Component<LinkProps, LinkState> {
58
59
  icon: PropTypes.Requireable<PropTypes.ReactNodeLike>;
59
60
  use: PropTypes.Requireable<string>;
60
61
  };
61
- static defaultProps: {
62
- href: string;
63
- use: string;
64
- };
65
- state: {
66
- focusedByTab: boolean;
67
- };
62
+ static defaultProps: DefaultProps;
63
+ private getProps;
64
+ state: LinkState;
68
65
  private theme;
69
66
  private setRootNode;
70
67
  render(): JSX.Element;
@@ -73,3 +70,4 @@ export declare class Link extends React.Component<LinkProps, LinkState> {
73
70
  private _handleBlur;
74
71
  private _handleClick;
75
72
  }
73
+ export {};
@@ -17,22 +17,24 @@ import { TaskWithDelayAndMinimalDuration } from "../../../lib/taskWithDelayAndMi
17
17
  import { getTabbableElements } from "../../../lib/dom/tabbableHelpers";
18
18
  import { rootNode } from "../../../lib/rootNode";
19
19
  import { getDOMRect } from "../../../lib/dom/getDOMRect";
20
+ import { createPropsGetter } from "../../../lib/createPropsGetter";
20
21
  import { styles } from "../Loader.styles";
21
22
  export var LoaderDataTids = {
22
23
  veil: 'Loader__Veil',
23
24
  spinner: 'Loader__Spinner'
24
25
  };
26
+ export
25
27
  /**
26
- * DRAFT - лоадер-контейнер
27
- */
28
-
29
- export var Loader = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_React$Component) {
28
+ * DRAFT - лоадер-контейнер
29
+ */
30
+ var Loader = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (_React$Component) {
30
31
  _inheritsLoose(Loader, _React$Component);
31
32
 
32
33
  function Loader(props) {
33
34
  var _this;
34
35
 
35
36
  _this = _React$Component.call(this, props) || this;
37
+ _this.getProps = createPropsGetter(Loader.defaultProps);
36
38
 
37
39
  _this.childrenRef = function (element) {
38
40
  _this.childrenContainerNode = element;
@@ -174,8 +176,8 @@ export var Loader = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (
174
176
  isLoaderActive: false
175
177
  };
176
178
  _this.spinnerTask = new TaskWithDelayAndMinimalDuration({
177
- delayBeforeTaskStart: _this.props.delayBeforeSpinnerShow,
178
- durationOfTask: _this.props.minimalDelayBeforeSpinnerHide,
179
+ delayBeforeTaskStart: _this.getProps().delayBeforeSpinnerShow,
180
+ durationOfTask: _this.getProps().minimalDelayBeforeSpinnerHide,
179
181
  taskStartCallback: function taskStartCallback() {
180
182
  return _this.setState({
181
183
  isSpinnerVisible: true
@@ -193,21 +195,24 @@ export var Loader = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (
193
195
  var _proto = Loader.prototype;
194
196
 
195
197
  _proto.componentDidMount = function componentDidMount() {
198
+ var active = this.getProps().active;
196
199
  this.checkSpinnerPosition();
197
- this.props.active && this.spinnerTask.start();
200
+ active && this.spinnerTask.start();
198
201
  this.layoutEvents = LayoutEvents.addListener(debounce(this.checkSpinnerPosition, 10));
199
202
 
200
- if (this.props.active) {
203
+ if (active) {
201
204
  this.disableChildrenFocus();
202
205
  }
203
206
  };
204
207
 
205
208
  _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {
206
- var _this$props = this.props,
207
- component = _this$props.component,
208
- active = _this$props.active,
209
- delayBeforeSpinnerShow = _this$props.delayBeforeSpinnerShow,
210
- minimalDelayBeforeSpinnerHide = _this$props.minimalDelayBeforeSpinnerHide;
209
+ var component = this.props.component;
210
+
211
+ var _this$getProps = this.getProps(),
212
+ active = _this$getProps.active,
213
+ delayBeforeSpinnerShow = _this$getProps.delayBeforeSpinnerShow,
214
+ minimalDelayBeforeSpinnerHide = _this$getProps.minimalDelayBeforeSpinnerHide;
215
+
211
216
  var isLoaderActive = this.state.isLoaderActive;
212
217
 
213
218
  if (active && !prevProps.active || prevProps.component !== component) {
@@ -272,10 +277,10 @@ export var Loader = rootNode(_class = (_temp = _class2 = /*#__PURE__*/function (
272
277
  _proto.renderMain = function renderMain() {
273
278
  var _cx;
274
279
 
275
- var _this$props2 = this.props,
276
- type = _this$props2.type,
277
- caption = _this$props2.caption,
278
- component = _this$props2.component;
280
+ var _this$props = this.props,
281
+ caption = _this$props.caption,
282
+ component = _this$props.component;
283
+ var type = this.getProps().type;
279
284
  var isLoaderActive = this.state.isLoaderActive;
280
285
  return /*#__PURE__*/React.createElement(CommonWrapper, _extends({
281
286
  rootNodeRef: this.setRootNode
@@ -1 +1 @@
1
- {"version":3,"sources":["Loader.tsx"],"names":["React","PropTypes","debounce","LayoutEvents","Spinner","ThemeContext","ZIndex","CommonWrapper","cx","isTestEnv","TaskWithDelayAndMinimalDuration","getTabbableElements","rootNode","getDOMRect","styles","LoaderDataTids","veil","spinner","Loader","props","childrenRef","element","childrenContainerNode","spinnerRef","spinnerContainerNode","checkSpinnerPosition","containerTop","top","containerRight","right","containerBottom","bottom","containerLeft","left","containerHeight","height","containerWidth","width","windowHeight","window","innerHeight","windowWidth","innerWidth","setState","isStickySpinner","spinnerStyle","Math","abs","spinnerHeight","spinnerNode","disableChildrenFocus","childrenObserver","makeObservable","tabbableElements","forEach","el","hasAttribute","setAttribute","tabIndex","toString","enableChildrenFocus","makeUnobservable","Array","from","document","querySelectorAll","getAttribute","removeAttribute","target","config","childList","subtree","observer","MutationObserver","observe","disconnect","state","isSpinnerVisible","isLoaderActive","spinnerTask","delayBeforeTaskStart","delayBeforeSpinnerShow","durationOfTask","minimalDelayBeforeSpinnerHide","taskStartCallback","taskStopCallback","componentDidMount","active","start","layoutEvents","addListener","componentDidUpdate","prevProps","prevState","component","update","stop","componentWillUnmount","remove","clearTask","getDerivedStateFromProps","render","theme","renderMain","type","caption","setRootNode","loader","children","renderSpinner","spinnerContainer","spinnerContainerSticky","spinnerComponentWrapper","undefined","Component","__KONTUR_REACT_UI__","defaultProps","Types","normal","propTypes","bool","node","className","string","oneOf","Object","keys","number"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debounce from 'lodash.debounce';\n\nimport * as LayoutEvents from '../../lib/LayoutEvents';\nimport { Spinner, SpinnerProps } from '../Spinner';\nimport { Nullable } from '../../typings/utility-types';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ZIndex } from '../../internal/ZIndex';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { isTestEnv } from '../../lib/currentEnvironment';\nimport { TaskWithDelayAndMinimalDuration } from '../../lib/taskWithDelayAndMinimalDuration';\nimport { getTabbableElements } from '../../lib/dom/tabbableHelpers';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { getDOMRect } from '../../lib/dom/getDOMRect';\n\nimport { styles } from './Loader.styles';\n\nexport interface LoaderProps extends CommonProps {\n children?: React.ReactNode;\n /**\n * Флаг переключения состояния лоадера\n * @default false\n */\n active: boolean;\n caption?: SpinnerProps['caption'];\n /**\n * Компонент заменяющий спиннер.\n */\n component?: React.ReactNode;\n className?: string;\n type?: 'mini' | 'normal' | 'big';\n /**\n * Время в миллисекундах для показа вуали без спиннера.\n * @default 300\n */\n delayBeforeSpinnerShow: number;\n /**\n * Минимальное время в миллисекундах для показа спиннера\n * @default 1000\n */\n minimalDelayBeforeSpinnerHide: number;\n}\n\nexport interface LoaderState {\n isStickySpinner: boolean;\n isSpinnerVisible: boolean;\n isLoaderActive: boolean;\n spinnerStyle?: object;\n}\n\nexport const LoaderDataTids = {\n veil: 'Loader__Veil',\n spinner: 'Loader__Spinner',\n} as const;\n\n/**\n * DRAFT - лоадер-контейнер\n */\n@rootNode\nexport class Loader extends React.Component<LoaderProps, LoaderState> {\n public static __KONTUR_REACT_UI__ = 'Loader';\n\n public static defaultProps: Partial<LoaderProps> = {\n type: Spinner.Types.normal,\n active: false,\n delayBeforeSpinnerShow: isTestEnv ? 0 : 300,\n minimalDelayBeforeSpinnerHide: isTestEnv ? 0 : 1000,\n };\n\n public static propTypes = {\n /**\n * показываем лоадер или нет\n */\n active: PropTypes.bool,\n\n /**\n * Текст рядом с лоадером.\n *\n * @default \"Загрузка\"\n */\n caption: Spinner.propTypes.caption,\n\n component: PropTypes.node,\n\n /**\n * Класс для обертки\n */\n className: PropTypes.string,\n\n /**\n * Тип спиннера: mini, normal, big\n *\n * @default normal\n *\n * Spinner.types - все доступные типы\n */\n type: PropTypes.oneOf(Object.keys(Spinner.Types)),\n /**\n * Время в миллисекундах для показа вуали без спиннера.\n * @default 300\n */\n delayBeforeSpinnerShow: PropTypes.number,\n /**\n * Минимальное время в миллисекундах для показа спиннера\n * @default 1000\n */\n minimalDelayBeforeSpinnerHide: PropTypes.number,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n private spinnerContainerNode: Nullable<HTMLDivElement>;\n private childrenContainerNode: Nullable<HTMLDivElement>;\n private spinnerNode: Nullable<HTMLDivElement>;\n private layoutEvents: Nullable<{ remove: () => void }>;\n private spinnerTask: TaskWithDelayAndMinimalDuration;\n private childrenObserver: Nullable<MutationObserver>;\n\n constructor(props: LoaderProps) {\n super(props);\n\n this.spinnerContainerNode = null;\n this.childrenContainerNode = null;\n this.childrenObserver = null;\n this.spinnerNode = null;\n\n this.state = {\n isStickySpinner: false,\n isSpinnerVisible: false,\n isLoaderActive: false,\n };\n\n this.spinnerTask = new TaskWithDelayAndMinimalDuration({\n delayBeforeTaskStart: this.props.delayBeforeSpinnerShow,\n durationOfTask: this.props.minimalDelayBeforeSpinnerHide,\n taskStartCallback: () => this.setState({ isSpinnerVisible: true }),\n taskStopCallback: () => this.setState({ isSpinnerVisible: false }),\n });\n }\n\n public componentDidMount() {\n this.checkSpinnerPosition();\n this.props.active && this.spinnerTask.start();\n this.layoutEvents = LayoutEvents.addListener(debounce(this.checkSpinnerPosition, 10));\n\n if (this.props.active) {\n this.disableChildrenFocus();\n }\n }\n\n public componentDidUpdate(prevProps: Readonly<LoaderProps>, prevState: Readonly<LoaderState>) {\n const { component, active, delayBeforeSpinnerShow, minimalDelayBeforeSpinnerHide } = this.props;\n const { isLoaderActive } = this.state;\n\n if ((active && !prevProps.active) || prevProps.component !== component) {\n this.checkSpinnerPosition();\n }\n\n if (\n delayBeforeSpinnerShow !== prevProps.delayBeforeSpinnerShow ||\n minimalDelayBeforeSpinnerHide !== prevProps.minimalDelayBeforeSpinnerHide\n ) {\n this.spinnerTask.update({\n delayBeforeTaskStart: delayBeforeSpinnerShow,\n durationOfTask: minimalDelayBeforeSpinnerHide,\n });\n }\n\n if (active !== prevProps.active) {\n active ? this.spinnerTask.start() : this.spinnerTask.stop();\n }\n\n if (isLoaderActive !== prevState.isLoaderActive) {\n if (isLoaderActive) {\n this.disableChildrenFocus();\n } else {\n this.enableChildrenFocus();\n }\n }\n }\n\n public componentWillUnmount() {\n this.makeUnobservable();\n if (this.layoutEvents) {\n this.layoutEvents.remove();\n }\n this.spinnerTask.clearTask();\n }\n\n public static getDerivedStateFromProps(props: LoaderProps, state: LoaderState): Partial<LoaderState> {\n if (props.active && !state.isLoaderActive) {\n return {\n isLoaderActive: true,\n };\n }\n if (state.isLoaderActive && !(props.active || state.isSpinnerVisible)) {\n return {\n isLoaderActive: false,\n };\n }\n\n return state;\n }\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { type, caption, component } = this.props;\n const { isLoaderActive } = this.state;\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div className={styles.loader()} data-tid={isLoaderActive ? LoaderDataTids.veil : ''}>\n <ZIndex\n priority={'Loader'}\n applyZIndex={isLoaderActive}\n coverChildren={isLoaderActive}\n style={{ height: '100%' }}\n wrapperRef={this.childrenRef}\n >\n {this.props.children}\n </ZIndex>\n {isLoaderActive && (\n <ZIndex\n wrapperRef={this.spinnerRef}\n priority={'Loader'}\n className={cx({\n [styles.active(this.theme)]: isLoaderActive,\n })}\n >\n {this.state.isSpinnerVisible && this.renderSpinner(type, caption, component)}\n </ZIndex>\n )}\n </div>\n </CommonWrapper>\n );\n }\n\n private childrenRef = (element: HTMLDivElement | null) => {\n this.childrenContainerNode = element;\n };\n\n private spinnerRef = (element: HTMLDivElement | null) => {\n this.spinnerContainerNode = element;\n };\n\n private renderSpinner(type?: 'mini' | 'normal' | 'big', caption?: React.ReactNode, component?: React.ReactNode) {\n return (\n <span\n data-tid={LoaderDataTids.spinner}\n className={cx(styles.spinnerContainer(), { [styles.spinnerContainerSticky()]: this.state.isStickySpinner })}\n style={this.state.spinnerStyle}\n >\n <div\n className={styles.spinnerComponentWrapper()}\n ref={(element) => {\n this.spinnerNode = element;\n }}\n >\n {component !== undefined ? component : <Spinner type={type} caption={caption} />}\n </div>\n </span>\n );\n }\n\n private checkSpinnerPosition = () => {\n if (!this.spinnerContainerNode) {\n return;\n }\n\n const {\n top: containerTop,\n right: containerRight,\n bottom: containerBottom,\n left: containerLeft,\n height: containerHeight,\n width: containerWidth,\n } = getDOMRect(this.spinnerContainerNode);\n\n const windowHeight = window.innerHeight;\n const windowWidth = window.innerWidth;\n\n // Если контейнер не больше высоты и не шире окна,\n // то просто выравниваем по центру\n if (windowHeight >= containerHeight && windowWidth >= containerWidth) {\n this.setState({\n isStickySpinner: false,\n spinnerStyle: {},\n });\n return;\n }\n\n const spinnerStyle: {\n top?: number;\n right: number;\n bottom: number;\n left: number;\n } = {\n top: 30,\n right: 0,\n bottom: 30,\n left: 0,\n };\n\n // ПО ВЕРТИКАЛИ\n // Если верхний край контейнера ниже верхнего края окна,\n // то сдвигаем и лоадер\n if (containerTop > 0) {\n spinnerStyle.top = containerTop + 30;\n }\n\n // Если нижний край контейнера выше нижнего края окна,\n // то сдвигаем и лоадер\n if (containerBottom < windowHeight) {\n spinnerStyle.bottom = Math.abs(windowHeight - containerBottom) + 30;\n }\n\n // Если знаем высоту спиннера и нижний край контейнера поднимается\n // выше отступа на высоту спиннера, то убираем верхнюю позицию лоадера\n\n const spinnerHeight = getDOMRect(this.spinnerNode).height;\n\n if (spinnerHeight && spinnerStyle.bottom >= windowHeight - spinnerHeight) {\n delete spinnerStyle.top;\n }\n\n // ПО ГОРИЗОНТАЛИ\n // Если левый край контейнера правее левого края окна,\n // то сдвигаем и лоадер\n if (containerLeft > 0) {\n spinnerStyle.left = containerLeft;\n }\n\n // Если правый край контейнера левее правого края окна,\n // то сдвигаем и лоадер\n if (containerRight < windowWidth) {\n spinnerStyle.right = windowWidth - containerRight;\n }\n\n this.setState({\n isStickySpinner: true,\n spinnerStyle,\n });\n };\n\n private disableChildrenFocus = () => {\n if (!this.childrenObserver) {\n this.makeObservable();\n }\n const tabbableElements = getTabbableElements(this.childrenContainerNode);\n tabbableElements.forEach((el) => {\n if (!el.hasAttribute('origin-tabindex')) {\n el.setAttribute('origin-tabindex', el.tabIndex.toString());\n }\n el.tabIndex = -1;\n });\n };\n\n private enableChildrenFocus = () => {\n this.makeUnobservable();\n // NOTE: NodeList doesn't support 'forEach' method in IE11 and other older browsers\n Array.from(document.querySelectorAll('[origin-tabindex]')).forEach((el) => {\n el.setAttribute('tabindex', el.getAttribute('origin-tabindex') ?? '0');\n el.removeAttribute('origin-tabindex');\n });\n };\n\n private makeObservable = () => {\n const target = this.childrenContainerNode;\n if (!target) {\n return;\n }\n const config = {\n childList: true,\n subtree: true,\n };\n const observer = new MutationObserver(this.disableChildrenFocus);\n observer.observe(target, config);\n this.childrenObserver = observer;\n };\n\n private makeUnobservable = () => {\n this.childrenObserver?.disconnect();\n this.childrenObserver = null;\n };\n}\n"]}
1
+ {"version":3,"sources":["Loader.tsx"],"names":["React","PropTypes","debounce","LayoutEvents","Spinner","ThemeContext","ZIndex","CommonWrapper","cx","isTestEnv","TaskWithDelayAndMinimalDuration","getTabbableElements","rootNode","getDOMRect","createPropsGetter","styles","LoaderDataTids","veil","spinner","Loader","props","getProps","defaultProps","childrenRef","element","childrenContainerNode","spinnerRef","spinnerContainerNode","checkSpinnerPosition","containerTop","top","containerRight","right","containerBottom","bottom","containerLeft","left","containerHeight","height","containerWidth","width","windowHeight","window","innerHeight","windowWidth","innerWidth","setState","isStickySpinner","spinnerStyle","Math","abs","spinnerHeight","spinnerNode","disableChildrenFocus","childrenObserver","makeObservable","tabbableElements","forEach","el","hasAttribute","setAttribute","tabIndex","toString","enableChildrenFocus","makeUnobservable","Array","from","document","querySelectorAll","getAttribute","removeAttribute","target","config","childList","subtree","observer","MutationObserver","observe","disconnect","state","isSpinnerVisible","isLoaderActive","spinnerTask","delayBeforeTaskStart","delayBeforeSpinnerShow","durationOfTask","minimalDelayBeforeSpinnerHide","taskStartCallback","taskStopCallback","componentDidMount","active","start","layoutEvents","addListener","componentDidUpdate","prevProps","prevState","component","update","stop","componentWillUnmount","remove","clearTask","getDerivedStateFromProps","render","theme","renderMain","caption","type","setRootNode","loader","children","renderSpinner","spinnerContainer","spinnerContainerSticky","spinnerComponentWrapper","undefined","Component","__KONTUR_REACT_UI__","Types","normal","propTypes","bool","node","className","string","oneOf","Object","keys","number"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debounce from 'lodash.debounce';\n\nimport { AnyObject } from '../../lib/utils';\nimport * as LayoutEvents from '../../lib/LayoutEvents';\nimport { Spinner, SpinnerProps } from '../Spinner';\nimport { Nullable } from '../../typings/utility-types';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ZIndex } from '../../internal/ZIndex';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { isTestEnv } from '../../lib/currentEnvironment';\nimport { TaskWithDelayAndMinimalDuration } from '../../lib/taskWithDelayAndMinimalDuration';\nimport { getTabbableElements } from '../../lib/dom/tabbableHelpers';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { getDOMRect } from '../../lib/dom/getDOMRect';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\n\nimport { styles } from './Loader.styles';\n\nexport interface LoaderProps extends CommonProps {\n children?: React.ReactNode;\n /**\n * Флаг переключения состояния лоадера\n * @default false\n */\n active?: boolean;\n caption?: SpinnerProps['caption'];\n /**\n * Компонент заменяющий спиннер.\n */\n component?: React.ReactNode;\n className?: string;\n type?: 'mini' | 'normal' | 'big';\n /**\n * Время в миллисекундах для показа вуали без спиннера.\n * @default 300\n */\n delayBeforeSpinnerShow?: number;\n /**\n * Минимальное время в миллисекундах для показа спиннера\n * @default 1000\n */\n minimalDelayBeforeSpinnerHide?: number;\n}\n\nexport interface LoaderState {\n isStickySpinner: boolean;\n isSpinnerVisible: boolean;\n isLoaderActive: boolean;\n spinnerStyle?: AnyObject;\n}\n\nexport const LoaderDataTids = {\n veil: 'Loader__Veil',\n spinner: 'Loader__Spinner',\n} as const;\n\ntype DefaultProps = Required<\n Pick<LoaderProps, 'type' | 'active' | 'delayBeforeSpinnerShow' | 'minimalDelayBeforeSpinnerHide'>\n>;\n\n/**\n * DRAFT - лоадер-контейнер\n */\n@rootNode\nexport class Loader extends React.Component<LoaderProps, LoaderState> {\n public static __KONTUR_REACT_UI__ = 'Loader';\n\n public static defaultProps: DefaultProps = {\n type: Spinner.Types.normal,\n active: false,\n delayBeforeSpinnerShow: isTestEnv ? 0 : 300,\n minimalDelayBeforeSpinnerHide: isTestEnv ? 0 : 1000,\n };\n\n private getProps = createPropsGetter(Loader.defaultProps);\n\n public static propTypes = {\n /**\n * показываем лоадер или нет\n */\n active: PropTypes.bool,\n\n /**\n * Текст рядом с лоадером.\n *\n * @default \"Загрузка\"\n */\n caption: Spinner.propTypes.caption,\n\n component: PropTypes.node,\n\n /**\n * Класс для обертки\n */\n className: PropTypes.string,\n\n /**\n * Тип спиннера: mini, normal, big\n *\n * @default normal\n *\n * Spinner.types - все доступные типы\n */\n type: PropTypes.oneOf(Object.keys(Spinner.Types)),\n /**\n * Время в миллисекундах для показа вуали без спиннера.\n * @default 300\n */\n delayBeforeSpinnerShow: PropTypes.number,\n /**\n * Минимальное время в миллисекундах для показа спиннера\n * @default 1000\n */\n minimalDelayBeforeSpinnerHide: PropTypes.number,\n };\n\n private theme!: Theme;\n private setRootNode!: TSetRootNode;\n private spinnerContainerNode: Nullable<HTMLDivElement>;\n private childrenContainerNode: Nullable<HTMLDivElement>;\n private spinnerNode: Nullable<HTMLDivElement>;\n private layoutEvents: Nullable<{ remove: () => void }>;\n private spinnerTask: TaskWithDelayAndMinimalDuration;\n private childrenObserver: Nullable<MutationObserver>;\n\n constructor(props: LoaderProps) {\n super(props);\n\n this.spinnerContainerNode = null;\n this.childrenContainerNode = null;\n this.childrenObserver = null;\n this.spinnerNode = null;\n\n this.state = {\n isStickySpinner: false,\n isSpinnerVisible: false,\n isLoaderActive: false,\n };\n\n this.spinnerTask = new TaskWithDelayAndMinimalDuration({\n delayBeforeTaskStart: this.getProps().delayBeforeSpinnerShow,\n durationOfTask: this.getProps().minimalDelayBeforeSpinnerHide,\n taskStartCallback: () => this.setState({ isSpinnerVisible: true }),\n taskStopCallback: () => this.setState({ isSpinnerVisible: false }),\n });\n }\n\n public componentDidMount() {\n const active = this.getProps().active;\n this.checkSpinnerPosition();\n active && this.spinnerTask.start();\n this.layoutEvents = LayoutEvents.addListener(debounce(this.checkSpinnerPosition, 10));\n\n if (active) {\n this.disableChildrenFocus();\n }\n }\n\n public componentDidUpdate(prevProps: Readonly<LoaderProps>, prevState: Readonly<LoaderState>) {\n const { component } = this.props;\n const { active, delayBeforeSpinnerShow, minimalDelayBeforeSpinnerHide } = this.getProps();\n const { isLoaderActive } = this.state;\n\n if ((active && !prevProps.active) || prevProps.component !== component) {\n this.checkSpinnerPosition();\n }\n\n if (\n delayBeforeSpinnerShow !== prevProps.delayBeforeSpinnerShow ||\n minimalDelayBeforeSpinnerHide !== prevProps.minimalDelayBeforeSpinnerHide\n ) {\n this.spinnerTask.update({\n delayBeforeTaskStart: delayBeforeSpinnerShow,\n durationOfTask: minimalDelayBeforeSpinnerHide,\n });\n }\n\n if (active !== prevProps.active) {\n active ? this.spinnerTask.start() : this.spinnerTask.stop();\n }\n\n if (isLoaderActive !== prevState.isLoaderActive) {\n if (isLoaderActive) {\n this.disableChildrenFocus();\n } else {\n this.enableChildrenFocus();\n }\n }\n }\n\n public componentWillUnmount() {\n this.makeUnobservable();\n if (this.layoutEvents) {\n this.layoutEvents.remove();\n }\n this.spinnerTask.clearTask();\n }\n\n public static getDerivedStateFromProps(props: LoaderProps, state: LoaderState): Partial<LoaderState> {\n if (props.active && !state.isLoaderActive) {\n return {\n isLoaderActive: true,\n };\n }\n if (state.isLoaderActive && !(props.active || state.isSpinnerVisible)) {\n return {\n isLoaderActive: false,\n };\n }\n\n return state;\n }\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { caption, component } = this.props;\n const type = this.getProps().type;\n const { isLoaderActive } = this.state;\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div className={styles.loader()} data-tid={isLoaderActive ? LoaderDataTids.veil : ''}>\n <ZIndex\n priority={'Loader'}\n applyZIndex={isLoaderActive}\n coverChildren={isLoaderActive}\n style={{ height: '100%' }}\n wrapperRef={this.childrenRef}\n >\n {this.props.children}\n </ZIndex>\n {isLoaderActive && (\n <ZIndex\n wrapperRef={this.spinnerRef}\n priority={'Loader'}\n className={cx({\n [styles.active(this.theme)]: isLoaderActive,\n })}\n >\n {this.state.isSpinnerVisible && this.renderSpinner(type, caption, component)}\n </ZIndex>\n )}\n </div>\n </CommonWrapper>\n );\n }\n\n private childrenRef = (element: HTMLDivElement | null) => {\n this.childrenContainerNode = element;\n };\n\n private spinnerRef = (element: HTMLDivElement | null) => {\n this.spinnerContainerNode = element;\n };\n\n private renderSpinner(type?: 'mini' | 'normal' | 'big', caption?: React.ReactNode, component?: React.ReactNode) {\n return (\n <span\n data-tid={LoaderDataTids.spinner}\n className={cx(styles.spinnerContainer(), { [styles.spinnerContainerSticky()]: this.state.isStickySpinner })}\n style={this.state.spinnerStyle}\n >\n <div\n className={styles.spinnerComponentWrapper()}\n ref={(element) => {\n this.spinnerNode = element;\n }}\n >\n {component !== undefined ? component : <Spinner type={type} caption={caption} />}\n </div>\n </span>\n );\n }\n\n private checkSpinnerPosition = () => {\n if (!this.spinnerContainerNode) {\n return;\n }\n\n const {\n top: containerTop,\n right: containerRight,\n bottom: containerBottom,\n left: containerLeft,\n height: containerHeight,\n width: containerWidth,\n } = getDOMRect(this.spinnerContainerNode);\n\n const windowHeight = window.innerHeight;\n const windowWidth = window.innerWidth;\n\n // Если контейнер не больше высоты и не шире окна,\n // то просто выравниваем по центру\n if (windowHeight >= containerHeight && windowWidth >= containerWidth) {\n this.setState({\n isStickySpinner: false,\n spinnerStyle: {},\n });\n return;\n }\n\n const spinnerStyle: {\n top?: number;\n right: number;\n bottom: number;\n left: number;\n } = {\n top: 30,\n right: 0,\n bottom: 30,\n left: 0,\n };\n\n // ПО ВЕРТИКАЛИ\n // Если верхний край контейнера ниже верхнего края окна,\n // то сдвигаем и лоадер\n if (containerTop > 0) {\n spinnerStyle.top = containerTop + 30;\n }\n\n // Если нижний край контейнера выше нижнего края окна,\n // то сдвигаем и лоадер\n if (containerBottom < windowHeight) {\n spinnerStyle.bottom = Math.abs(windowHeight - containerBottom) + 30;\n }\n\n // Если знаем высоту спиннера и нижний край контейнера поднимается\n // выше отступа на высоту спиннера, то убираем верхнюю позицию лоадера\n\n const spinnerHeight = getDOMRect(this.spinnerNode).height;\n\n if (spinnerHeight && spinnerStyle.bottom >= windowHeight - spinnerHeight) {\n delete spinnerStyle.top;\n }\n\n // ПО ГОРИЗОНТАЛИ\n // Если левый край контейнера правее левого края окна,\n // то сдвигаем и лоадер\n if (containerLeft > 0) {\n spinnerStyle.left = containerLeft;\n }\n\n // Если правый край контейнера левее правого края окна,\n // то сдвигаем и лоадер\n if (containerRight < windowWidth) {\n spinnerStyle.right = windowWidth - containerRight;\n }\n\n this.setState({\n isStickySpinner: true,\n spinnerStyle,\n });\n };\n\n private disableChildrenFocus = () => {\n if (!this.childrenObserver) {\n this.makeObservable();\n }\n const tabbableElements = getTabbableElements(this.childrenContainerNode);\n tabbableElements.forEach((el) => {\n if (!el.hasAttribute('origin-tabindex')) {\n el.setAttribute('origin-tabindex', el.tabIndex.toString());\n }\n el.tabIndex = -1;\n });\n };\n\n private enableChildrenFocus = () => {\n this.makeUnobservable();\n // NOTE: NodeList doesn't support 'forEach' method in IE11 and other older browsers\n Array.from(document.querySelectorAll('[origin-tabindex]')).forEach((el) => {\n el.setAttribute('tabindex', el.getAttribute('origin-tabindex') ?? '0');\n el.removeAttribute('origin-tabindex');\n });\n };\n\n private makeObservable = () => {\n const target = this.childrenContainerNode;\n if (!target) {\n return;\n }\n const config = {\n childList: true,\n subtree: true,\n };\n const observer = new MutationObserver(this.disableChildrenFocus);\n observer.observe(target, config);\n this.childrenObserver = observer;\n };\n\n private makeUnobservable = () => {\n this.childrenObserver?.disconnect();\n this.childrenObserver = null;\n };\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import { AnyObject } from '../../lib/utils';
3
4
  import { SpinnerProps } from '../Spinner';
4
5
  import { CommonProps } from '../../internal/CommonWrapper';
5
6
  export interface LoaderProps extends CommonProps {
@@ -8,7 +9,7 @@ export interface LoaderProps extends CommonProps {
8
9
  * Флаг переключения состояния лоадера
9
10
  * @default false
10
11
  */
11
- active: boolean;
12
+ active?: boolean;
12
13
  caption?: SpinnerProps['caption'];
13
14
  /**
14
15
  * Компонент заменяющий спиннер.
@@ -20,29 +21,31 @@ export interface LoaderProps extends CommonProps {
20
21
  * Время в миллисекундах для показа вуали без спиннера.
21
22
  * @default 300
22
23
  */
23
- delayBeforeSpinnerShow: number;
24
+ delayBeforeSpinnerShow?: number;
24
25
  /**
25
26
  * Минимальное время в миллисекундах для показа спиннера
26
27
  * @default 1000
27
28
  */
28
- minimalDelayBeforeSpinnerHide: number;
29
+ minimalDelayBeforeSpinnerHide?: number;
29
30
  }
30
31
  export interface LoaderState {
31
32
  isStickySpinner: boolean;
32
33
  isSpinnerVisible: boolean;
33
34
  isLoaderActive: boolean;
34
- spinnerStyle?: object;
35
+ spinnerStyle?: AnyObject;
35
36
  }
36
37
  export declare const LoaderDataTids: {
37
38
  readonly veil: "Loader__Veil";
38
39
  readonly spinner: "Loader__Spinner";
39
40
  };
41
+ declare type DefaultProps = Required<Pick<LoaderProps, 'type' | 'active' | 'delayBeforeSpinnerShow' | 'minimalDelayBeforeSpinnerHide'>>;
40
42
  /**
41
43
  * DRAFT - лоадер-контейнер
42
44
  */
43
45
  export declare class Loader extends React.Component<LoaderProps, LoaderState> {
44
46
  static __KONTUR_REACT_UI__: string;
45
- static defaultProps: Partial<LoaderProps>;
47
+ static defaultProps: DefaultProps;
48
+ private getProps;
46
49
  static propTypes: {
47
50
  /**
48
51
  * показываем лоадер или нет
@@ -102,3 +105,4 @@ export declare class Loader extends React.Component<LoaderProps, LoaderState> {
102
105
  private makeObservable;
103
106
  private makeUnobservable;
104
107
  }
108
+ export {};
@@ -1 +1 @@
1
- {"version":3,"sources":["LoaderAndButton.tsx"],"names":["React","Tooltip","Button","Loader","LoaderAndButton","state","isTooltipOpened","render","props","active","setState","isActive","Component"],"mappings":"sEAAA,OAAOA,KAAP,MAAkB,OAAlB;;AAEA,SAASC,OAAT,QAAwB,eAAxB;AACA,SAASC,MAAT,QAAuB,cAAvB;AACA,SAASC,MAAT,QAAuB,WAAvB;;AAEA,WAAaC,eAAb;AACSC,IAAAA,KADT,GACiB;AACbC,MAAAA,eAAe,EAAE,KADJ,EADjB;;;AAKSC,EAAAA,MALT,GAKE,kBAAgB;AACd;AACE,0BAAC,MAAD,IAAQ,MAAM,EAAE,KAAKC,KAAL,CAAWC,MAA3B,EAAmC,IAAI,EAAE,KAAzC;AACE,wJADF;;;;AAKE,0BAAC,OAAD,IAAS,MAAM,EAAE,0BAAM,eAAN,EAAjB,EAAwC,OAAO,EAAE,KAAKJ,KAAL,CAAWC,eAAX,GAA6B,QAA7B,GAAwC,QAAzF;AACE,0BAAC,MAAD;AACE,QAAA,OAAO,EAAE,mBAAM;AACb,UAAA,MAAI,CAACI,QAAL,CAAc,EAAEC,QAAQ,EAAE,IAAZ,EAAkBL,eAAe,EAAE,IAAnC,EAAd;AACD,SAHH,wBADF,CALF;;;;;AAcE,+LAdF;;;;AAkBE;AACqG,SADrG;AAEE,iIAFF;AAGE,2DAHF,yBAlBF;;AAuBE,iFAvBF;AAwBE,uTAxBF;;;;;AA6BE;AACE,kGADF;AAEE,+EAFF;AAGE,+EAHF,CA7BF,CADF;;;;AAqCD,GA3CH,0BAAqCN,KAAK,CAACY,SAA3C","sourcesContent":["import React from 'react';\n\nimport { Tooltip } from '../../Tooltip';\nimport { Button } from '../../Button';\nimport { Loader } from '../Loader';\n\nexport class LoaderAndButton extends React.Component<{ active: boolean }> {\n public state = {\n isTooltipOpened: false,\n };\n\n public render() {\n return (\n <Loader active={this.props.active} type={'big'}>\n <h1>\n Yeah, and if you were the pope they&apos;d be all, &quot;Straighten your pope hat.&quot; And &quot;Put on your\n good vestments.&quot;\n </h1>\n <Tooltip render={() => 'Yes, you can!'} trigger={this.state.isTooltipOpened ? 'opened' : 'closed'}>\n <Button\n onClick={() => {\n this.setState({ isActive: true, isTooltipOpened: true });\n }}\n >\n Can you click me?\n </Button>\n </Tooltip>\n <p>\n No, I&apos;m Santa Claus! I guess if you want children beaten, you have to do it yourself. We&apos;re also\n Santa Claus! Leela, Bender, we&apos;re going grave robbing.\n </p>\n <p>\n Are you crazy? I can&apos;t swallow that. Large bet on myself in round one. Hey, whatcha watching?{' '}\n <strong> Moving along… I guess if you want children beaten, you have to do it yourself.</strong>\n <em>It&apos;s okay, Bender.</em> I like cooking too.\n </p>\n <h2>Oh, I think we should just stay friends.</h2>\n <p>\n No argument here. And when we woke up, we had these bodies. You guys go on without me! I&apos;m going to go…\n look for more stuff to steal! Oh, how awful. Did he at least die painlessly? …To shreds, you say. Well, how is\n his wife holding up? …To shreds, you say.\n </p>\n <ol>\n <li>No! The kind with looting and maybe starting a few fires!</li>\n <li>You are the last hope of the universe.</li>\n <li>Hey, guess what you&apos;re accessories to.</li>\n </ol>\n </Loader>\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["LoaderAndButton.tsx"],"names":["React","Tooltip","Button","Loader","LoaderAndButton","state","isTooltipOpened","render","props","active","setState","isActive","Component"],"mappings":"sEAAA,OAAOA,KAAP,MAAkB,OAAlB;;AAEA,SAASC,OAAT,QAAwB,eAAxB;AACA,SAASC,MAAT,QAAuB,cAAvB;AACA,SAASC,MAAT,QAAuB,WAAvB;;;;;;;;AAQA,WAAaC,eAAb;AACSC,IAAAA,KADT,GACuC;AACnCC,MAAAA,eAAe,EAAE,KADkB,EADvC;;;AAKSC,EAAAA,MALT,GAKE,kBAAgB;AACd;AACE,0BAAC,MAAD,IAAQ,MAAM,EAAE,KAAKC,KAAL,CAAWC,MAA3B,EAAmC,IAAI,EAAE,KAAzC;AACE,wJADF;;;;AAKE,0BAAC,OAAD,IAAS,MAAM,EAAE,0BAAM,eAAN,EAAjB,EAAwC,OAAO,EAAE,KAAKJ,KAAL,CAAWC,eAAX,GAA6B,QAA7B,GAAwC,QAAzF;AACE,0BAAC,MAAD;AACE,QAAA,OAAO,EAAE,mBAAM;AACb,UAAA,MAAI,CAACI,QAAL,CAAc,EAAEC,QAAQ,EAAE,IAAZ,EAAkBL,eAAe,EAAE,IAAnC,EAAd;AACD,SAHH,wBADF,CALF;;;;;AAcE,+LAdF;;;;AAkBE;AACqG,SADrG;AAEE,iIAFF;AAGE,2DAHF,yBAlBF;;AAuBE,iFAvBF;AAwBE,uTAxBF;;;;;AA6BE;AACE,kGADF;AAEE,+EAFF;AAGE,+EAHF,CA7BF,CADF;;;;AAqCD,GA3CH,0BAAqCN,KAAK,CAACY,SAA3C","sourcesContent":["import React from 'react';\n\nimport { Tooltip } from '../../Tooltip';\nimport { Button } from '../../Button';\nimport { Loader } from '../Loader';\nimport { LoaderProps } from '..';\n\ntype LoaderAndButtonProps = Pick<LoaderProps, 'active'>;\ninterface LoaderAndButtonState {\n isTooltipOpened: boolean;\n isActive?: boolean;\n}\nexport class LoaderAndButton extends React.Component<LoaderAndButtonProps, LoaderAndButtonState> {\n public state: LoaderAndButtonState = {\n isTooltipOpened: false,\n };\n\n public render() {\n return (\n <Loader active={this.props.active} type={'big'}>\n <h1>\n Yeah, and if you were the pope they&apos;d be all, &quot;Straighten your pope hat.&quot; And &quot;Put on your\n good vestments.&quot;\n </h1>\n <Tooltip render={() => 'Yes, you can!'} trigger={this.state.isTooltipOpened ? 'opened' : 'closed'}>\n <Button\n onClick={() => {\n this.setState({ isActive: true, isTooltipOpened: true });\n }}\n >\n Can you click me?\n </Button>\n </Tooltip>\n <p>\n No, I&apos;m Santa Claus! I guess if you want children beaten, you have to do it yourself. We&apos;re also\n Santa Claus! Leela, Bender, we&apos;re going grave robbing.\n </p>\n <p>\n Are you crazy? I can&apos;t swallow that. Large bet on myself in round one. Hey, whatcha watching?{' '}\n <strong> Moving along… I guess if you want children beaten, you have to do it yourself.</strong>\n <em>It&apos;s okay, Bender.</em> I like cooking too.\n </p>\n <h2>Oh, I think we should just stay friends.</h2>\n <p>\n No argument here. And when we woke up, we had these bodies. You guys go on without me! I&apos;m going to go…\n look for more stuff to steal! Oh, how awful. Did he at least die painlessly? …To shreds, you say. Well, how is\n his wife holding up? …To shreds, you say.\n </p>\n <ol>\n <li>No! The kind with looting and maybe starting a few fires!</li>\n <li>You are the last hope of the universe.</li>\n <li>Hey, guess what you&apos;re accessories to.</li>\n </ol>\n </Loader>\n );\n }\n}\n"]}
@@ -3,7 +3,10 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWith
3
3
  import _inheritsLoose from "@babel/runtime/helpers/esm/inheritsLoose";
4
4
  var _excluded = ["link", "comment", "icon", "loose", "state", "_enableIconPadding", "component", "onMouseEnter", "onMouseLeave", "isMobile"];
5
5
 
6
- var _class, _class2, _temp;
6
+ var _class, _class2, _temp; // TODO: Enable this rule in functional components.
7
+
8
+ /* eslint-disable @typescript-eslint/no-unused-vars */
9
+
7
10
 
8
11
  import React from 'react';
9
12
  import PropTypes from 'prop-types';