@skbkontur/react-ui 2.17.6 → 2.17.7-sidepage-header

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 (1099) hide show
  1. package/CHANGELOG.md +2194 -2183
  2. package/README.md +61 -61
  3. package/cjs/components/Autocomplete/Autocomplete.js +23 -23
  4. package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
  5. package/cjs/components/Autocomplete/Autocomplete.md +7 -7
  6. package/cjs/components/Autocomplete/index.js.map +1 -1
  7. package/cjs/components/Button/Button.js +4 -4
  8. package/cjs/components/Button/Button.js.map +1 -1
  9. package/cjs/components/Button/Button.md +89 -89
  10. package/cjs/components/Button/Button.mixins.js.map +1 -1
  11. package/cjs/components/Button/Button.styles.js.map +1 -1
  12. package/cjs/components/Button/Corners.js.map +1 -1
  13. package/cjs/components/Button/index.js.map +1 -1
  14. package/cjs/components/Center/Center.js +3 -3
  15. package/cjs/components/Center/Center.js.map +1 -1
  16. package/cjs/components/Center/Center.md +5 -5
  17. package/cjs/components/Center/Center.styles.js.map +1 -1
  18. package/cjs/components/Center/index.js.map +1 -1
  19. package/cjs/components/Checkbox/Checkbox.js +9 -9
  20. package/cjs/components/Checkbox/Checkbox.js.map +1 -1
  21. package/cjs/components/Checkbox/Checkbox.md +63 -63
  22. package/cjs/components/Checkbox/Checkbox.styles.js.map +1 -1
  23. package/cjs/components/Checkbox/index.js.map +1 -1
  24. package/cjs/components/ComboBox/ComboBox.js +20 -20
  25. package/cjs/components/ComboBox/ComboBox.js.map +1 -1
  26. package/cjs/components/ComboBox/ComboBox.md +432 -432
  27. package/cjs/components/ComboBox/index.js.map +1 -1
  28. package/cjs/components/CurrencyInput/CurrencyHelper.js.map +1 -1
  29. package/cjs/components/CurrencyInput/CurrencyInput.js +7 -7
  30. package/cjs/components/CurrencyInput/CurrencyInput.js.map +1 -1
  31. package/cjs/components/CurrencyInput/CurrencyInput.md +20 -20
  32. package/cjs/components/CurrencyInput/CurrencyInputHelper.js.map +1 -1
  33. package/cjs/components/CurrencyInput/CurrencyInputKeyboardActions.js.map +1 -1
  34. package/cjs/components/CurrencyInput/CursorHelper.js.map +1 -1
  35. package/cjs/components/CurrencyInput/SelectionHelper.js.map +1 -1
  36. package/cjs/components/CurrencyInput/constants.js.map +1 -1
  37. package/cjs/components/CurrencyInput/index.js.map +1 -1
  38. package/cjs/components/CurrencyLabel/CurrencyLabel.js.map +1 -1
  39. package/cjs/components/CurrencyLabel/index.js.map +1 -1
  40. package/cjs/components/DateInput/DateFragmentsView.js.map +1 -1
  41. package/cjs/components/DateInput/DateFragmentsView.styles.js.map +1 -1
  42. package/cjs/components/DateInput/DateInput.js.map +1 -1
  43. package/cjs/components/DateInput/DateInput.md +104 -104
  44. package/cjs/components/DateInput/DateInput.styles.js.map +1 -1
  45. package/cjs/components/DateInput/ViewDateInputValidateChecks.js.map +1 -1
  46. package/cjs/components/DateInput/helpers/DateInputKeyboardActions.js.map +1 -1
  47. package/cjs/components/DateInput/helpers/InternalDateMediator.js.map +1 -1
  48. package/cjs/components/DateInput/helpers/SelectionHelpers.js.map +1 -1
  49. package/cjs/components/DateInput/helpers/inputNumber.js.map +1 -1
  50. package/cjs/components/DateInput/index.js.map +1 -1
  51. package/cjs/components/DatePicker/DatePicker.js +15 -15
  52. package/cjs/components/DatePicker/DatePicker.js.map +1 -1
  53. package/cjs/components/DatePicker/DatePicker.md +310 -310
  54. package/cjs/components/DatePicker/DatePicker.styles.js.map +1 -1
  55. package/cjs/components/DatePicker/DatePickerHelpers.js.map +1 -1
  56. package/cjs/components/DatePicker/Picker.js.map +1 -1
  57. package/cjs/components/DatePicker/Picker.styles.js.map +1 -1
  58. package/cjs/components/DatePicker/index.js.map +1 -1
  59. package/cjs/components/DatePicker/locale/index.js.map +1 -1
  60. package/cjs/components/DatePicker/locale/locales/en.js.map +1 -1
  61. package/cjs/components/DatePicker/locale/locales/ru.js.map +1 -1
  62. package/cjs/components/Dropdown/Dropdown.js +24 -24
  63. package/cjs/components/Dropdown/Dropdown.js.map +1 -1
  64. package/cjs/components/Dropdown/Dropdown.md +12 -12
  65. package/cjs/components/Dropdown/index.js.map +1 -1
  66. package/cjs/components/DropdownMenu/DropdownMenu.js +2 -2
  67. package/cjs/components/DropdownMenu/DropdownMenu.js.map +1 -1
  68. package/cjs/components/DropdownMenu/DropdownMenu.md +73 -73
  69. package/cjs/components/DropdownMenu/index.js.map +1 -1
  70. package/cjs/components/Fias/Fias.js +2 -2
  71. package/cjs/components/Fias/Fias.js.map +1 -1
  72. package/cjs/components/Fias/Fias.md +451 -451
  73. package/cjs/components/Fias/Fias.styles.js.map +1 -1
  74. package/cjs/components/Fias/FiasModal.js.map +1 -1
  75. package/cjs/components/Fias/FiasSearch/FiasSearch.js +2 -2
  76. package/cjs/components/Fias/FiasSearch/FiasSearch.js.map +1 -1
  77. package/cjs/components/Fias/FiasSearch/FiasSearch.md +78 -78
  78. package/cjs/components/Fias/Form/FiasComboBox.js.map +1 -1
  79. package/cjs/components/Fias/Form/FiasCountrySelector.js.map +1 -1
  80. package/cjs/components/Fias/Form/FiasForm.js.map +1 -1
  81. package/cjs/components/Fias/Form/FiasForm.styles.js.map +1 -1
  82. package/cjs/components/Fias/api/FiasAPI.js.map +1 -1
  83. package/cjs/components/Fias/api/FiasAPIResultFactory.js.map +1 -1
  84. package/cjs/components/Fias/api/FiasMockAPI.js.map +1 -1
  85. package/cjs/components/Fias/api/data.json +285 -285
  86. package/cjs/components/Fias/constants/abbreviations.js.map +1 -1
  87. package/cjs/components/Fias/index.js.map +1 -1
  88. package/cjs/components/Fias/locale/index.js.map +1 -1
  89. package/cjs/components/Fias/locale/locales/ru.js.map +1 -1
  90. package/cjs/components/Fias/logger/FiasLogger.js.map +1 -1
  91. package/cjs/components/Fias/models/FiasAddress.js.map +1 -1
  92. package/cjs/components/Fias/models/FiasAddressElement.js.map +1 -1
  93. package/cjs/components/Fias/models/FiasData.js.map +1 -1
  94. package/cjs/components/Fias/types.js.map +1 -1
  95. package/cjs/components/FxInput/FxInput.js.map +1 -1
  96. package/cjs/components/FxInput/FxInput.md +13 -13
  97. package/cjs/components/FxInput/index.js.map +1 -1
  98. package/cjs/components/Gapped/Gapped.js +8 -8
  99. package/cjs/components/Gapped/Gapped.js.map +1 -1
  100. package/cjs/components/Gapped/index.js.map +1 -1
  101. package/cjs/components/Group/Group.js.map +1 -1
  102. package/cjs/components/Group/Group.md +26 -26
  103. package/cjs/components/Group/Group.styles.js.map +1 -1
  104. package/cjs/components/Group/index.js.map +1 -1
  105. package/cjs/components/Hint/Hint.js.map +1 -1
  106. package/cjs/components/Hint/Hint.md +3 -3
  107. package/cjs/components/Hint/Hint.styles.js.map +1 -1
  108. package/cjs/components/Hint/index.js.map +1 -1
  109. package/cjs/components/Input/Input.js +13 -13
  110. package/cjs/components/Input/Input.js.map +1 -1
  111. package/cjs/components/Input/Input.styles.js.map +1 -1
  112. package/cjs/components/Input/index.js.map +1 -1
  113. package/cjs/components/Kebab/Kebab.js +6 -6
  114. package/cjs/components/Kebab/Kebab.js.map +1 -1
  115. package/cjs/components/Kebab/Kebab.md +45 -45
  116. package/cjs/components/Kebab/Kebab.styles.js.map +1 -1
  117. package/cjs/components/Kebab/__stories__/Kebab.items.js.map +1 -1
  118. package/cjs/components/Kebab/index.js.map +1 -1
  119. package/cjs/components/Link/Link.js +5 -5
  120. package/cjs/components/Link/Link.js.map +1 -1
  121. package/cjs/components/Link/Link.md +11 -11
  122. package/cjs/components/Link/Link.mixins.js.map +1 -1
  123. package/cjs/components/Link/Link.styles.js.map +1 -1
  124. package/cjs/components/Link/index.js.map +1 -1
  125. package/cjs/components/Loader/Loader.js +20 -20
  126. package/cjs/components/Loader/Loader.js.map +1 -1
  127. package/cjs/components/Loader/Loader.md +25 -25
  128. package/cjs/components/Loader/Loader.styles.js.map +1 -1
  129. package/cjs/components/Loader/__stories__/LoaderAndButton.js.map +1 -1
  130. package/cjs/components/Loader/index.js.map +1 -1
  131. package/cjs/components/LocaleProvider/LocaleProvider.js.map +1 -1
  132. package/cjs/components/LocaleProvider/index.js.map +1 -1
  133. package/cjs/components/Logotype/Logotype.js +2 -2
  134. package/cjs/components/Logotype/Logotype.js.map +1 -1
  135. package/cjs/components/Logotype/Logotype.md +33 -33
  136. package/cjs/components/Logotype/Logotype.styles.js.map +1 -1
  137. package/cjs/components/Logotype/ProductWidget.js.map +1 -1
  138. package/cjs/components/Logotype/index.js.map +1 -1
  139. package/cjs/components/Logotype/locale/index.js.map +1 -1
  140. package/cjs/components/Logotype/locale/locales/en.js.map +1 -1
  141. package/cjs/components/Logotype/locale/locales/ru.js.map +1 -1
  142. package/cjs/components/MenuHeader/MenuHeader.js +2 -2
  143. package/cjs/components/MenuHeader/MenuHeader.js.map +1 -1
  144. package/cjs/components/MenuHeader/MenuHeader.styles.js.map +1 -1
  145. package/cjs/components/MenuHeader/index.js.map +1 -1
  146. package/cjs/components/MenuItem/MenuItem.js +2 -2
  147. package/cjs/components/MenuItem/MenuItem.js.map +1 -1
  148. package/cjs/components/MenuItem/MenuItem.md +7 -7
  149. package/cjs/components/MenuItem/MenuItem.styles.js.map +1 -1
  150. package/cjs/components/MenuItem/index.js.map +1 -1
  151. package/cjs/components/MenuSeparator/MenuSeparator.js +2 -2
  152. package/cjs/components/MenuSeparator/MenuSeparator.js.map +1 -1
  153. package/cjs/components/MenuSeparator/MenuSeparator.styles.js.map +1 -1
  154. package/cjs/components/MenuSeparator/index.js.map +1 -1
  155. package/cjs/components/Modal/Modal.js +13 -13
  156. package/cjs/components/Modal/Modal.js.map +1 -1
  157. package/cjs/components/Modal/Modal.md +37 -37
  158. package/cjs/components/Modal/Modal.styles.js.map +1 -1
  159. package/cjs/components/Modal/ModalBody.js +4 -4
  160. package/cjs/components/Modal/ModalBody.js.map +1 -1
  161. package/cjs/components/Modal/ModalClose.js.map +1 -1
  162. package/cjs/components/Modal/ModalContext.js.map +1 -1
  163. package/cjs/components/Modal/ModalFooter.js +4 -4
  164. package/cjs/components/Modal/ModalFooter.js.map +1 -1
  165. package/cjs/components/Modal/ModalHeader.js +4 -4
  166. package/cjs/components/Modal/ModalHeader.js.map +1 -1
  167. package/cjs/components/Modal/helpers.js.map +1 -1
  168. package/cjs/components/Modal/index.js.map +1 -1
  169. package/cjs/components/Paging/NavigationHelper.js.map +1 -1
  170. package/cjs/components/Paging/Paging.js +10 -10
  171. package/cjs/components/Paging/Paging.js.map +1 -1
  172. package/cjs/components/Paging/Paging.md +43 -43
  173. package/cjs/components/Paging/Paging.styles.js.map +1 -1
  174. package/cjs/components/Paging/PagingHelper.js.map +1 -1
  175. package/cjs/components/Paging/index.js.map +1 -1
  176. package/cjs/components/Paging/locale/index.js.map +1 -1
  177. package/cjs/components/Paging/locale/locales/en.js.map +1 -1
  178. package/cjs/components/Paging/locale/locales/ru.js.map +1 -1
  179. package/cjs/components/PasswordInput/PasswordInput.js +6 -6
  180. package/cjs/components/PasswordInput/PasswordInput.js.map +1 -1
  181. package/cjs/components/PasswordInput/PasswordInput.styles.js.map +1 -1
  182. package/cjs/components/PasswordInput/index.js.map +1 -1
  183. package/cjs/components/Radio/Radio.js +4 -4
  184. package/cjs/components/Radio/Radio.js.map +1 -1
  185. package/cjs/components/Radio/Radio.md +14 -14
  186. package/cjs/components/Radio/Radio.styles.js.map +1 -1
  187. package/cjs/components/Radio/index.js.map +1 -1
  188. package/cjs/components/RadioGroup/Prevent.js.map +1 -1
  189. package/cjs/components/RadioGroup/RadioGroup.js +46 -46
  190. package/cjs/components/RadioGroup/RadioGroup.js.map +1 -1
  191. package/cjs/components/RadioGroup/RadioGroup.styles.js.map +1 -1
  192. package/cjs/components/RadioGroup/index.js.map +1 -1
  193. package/cjs/components/ScrollContainer/ScrollContainer.js +6 -6
  194. package/cjs/components/ScrollContainer/ScrollContainer.js.map +1 -1
  195. package/cjs/components/ScrollContainer/ScrollContainer.md +94 -94
  196. package/cjs/components/ScrollContainer/ScrollContainer.styles.js.map +1 -1
  197. package/cjs/components/ScrollContainer/index.js.map +1 -1
  198. package/cjs/components/Select/Item.js.map +1 -1
  199. package/cjs/components/Select/Select.js +2 -2
  200. package/cjs/components/Select/Select.js.map +1 -1
  201. package/cjs/components/Select/Select.md +23 -23
  202. package/cjs/components/Select/Select.styles.js.map +1 -1
  203. package/cjs/components/Select/index.js.map +1 -1
  204. package/cjs/components/Select/locale/index.js.map +1 -1
  205. package/cjs/components/Select/locale/locales/en.js.map +1 -1
  206. package/cjs/components/Select/locale/locales/ru.js.map +1 -1
  207. package/cjs/components/Select/selectTheme.js.map +1 -1
  208. package/cjs/components/SidePage/SidePage.d.ts +2 -0
  209. package/cjs/components/SidePage/SidePage.js +21 -16
  210. package/cjs/components/SidePage/SidePage.js.map +1 -1
  211. package/cjs/components/SidePage/SidePage.md +48 -48
  212. package/cjs/components/SidePage/SidePage.styles.js.map +1 -1
  213. package/cjs/components/SidePage/SidePageBody.js +4 -4
  214. package/cjs/components/SidePage/SidePageBody.js.map +1 -1
  215. package/cjs/components/SidePage/SidePageContainer.js +4 -4
  216. package/cjs/components/SidePage/SidePageContainer.js.map +1 -1
  217. package/cjs/components/SidePage/SidePageContext.d.ts +2 -0
  218. package/cjs/components/SidePage/SidePageContext.js +3 -0
  219. package/cjs/components/SidePage/SidePageContext.js.map +1 -1
  220. package/cjs/components/SidePage/SidePageFooter.js +4 -4
  221. package/cjs/components/SidePage/SidePageFooter.js.map +1 -1
  222. package/cjs/components/SidePage/SidePageHeader.d.ts +5 -0
  223. package/cjs/components/SidePage/SidePageHeader.js +24 -7
  224. package/cjs/components/SidePage/SidePageHeader.js.map +1 -1
  225. package/cjs/components/SidePage/helpers.js.map +1 -1
  226. package/cjs/components/SidePage/index.js.map +1 -1
  227. package/cjs/components/Spinner/Spinner.js +16 -16
  228. package/cjs/components/Spinner/Spinner.js.map +1 -1
  229. package/cjs/components/Spinner/Spinner.md +34 -34
  230. package/cjs/components/Spinner/Spinner.styles.js.map +1 -1
  231. package/cjs/components/Spinner/SpinnerFallbackAnimation.js.map +1 -1
  232. package/cjs/components/Spinner/index.js.map +1 -1
  233. package/cjs/components/Spinner/locale/index.js.map +1 -1
  234. package/cjs/components/Spinner/locale/locales/en.js.map +1 -1
  235. package/cjs/components/Spinner/locale/locales/ru.js.map +1 -1
  236. package/cjs/components/Sticky/Sticky.d.ts +1 -1
  237. package/cjs/components/Sticky/Sticky.js +4 -4
  238. package/cjs/components/Sticky/Sticky.js.map +1 -1
  239. package/cjs/components/Sticky/Sticky.md +27 -27
  240. package/cjs/components/Sticky/Sticky.styles.js.map +1 -1
  241. package/cjs/components/Sticky/index.js.map +1 -1
  242. package/cjs/components/Switcher/Switcher.js.map +1 -1
  243. package/cjs/components/Switcher/Switcher.md +10 -10
  244. package/cjs/components/Switcher/Switcher.styles.js.map +1 -1
  245. package/cjs/components/Switcher/index.js.map +1 -1
  246. package/cjs/components/Switcher/switcherTheme.js.map +1 -1
  247. package/cjs/components/Tabs/Indicator.js.map +1 -1
  248. package/cjs/components/Tabs/Indicator.styles.js.map +1 -1
  249. package/cjs/components/Tabs/Tab.js +14 -14
  250. package/cjs/components/Tabs/Tab.js.map +1 -1
  251. package/cjs/components/Tabs/Tab.styles.js.map +1 -1
  252. package/cjs/components/Tabs/Tabs.js +4 -4
  253. package/cjs/components/Tabs/Tabs.js.map +1 -1
  254. package/cjs/components/Tabs/Tabs.md +36 -36
  255. package/cjs/components/Tabs/Tabs.styles.js.map +1 -1
  256. package/cjs/components/Tabs/TabsContext.js.map +1 -1
  257. package/cjs/components/Tabs/index.js.map +1 -1
  258. package/cjs/components/Textarea/Textarea.js +12 -12
  259. package/cjs/components/Textarea/Textarea.js.map +1 -1
  260. package/cjs/components/Textarea/Textarea.md +25 -25
  261. package/cjs/components/Textarea/Textarea.styles.js.map +1 -1
  262. package/cjs/components/Textarea/TextareaCounter.js.map +1 -1
  263. package/cjs/components/Textarea/TextareaHelpers.js.map +1 -1
  264. package/cjs/components/Textarea/index.js.map +1 -1
  265. package/cjs/components/ThemeConsumer/ThemeConsumer.js.map +1 -1
  266. package/cjs/components/ThemeConsumer/index.js.map +1 -1
  267. package/cjs/components/ThemeProvider/ThemeProvider.js.map +1 -1
  268. package/cjs/components/ThemeProvider/index.js.map +1 -1
  269. package/cjs/components/Toast/Toast.js +19 -19
  270. package/cjs/components/Toast/Toast.js.map +1 -1
  271. package/cjs/components/Toast/Toast.md +41 -41
  272. package/cjs/components/Toast/Toast.styles.js.map +1 -1
  273. package/cjs/components/Toast/ToastStatic.js.map +1 -1
  274. package/cjs/components/Toast/ToastView.js +4 -4
  275. package/cjs/components/Toast/ToastView.js.map +1 -1
  276. package/cjs/components/Toast/ToastView.styles.js.map +1 -1
  277. package/cjs/components/Toast/index.js.map +1 -1
  278. package/cjs/components/Toggle/Toggle.js +2 -2
  279. package/cjs/components/Toggle/Toggle.js.map +1 -1
  280. package/cjs/components/Toggle/Toggle.md +24 -24
  281. package/cjs/components/Toggle/Toggle.styles.js.map +1 -1
  282. package/cjs/components/Toggle/index.js.map +1 -1
  283. package/cjs/components/Token/Token.js.map +1 -1
  284. package/cjs/components/Token/Token.styles.js.map +1 -1
  285. package/cjs/components/Token/index.js.map +1 -1
  286. package/cjs/components/TokenInput/TextWidthHelper.js +3 -3
  287. package/cjs/components/TokenInput/TextWidthHelper.js.map +1 -1
  288. package/cjs/components/TokenInput/TokenInput.js +17 -17
  289. package/cjs/components/TokenInput/TokenInput.js.map +1 -1
  290. package/cjs/components/TokenInput/TokenInput.md +77 -77
  291. package/cjs/components/TokenInput/TokenInput.styles.js.map +1 -1
  292. package/cjs/components/TokenInput/TokenInputMenu.js.map +1 -1
  293. package/cjs/components/TokenInput/TokenInputReducer.js.map +1 -1
  294. package/cjs/components/TokenInput/index.js.map +1 -1
  295. package/cjs/components/TokenInput/locale/index.js.map +1 -1
  296. package/cjs/components/TokenInput/locale/locales/en.js.map +1 -1
  297. package/cjs/components/TokenInput/locale/locales/ru.js.map +1 -1
  298. package/cjs/components/Tooltip/Tooltip.js +8 -8
  299. package/cjs/components/Tooltip/Tooltip.js.map +1 -1
  300. package/cjs/components/Tooltip/Tooltip.md +301 -301
  301. package/cjs/components/Tooltip/Tooltip.styles.js.map +1 -1
  302. package/cjs/components/Tooltip/index.js.map +1 -1
  303. package/cjs/components/TooltipMenu/TooltipMenu.js +7 -7
  304. package/cjs/components/TooltipMenu/TooltipMenu.js.map +1 -1
  305. package/cjs/components/TooltipMenu/TooltipMenu.md +115 -115
  306. package/cjs/components/TooltipMenu/index.js.map +1 -1
  307. package/cjs/components/TopBar/TopBar.js +38 -38
  308. package/cjs/components/TopBar/TopBar.js.map +1 -1
  309. package/cjs/components/TopBar/TopBar.md +111 -111
  310. package/cjs/components/TopBar/TopBar.styles.js.map +1 -1
  311. package/cjs/components/TopBar/TopBarButtonItem.js +4 -4
  312. package/cjs/components/TopBar/TopBarButtonItem.js.map +1 -1
  313. package/cjs/components/TopBar/TopBarDivider.js +4 -4
  314. package/cjs/components/TopBar/TopBarDivider.js.map +1 -1
  315. package/cjs/components/TopBar/TopBarDropdown.js +4 -4
  316. package/cjs/components/TopBar/TopBarDropdown.js.map +1 -1
  317. package/cjs/components/TopBar/TopBarEnd.js +4 -4
  318. package/cjs/components/TopBar/TopBarEnd.js.map +1 -1
  319. package/cjs/components/TopBar/TopBarItem.js +4 -4
  320. package/cjs/components/TopBar/TopBarItem.js.map +1 -1
  321. package/cjs/components/TopBar/TopBarLogout.js +4 -4
  322. package/cjs/components/TopBar/TopBarLogout.js.map +1 -1
  323. package/cjs/components/TopBar/TopBarOrganizations.js +4 -4
  324. package/cjs/components/TopBar/TopBarOrganizations.js.map +1 -1
  325. package/cjs/components/TopBar/TopBarStart.js +4 -4
  326. package/cjs/components/TopBar/TopBarStart.js.map +1 -1
  327. package/cjs/components/TopBar/TopBarUser.js +6 -6
  328. package/cjs/components/TopBar/TopBarUser.js.map +1 -1
  329. package/cjs/components/TopBar/index.js.map +1 -1
  330. package/cjs/components/TopBar/locale/index.js.map +1 -1
  331. package/cjs/components/TopBar/locale/locales/en.js.map +1 -1
  332. package/cjs/components/TopBar/locale/locales/ru.js.map +1 -1
  333. package/cjs/index.js.map +1 -1
  334. package/cjs/internal/BGRuler.js +5 -5
  335. package/cjs/internal/BGRuler.js.map +1 -1
  336. package/cjs/internal/Calendar/Calendar.js +3 -3
  337. package/cjs/internal/Calendar/Calendar.js.map +1 -1
  338. package/cjs/internal/Calendar/Calendar.styles.js.map +1 -1
  339. package/cjs/internal/Calendar/CalendarDateShape.js.map +1 -1
  340. package/cjs/internal/Calendar/CalendarScrollEvents.js.map +1 -1
  341. package/cjs/internal/Calendar/CalendarUtils.js.map +1 -1
  342. package/cjs/internal/Calendar/DayCellView.js.map +1 -1
  343. package/cjs/internal/Calendar/DayCellView.styles.js.map +1 -1
  344. package/cjs/internal/Calendar/DayCellViewModel.js.map +1 -1
  345. package/cjs/internal/Calendar/Month.js.map +1 -1
  346. package/cjs/internal/Calendar/MonthView.js.map +1 -1
  347. package/cjs/internal/Calendar/MonthView.styles.js.map +1 -1
  348. package/cjs/internal/Calendar/MonthViewModel.js.map +1 -1
  349. package/cjs/internal/Calendar/config.js.map +1 -1
  350. package/cjs/internal/Calendar/index.js.map +1 -1
  351. package/cjs/internal/CommonWrapper/CommonWrapper.js.map +1 -1
  352. package/cjs/internal/CommonWrapper/index.js.map +1 -1
  353. package/cjs/internal/ComponentCombinator.js.map +1 -1
  354. package/cjs/internal/ComponentTable.js.map +1 -1
  355. package/cjs/internal/CustomComboBox/ComboBoxMenu.js.map +1 -1
  356. package/cjs/internal/CustomComboBox/ComboBoxView.js.map +1 -1
  357. package/cjs/internal/CustomComboBox/CustomComboBox.js +10 -10
  358. package/cjs/internal/CustomComboBox/CustomComboBox.js.map +1 -1
  359. package/cjs/internal/CustomComboBox/CustomComboBox.styles.js.map +1 -1
  360. package/cjs/internal/CustomComboBox/CustomComboBoxReducer.js.map +1 -1
  361. package/cjs/internal/CustomComboBox/CustomComboBoxTypes.js.map +1 -1
  362. package/cjs/internal/CustomComboBox/index.js.map +1 -1
  363. package/cjs/internal/CustomComboBox/locale/index.js.map +1 -1
  364. package/cjs/internal/CustomComboBox/locale/locales/en.js.map +1 -1
  365. package/cjs/internal/CustomComboBox/locale/locales/ru.js.map +1 -1
  366. package/cjs/internal/DateSelect/DateSelect.js +2 -2
  367. package/cjs/internal/DateSelect/DateSelect.js.map +1 -1
  368. package/cjs/internal/DateSelect/DateSelect.styles.js.map +1 -1
  369. package/cjs/internal/DateSelect/index.js.map +1 -1
  370. package/cjs/internal/DropdownContainer/DropdownContainer.js.map +1 -1
  371. package/cjs/internal/DropdownContainer/index.js.map +1 -1
  372. package/cjs/internal/FocusTrap/FocusTrap.js.map +1 -1
  373. package/cjs/internal/FocusTrap/index.js.map +1 -1
  374. package/cjs/internal/HideBodyVerticalScroll/HideBodyVerticalScroll.js.map +1 -1
  375. package/cjs/internal/HideBodyVerticalScroll/index.js.map +1 -1
  376. package/cjs/internal/IgnoreLayerClick/IgnoreLayerClick.js.map +1 -1
  377. package/cjs/internal/IgnoreLayerClick/index.js.map +1 -1
  378. package/cjs/internal/InputLikeText/HiddenInput.js +4 -4
  379. package/cjs/internal/InputLikeText/HiddenInput.js.map +1 -1
  380. package/cjs/internal/InputLikeText/InputLikeText.js +6 -6
  381. package/cjs/internal/InputLikeText/InputLikeText.js.map +1 -1
  382. package/cjs/internal/InputLikeText/InputLikeText.styles.js.map +1 -1
  383. package/cjs/internal/InputLikeText/index.js.map +1 -1
  384. package/cjs/internal/InternalMenu/InternalMenu.js.map +1 -1
  385. package/cjs/internal/InternalMenu/InternalMenu.styles.js.map +1 -1
  386. package/cjs/internal/InternalMenu/index.js.map +1 -1
  387. package/cjs/internal/InternalMenu/isActiveElement.js.map +1 -1
  388. package/cjs/internal/MaskCharLowLine/MaskCharLowLine.js +6 -6
  389. package/cjs/internal/MaskCharLowLine/MaskCharLowLine.js.map +1 -1
  390. package/cjs/internal/MaskCharLowLine/MaskCharLowLine.styles.js.map +1 -1
  391. package/cjs/internal/MaskCharLowLine/index.js.map +1 -1
  392. package/cjs/internal/MaskedInput/MaskedInput.js.map +1 -1
  393. package/cjs/internal/MaskedInput/MaskedInput.styles.js.map +1 -1
  394. package/cjs/internal/MaskedInput/index.js.map +1 -1
  395. package/cjs/internal/Menu/Menu.js +10 -10
  396. package/cjs/internal/Menu/Menu.js.map +1 -1
  397. package/cjs/internal/Menu/Menu.styles.js.map +1 -1
  398. package/cjs/internal/Menu/index.js.map +1 -1
  399. package/cjs/internal/Menu/isActiveElement.js.map +1 -1
  400. package/cjs/internal/PerformanceMetrics/PerformanceMetrics.js.map +1 -1
  401. package/cjs/internal/Popup/Popup.js +31 -31
  402. package/cjs/internal/Popup/Popup.js.map +1 -1
  403. package/cjs/internal/Popup/Popup.styles.js.map +1 -1
  404. package/cjs/internal/Popup/PopupHelper.js.map +1 -1
  405. package/cjs/internal/Popup/PopupPin.js +16 -16
  406. package/cjs/internal/Popup/PopupPin.js.map +1 -1
  407. package/cjs/internal/Popup/PopupPin.styles.js.map +1 -1
  408. package/cjs/internal/Popup/index.js.map +1 -1
  409. package/cjs/internal/PopupMenu/PopupMenu.js.map +1 -1
  410. package/cjs/internal/PopupMenu/PopupMenu.styles.js.map +1 -1
  411. package/cjs/internal/PopupMenu/PopupMenuPositions.js.map +1 -1
  412. package/cjs/internal/PopupMenu/index.js.map +1 -1
  413. package/cjs/internal/PopupMenu/validatePositions.js.map +1 -1
  414. package/cjs/internal/RenderContainer/RenderContainer.js.map +1 -1
  415. package/cjs/internal/RenderContainer/RenderInnerContainer.js.map +1 -1
  416. package/cjs/internal/RenderContainer/index.js.map +1 -1
  417. package/cjs/internal/RenderLayer/RenderLayer.js.map +1 -1
  418. package/cjs/internal/RenderLayer/index.js.map +1 -1
  419. package/cjs/internal/ResizeDetector/ResizeDetector.js.map +1 -1
  420. package/cjs/internal/ResizeDetector/ResizeDetector.styles.js.map +1 -1
  421. package/cjs/internal/ResizeDetector/index.js.map +1 -1
  422. package/cjs/internal/SpinnerOld/SpinnerOld.js +12 -12
  423. package/cjs/internal/SpinnerOld/SpinnerOld.js.map +1 -1
  424. package/cjs/internal/SpinnerOld/SpinnerOld.styles.js.map +1 -1
  425. package/cjs/internal/SpinnerOld/SpinnerOldCloudIcon.js.map +1 -1
  426. package/cjs/internal/SpinnerOld/index.js.map +1 -1
  427. package/cjs/internal/SpinnerOld/locale/index.js.map +1 -1
  428. package/cjs/internal/SpinnerOld/locale/locales/en.js.map +1 -1
  429. package/cjs/internal/SpinnerOld/locale/locales/ru.js.map +1 -1
  430. package/cjs/internal/ThemePlayground/AnotherInputsPlayground.js.map +1 -1
  431. package/cjs/internal/ThemePlayground/CheckboxPlayground.js.map +1 -1
  432. package/cjs/internal/ThemePlayground/ComponentsGroup.js.map +1 -1
  433. package/cjs/internal/ThemePlayground/CurrencyInputPlayground.js.map +1 -1
  434. package/cjs/internal/ThemePlayground/FxInputPlayground.js.map +1 -1
  435. package/cjs/internal/ThemePlayground/HintPlayground.js.map +1 -1
  436. package/cjs/internal/ThemePlayground/PagingPlayground.js.map +1 -1
  437. package/cjs/internal/ThemePlayground/Playground.js.map +1 -1
  438. package/cjs/internal/ThemePlayground/Playground.md +7 -7
  439. package/cjs/internal/ThemePlayground/Playground.styles.js.map +1 -1
  440. package/cjs/internal/ThemePlayground/RadioPlayground.js.map +1 -1
  441. package/cjs/internal/ThemePlayground/SelectPlayground.js.map +1 -1
  442. package/cjs/internal/ThemePlayground/ShowcaseGroup.js.map +1 -1
  443. package/cjs/internal/ThemePlayground/SwitcherPlayground.js.map +1 -1
  444. package/cjs/internal/ThemePlayground/ThemeContextPlayground.js.map +1 -1
  445. package/cjs/internal/ThemePlayground/ThemeEditor.js.map +1 -1
  446. package/cjs/internal/ThemePlayground/TogglePlayground.js.map +1 -1
  447. package/cjs/internal/ThemePlayground/TokenInputPlayground.js.map +1 -1
  448. package/cjs/internal/ThemePlayground/VariableValue.js.map +1 -1
  449. package/cjs/internal/ThemePlayground/constants.js.map +1 -1
  450. package/cjs/internal/ThemePlayground/darkTheme.js.map +1 -1
  451. package/cjs/internal/ThemePlayground/helpers.js.map +1 -1
  452. package/cjs/internal/ThemeShowcase/ThemeShowcase.js.map +1 -1
  453. package/cjs/internal/ThemeShowcase/ThemeShowcase.styles.js.map +1 -1
  454. package/cjs/internal/ThemeShowcase/VariablesCollector.js.map +1 -1
  455. package/cjs/internal/ZIndex/ZIndex.js.map +1 -1
  456. package/cjs/internal/ZIndex/ZIndexStorage.js.map +1 -1
  457. package/cjs/internal/ZIndex/index.js.map +1 -1
  458. package/cjs/internal/icons/16px/icon.styles.js.map +1 -1
  459. package/cjs/internal/icons/16px/index.js.map +1 -1
  460. package/cjs/internal/icons/20px/Icon.js +2 -2
  461. package/cjs/internal/icons/20px/Icon.js.map +1 -1
  462. package/cjs/internal/icons/20px/icon.styles.js.map +1 -1
  463. package/cjs/internal/icons/20px/index.js.map +1 -1
  464. package/cjs/internal/icons/20px/svg.js.map +1 -1
  465. package/cjs/internal/icons/CloudIcon.js.map +1 -1
  466. package/cjs/internal/icons/CrossIcon.js.map +1 -1
  467. package/cjs/internal/icons/SpinnerIcon.js.map +1 -1
  468. package/cjs/internal/icons/SpinnerIcon.styles.js.map +1 -1
  469. package/cjs/internal/themes/DefaultTheme.js.map +1 -1
  470. package/cjs/internal/themes/FlatTheme.js.map +1 -1
  471. package/cjs/internal/themes/Theme8px.js.map +1 -1
  472. package/cjs/lib/ConditionalHandler.js +2 -2
  473. package/cjs/lib/ConditionalHandler.js.map +1 -1
  474. package/cjs/lib/LayoutEvents.js.map +1 -1
  475. package/cjs/lib/MockDate.js.map +1 -1
  476. package/cjs/lib/ModalStack.js +4 -4
  477. package/cjs/lib/ModalStack.js.map +1 -1
  478. package/cjs/lib/SSRSafe.js.map +1 -1
  479. package/cjs/lib/Supports.js.map +1 -1
  480. package/cjs/lib/Upgrades.js.map +1 -1
  481. package/cjs/lib/animation/index.js.map +1 -1
  482. package/cjs/lib/animation/presets.js.map +1 -1
  483. package/cjs/lib/animation/stepper.js.map +1 -1
  484. package/cjs/lib/client.js.map +1 -1
  485. package/cjs/lib/createPropsGetter.js.map +1 -1
  486. package/cjs/lib/currentEnvironment.js.map +1 -1
  487. package/cjs/lib/date/InternalDate.js +3 -3
  488. package/cjs/lib/date/InternalDate.js.map +1 -1
  489. package/cjs/lib/date/InternalDateCalculator.js.map +1 -1
  490. package/cjs/lib/date/InternalDateGetter.js.map +1 -1
  491. package/cjs/lib/date/InternalDateSetter.js.map +1 -1
  492. package/cjs/lib/date/InternalDateTransformer.js.map +1 -1
  493. package/cjs/lib/date/InternalDateValidator.js.map +1 -1
  494. package/cjs/lib/date/constants.js.map +1 -1
  495. package/cjs/lib/date/localeSets.js.map +1 -1
  496. package/cjs/lib/date/types.js.map +1 -1
  497. package/cjs/lib/dom/getFocusableElements.js +33 -33
  498. package/cjs/lib/dom/getFocusableElements.js.map +1 -1
  499. package/cjs/lib/dom/getScrollWidth.js.map +1 -1
  500. package/cjs/lib/events/MouseDrag.js +26 -26
  501. package/cjs/lib/events/MouseDrag.js.map +1 -1
  502. package/cjs/lib/events/keyboard/KeyboardEventCodes.js.map +1 -1
  503. package/cjs/lib/events/keyboard/KeyboardMapKeys.js.map +1 -1
  504. package/cjs/lib/events/keyboard/extractCode.js.map +1 -1
  505. package/cjs/lib/events/keyboard/identifiers.js.map +1 -1
  506. package/cjs/lib/events/stopPropagation.js.map +1 -1
  507. package/cjs/lib/events/tabListener.js.map +1 -1
  508. package/cjs/lib/extractKeyboardAction.js.map +1 -1
  509. package/cjs/lib/filterProps.js.map +1 -1
  510. package/cjs/lib/listenFocusOutside.js +9 -9
  511. package/cjs/lib/listenFocusOutside.js.map +1 -1
  512. package/cjs/lib/locale/LOCALECONTEXT.md +246 -246
  513. package/cjs/lib/locale/LocaleContext.js.map +1 -1
  514. package/cjs/lib/locale/LocaleHelper.js.map +1 -1
  515. package/cjs/lib/locale/constants.js.map +1 -1
  516. package/cjs/lib/locale/decorators.js.map +1 -1
  517. package/cjs/lib/locale/index.js.map +1 -1
  518. package/cjs/lib/locale/types.js.map +1 -1
  519. package/cjs/lib/memo.js.map +1 -1
  520. package/cjs/lib/net/fetch.js.map +1 -1
  521. package/cjs/lib/polyfillPlaceholder.js.map +1 -1
  522. package/cjs/lib/reactGetTextContent.js.map +1 -1
  523. package/cjs/lib/styles/ColorFactory.js.map +1 -1
  524. package/cjs/lib/styles/ColorFunctions.js.map +1 -1
  525. package/cjs/lib/styles/ColorHelpers.js.map +1 -1
  526. package/cjs/lib/styles/ColorKeywords.js.map +1 -1
  527. package/cjs/lib/styles/ColorObject.js.map +1 -1
  528. package/cjs/lib/styles/DimensionFunctions.js.map +1 -1
  529. package/cjs/lib/styles/HoldSelectionColor.js.map +1 -1
  530. package/cjs/lib/styles/Mixins.js.map +1 -1
  531. package/cjs/lib/theming/AnimationKeyframes.js.map +1 -1
  532. package/cjs/lib/theming/Emotion.js.map +1 -1
  533. package/cjs/lib/theming/ThemeContext.js.map +1 -1
  534. package/cjs/lib/theming/ThemeContext.md +248 -248
  535. package/cjs/lib/theming/ThemeFactory.js.map +1 -1
  536. package/cjs/lib/theming/ThemeHelpers.js.map +1 -1
  537. package/cjs/lib/theming/themes/DefaultTheme.js.map +1 -1
  538. package/cjs/lib/theming/themes/DefaultTheme8px.js.map +1 -1
  539. package/cjs/lib/theming/themes/FlatTheme.js.map +1 -1
  540. package/cjs/lib/theming/themes/FlatTheme8px.js.map +1 -1
  541. package/cjs/lib/utils.js +2 -2
  542. package/cjs/lib/utils.js.map +1 -1
  543. package/cjs/typings/console.d.ts +3 -3
  544. package/cjs/typings/event-types.d.ts +4 -4
  545. package/cjs/typings/fonts.d.ts +12 -12
  546. package/cjs/typings/global.d.ts +6 -6
  547. package/cjs/typings/images.d.ts +1 -1
  548. package/cjs/typings/normalize-wheel.d.ts +5 -5
  549. package/cjs/typings/stylis-plugin-extra-scope.d.ts +3 -3
  550. package/cjs/typings/utility-types.d.ts +14 -14
  551. package/components/Autocomplete/Autocomplete/Autocomplete.js +23 -23
  552. package/components/Autocomplete/Autocomplete/Autocomplete.js.map +1 -1
  553. package/components/Autocomplete/Autocomplete.md +7 -7
  554. package/components/Autocomplete/index/index.js.map +1 -1
  555. package/components/Button/Button/Button.js +4 -4
  556. package/components/Button/Button/Button.js.map +1 -1
  557. package/components/Button/Button.md +89 -89
  558. package/components/Button/Button.mixins/Button.mixins.js.map +1 -1
  559. package/components/Button/Button.styles/Button.styles.js.map +1 -1
  560. package/components/Button/Corners/Corners.js.map +1 -1
  561. package/components/Button/index/index.js.map +1 -1
  562. package/components/Center/Center/Center.js +3 -3
  563. package/components/Center/Center/Center.js.map +1 -1
  564. package/components/Center/Center.md +5 -5
  565. package/components/Center/Center.styles/Center.styles.js.map +1 -1
  566. package/components/Center/index/index.js.map +1 -1
  567. package/components/Checkbox/Checkbox/Checkbox.js +9 -9
  568. package/components/Checkbox/Checkbox/Checkbox.js.map +1 -1
  569. package/components/Checkbox/Checkbox.md +63 -63
  570. package/components/Checkbox/Checkbox.styles/Checkbox.styles.js.map +1 -1
  571. package/components/Checkbox/index/index.js.map +1 -1
  572. package/components/ComboBox/ComboBox/ComboBox.js +20 -20
  573. package/components/ComboBox/ComboBox/ComboBox.js.map +1 -1
  574. package/components/ComboBox/ComboBox.md +432 -432
  575. package/components/ComboBox/index/index.js.map +1 -1
  576. package/components/CurrencyInput/CurrencyHelper/CurrencyHelper.js.map +1 -1
  577. package/components/CurrencyInput/CurrencyInput/CurrencyInput.js +7 -7
  578. package/components/CurrencyInput/CurrencyInput/CurrencyInput.js.map +1 -1
  579. package/components/CurrencyInput/CurrencyInput.md +20 -20
  580. package/components/CurrencyInput/CurrencyInputHelper/CurrencyInputHelper.js.map +1 -1
  581. package/components/CurrencyInput/CurrencyInputKeyboardActions/CurrencyInputKeyboardActions.js.map +1 -1
  582. package/components/CurrencyInput/CursorHelper/CursorHelper.js.map +1 -1
  583. package/components/CurrencyInput/SelectionHelper/SelectionHelper.js.map +1 -1
  584. package/components/CurrencyInput/constants/constants.js.map +1 -1
  585. package/components/CurrencyInput/index/index.js.map +1 -1
  586. package/components/CurrencyLabel/CurrencyLabel/CurrencyLabel.js.map +1 -1
  587. package/components/CurrencyLabel/index/index.js.map +1 -1
  588. package/components/DateInput/DateFragmentsView/DateFragmentsView.js.map +1 -1
  589. package/components/DateInput/DateFragmentsView.styles/DateFragmentsView.styles.js.map +1 -1
  590. package/components/DateInput/DateInput/DateInput.js.map +1 -1
  591. package/components/DateInput/DateInput.md +104 -104
  592. package/components/DateInput/DateInput.styles/DateInput.styles.js.map +1 -1
  593. package/components/DateInput/ViewDateInputValidateChecks/ViewDateInputValidateChecks.js.map +1 -1
  594. package/components/DateInput/helpers/DateInputKeyboardActions/DateInputKeyboardActions.js.map +1 -1
  595. package/components/DateInput/helpers/InternalDateMediator/InternalDateMediator.js.map +1 -1
  596. package/components/DateInput/helpers/SelectionHelpers/SelectionHelpers.js.map +1 -1
  597. package/components/DateInput/helpers/inputNumber/inputNumber.js.map +1 -1
  598. package/components/DateInput/index/index.js.map +1 -1
  599. package/components/DatePicker/DatePicker/DatePicker.js +15 -15
  600. package/components/DatePicker/DatePicker/DatePicker.js.map +1 -1
  601. package/components/DatePicker/DatePicker.md +310 -310
  602. package/components/DatePicker/DatePicker.styles/DatePicker.styles.js.map +1 -1
  603. package/components/DatePicker/DatePickerHelpers/DatePickerHelpers.js.map +1 -1
  604. package/components/DatePicker/Picker/Picker.js.map +1 -1
  605. package/components/DatePicker/Picker.styles/Picker.styles.js.map +1 -1
  606. package/components/DatePicker/index/index.js.map +1 -1
  607. package/components/DatePicker/locale/index/index.js.map +1 -1
  608. package/components/DatePicker/locale/locales/en/en.js.map +1 -1
  609. package/components/DatePicker/locale/locales/ru/ru.js.map +1 -1
  610. package/components/Dropdown/Dropdown/Dropdown.js +24 -24
  611. package/components/Dropdown/Dropdown/Dropdown.js.map +1 -1
  612. package/components/Dropdown/Dropdown.md +12 -12
  613. package/components/Dropdown/index/index.js.map +1 -1
  614. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js +2 -2
  615. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js.map +1 -1
  616. package/components/DropdownMenu/DropdownMenu.md +73 -73
  617. package/components/DropdownMenu/index/index.js.map +1 -1
  618. package/components/Fias/Fias/Fias.js +2 -2
  619. package/components/Fias/Fias/Fias.js.map +1 -1
  620. package/components/Fias/Fias.md +451 -451
  621. package/components/Fias/Fias.styles/Fias.styles.js.map +1 -1
  622. package/components/Fias/FiasModal/FiasModal.js.map +1 -1
  623. package/components/Fias/FiasSearch/FiasSearch/FiasSearch.js +2 -2
  624. package/components/Fias/FiasSearch/FiasSearch/FiasSearch.js.map +1 -1
  625. package/components/Fias/FiasSearch/FiasSearch.md +78 -78
  626. package/components/Fias/Form/FiasComboBox/FiasComboBox.js.map +1 -1
  627. package/components/Fias/Form/FiasCountrySelector/FiasCountrySelector.js.map +1 -1
  628. package/components/Fias/Form/FiasForm/FiasForm.js.map +1 -1
  629. package/components/Fias/Form/FiasForm.styles/FiasForm.styles.js.map +1 -1
  630. package/components/Fias/api/FiasAPI/FiasAPI.js.map +1 -1
  631. package/components/Fias/api/FiasAPIResultFactory/FiasAPIResultFactory.js.map +1 -1
  632. package/components/Fias/api/FiasMockAPI/FiasMockAPI.js.map +1 -1
  633. package/components/Fias/api/data.json +285 -285
  634. package/components/Fias/constants/abbreviations/abbreviations.js.map +1 -1
  635. package/components/Fias/index/index.js.map +1 -1
  636. package/components/Fias/locale/index/index.js.map +1 -1
  637. package/components/Fias/locale/locales/ru/ru.js.map +1 -1
  638. package/components/Fias/logger/FiasLogger/FiasLogger.js.map +1 -1
  639. package/components/Fias/models/FiasAddress/FiasAddress.js.map +1 -1
  640. package/components/Fias/models/FiasAddressElement/FiasAddressElement.js.map +1 -1
  641. package/components/Fias/models/FiasData/FiasData.js.map +1 -1
  642. package/components/Fias/types/types.js.map +1 -1
  643. package/components/FxInput/FxInput/FxInput.js.map +1 -1
  644. package/components/FxInput/FxInput.md +13 -13
  645. package/components/FxInput/index/index.js.map +1 -1
  646. package/components/Gapped/Gapped/Gapped.js +8 -8
  647. package/components/Gapped/Gapped/Gapped.js.map +1 -1
  648. package/components/Gapped/index/index.js.map +1 -1
  649. package/components/Group/Group/Group.js.map +1 -1
  650. package/components/Group/Group.md +26 -26
  651. package/components/Group/Group.styles/Group.styles.js.map +1 -1
  652. package/components/Group/index/index.js.map +1 -1
  653. package/components/Hint/Hint/Hint.js.map +1 -1
  654. package/components/Hint/Hint.md +3 -3
  655. package/components/Hint/Hint.styles/Hint.styles.js.map +1 -1
  656. package/components/Hint/index/index.js.map +1 -1
  657. package/components/Input/Input/Input.js +13 -13
  658. package/components/Input/Input/Input.js.map +1 -1
  659. package/components/Input/Input.styles/Input.styles.js.map +1 -1
  660. package/components/Input/index/index.js.map +1 -1
  661. package/components/Kebab/Kebab/Kebab.js +6 -6
  662. package/components/Kebab/Kebab/Kebab.js.map +1 -1
  663. package/components/Kebab/Kebab.md +45 -45
  664. package/components/Kebab/Kebab.styles/Kebab.styles.js.map +1 -1
  665. package/components/Kebab/__stories__/Kebab.items/Kebab.items.js.map +1 -1
  666. package/components/Kebab/index/index.js.map +1 -1
  667. package/components/Link/Link/Link.js +5 -5
  668. package/components/Link/Link/Link.js.map +1 -1
  669. package/components/Link/Link.md +11 -11
  670. package/components/Link/Link.mixins/Link.mixins.js.map +1 -1
  671. package/components/Link/Link.styles/Link.styles.js.map +1 -1
  672. package/components/Link/index/index.js.map +1 -1
  673. package/components/Loader/Loader/Loader.js +20 -20
  674. package/components/Loader/Loader/Loader.js.map +1 -1
  675. package/components/Loader/Loader.md +25 -25
  676. package/components/Loader/Loader.styles/Loader.styles.js.map +1 -1
  677. package/components/Loader/__stories__/LoaderAndButton/LoaderAndButton.js.map +1 -1
  678. package/components/Loader/index/index.js.map +1 -1
  679. package/components/LocaleProvider/LocaleProvider/LocaleProvider.js.map +1 -1
  680. package/components/LocaleProvider/index/index.js.map +1 -1
  681. package/components/Logotype/Logotype/Logotype.js +2 -2
  682. package/components/Logotype/Logotype/Logotype.js.map +1 -1
  683. package/components/Logotype/Logotype.md +33 -33
  684. package/components/Logotype/Logotype.styles/Logotype.styles.js.map +1 -1
  685. package/components/Logotype/ProductWidget/ProductWidget.js.map +1 -1
  686. package/components/Logotype/index/index.js.map +1 -1
  687. package/components/Logotype/locale/index/index.js.map +1 -1
  688. package/components/Logotype/locale/locales/en/en.js.map +1 -1
  689. package/components/Logotype/locale/locales/ru/ru.js.map +1 -1
  690. package/components/MenuHeader/MenuHeader/MenuHeader.js +2 -2
  691. package/components/MenuHeader/MenuHeader/MenuHeader.js.map +1 -1
  692. package/components/MenuHeader/MenuHeader.styles/MenuHeader.styles.js.map +1 -1
  693. package/components/MenuHeader/index/index.js.map +1 -1
  694. package/components/MenuItem/MenuItem/MenuItem.js +2 -2
  695. package/components/MenuItem/MenuItem/MenuItem.js.map +1 -1
  696. package/components/MenuItem/MenuItem.md +7 -7
  697. package/components/MenuItem/MenuItem.styles/MenuItem.styles.js.map +1 -1
  698. package/components/MenuItem/index/index.js.map +1 -1
  699. package/components/MenuSeparator/MenuSeparator/MenuSeparator.js +2 -2
  700. package/components/MenuSeparator/MenuSeparator/MenuSeparator.js.map +1 -1
  701. package/components/MenuSeparator/MenuSeparator.styles/MenuSeparator.styles.js.map +1 -1
  702. package/components/MenuSeparator/index/index.js.map +1 -1
  703. package/components/Modal/Modal/Modal.js +13 -13
  704. package/components/Modal/Modal/Modal.js.map +1 -1
  705. package/components/Modal/Modal.md +37 -37
  706. package/components/Modal/Modal.styles/Modal.styles.js.map +1 -1
  707. package/components/Modal/ModalBody/ModalBody.js +4 -4
  708. package/components/Modal/ModalBody/ModalBody.js.map +1 -1
  709. package/components/Modal/ModalClose/ModalClose.js.map +1 -1
  710. package/components/Modal/ModalContext/ModalContext.js.map +1 -1
  711. package/components/Modal/ModalFooter/ModalFooter.js +4 -4
  712. package/components/Modal/ModalFooter/ModalFooter.js.map +1 -1
  713. package/components/Modal/ModalHeader/ModalHeader.js +4 -4
  714. package/components/Modal/ModalHeader/ModalHeader.js.map +1 -1
  715. package/components/Modal/helpers/helpers.js.map +1 -1
  716. package/components/Modal/index/index.js.map +1 -1
  717. package/components/Paging/NavigationHelper/NavigationHelper.js.map +1 -1
  718. package/components/Paging/Paging/Paging.js +10 -10
  719. package/components/Paging/Paging/Paging.js.map +1 -1
  720. package/components/Paging/Paging.md +43 -43
  721. package/components/Paging/Paging.styles/Paging.styles.js.map +1 -1
  722. package/components/Paging/PagingHelper/PagingHelper.js.map +1 -1
  723. package/components/Paging/index/index.js.map +1 -1
  724. package/components/Paging/locale/index/index.js.map +1 -1
  725. package/components/Paging/locale/locales/en/en.js.map +1 -1
  726. package/components/Paging/locale/locales/ru/ru.js.map +1 -1
  727. package/components/PasswordInput/PasswordInput/PasswordInput.js +6 -6
  728. package/components/PasswordInput/PasswordInput/PasswordInput.js.map +1 -1
  729. package/components/PasswordInput/PasswordInput.styles/PasswordInput.styles.js.map +1 -1
  730. package/components/PasswordInput/index/index.js.map +1 -1
  731. package/components/Radio/Radio/Radio.js +4 -4
  732. package/components/Radio/Radio/Radio.js.map +1 -1
  733. package/components/Radio/Radio.md +14 -14
  734. package/components/Radio/Radio.styles/Radio.styles.js.map +1 -1
  735. package/components/Radio/index/index.js.map +1 -1
  736. package/components/RadioGroup/Prevent/Prevent.js.map +1 -1
  737. package/components/RadioGroup/RadioGroup/RadioGroup.js +46 -46
  738. package/components/RadioGroup/RadioGroup/RadioGroup.js.map +1 -1
  739. package/components/RadioGroup/RadioGroup.styles/RadioGroup.styles.js.map +1 -1
  740. package/components/RadioGroup/index/index.js.map +1 -1
  741. package/components/ScrollContainer/ScrollContainer/ScrollContainer.js +6 -6
  742. package/components/ScrollContainer/ScrollContainer/ScrollContainer.js.map +1 -1
  743. package/components/ScrollContainer/ScrollContainer.md +94 -94
  744. package/components/ScrollContainer/ScrollContainer.styles/ScrollContainer.styles.js.map +1 -1
  745. package/components/ScrollContainer/index/index.js.map +1 -1
  746. package/components/Select/Item/Item.js.map +1 -1
  747. package/components/Select/Select/Select.js +2 -2
  748. package/components/Select/Select/Select.js.map +1 -1
  749. package/components/Select/Select.md +23 -23
  750. package/components/Select/Select.styles/Select.styles.js.map +1 -1
  751. package/components/Select/index/index.js.map +1 -1
  752. package/components/Select/locale/index/index.js.map +1 -1
  753. package/components/Select/locale/locales/en/en.js.map +1 -1
  754. package/components/Select/locale/locales/ru/ru.js.map +1 -1
  755. package/components/Select/selectTheme/selectTheme.js.map +1 -1
  756. package/components/SidePage/SidePage/SidePage.js +22 -15
  757. package/components/SidePage/SidePage/SidePage.js.map +1 -1
  758. package/components/SidePage/SidePage.d.ts +2 -0
  759. package/components/SidePage/SidePage.md +48 -48
  760. package/components/SidePage/SidePage.styles/SidePage.styles.js.map +1 -1
  761. package/components/SidePage/SidePageBody/SidePageBody.js +4 -4
  762. package/components/SidePage/SidePageBody/SidePageBody.js.map +1 -1
  763. package/components/SidePage/SidePageContainer/SidePageContainer.js +4 -4
  764. package/components/SidePage/SidePageContainer/SidePageContainer.js.map +1 -1
  765. package/components/SidePage/SidePageContext/SidePageContext.js +3 -0
  766. package/components/SidePage/SidePageContext/SidePageContext.js.map +1 -1
  767. package/components/SidePage/SidePageContext.d.ts +2 -0
  768. package/components/SidePage/SidePageFooter/SidePageFooter.js +4 -4
  769. package/components/SidePage/SidePageFooter/SidePageFooter.js.map +1 -1
  770. package/components/SidePage/SidePageHeader/SidePageHeader.js +23 -6
  771. package/components/SidePage/SidePageHeader/SidePageHeader.js.map +1 -1
  772. package/components/SidePage/SidePageHeader.d.ts +5 -0
  773. package/components/SidePage/helpers/helpers.js.map +1 -1
  774. package/components/SidePage/index/index.js.map +1 -1
  775. package/components/Spinner/Spinner/Spinner.js +16 -16
  776. package/components/Spinner/Spinner/Spinner.js.map +1 -1
  777. package/components/Spinner/Spinner.md +34 -34
  778. package/components/Spinner/Spinner.styles/Spinner.styles.js.map +1 -1
  779. package/components/Spinner/SpinnerFallbackAnimation/SpinnerFallbackAnimation.js.map +1 -1
  780. package/components/Spinner/index/index.js.map +1 -1
  781. package/components/Spinner/locale/index/index.js.map +1 -1
  782. package/components/Spinner/locale/locales/en/en.js.map +1 -1
  783. package/components/Spinner/locale/locales/ru/ru.js.map +1 -1
  784. package/components/Sticky/Sticky/Sticky.js +4 -4
  785. package/components/Sticky/Sticky/Sticky.js.map +1 -1
  786. package/components/Sticky/Sticky.d.ts +1 -1
  787. package/components/Sticky/Sticky.md +27 -27
  788. package/components/Sticky/Sticky.styles/Sticky.styles.js.map +1 -1
  789. package/components/Sticky/index/index.js.map +1 -1
  790. package/components/Switcher/Switcher/Switcher.js.map +1 -1
  791. package/components/Switcher/Switcher.md +10 -10
  792. package/components/Switcher/Switcher.styles/Switcher.styles.js.map +1 -1
  793. package/components/Switcher/index/index.js.map +1 -1
  794. package/components/Switcher/switcherTheme/switcherTheme.js.map +1 -1
  795. package/components/Tabs/Indicator/Indicator.js.map +1 -1
  796. package/components/Tabs/Indicator.styles/Indicator.styles.js.map +1 -1
  797. package/components/Tabs/Tab/Tab.js +14 -14
  798. package/components/Tabs/Tab/Tab.js.map +1 -1
  799. package/components/Tabs/Tab.styles/Tab.styles.js.map +1 -1
  800. package/components/Tabs/Tabs/Tabs.js +4 -4
  801. package/components/Tabs/Tabs/Tabs.js.map +1 -1
  802. package/components/Tabs/Tabs.md +36 -36
  803. package/components/Tabs/Tabs.styles/Tabs.styles.js.map +1 -1
  804. package/components/Tabs/TabsContext/TabsContext.js.map +1 -1
  805. package/components/Tabs/index/index.js.map +1 -1
  806. package/components/Textarea/Textarea/Textarea.js +12 -12
  807. package/components/Textarea/Textarea/Textarea.js.map +1 -1
  808. package/components/Textarea/Textarea.md +25 -25
  809. package/components/Textarea/Textarea.styles/Textarea.styles.js.map +1 -1
  810. package/components/Textarea/TextareaCounter/TextareaCounter.js.map +1 -1
  811. package/components/Textarea/TextareaHelpers/TextareaHelpers.js.map +1 -1
  812. package/components/Textarea/index/index.js.map +1 -1
  813. package/components/ThemeConsumer/ThemeConsumer/ThemeConsumer.js.map +1 -1
  814. package/components/ThemeConsumer/index/index.js.map +1 -1
  815. package/components/ThemeProvider/ThemeProvider/ThemeProvider.js.map +1 -1
  816. package/components/ThemeProvider/index/index.js.map +1 -1
  817. package/components/Toast/Toast/Toast.js +19 -19
  818. package/components/Toast/Toast/Toast.js.map +1 -1
  819. package/components/Toast/Toast.md +41 -41
  820. package/components/Toast/Toast.styles/Toast.styles.js.map +1 -1
  821. package/components/Toast/ToastStatic/ToastStatic.js.map +1 -1
  822. package/components/Toast/ToastView/ToastView.js +4 -4
  823. package/components/Toast/ToastView/ToastView.js.map +1 -1
  824. package/components/Toast/ToastView.styles/ToastView.styles.js.map +1 -1
  825. package/components/Toast/index/index.js.map +1 -1
  826. package/components/Toggle/Toggle/Toggle.js +2 -2
  827. package/components/Toggle/Toggle/Toggle.js.map +1 -1
  828. package/components/Toggle/Toggle.md +24 -24
  829. package/components/Toggle/Toggle.styles/Toggle.styles.js.map +1 -1
  830. package/components/Toggle/index/index.js.map +1 -1
  831. package/components/Token/Token/Token.js.map +1 -1
  832. package/components/Token/Token.styles/Token.styles.js.map +1 -1
  833. package/components/Token/index/index.js.map +1 -1
  834. package/components/TokenInput/TextWidthHelper/TextWidthHelper.js +3 -3
  835. package/components/TokenInput/TextWidthHelper/TextWidthHelper.js.map +1 -1
  836. package/components/TokenInput/TokenInput/TokenInput.js +28 -17
  837. package/components/TokenInput/TokenInput/TokenInput.js.map +1 -1
  838. package/components/TokenInput/TokenInput.md +77 -77
  839. package/components/TokenInput/TokenInput.styles/TokenInput.styles.js.map +1 -1
  840. package/components/TokenInput/TokenInputMenu/TokenInputMenu.js.map +1 -1
  841. package/components/TokenInput/TokenInputReducer/TokenInputReducer.js.map +1 -1
  842. package/components/TokenInput/index/index.js.map +1 -1
  843. package/components/TokenInput/locale/index/index.js.map +1 -1
  844. package/components/TokenInput/locale/locales/en/en.js.map +1 -1
  845. package/components/TokenInput/locale/locales/ru/ru.js.map +1 -1
  846. package/components/Tooltip/Tooltip/Tooltip.js +8 -8
  847. package/components/Tooltip/Tooltip/Tooltip.js.map +1 -1
  848. package/components/Tooltip/Tooltip.md +301 -301
  849. package/components/Tooltip/Tooltip.styles/Tooltip.styles.js.map +1 -1
  850. package/components/Tooltip/index/index.js.map +1 -1
  851. package/components/TooltipMenu/TooltipMenu/TooltipMenu.js +7 -7
  852. package/components/TooltipMenu/TooltipMenu/TooltipMenu.js.map +1 -1
  853. package/components/TooltipMenu/TooltipMenu.md +115 -115
  854. package/components/TooltipMenu/index/index.js.map +1 -1
  855. package/components/TopBar/TopBar/TopBar.js +38 -38
  856. package/components/TopBar/TopBar/TopBar.js.map +1 -1
  857. package/components/TopBar/TopBar.md +111 -111
  858. package/components/TopBar/TopBar.styles/TopBar.styles.js.map +1 -1
  859. package/components/TopBar/TopBarButtonItem/TopBarButtonItem.js +4 -4
  860. package/components/TopBar/TopBarButtonItem/TopBarButtonItem.js.map +1 -1
  861. package/components/TopBar/TopBarDivider/TopBarDivider.js +4 -4
  862. package/components/TopBar/TopBarDivider/TopBarDivider.js.map +1 -1
  863. package/components/TopBar/TopBarDropdown/TopBarDropdown.js +4 -4
  864. package/components/TopBar/TopBarDropdown/TopBarDropdown.js.map +1 -1
  865. package/components/TopBar/TopBarEnd/TopBarEnd.js +4 -4
  866. package/components/TopBar/TopBarEnd/TopBarEnd.js.map +1 -1
  867. package/components/TopBar/TopBarItem/TopBarItem.js +4 -4
  868. package/components/TopBar/TopBarItem/TopBarItem.js.map +1 -1
  869. package/components/TopBar/TopBarLogout/TopBarLogout.js +4 -4
  870. package/components/TopBar/TopBarLogout/TopBarLogout.js.map +1 -1
  871. package/components/TopBar/TopBarOrganizations/TopBarOrganizations.js +4 -4
  872. package/components/TopBar/TopBarOrganizations/TopBarOrganizations.js.map +1 -1
  873. package/components/TopBar/TopBarStart/TopBarStart.js +4 -4
  874. package/components/TopBar/TopBarStart/TopBarStart.js.map +1 -1
  875. package/components/TopBar/TopBarUser/TopBarUser.js +6 -6
  876. package/components/TopBar/TopBarUser/TopBarUser.js.map +1 -1
  877. package/components/TopBar/index/index.js.map +1 -1
  878. package/components/TopBar/locale/index/index.js.map +1 -1
  879. package/components/TopBar/locale/locales/en/en.js.map +1 -1
  880. package/components/TopBar/locale/locales/ru/ru.js.map +1 -1
  881. package/index.js.map +1 -1
  882. package/internal/BGRuler/BGRuler.js +5 -5
  883. package/internal/BGRuler/BGRuler.js.map +1 -1
  884. package/internal/Calendar/Calendar/Calendar.js +3 -3
  885. package/internal/Calendar/Calendar/Calendar.js.map +1 -1
  886. package/internal/Calendar/Calendar.styles/Calendar.styles.js.map +1 -1
  887. package/internal/Calendar/CalendarDateShape/CalendarDateShape.js.map +1 -1
  888. package/internal/Calendar/CalendarScrollEvents/CalendarScrollEvents.js.map +1 -1
  889. package/internal/Calendar/CalendarUtils/CalendarUtils.js.map +1 -1
  890. package/internal/Calendar/DayCellView/DayCellView.js.map +1 -1
  891. package/internal/Calendar/DayCellView.styles/DayCellView.styles.js.map +1 -1
  892. package/internal/Calendar/DayCellViewModel/DayCellViewModel.js.map +1 -1
  893. package/internal/Calendar/Month/Month.js.map +1 -1
  894. package/internal/Calendar/MonthView/MonthView.js.map +1 -1
  895. package/internal/Calendar/MonthView.styles/MonthView.styles.js.map +1 -1
  896. package/internal/Calendar/MonthViewModel/MonthViewModel.js.map +1 -1
  897. package/internal/Calendar/config/config.js.map +1 -1
  898. package/internal/Calendar/index/index.js.map +1 -1
  899. package/internal/CommonWrapper/CommonWrapper/CommonWrapper.js.map +1 -1
  900. package/internal/CommonWrapper/index/index.js.map +1 -1
  901. package/internal/ComponentCombinator/ComponentCombinator.js.map +1 -1
  902. package/internal/ComponentTable/ComponentTable.js.map +1 -1
  903. package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js.map +1 -1
  904. package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js.map +1 -1
  905. package/internal/CustomComboBox/CustomComboBox/CustomComboBox.js +10 -10
  906. package/internal/CustomComboBox/CustomComboBox/CustomComboBox.js.map +1 -1
  907. package/internal/CustomComboBox/CustomComboBox.styles/CustomComboBox.styles.js.map +1 -1
  908. package/internal/CustomComboBox/CustomComboBoxReducer/CustomComboBoxReducer.js.map +1 -1
  909. package/internal/CustomComboBox/CustomComboBoxTypes/CustomComboBoxTypes.js.map +1 -1
  910. package/internal/CustomComboBox/index/index.js.map +1 -1
  911. package/internal/CustomComboBox/locale/index/index.js.map +1 -1
  912. package/internal/CustomComboBox/locale/locales/en/en.js.map +1 -1
  913. package/internal/CustomComboBox/locale/locales/ru/ru.js.map +1 -1
  914. package/internal/DateSelect/DateSelect/DateSelect.js +2 -2
  915. package/internal/DateSelect/DateSelect/DateSelect.js.map +1 -1
  916. package/internal/DateSelect/DateSelect.styles/DateSelect.styles.js.map +1 -1
  917. package/internal/DateSelect/index/index.js.map +1 -1
  918. package/internal/DropdownContainer/DropdownContainer/DropdownContainer.js.map +1 -1
  919. package/internal/DropdownContainer/index/index.js.map +1 -1
  920. package/internal/FocusTrap/FocusTrap/FocusTrap.js.map +1 -1
  921. package/internal/FocusTrap/index/index.js.map +1 -1
  922. package/internal/HideBodyVerticalScroll/HideBodyVerticalScroll/HideBodyVerticalScroll.js.map +1 -1
  923. package/internal/HideBodyVerticalScroll/index/index.js.map +1 -1
  924. package/internal/IgnoreLayerClick/IgnoreLayerClick/IgnoreLayerClick.js.map +1 -1
  925. package/internal/IgnoreLayerClick/index/index.js.map +1 -1
  926. package/internal/InputLikeText/HiddenInput/HiddenInput.js +4 -4
  927. package/internal/InputLikeText/HiddenInput/HiddenInput.js.map +1 -1
  928. package/internal/InputLikeText/InputLikeText/InputLikeText.js +6 -6
  929. package/internal/InputLikeText/InputLikeText/InputLikeText.js.map +1 -1
  930. package/internal/InputLikeText/InputLikeText.styles/InputLikeText.styles.js.map +1 -1
  931. package/internal/InputLikeText/index/index.js.map +1 -1
  932. package/internal/InternalMenu/InternalMenu/InternalMenu.js.map +1 -1
  933. package/internal/InternalMenu/InternalMenu.styles/InternalMenu.styles.js.map +1 -1
  934. package/internal/InternalMenu/index/index.js.map +1 -1
  935. package/internal/InternalMenu/isActiveElement/isActiveElement.js.map +1 -1
  936. package/internal/MaskCharLowLine/MaskCharLowLine/MaskCharLowLine.js +6 -6
  937. package/internal/MaskCharLowLine/MaskCharLowLine/MaskCharLowLine.js.map +1 -1
  938. package/internal/MaskCharLowLine/MaskCharLowLine.styles/MaskCharLowLine.styles.js.map +1 -1
  939. package/internal/MaskCharLowLine/index/index.js.map +1 -1
  940. package/internal/MaskedInput/MaskedInput/MaskedInput.js.map +1 -1
  941. package/internal/MaskedInput/MaskedInput.styles/MaskedInput.styles.js.map +1 -1
  942. package/internal/MaskedInput/index/index.js.map +1 -1
  943. package/internal/Menu/Menu/Menu.js +10 -10
  944. package/internal/Menu/Menu/Menu.js.map +1 -1
  945. package/internal/Menu/Menu.styles/Menu.styles.js.map +1 -1
  946. package/internal/Menu/index/index.js.map +1 -1
  947. package/internal/Menu/isActiveElement/isActiveElement.js.map +1 -1
  948. package/internal/PerformanceMetrics/PerformanceMetrics/PerformanceMetrics.js.map +1 -1
  949. package/internal/Popup/Popup/Popup.js +31 -31
  950. package/internal/Popup/Popup/Popup.js.map +1 -1
  951. package/internal/Popup/Popup.styles/Popup.styles.js.map +1 -1
  952. package/internal/Popup/PopupHelper/PopupHelper.js.map +1 -1
  953. package/internal/Popup/PopupPin/PopupPin.js +16 -16
  954. package/internal/Popup/PopupPin/PopupPin.js.map +1 -1
  955. package/internal/Popup/PopupPin.styles/PopupPin.styles.js.map +1 -1
  956. package/internal/Popup/index/index.js.map +1 -1
  957. package/internal/PopupMenu/PopupMenu/PopupMenu.js.map +1 -1
  958. package/internal/PopupMenu/PopupMenu.styles/PopupMenu.styles.js.map +1 -1
  959. package/internal/PopupMenu/PopupMenuPositions/PopupMenuPositions.js.map +1 -1
  960. package/internal/PopupMenu/index/index.js.map +1 -1
  961. package/internal/PopupMenu/validatePositions/validatePositions.js.map +1 -1
  962. package/internal/RenderContainer/RenderContainer/RenderContainer.js.map +1 -1
  963. package/internal/RenderContainer/RenderInnerContainer/RenderInnerContainer.js.map +1 -1
  964. package/internal/RenderContainer/index/index.js.map +1 -1
  965. package/internal/RenderLayer/RenderLayer/RenderLayer.js.map +1 -1
  966. package/internal/RenderLayer/index/index.js.map +1 -1
  967. package/internal/ResizeDetector/ResizeDetector/ResizeDetector.js.map +1 -1
  968. package/internal/ResizeDetector/ResizeDetector.styles/ResizeDetector.styles.js.map +1 -1
  969. package/internal/ResizeDetector/index/index.js.map +1 -1
  970. package/internal/SpinnerOld/SpinnerOld/SpinnerOld.js +12 -12
  971. package/internal/SpinnerOld/SpinnerOld/SpinnerOld.js.map +1 -1
  972. package/internal/SpinnerOld/SpinnerOld.styles/SpinnerOld.styles.js.map +1 -1
  973. package/internal/SpinnerOld/SpinnerOldCloudIcon/SpinnerOldCloudIcon.js.map +1 -1
  974. package/internal/SpinnerOld/index/index.js.map +1 -1
  975. package/internal/SpinnerOld/locale/index/index.js.map +1 -1
  976. package/internal/SpinnerOld/locale/locales/en/en.js.map +1 -1
  977. package/internal/SpinnerOld/locale/locales/ru/ru.js.map +1 -1
  978. package/internal/ThemePlayground/AnotherInputsPlayground/AnotherInputsPlayground.js.map +1 -1
  979. package/internal/ThemePlayground/CheckboxPlayground/CheckboxPlayground.js.map +1 -1
  980. package/internal/ThemePlayground/ComponentsGroup/ComponentsGroup.js.map +1 -1
  981. package/internal/ThemePlayground/CurrencyInputPlayground/CurrencyInputPlayground.js.map +1 -1
  982. package/internal/ThemePlayground/FxInputPlayground/FxInputPlayground.js.map +1 -1
  983. package/internal/ThemePlayground/HintPlayground/HintPlayground.js.map +1 -1
  984. package/internal/ThemePlayground/PagingPlayground/PagingPlayground.js.map +1 -1
  985. package/internal/ThemePlayground/Playground/Playground.js.map +1 -1
  986. package/internal/ThemePlayground/Playground.md +7 -7
  987. package/internal/ThemePlayground/Playground.styles/Playground.styles.js.map +1 -1
  988. package/internal/ThemePlayground/RadioPlayground/RadioPlayground.js.map +1 -1
  989. package/internal/ThemePlayground/SelectPlayground/SelectPlayground.js.map +1 -1
  990. package/internal/ThemePlayground/ShowcaseGroup/ShowcaseGroup.js.map +1 -1
  991. package/internal/ThemePlayground/SwitcherPlayground/SwitcherPlayground.js.map +1 -1
  992. package/internal/ThemePlayground/ThemeContextPlayground/ThemeContextPlayground.js.map +1 -1
  993. package/internal/ThemePlayground/ThemeEditor/ThemeEditor.js.map +1 -1
  994. package/internal/ThemePlayground/TogglePlayground/TogglePlayground.js.map +1 -1
  995. package/internal/ThemePlayground/TokenInputPlayground/TokenInputPlayground.js.map +1 -1
  996. package/internal/ThemePlayground/VariableValue/VariableValue.js.map +1 -1
  997. package/internal/ThemePlayground/constants/constants.js.map +1 -1
  998. package/internal/ThemePlayground/darkTheme/darkTheme.js.map +1 -1
  999. package/internal/ThemePlayground/helpers/helpers.js.map +1 -1
  1000. package/internal/ThemeShowcase/ThemeShowcase/ThemeShowcase.js.map +1 -1
  1001. package/internal/ThemeShowcase/ThemeShowcase.styles/ThemeShowcase.styles.js.map +1 -1
  1002. package/internal/ThemeShowcase/VariablesCollector/VariablesCollector.js.map +1 -1
  1003. package/internal/ZIndex/ZIndex/ZIndex.js.map +1 -1
  1004. package/internal/ZIndex/ZIndexStorage/ZIndexStorage.js.map +1 -1
  1005. package/internal/ZIndex/index/index.js.map +1 -1
  1006. package/internal/icons/16px/icon.styles/icon.styles.js.map +1 -1
  1007. package/internal/icons/16px/index/index.js.map +1 -1
  1008. package/internal/icons/20px/Icon/Icon.js +2 -2
  1009. package/internal/icons/20px/Icon/Icon.js.map +1 -1
  1010. package/internal/icons/20px/icon.styles/icon.styles.js.map +1 -1
  1011. package/internal/icons/20px/index/index.js.map +1 -1
  1012. package/internal/icons/20px/svg/svg.js.map +1 -1
  1013. package/internal/icons/CloudIcon/CloudIcon.js.map +1 -1
  1014. package/internal/icons/CrossIcon/CrossIcon.js.map +1 -1
  1015. package/internal/icons/SpinnerIcon/SpinnerIcon.js.map +1 -1
  1016. package/internal/icons/SpinnerIcon.styles/SpinnerIcon.styles.js.map +1 -1
  1017. package/internal/themes/DefaultTheme/DefaultTheme.js.map +1 -1
  1018. package/internal/themes/FlatTheme/FlatTheme.js.map +1 -1
  1019. package/internal/themes/Theme8px/Theme8px.js.map +1 -1
  1020. package/lib/ConditionalHandler/ConditionalHandler.js +2 -2
  1021. package/lib/ConditionalHandler/ConditionalHandler.js.map +1 -1
  1022. package/lib/LayoutEvents/LayoutEvents.js.map +1 -1
  1023. package/lib/MockDate/MockDate.js.map +1 -1
  1024. package/lib/ModalStack/ModalStack.js +4 -4
  1025. package/lib/ModalStack/ModalStack.js.map +1 -1
  1026. package/lib/SSRSafe/SSRSafe.js.map +1 -1
  1027. package/lib/Supports/Supports.js.map +1 -1
  1028. package/lib/Upgrades/Upgrades.js.map +1 -1
  1029. package/lib/animation/index/index.js.map +1 -1
  1030. package/lib/animation/presets/presets.js.map +1 -1
  1031. package/lib/animation/stepper/stepper.js.map +1 -1
  1032. package/lib/client/client.js.map +1 -1
  1033. package/lib/createPropsGetter/createPropsGetter.js.map +1 -1
  1034. package/lib/currentEnvironment/currentEnvironment.js.map +1 -1
  1035. package/lib/date/InternalDate/InternalDate.js +3 -3
  1036. package/lib/date/InternalDate/InternalDate.js.map +1 -1
  1037. package/lib/date/InternalDateCalculator/InternalDateCalculator.js.map +1 -1
  1038. package/lib/date/InternalDateGetter/InternalDateGetter.js.map +1 -1
  1039. package/lib/date/InternalDateSetter/InternalDateSetter.js.map +1 -1
  1040. package/lib/date/InternalDateTransformer/InternalDateTransformer.js.map +1 -1
  1041. package/lib/date/InternalDateValidator/InternalDateValidator.js.map +1 -1
  1042. package/lib/date/constants/constants.js.map +1 -1
  1043. package/lib/date/localeSets/localeSets.js.map +1 -1
  1044. package/lib/date/types/types.js.map +1 -1
  1045. package/lib/dom/getFocusableElements/getFocusableElements.js +33 -33
  1046. package/lib/dom/getFocusableElements/getFocusableElements.js.map +1 -1
  1047. package/lib/dom/getScrollWidth/getScrollWidth.js.map +1 -1
  1048. package/lib/events/MouseDrag/MouseDrag.js +26 -26
  1049. package/lib/events/MouseDrag/MouseDrag.js.map +1 -1
  1050. package/lib/events/keyboard/KeyboardEventCodes/KeyboardEventCodes.js.map +1 -1
  1051. package/lib/events/keyboard/KeyboardMapKeys/KeyboardMapKeys.js.map +1 -1
  1052. package/lib/events/keyboard/extractCode/extractCode.js.map +1 -1
  1053. package/lib/events/keyboard/identifiers/identifiers.js.map +1 -1
  1054. package/lib/events/stopPropagation/stopPropagation.js.map +1 -1
  1055. package/lib/events/tabListener/tabListener.js.map +1 -1
  1056. package/lib/extractKeyboardAction/extractKeyboardAction.js.map +1 -1
  1057. package/lib/filterProps/filterProps.js.map +1 -1
  1058. package/lib/listenFocusOutside/listenFocusOutside.js +9 -9
  1059. package/lib/listenFocusOutside/listenFocusOutside.js.map +1 -1
  1060. package/lib/locale/LOCALECONTEXT.md +246 -246
  1061. package/lib/locale/LocaleContext/LocaleContext.js.map +1 -1
  1062. package/lib/locale/LocaleHelper/LocaleHelper.js.map +1 -1
  1063. package/lib/locale/constants/constants.js.map +1 -1
  1064. package/lib/locale/decorators/decorators.js.map +1 -1
  1065. package/lib/locale/index/index.js.map +1 -1
  1066. package/lib/locale/types/types.js.map +1 -1
  1067. package/lib/memo/memo.js.map +1 -1
  1068. package/lib/net/fetch/fetch.js.map +1 -1
  1069. package/lib/polyfillPlaceholder/polyfillPlaceholder.js.map +1 -1
  1070. package/lib/reactGetTextContent/reactGetTextContent.js.map +1 -1
  1071. package/lib/styles/ColorFactory/ColorFactory.js.map +1 -1
  1072. package/lib/styles/ColorFunctions/ColorFunctions.js.map +1 -1
  1073. package/lib/styles/ColorHelpers/ColorHelpers.js.map +1 -1
  1074. package/lib/styles/ColorKeywords/ColorKeywords.js.map +1 -1
  1075. package/lib/styles/ColorObject/ColorObject.js.map +1 -1
  1076. package/lib/styles/DimensionFunctions/DimensionFunctions.js.map +1 -1
  1077. package/lib/styles/HoldSelectionColor/HoldSelectionColor.js.map +1 -1
  1078. package/lib/styles/Mixins/Mixins.js.map +1 -1
  1079. package/lib/theming/AnimationKeyframes/AnimationKeyframes.js.map +1 -1
  1080. package/lib/theming/Emotion/Emotion.js.map +1 -1
  1081. package/lib/theming/ThemeContext/ThemeContext.js.map +1 -1
  1082. package/lib/theming/ThemeContext.md +248 -248
  1083. package/lib/theming/ThemeFactory/ThemeFactory.js.map +1 -1
  1084. package/lib/theming/ThemeHelpers/ThemeHelpers.js.map +1 -1
  1085. package/lib/theming/themes/DefaultTheme/DefaultTheme.js.map +1 -1
  1086. package/lib/theming/themes/DefaultTheme8px/DefaultTheme8px.js.map +1 -1
  1087. package/lib/theming/themes/FlatTheme/FlatTheme.js.map +1 -1
  1088. package/lib/theming/themes/FlatTheme8px/FlatTheme8px.js.map +1 -1
  1089. package/lib/utils/utils.js +2 -2
  1090. package/lib/utils/utils.js.map +1 -1
  1091. package/package.json +2 -5
  1092. package/typings/console.d.ts +3 -3
  1093. package/typings/event-types.d.ts +4 -4
  1094. package/typings/fonts.d.ts +12 -12
  1095. package/typings/global.d.ts +6 -6
  1096. package/typings/images.d.ts +1 -1
  1097. package/typings/normalize-wheel.d.ts +5 -5
  1098. package/typings/stylis-plugin-extra-scope.d.ts +3 -3
  1099. package/typings/utility-types.d.ts +14 -14
@@ -1 +1 @@
1
- {"version":3,"sources":["SidePageHeader.tsx"],"names":["React","cn","Sticky","CrossIcon","isFunction","ThemeContext","CommonWrapper","jsStyles","SidePageContext","SidePageHeader","state","isReadyToFix","theme","wrapper","lastRegularHeight","componentDidMount","window","addEventListener","update","componentWillUnmount","removeEventListener","updateReadyToFix","renderHeader","fixed","header","headerFixed","renderClose","title","titleFixed","props","children","renderCloseContent","requestClose","close","closeIcon","stickyOffset","parseInt","sidePageHeaderStickyOffset","wrapperScrolledUp","getBoundingClientRect","top","regularHeight","fixedHeaderHeight","setState","wrapperRef","el","render","renderMain","height","sidePageHeaderFixedLineHeight","sidePageHeaderFixedPaddingY","Component","__KONTUR_REACT_UI__"],"mappings":"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","sourcesContent":["import React from 'react';\r\nimport cn from 'classnames';\r\n\r\nimport { Sticky } from '../Sticky';\r\nimport { CrossIcon } from '../../internal/icons/CrossIcon';\r\nimport { isFunction } from '../../lib/utils';\r\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\r\nimport { Theme } from '../../lib/theming/Theme';\r\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\r\n\r\nimport { jsStyles } from './SidePage.styles';\r\nimport { SidePageContext } from './SidePageContext';\r\n\r\nexport interface SidePageHeaderProps extends CommonProps {\r\n children?: React.ReactNode | ((fixed: boolean) => React.ReactNode);\r\n}\r\n\r\nexport interface SidePageHeaderState {\r\n isReadyToFix: boolean;\r\n}\r\n\r\n/**\r\n * Шапка сайдпейджа\r\n *\r\n * @visibleName SidePage.Header\r\n */\r\nexport class SidePageHeader extends React.Component<SidePageHeaderProps, SidePageHeaderState> {\r\n public static __KONTUR_REACT_UI__ = 'SidePageHeader';\r\n\r\n public state = {\r\n isReadyToFix: false,\r\n };\r\n\r\n private theme!: Theme;\r\n private wrapper: HTMLElement | null = null;\r\n private lastRegularHeight = 0;\r\n\r\n public get regularHeight(): number {\r\n const { isReadyToFix } = this.state;\r\n if (!this.wrapper) {\r\n return 0;\r\n }\r\n if (!isReadyToFix) {\r\n this.lastRegularHeight = this.wrapper.getBoundingClientRect().height;\r\n }\r\n return this.lastRegularHeight;\r\n }\r\n\r\n public get fixedHeaderHeight(): number {\r\n const { theme } = this;\r\n return parseInt(theme.sidePageHeaderFixedLineHeight) + parseInt(theme.sidePageHeaderFixedPaddingY) * 2;\r\n }\r\n\r\n public componentDidMount = () => {\r\n window.addEventListener('scroll', this.update, true);\r\n };\r\n\r\n public componentWillUnmount = () => {\r\n window.removeEventListener('scroll', this.update, true);\r\n };\r\n\r\n public update = () => {\r\n this.updateReadyToFix();\r\n };\r\n\r\n public render(): JSX.Element {\r\n return (\r\n <ThemeContext.Consumer>\r\n {theme => {\r\n this.theme = theme;\r\n return this.renderMain();\r\n }}\r\n </ThemeContext.Consumer>\r\n );\r\n }\r\n\r\n private renderMain() {\r\n const { isReadyToFix } = this.state;\r\n return (\r\n <CommonWrapper {...this.props}>\r\n <div ref={this.wrapperRef}>\r\n {isReadyToFix ? <Sticky side=\"top\">{this.renderHeader}</Sticky> : this.renderHeader()}\r\n </div>\r\n </CommonWrapper>\r\n );\r\n }\r\n\r\n private renderHeader = (fixed = false) => {\r\n return (\r\n <div className={cn(jsStyles.header(this.theme), { [jsStyles.headerFixed(this.theme)]: fixed })}>\r\n {this.renderClose()}\r\n <div className={cn(jsStyles.title(this.theme), { [jsStyles.titleFixed()]: fixed })}>\r\n {isFunction(this.props.children) ? this.props.children(fixed) : this.props.children}\r\n </div>\r\n </div>\r\n );\r\n };\r\n\r\n private renderCloseContent = (fixed: boolean) => (\r\n <SidePageContext.Consumer>\r\n {({ requestClose }) => (\r\n <a\r\n className={cn(jsStyles.close(this.theme), {\r\n [jsStyles.fixed(this.theme)]: fixed,\r\n })}\r\n onClick={requestClose}\r\n data-tid=\"SidePage__close\"\r\n >\r\n <span\r\n className={cn(jsStyles.closeIcon(this.theme), {\r\n [jsStyles.fixed(this.theme)]: fixed,\r\n })}\r\n >\r\n <CrossIcon />\r\n </span>\r\n </a>\r\n )}\r\n </SidePageContext.Consumer>\r\n );\r\n\r\n private renderClose = () => {\r\n const stickyOffset = parseInt(this.theme.sidePageHeaderStickyOffset);\r\n\r\n return (\r\n <Sticky side=\"top\" offset={stickyOffset}>\r\n {this.renderCloseContent}\r\n </Sticky>\r\n );\r\n };\r\n\r\n private updateReadyToFix = () => {\r\n if (this.wrapper) {\r\n const wrapperScrolledUp = this.wrapper.getBoundingClientRect().top;\r\n const isReadyToFix = this.regularHeight + wrapperScrolledUp <= this.fixedHeaderHeight;\r\n this.setState(state => (state.isReadyToFix !== isReadyToFix ? { isReadyToFix } : state));\r\n }\r\n };\r\n\r\n private wrapperRef = (el: HTMLElement | null) => {\r\n this.wrapper = el;\r\n };\r\n}\r\n"]}
1
+ {"version":3,"sources":["SidePageHeader.tsx"],"names":["React","cn","Sticky","CrossIcon","isFunction","ThemeContext","CommonWrapper","jsStyles","SidePageContext","SidePageHeader","state","isReadyToFix","context","theme","wrapper","sticky","lastRegularHeight","componentDidMount","window","addEventListener","update","headerRef","componentWillUnmount","removeEventListener","reflow","updateReadyToFix","renderHeader","fixed","header","headerFixed","renderClose","title","titleFixed","props","children","renderCloseContent","requestClose","close","closeIcon","stickyOffset","parseInt","sidePageHeaderStickyOffset","wrapperScrolledUp","getBoundingClientRect","top","regularHeight","fixedHeaderHeight","setState","wrapperRef","el","stickyRef","render","renderMain","height","sidePageHeaderFixedLineHeight","sidePageHeaderFixedPaddingY","Component","__KONTUR_REACT_UI__","contextType"],"mappings":"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","sourcesContent":["import React from 'react';\nimport cn from 'classnames';\n\nimport { Sticky } from '../Sticky';\nimport { CrossIcon } from '../../internal/icons/CrossIcon';\nimport { isFunction } from '../../lib/utils';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\n\nimport { jsStyles } from './SidePage.styles';\nimport { SidePageContext, SidePageContextType } from './SidePageContext';\n\nexport interface SidePageHeaderProps extends CommonProps {\n children?: React.ReactNode | ((fixed: boolean) => React.ReactNode);\n}\n\nexport interface SidePageHeaderState {\n isReadyToFix: boolean;\n}\n\n/**\n * Шапка сайдпейджа\n *\n * @visibleName SidePage.Header\n */\nexport class SidePageHeader extends React.Component<SidePageHeaderProps, SidePageHeaderState> {\n public static __KONTUR_REACT_UI__ = 'SidePageHeader';\n\n public state = {\n isReadyToFix: false,\n };\n\n public static contextType = SidePageContext;\n public context: SidePageContextType = this.context;\n\n private theme!: Theme;\n private wrapper: HTMLElement | null = null;\n private sticky: Sticky | null = null;\n private lastRegularHeight = 0;\n\n public get regularHeight(): number {\n const { isReadyToFix } = this.state;\n if (!this.wrapper) {\n return 0;\n }\n if (!isReadyToFix) {\n this.lastRegularHeight = this.wrapper.getBoundingClientRect().height;\n }\n return this.lastRegularHeight;\n }\n\n public get fixedHeaderHeight(): number {\n const { theme } = this;\n return parseInt(theme.sidePageHeaderFixedLineHeight) + parseInt(theme.sidePageHeaderFixedPaddingY) * 2;\n }\n\n public componentDidMount = () => {\n window.addEventListener('scroll', this.update, true);\n this.context.headerRef(this);\n };\n\n public componentWillUnmount = () => {\n window.removeEventListener('scroll', this.update, true);\n this.context.headerRef(null);\n };\n\n public update = () => {\n this.sticky?.reflow();\n this.updateReadyToFix();\n };\n\n public render(): JSX.Element {\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 { isReadyToFix } = this.state;\n return (\n <CommonWrapper {...this.props}>\n <div ref={this.wrapperRef}>\n {isReadyToFix ? (\n <Sticky side=\"top\" ref={this.stickyRef}>\n {this.renderHeader}\n </Sticky>\n ) : (\n this.renderHeader()\n )}\n </div>\n </CommonWrapper>\n );\n }\n\n private renderHeader = (fixed = false) => {\n return (\n <div className={cn(jsStyles.header(this.theme), { [jsStyles.headerFixed(this.theme)]: fixed })}>\n {this.renderClose()}\n <div className={cn(jsStyles.title(this.theme), { [jsStyles.titleFixed()]: fixed })}>\n {isFunction(this.props.children) ? this.props.children(fixed) : this.props.children}\n </div>\n </div>\n );\n };\n\n private renderCloseContent = (fixed: boolean) => (\n <SidePageContext.Consumer>\n {({ requestClose }) => (\n <a\n className={cn(jsStyles.close(this.theme), {\n [jsStyles.fixed(this.theme)]: fixed,\n })}\n onClick={requestClose}\n data-tid=\"SidePage__close\"\n >\n <span\n className={cn(jsStyles.closeIcon(this.theme), {\n [jsStyles.fixed(this.theme)]: fixed,\n })}\n >\n <CrossIcon />\n </span>\n </a>\n )}\n </SidePageContext.Consumer>\n );\n\n private renderClose = () => {\n const stickyOffset = parseInt(this.theme.sidePageHeaderStickyOffset);\n\n return (\n <Sticky side=\"top\" offset={stickyOffset}>\n {this.renderCloseContent}\n </Sticky>\n );\n };\n\n private updateReadyToFix = () => {\n if (this.wrapper) {\n const wrapperScrolledUp = this.wrapper.getBoundingClientRect().top;\n const isReadyToFix = this.regularHeight + wrapperScrolledUp <= this.fixedHeaderHeight;\n this.setState((state) => (state.isReadyToFix !== isReadyToFix ? { isReadyToFix } : state));\n }\n };\n\n private wrapperRef = (el: HTMLElement | null) => {\n this.wrapper = el;\n };\n\n private stickyRef = (el: Sticky | null) => {\n this.sticky = el;\n };\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import React from 'react';
2
2
  import { CommonProps } from '../../internal/CommonWrapper';
3
+ import { SidePageContextType } from './SidePageContext';
3
4
  export interface SidePageHeaderProps extends CommonProps {
4
5
  children?: React.ReactNode | ((fixed: boolean) => React.ReactNode);
5
6
  }
@@ -16,8 +17,11 @@ export declare class SidePageHeader extends React.Component<SidePageHeaderProps,
16
17
  state: {
17
18
  isReadyToFix: boolean;
18
19
  };
20
+ static contextType: React.Context<SidePageContextType>;
21
+ context: SidePageContextType;
19
22
  private theme;
20
23
  private wrapper;
24
+ private sticky;
21
25
  private lastRegularHeight;
22
26
  get regularHeight(): number;
23
27
  get fixedHeaderHeight(): number;
@@ -31,4 +35,5 @@ export declare class SidePageHeader extends React.Component<SidePageHeaderProps,
31
35
  private renderClose;
32
36
  private updateReadyToFix;
33
37
  private wrapperRef;
38
+ private stickyRef;
34
39
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["helpers.ts"],"names":["isReactUINode","isFooter","component","isHeader"],"mappings":";;AAEA,SAASA,aAAT,QAA8B,iBAA9B;;;;;AAKA,OAAO,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACC,SAAD,EAAmF;AACzG,SAAOF,aAAa,CAAC,gBAAD,EAAmBE,SAAnB,CAApB;AACD,CAFM;;AAIP,OAAO,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACD,SAAD,EAAmF;AACzG,SAAOF,aAAa,CAAC,gBAAD,EAAmBE,SAAnB,CAApB;AACD,CAFM","sourcesContent":["import React from 'react';\r\n\r\nimport { isReactUINode } from '../../lib/utils';\r\n\r\nimport { SidePageFooterProps } from './SidePageFooter';\r\nimport { SidePageHeaderProps } from './SidePageHeader';\r\n\r\nexport const isFooter = (component: React.ReactNode): component is React.Component<SidePageFooterProps> => {\r\n return isReactUINode('SidePageFooter', component);\r\n};\r\n\r\nexport const isHeader = (component: React.ReactNode): component is React.Component<SidePageHeaderProps> => {\r\n return isReactUINode('SidePageHeader', component);\r\n};\r\n"]}
1
+ {"version":3,"sources":["helpers.ts"],"names":["isReactUINode","isFooter","component","isHeader"],"mappings":";;AAEA,SAASA,aAAT,QAA8B,iBAA9B;;;;;AAKA,OAAO,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACC,SAAD,EAAmF;AACzG,SAAOF,aAAa,CAAC,gBAAD,EAAmBE,SAAnB,CAApB;AACD,CAFM;;AAIP,OAAO,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACD,SAAD,EAAmF;AACzG,SAAOF,aAAa,CAAC,gBAAD,EAAmBE,SAAnB,CAApB;AACD,CAFM","sourcesContent":["import React from 'react';\n\nimport { isReactUINode } from '../../lib/utils';\n\nimport { SidePageFooterProps } from './SidePageFooter';\nimport { SidePageHeaderProps } from './SidePageHeader';\n\nexport const isFooter = (component: React.ReactNode): component is React.Component<SidePageFooterProps> => {\n return isReactUINode('SidePageFooter', component);\n};\n\nexport const isHeader = (component: React.ReactNode): component is React.Component<SidePageHeaderProps> => {\n return isReactUINode('SidePageHeader', component);\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAd;AACA,cAAc,kBAAd;AACA,cAAc,gBAAd;AACA,cAAc,kBAAd;AACA,cAAc,qBAAd","sourcesContent":["export * from './SidePage';\r\nexport * from './SidePageHeader';\r\nexport * from './SidePageBody';\r\nexport * from './SidePageFooter';\r\nexport * from './SidePageContainer';\r\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAd;AACA,cAAc,kBAAd;AACA,cAAc,gBAAd;AACA,cAAc,kBAAd;AACA,cAAc,qBAAd","sourcesContent":["export * from './SidePage';\nexport * from './SidePageHeader';\nexport * from './SidePageBody';\nexport * from './SidePageFooter';\nexport * from './SidePageContainer';\n"]}
@@ -19,8 +19,8 @@ var types = {
19
19
  normal: 'normal'
20
20
  };
21
21
  export
22
- /**
23
- * DRAFT - инлайн-лоадер
22
+ /**
23
+ * DRAFT - инлайн-лоадер
24
24
  */
25
25
  var Spinner = (_dec = locale('Spinner', SpinnerLocaleHelper), _dec(_class = (_temp = _class2 = /*#__PURE__*/function (_React$Component) {
26
26
  _inheritsLoose(Spinner, _React$Component);
@@ -81,27 +81,27 @@ var Spinner = (_dec = locale('Spinner', SpinnerLocaleHelper), _dec(_class = (_te
81
81
 
82
82
  return Spinner;
83
83
  }(React.Component), _class2.__KONTUR_REACT_UI__ = 'Spinner', _class2.propTypes = {
84
- /**
85
- * Текст рядом с мини-лоадером.
86
- *
87
- * 'Загрузка' - значение по-умолчанию
84
+ /**
85
+ * Текст рядом с мини-лоадером.
86
+ *
87
+ * 'Загрузка' - значение по-умолчанию
88
88
  */
89
89
  caption: PropTypes.node,
90
90
  dimmed: PropTypes.bool,
91
91
 
92
- /**
93
- * Тип спиннера: mini, normal, big
94
- *
95
- * Значение по-умолчанию - normal
96
- *
97
- * Spinner.types - все доступные типы
92
+ /**
93
+ * Тип спиннера: mini, normal, big
94
+ *
95
+ * Значение по-умолчанию - normal
96
+ *
97
+ * Spinner.types - все доступные типы
98
98
  */
99
99
  type: PropTypes.oneOf(Object.keys(types)),
100
100
 
101
- /**
102
- * @deprecated Старое поведение спиннера - облачко при среднем и большом размере
103
- *
104
- * @default false - исчезнет в 3.0
101
+ /**
102
+ * @deprecated Старое поведение спиннера - облачко при среднем и большом размере
103
+ *
104
+ * @default false - исчезнет в 3.0
105
105
  */
106
106
  cloud: PropTypes.bool
107
107
  }, _class2.defaultProps = {
@@ -1 +1 @@
1
- {"version":3,"sources":["Spinner.tsx"],"names":["React","PropTypes","warning","cn","locale","ThemeContext","SpinnerIcon","SpinnerOld","CommonWrapper","jsStyles","SpinnerLocaleHelper","types","big","mini","normal","Spinner","props","theme","renderSpinner","type","dimmed","circleClassName","circleDimmed","circle","renderCaption","caption","captionColor","cloud","render","renderMain","renderSpinnerOld","loading","spinner","inner","Component","__KONTUR_REACT_UI__","propTypes","node","bool","oneOf","Object","keys","defaultProps","Types"],"mappings":"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","sourcesContent":["import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport warning from 'warning';\r\nimport cn from 'classnames';\r\n\r\nimport { locale } from '../../lib/locale/decorators';\r\nimport { Theme } from '../../lib/theming/Theme';\r\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\r\nimport { SpinnerIcon } from '../../internal/icons/SpinnerIcon';\r\nimport { SpinnerOld } from '../../internal/SpinnerOld';\r\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\r\n\r\nimport { jsStyles } from './Spinner.styles';\r\nimport { SpinnerLocale, SpinnerLocaleHelper } from './locale';\r\n\r\nconst types: Record<SpinnerType, SpinnerType> = {\r\n big: 'big',\r\n mini: 'mini',\r\n normal: 'normal',\r\n};\r\n\r\nexport type SpinnerType = 'mini' | 'normal' | 'big';\r\n\r\nexport interface SpinnerProps extends CommonProps {\r\n caption?: React.ReactNode;\r\n dimmed?: boolean;\r\n /**\r\n * Тип спиннера\r\n * @default normal\r\n */\r\n type: SpinnerType;\r\n /**\r\n * @deprecated Старое поведение спиннера - облачко при среднем и большом размере - исчезнет в 3.0 поведение пересено в `@skbkontur/react-ui-addons` смотри [миграцию](https://github.com/skbkontur/retail-ui/blob/master/packages/react-ui/MIGRATION.md)\r\n *\r\n * @default false\r\n */\r\n cloud?: boolean;\r\n}\r\n\r\n/**\r\n * DRAFT - инлайн-лоадер\r\n */\r\n\r\n@locale('Spinner', SpinnerLocaleHelper)\r\nexport class Spinner extends React.Component<SpinnerProps> {\r\n public static __KONTUR_REACT_UI__ = 'Spinner';\r\n\r\n public static propTypes = {\r\n /**\r\n * Текст рядом с мини-лоадером.\r\n *\r\n * 'Загрузка' - значение по-умолчанию\r\n */\r\n caption: PropTypes.node,\r\n\r\n dimmed: PropTypes.bool,\r\n\r\n /**\r\n * Тип спиннера: mini, normal, big\r\n *\r\n * Значение по-умолчанию - normal\r\n *\r\n * Spinner.types - все доступные типы\r\n */\r\n type: PropTypes.oneOf(Object.keys(types)),\r\n /**\r\n * @deprecated Старое поведение спиннера - облачко при среднем и большом размере\r\n *\r\n * @default false - исчезнет в 3.0\r\n */\r\n cloud: PropTypes.bool,\r\n };\r\n\r\n public static defaultProps: SpinnerProps = {\r\n type: 'normal',\r\n };\r\n\r\n public static Types: typeof types = types;\r\n private theme!: Theme;\r\n private readonly locale!: SpinnerLocale;\r\n\r\n constructor(props: SpinnerProps) {\r\n super(props);\r\n warning(!this.props.cloud, 'cloud is deprecated, will removed in 3.0. ');\r\n }\r\n\r\n public render() {\r\n return (\r\n <ThemeContext.Consumer>\r\n {theme => {\r\n this.theme = theme;\r\n return !this.props.cloud ? this.renderMain() : this.renderSpinnerOld();\r\n }}\r\n </ThemeContext.Consumer>\r\n );\r\n }\r\n\r\n private renderSpinnerOld() {\r\n return <SpinnerOld {...this.props} />;\r\n }\r\n\r\n private renderMain() {\r\n const { type, caption = this.locale.loading, dimmed } = this.props;\r\n\r\n return (\r\n <CommonWrapper {...this.props}>\r\n <div className={jsStyles.spinner()}>\r\n <span className={jsStyles.inner()}>{this.renderSpinner(type, dimmed)}</span>\r\n {caption && this.renderCaption(type, caption)}\r\n </div>\r\n </CommonWrapper>\r\n );\r\n }\r\n\r\n private renderSpinner = (type: SpinnerType, dimmed?: boolean) => {\r\n const circleClassName = dimmed ? jsStyles.circleDimmed(this.theme) : jsStyles.circle(this.theme);\r\n\r\n return <SpinnerIcon size={type} className={circleClassName} dimmed={dimmed} />;\r\n };\r\n\r\n private renderCaption = (type: SpinnerType, caption: React.ReactNode) => (\r\n <span className={cn(jsStyles[type](this.theme), jsStyles.captionColor(this.theme))}>{caption}</span>\r\n );\r\n}\r\n"]}
1
+ {"version":3,"sources":["Spinner.tsx"],"names":["React","PropTypes","warning","cn","locale","ThemeContext","SpinnerIcon","SpinnerOld","CommonWrapper","jsStyles","SpinnerLocaleHelper","types","big","mini","normal","Spinner","props","theme","renderSpinner","type","dimmed","circleClassName","circleDimmed","circle","renderCaption","caption","captionColor","cloud","render","renderMain","renderSpinnerOld","loading","spinner","inner","Component","__KONTUR_REACT_UI__","propTypes","node","bool","oneOf","Object","keys","defaultProps","Types"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport warning from 'warning';\nimport cn from 'classnames';\n\nimport { locale } from '../../lib/locale/decorators';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { SpinnerIcon } from '../../internal/icons/SpinnerIcon';\nimport { SpinnerOld } from '../../internal/SpinnerOld';\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\n\nimport { jsStyles } from './Spinner.styles';\nimport { SpinnerLocale, SpinnerLocaleHelper } from './locale';\n\nconst types: Record<SpinnerType, SpinnerType> = {\n big: 'big',\n mini: 'mini',\n normal: 'normal',\n};\n\nexport type SpinnerType = 'mini' | 'normal' | 'big';\n\nexport interface SpinnerProps extends CommonProps {\n caption?: React.ReactNode;\n dimmed?: boolean;\n /**\n * Тип спиннера\n * @default normal\n */\n type: SpinnerType;\n /**\n * @deprecated Старое поведение спиннера - облачко при среднем и большом размере - исчезнет в 3.0 поведение пересено в `@skbkontur/react-ui-addons` смотри [миграцию](https://github.com/skbkontur/retail-ui/blob/master/packages/react-ui/MIGRATION.md)\n *\n * @default false\n */\n cloud?: boolean;\n}\n\n/**\n * DRAFT - инлайн-лоадер\n */\n\n@locale('Spinner', SpinnerLocaleHelper)\nexport class Spinner extends React.Component<SpinnerProps> {\n public static __KONTUR_REACT_UI__ = 'Spinner';\n\n public static propTypes = {\n /**\n * Текст рядом с мини-лоадером.\n *\n * 'Загрузка' - значение по-умолчанию\n */\n caption: PropTypes.node,\n\n dimmed: PropTypes.bool,\n\n /**\n * Тип спиннера: mini, normal, big\n *\n * Значение по-умолчанию - normal\n *\n * Spinner.types - все доступные типы\n */\n type: PropTypes.oneOf(Object.keys(types)),\n /**\n * @deprecated Старое поведение спиннера - облачко при среднем и большом размере\n *\n * @default false - исчезнет в 3.0\n */\n cloud: PropTypes.bool,\n };\n\n public static defaultProps: SpinnerProps = {\n type: 'normal',\n };\n\n public static Types: typeof types = types;\n private theme!: Theme;\n private readonly locale!: SpinnerLocale;\n\n constructor(props: SpinnerProps) {\n super(props);\n warning(!this.props.cloud, 'cloud is deprecated, will removed in 3.0. ');\n }\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {theme => {\n this.theme = theme;\n return !this.props.cloud ? this.renderMain() : this.renderSpinnerOld();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderSpinnerOld() {\n return <SpinnerOld {...this.props} />;\n }\n\n private renderMain() {\n const { type, caption = this.locale.loading, dimmed } = this.props;\n\n return (\n <CommonWrapper {...this.props}>\n <div className={jsStyles.spinner()}>\n <span className={jsStyles.inner()}>{this.renderSpinner(type, dimmed)}</span>\n {caption && this.renderCaption(type, caption)}\n </div>\n </CommonWrapper>\n );\n }\n\n private renderSpinner = (type: SpinnerType, dimmed?: boolean) => {\n const circleClassName = dimmed ? jsStyles.circleDimmed(this.theme) : jsStyles.circle(this.theme);\n\n return <SpinnerIcon size={type} className={circleClassName} dimmed={dimmed} />;\n };\n\n private renderCaption = (type: SpinnerType, caption: React.ReactNode) => (\n <span className={cn(jsStyles[type](this.theme), jsStyles.captionColor(this.theme))}>{caption}</span>\n );\n}\n"]}
@@ -1,34 +1,34 @@
1
- ```jsx harmony
2
- import { Gapped, Spinner } from '@skbkontur/react-ui';
3
-
4
- const reactNodeCaption = (
5
- <div>
6
- <Spinner type="mini" caption={null} /> <span style={{ color: 'tomato', fontSize: '1.3em' }}>З</span>
7
- агрузка ...
8
- </div>
9
- );
10
-
11
- <Gapped>
12
- <Spinner type="big" caption="big" />
13
- <Spinner type="normal" caption="normal" />
14
- <Spinner type="mini" caption="mini" />
15
- <Spinner type="mini" dimmed caption="mini dimmed" />
16
- <Spinner type="big" caption={reactNodeCaption} />
17
- </Gapped>;
18
- ```
19
-
20
- #### Локали по умолчанию (см. `LocaleProvider`)
21
-
22
- ```typescript
23
- interface SpinnerLocale {
24
- loading?: React.ReactNode;
25
- }
26
-
27
- const ru_RU = {
28
- loading: 'Загрузка',
29
- };
30
-
31
- const en_GB = {
32
- loading: 'Loading',
33
- };
34
- ```
1
+ ```jsx harmony
2
+ import { Gapped, Spinner } from '@skbkontur/react-ui';
3
+
4
+ const reactNodeCaption = (
5
+ <div>
6
+ <Spinner type="mini" caption={null} /> <span style={{ color: 'tomato', fontSize: '1.3em' }}>З</span>
7
+ агрузка ...
8
+ </div>
9
+ );
10
+
11
+ <Gapped>
12
+ <Spinner type="big" caption="big" />
13
+ <Spinner type="normal" caption="normal" />
14
+ <Spinner type="mini" caption="mini" />
15
+ <Spinner type="mini" dimmed caption="mini dimmed" />
16
+ <Spinner type="big" caption={reactNodeCaption} />
17
+ </Gapped>;
18
+ ```
19
+
20
+ #### Локали по умолчанию (см. `LocaleProvider`)
21
+
22
+ ```typescript
23
+ interface SpinnerLocale {
24
+ loading?: React.ReactNode;
25
+ }
26
+
27
+ const ru_RU = {
28
+ loading: 'Загрузка',
29
+ };
30
+
31
+ const en_GB = {
32
+ loading: 'Loading',
33
+ };
34
+ ```
@@ -1 +1 @@
1
- {"version":3,"sources":["Spinner.styles.ts"],"names":["css","memoizeStyle","AnimationKeyframes","isIE11","styles","circle","t","spinnerColor","spinnerCircleOffset","spinnerCircleLength","spinnerCircleRotate","circleDimmed","spinnerDimmedColor","captionColor","spinnerCaptionColor","mini","spinnerCaptionGapSmall","spinnerFontSizeSmall","spinnerLineHeightSmall","normal","spinnerFontSizeMedium","spinnerLineHeightMedium","spinnerCaptionGapMedium","big","spinnerFontSizeLarge","spinnerLineHeightLarge","spinnerCaptionGapLarge","spinner","inner","jsStyles"],"mappings":"svDAAA,SAASA,GAAT,EAAcC,YAAd,QAAkC,2BAAlC;;AAEA,SAASC,kBAAT,QAAmC,sCAAnC;AACA,SAASC,MAAT,QAAuB,kBAAvB;;AAEA,IAAMC,MAAM,GAAG;AACbC,EAAAA,MADa,kBACNC,CADM,EACI;AACf,WAAON,GAAP;AACYM,IAAAA,CAAC,CAACC,YADd;;AAGI,KAACJ,MAAD;;AAEeD,IAAAA,kBAAkB,CAACM,mBAAnB,CAAuCF,CAAvC,CAFf;AAGMJ,IAAAA,kBAAkB,CAACO,mBAAnB,CAAuCH,CAAvC,CAHN;AAIMJ,IAAAA,kBAAkB,CAACQ,mBAAnB,CAAuCJ,CAAvC,CAJN;AAKMJ,IAAAA,kBAAkB,CAACK,YAAnB,CAAgCD,CAAhC,CALN,wCAHJ;;;AAWD,GAbY;AAcbK,EAAAA,YAda,wBAcAL,CAdA,EAcU;AACrB,WAAON,GAAP;AACYM,IAAAA,CAAC,CAACM,kBADd;;AAGI,KAACT,MAAD;;AAEeD,IAAAA,kBAAkB,CAACM,mBAAnB,CAAuCF,CAAvC,CAFf;AAGIJ,IAAAA,kBAAkB,CAACO,mBAAnB,CAAuCH,CAAvC,CAHJ;AAIIJ,IAAAA,kBAAkB,CAACQ,mBAAnB,CAAuCJ,CAAvC,CAJJ,mCAHJ;;;AAUD,GAzBY;;AA2BbO,EAAAA,YA3Ba,wBA2BAP,CA3BA,EA2BU;AACrB,WAAON,GAAP;AACWM,IAAAA,CAAC,CAACQ,mBADb;;AAGD,GA/BY;;AAiCbC,EAAAA,IAjCa,gBAiCRT,CAjCQ,EAiCE;AACb,WAAON,GAAP;AACiBM,IAAAA,CAAC,CAACU,sBADnB;AAEeV,IAAAA,CAAC,CAACW,oBAFjB;AAGiBX,IAAAA,CAAC,CAACY,sBAHnB;;AAKD,GAvCY;;AAyCbC,EAAAA,MAzCa,kBAyCNb,CAzCM,EAyCI;AACf,WAAON,GAAP;;AAEeM,IAAAA,CAAC,CAACc,qBAFjB;AAGiBd,IAAAA,CAAC,CAACe,uBAHnB;AAIgBf,IAAAA,CAAC,CAACgB,uBAJlB;;AAMD,GAhDY;;AAkDbC,EAAAA,GAlDa,eAkDTjB,CAlDS,EAkDC;AACZ,WAAON,GAAP;;AAEeM,IAAAA,CAAC,CAACkB,oBAFjB;AAGiBlB,IAAAA,CAAC,CAACmB,sBAHnB;AAIgBnB,IAAAA,CAAC,CAACoB,sBAJlB;;AAMD,GAzDY;;AA2DbC,EAAAA,OA3Da,qBA2DH;AACR,WAAO3B,GAAP;;;;AAID,GAhEY;;AAkEb4B,EAAAA,KAlEa,mBAkEL;AACN,WAAO5B,GAAP;;;AAGD,GAtEY,EAAf;;;AAyEA,OAAO,IAAM6B,QAAQ,GAAG5B,YAAY,CAACG,MAAD,CAA7B","sourcesContent":["import { css, memoizeStyle } from '../../lib/theming/Emotion';\r\nimport { Theme } from '../../lib/theming/Theme';\r\nimport { AnimationKeyframes } from '../../lib/theming/AnimationKeyframes';\r\nimport { isIE11 } from '../../lib/client';\r\n\r\nconst styles = {\r\n circle(t: Theme) {\r\n return css`\r\n stroke: ${t.spinnerColor};\r\n\r\n ${!isIE11 &&\r\n `\r\n animation: ${AnimationKeyframes.spinnerCircleOffset(t)} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\r\n ${AnimationKeyframes.spinnerCircleLength(t)} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\r\n ${AnimationKeyframes.spinnerCircleRotate(t)} 2s linear infinite,\r\n ${AnimationKeyframes.spinnerColor(t)} 6s ease-in-out infinite;\r\n `}\r\n `;\r\n },\r\n circleDimmed(t: Theme) {\r\n return css`\r\n stroke: ${t.spinnerDimmedColor};\r\n\r\n ${!isIE11 &&\r\n `\r\n animation: ${AnimationKeyframes.spinnerCircleOffset(t)} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\r\n ${AnimationKeyframes.spinnerCircleLength(t)} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\r\n ${AnimationKeyframes.spinnerCircleRotate(t)} 2s linear infinite;\r\n `}\r\n `;\r\n },\r\n\r\n captionColor(t: Theme) {\r\n return css`\r\n color: ${t.spinnerCaptionColor};\r\n `;\r\n },\r\n\r\n mini(t: Theme) {\r\n return css`\r\n margin-left: ${t.spinnerCaptionGapSmall};\r\n font-size: ${t.spinnerFontSizeSmall};\r\n line-height: ${t.spinnerLineHeightSmall};\r\n `;\r\n },\r\n\r\n normal(t: Theme) {\r\n return css`\r\n display: block;\r\n font-size: ${t.spinnerFontSizeMedium};\r\n line-height: ${t.spinnerLineHeightMedium};\r\n margin-top: ${t.spinnerCaptionGapMedium};\r\n `;\r\n },\r\n\r\n big(t: Theme) {\r\n return css`\r\n display: block;\r\n font-size: ${t.spinnerFontSizeLarge};\r\n line-height: ${t.spinnerLineHeightLarge};\r\n margin-top: ${t.spinnerCaptionGapLarge};\r\n `;\r\n },\r\n\r\n spinner() {\r\n return css`\r\n display: inline-block;\r\n text-align: center;\r\n `;\r\n },\r\n\r\n inner() {\r\n return css`\r\n display: inline-block;\r\n `;\r\n },\r\n};\r\n\r\nexport const jsStyles = memoizeStyle(styles);\r\n"]}
1
+ {"version":3,"sources":["Spinner.styles.ts"],"names":["css","memoizeStyle","AnimationKeyframes","isIE11","styles","circle","t","spinnerColor","spinnerCircleOffset","spinnerCircleLength","spinnerCircleRotate","circleDimmed","spinnerDimmedColor","captionColor","spinnerCaptionColor","mini","spinnerCaptionGapSmall","spinnerFontSizeSmall","spinnerLineHeightSmall","normal","spinnerFontSizeMedium","spinnerLineHeightMedium","spinnerCaptionGapMedium","big","spinnerFontSizeLarge","spinnerLineHeightLarge","spinnerCaptionGapLarge","spinner","inner","jsStyles"],"mappings":"svDAAA,SAASA,GAAT,EAAcC,YAAd,QAAkC,2BAAlC;;AAEA,SAASC,kBAAT,QAAmC,sCAAnC;AACA,SAASC,MAAT,QAAuB,kBAAvB;;AAEA,IAAMC,MAAM,GAAG;AACbC,EAAAA,MADa,kBACNC,CADM,EACI;AACf,WAAON,GAAP;AACYM,IAAAA,CAAC,CAACC,YADd;;AAGI,KAACJ,MAAD;;AAEeD,IAAAA,kBAAkB,CAACM,mBAAnB,CAAuCF,CAAvC,CAFf;AAGMJ,IAAAA,kBAAkB,CAACO,mBAAnB,CAAuCH,CAAvC,CAHN;AAIMJ,IAAAA,kBAAkB,CAACQ,mBAAnB,CAAuCJ,CAAvC,CAJN;AAKMJ,IAAAA,kBAAkB,CAACK,YAAnB,CAAgCD,CAAhC,CALN,wCAHJ;;;AAWD,GAbY;AAcbK,EAAAA,YAda,wBAcAL,CAdA,EAcU;AACrB,WAAON,GAAP;AACYM,IAAAA,CAAC,CAACM,kBADd;;AAGI,KAACT,MAAD;;AAEeD,IAAAA,kBAAkB,CAACM,mBAAnB,CAAuCF,CAAvC,CAFf;AAGIJ,IAAAA,kBAAkB,CAACO,mBAAnB,CAAuCH,CAAvC,CAHJ;AAIIJ,IAAAA,kBAAkB,CAACQ,mBAAnB,CAAuCJ,CAAvC,CAJJ,mCAHJ;;;AAUD,GAzBY;;AA2BbO,EAAAA,YA3Ba,wBA2BAP,CA3BA,EA2BU;AACrB,WAAON,GAAP;AACWM,IAAAA,CAAC,CAACQ,mBADb;;AAGD,GA/BY;;AAiCbC,EAAAA,IAjCa,gBAiCRT,CAjCQ,EAiCE;AACb,WAAON,GAAP;AACiBM,IAAAA,CAAC,CAACU,sBADnB;AAEeV,IAAAA,CAAC,CAACW,oBAFjB;AAGiBX,IAAAA,CAAC,CAACY,sBAHnB;;AAKD,GAvCY;;AAyCbC,EAAAA,MAzCa,kBAyCNb,CAzCM,EAyCI;AACf,WAAON,GAAP;;AAEeM,IAAAA,CAAC,CAACc,qBAFjB;AAGiBd,IAAAA,CAAC,CAACe,uBAHnB;AAIgBf,IAAAA,CAAC,CAACgB,uBAJlB;;AAMD,GAhDY;;AAkDbC,EAAAA,GAlDa,eAkDTjB,CAlDS,EAkDC;AACZ,WAAON,GAAP;;AAEeM,IAAAA,CAAC,CAACkB,oBAFjB;AAGiBlB,IAAAA,CAAC,CAACmB,sBAHnB;AAIgBnB,IAAAA,CAAC,CAACoB,sBAJlB;;AAMD,GAzDY;;AA2DbC,EAAAA,OA3Da,qBA2DH;AACR,WAAO3B,GAAP;;;;AAID,GAhEY;;AAkEb4B,EAAAA,KAlEa,mBAkEL;AACN,WAAO5B,GAAP;;;AAGD,GAtEY,EAAf;;;AAyEA,OAAO,IAAM6B,QAAQ,GAAG5B,YAAY,CAACG,MAAD,CAA7B","sourcesContent":["import { css, memoizeStyle } from '../../lib/theming/Emotion';\nimport { Theme } from '../../lib/theming/Theme';\nimport { AnimationKeyframes } from '../../lib/theming/AnimationKeyframes';\nimport { isIE11 } from '../../lib/client';\n\nconst styles = {\n circle(t: Theme) {\n return css`\n stroke: ${t.spinnerColor};\n\n ${!isIE11 &&\n `\n animation: ${AnimationKeyframes.spinnerCircleOffset(t)} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength(t)} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate(t)} 2s linear infinite,\n ${AnimationKeyframes.spinnerColor(t)} 6s ease-in-out infinite;\n `}\n `;\n },\n circleDimmed(t: Theme) {\n return css`\n stroke: ${t.spinnerDimmedColor};\n\n ${!isIE11 &&\n `\n animation: ${AnimationKeyframes.spinnerCircleOffset(t)} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength(t)} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate(t)} 2s linear infinite;\n `}\n `;\n },\n\n captionColor(t: Theme) {\n return css`\n color: ${t.spinnerCaptionColor};\n `;\n },\n\n mini(t: Theme) {\n return css`\n margin-left: ${t.spinnerCaptionGapSmall};\n font-size: ${t.spinnerFontSizeSmall};\n line-height: ${t.spinnerLineHeightSmall};\n `;\n },\n\n normal(t: Theme) {\n return css`\n display: block;\n font-size: ${t.spinnerFontSizeMedium};\n line-height: ${t.spinnerLineHeightMedium};\n margin-top: ${t.spinnerCaptionGapMedium};\n `;\n },\n\n big(t: Theme) {\n return css`\n display: block;\n font-size: ${t.spinnerFontSizeLarge};\n line-height: ${t.spinnerLineHeightLarge};\n margin-top: ${t.spinnerCaptionGapLarge};\n `;\n },\n\n spinner() {\n return css`\n display: inline-block;\n text-align: center;\n `;\n },\n\n inner() {\n return css`\n display: inline-block;\n `;\n },\n};\n\nexport const jsStyles = memoizeStyle(styles);\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["SpinnerFallbackAnimation.ts"],"names":["ColorFactory","SpinnerFallbackAnimationRunner","animations","FPS","interval","start","forEach","animation","rafInterval","step","stop","clear","finish","fn","delay","lastcall","cleared","rafId","timestamp","Date","getTime","requestAnimationFrame","cancelAnimationFrame","Animation","duration","onProgress","onFinish","startTime","isFinished","progress","reset","createOffsetAnimation","from","to","setStyleProperty","units","current","createLengthAnimation","reverse","p","createColorAnimation","colors","rgbColors","map","color","create","rgb","currentIndex","nextIndex","Math","round","length","createRotationAnimation"],"mappings":"AAAA,SAASA,YAAT,QAA6B,+BAA7B;;AAEA,WAAaC,8BAAb;;;AAGE,wCAAoBC,UAApB,EAAqDC,GAArD,EAAkE,uBAA9CD,UAA8C,GAA9CA,UAA8C,MAAbC,GAAa,GAAbA,GAAa,MAF1DC,QAE0D,GAFR,IAEQ;;;;AAI3DC,EAAAA,KAJ2D,GAInD,YAAM;AACnB,IAAA,KAAI,CAACH,UAAL,CAAgBI,OAAhB,CAAwB,UAAAC,SAAS,UAAIA,SAAS,CAACF,KAAV,EAAJ,EAAjC;AACA,IAAA,KAAI,CAACD,QAAL,GAAgBI,WAAW,CAAC,YAAM;AAChC,MAAA,KAAI,CAACN,UAAL,CAAgBI,OAAhB,CAAwB,UAAAC,SAAS,UAAIA,SAAS,CAACE,IAAV,EAAJ,EAAjC;AACD,KAF0B,EAExB,KAAI,CAACN,GAFmB,CAA3B;AAGD,GATiE;;AAW3DO,EAAAA,IAX2D,GAWpD,YAAM;AAClB,QAAI,KAAI,CAACN,QAAT,EAAmB;AACjB,MAAA,KAAI,CAACA,QAAL,CAAcO,KAAd;AACA,MAAA,KAAI,CAACT,UAAL,CAAgBI,OAAhB,CAAwB,UAAAC,SAAS,UAAIA,SAAS,CAACK,MAAV,EAAJ,EAAjC;AACD;AACF,GAhBiE,CAChE,KAAKP,KAAL,GACD,CALH;;;AAsBA,IAAMG,WAAW,GAAG,SAAdA,WAAc,CAACK,EAAD,EAAiBC,KAAjB,EAAmC;AACrD,MAAIC,QAAQ,GAAG,CAAf;AACA,MAAIC,OAAO,GAAG,KAAd;AACA,MAAIC,KAAK,GAAG,CAAZ;;AAEA,MAAMb,QAAQ,GAAG,SAAXA,QAAW,GAAM;AACrB,QAAIY,OAAJ,EAAa;AACb,QAAME,SAAS,GAAG,IAAIC,IAAJ,GAAWC,OAAX,EAAlB;AACA,QAAI,CAACL,QAAL,EAAeA,QAAQ,GAAGG,SAAX;AACf,QAAIA,SAAS,GAAGH,QAAZ,GAAuBD,KAA3B,EAAkC;AAChCD,MAAAA,EAAE;AACFE,MAAAA,QAAQ,GAAGG,SAAX;AACD;AACDD,IAAAA,KAAK,GAAGI,qBAAqB,CAACjB,QAAD,CAA7B;AACD,GATD;AAUAA,EAAAA,QAAQ;;AAER,SAAO;AACLO,IAAAA,KAAK,EAAE,iBAAM;AACXK,MAAAA,OAAO,GAAG,IAAV;AACAM,MAAAA,oBAAoB,CAACL,KAAD,CAApB;AACD,KAJI,EAAP;;AAMD,CAvBD,C;;AAyBMM,S;;;;AAIJ;AACUC,QADV;AAEUC,UAFV;AAGUC,QAHV;AAIE,wBAHQF,QAGR,GAHQA,QAGR,MAFQC,UAER,GAFQA,UAER,MADQC,QACR,GADQA,QACR,MAPMC,SAON,GAPkB,CAOlB,MANMC,UAMN,GANmB,KAMnB;;AAEKnB,EAAAA,IAFL,GAEY,YAAM;AAClB,QAAI,MAAI,CAACmB,UAAT,EAAqB;AACrB,QAAMV,SAAS,GAAG,IAAIC,IAAJ,GAAWC,OAAX,EAAlB;AACA,QAAI,CAAC,MAAI,CAACO,SAAV,EAAqB,MAAI,CAACA,SAAL,GAAiBT,SAAjB;AACrB,QAAMW,QAAQ,GAAG,CAACX,SAAS,GAAG,MAAI,CAACS,SAAlB,IAA+B,MAAI,CAACH,QAArD;;AAEA,IAAA,MAAI,CAACC,UAAL,CAAgBI,QAAhB;;AAEA,QAAIA,QAAQ,IAAI,CAAhB,EAAmB;AACjB,MAAA,MAAI,CAACjB,MAAL;AACD;AACF,GAbC;;AAeKkB,EAAAA,KAfL,GAea,YAAM;AACnB,IAAA,MAAI,CAACH,SAAL,GAAiB,CAAjB;AACA,IAAA,MAAI,CAACC,UAAL,GAAkB,KAAlB;AACD,GAlBC;;AAoBKhB,EAAAA,MApBL,GAoBc,YAAM;AACpB,IAAA,MAAI,CAACgB,UAAL,GAAkB,IAAlB;AACA,IAAA,MAAI,CAACF,QAAL,IAAiB,MAAI,CAACA,QAAL,CAAc,MAAd,CAAjB;AACD,GAvBC;;AAyBKrB,EAAAA,KAzBL,GAyBa,YAAM;AACnB,QAAI,CAAC,MAAI,CAACuB,UAAV,EAAsB;AACpB,MAAA,MAAI,CAACnB,IAAL;AACD;AACF,GA7BC,CAAE,C;;;AAgCN,OAAO,IAAMsB,qBAAqB,GAAG,SAAxBA,qBAAwB;AACnCC,IADmC;AAEnCC,EAFmC;AAGnCT,QAHmC;AAInCU,gBAJmC;AAKnCC,KALmC;AAMhC,KADHA,KACG,cADHA,KACG,GADK,EACL;AACH,SAAO,IAAIZ,SAAJ;AACLC,EAAAA,QADK;AAEL,YAAAK,QAAQ,EAAI;AACV,QAAMO,OAAO,GAAGJ,IAAI,GAAG,CAACC,EAAE,GAAGD,IAAN,IAAcH,QAArC;AACAK,IAAAA,gBAAgB,CAAC,mBAAD,OAAyBE,OAAzB,GAAmCD,KAAnC,CAAhB;AACD,GALI;AAML,YAAA5B,SAAS,EAAI;AACXA,IAAAA,SAAS,CAACuB,KAAV;AACD,GARI,CAAP;;AAUD,CAjBM;;AAmBP,OAAO,IAAMO,qBAAqB,GAAG,SAAxBA,qBAAwB;AACnCL,IADmC;AAEnCC,EAFmC;AAGnCT,QAHmC;AAInCU,gBAJmC;AAKnCC,KALmC;AAMhC,KADHA,KACG,cADHA,KACG,GADK,EACL;AACH,MAAIG,OAAO,GAAG,KAAd;AACA,SAAO,IAAIf,SAAJ;AACLC,EAAAA,QADK;AAEL,YAAAK,QAAQ,EAAI;AACV,QAAMU,CAAC,GAAGD,OAAO,GAAG,IAAIT,QAAP,GAAkBA,QAAnC;AACA,QAAMO,OAAO,GAAG,CAACJ,IAAI,CAAC,CAAD,CAAJ,GAAU,CAACC,EAAE,CAAC,CAAD,CAAF,GAAQD,IAAI,CAAC,CAAD,CAAb,IAAoBO,CAA/B,EAAkCP,IAAI,CAAC,CAAD,CAAJ,GAAU,CAACC,EAAE,CAAC,CAAD,CAAF,GAAQD,IAAI,CAAC,CAAD,CAAb,IAAoBO,CAAhE,CAAhB;AACAL,IAAAA,gBAAgB,CAAC,kBAAD,OAAwBE,OAAO,CAAC,CAAD,CAA/B,GAAqCD,KAArC,SAA8CC,OAAO,CAAC,CAAD,CAArD,GAA2DD,KAA3D,CAAhB;AACD,GANI;AAOL,YAAA5B,SAAS,EAAI;AACX+B,IAAAA,OAAO,GAAG,CAACA,OAAX;AACA/B,IAAAA,SAAS,CAACuB,KAAV;AACD,GAVI,CAAP;;AAYD,CApBM;;AAsBP,OAAO,IAAMU,oBAAoB,GAAG,SAAvBA,oBAAuB;AAClCC,MADkC;AAElCjB,QAFkC;AAGlCU,gBAHkC;AAI/B;AACH,MAAMQ,SAAS,GAAGD,MAAM,CAACE,GAAP,CAAW,UAAAC,KAAK,UAAI5C,YAAY,CAAC6C,MAAb,CAAoBD,KAApB,EAA2BE,GAA/B,EAAhB,CAAlB;AACA,MAAIC,YAAY,GAAG,CAAnB;AACA,MAAIC,SAAS,GAAG,CAAhB;;AAEA,SAAO,IAAIzB,SAAJ;AACLC,EAAAA,QADK;AAEL,YAAAK,QAAQ,EAAI;AACV,QAAMG,IAAI,GAAGU,SAAS,CAACK,YAAD,CAAtB;AACA,QAAMd,EAAE,GAAGS,SAAS,CAACM,SAAD,CAApB;AACA,QAAIhB,IAAI,IAAIC,EAAZ,EAAgB;AACd,UAAMG,OAAO,GAAG;AACda,MAAAA,IAAI,CAACC,KAAL,CAAWlB,IAAI,CAAC,CAAD,CAAJ,GAAU,CAACC,EAAE,CAAC,CAAD,CAAF,GAAQD,IAAI,CAAC,CAAD,CAAb,IAAoBH,QAAzC,CADc;AAEdoB,MAAAA,IAAI,CAACC,KAAL,CAAWlB,IAAI,CAAC,CAAD,CAAJ,GAAU,CAACC,EAAE,CAAC,CAAD,CAAF,GAAQD,IAAI,CAAC,CAAD,CAAb,IAAoBH,QAAzC,CAFc;AAGdoB,MAAAA,IAAI,CAACC,KAAL,CAAWlB,IAAI,CAAC,CAAD,CAAJ,GAAU,CAACC,EAAE,CAAC,CAAD,CAAF,GAAQD,IAAI,CAAC,CAAD,CAAb,IAAoBH,QAAzC,CAHc,CAAhB;;AAKAK,MAAAA,gBAAgB,CAAC,QAAD,WAAkBE,OAAlB,OAAhB;AACD;AACF,GAbI;AAcL,YAAA7B,SAAS,EAAI;AACXA,IAAAA,SAAS,CAACuB,KAAV;AACAiB,IAAAA,YAAY,GAAGC,SAAf;AACAA,IAAAA,SAAS,GAAG,CAACA,SAAS,GAAG,CAAb,IAAkBP,MAAM,CAACU,MAArC;AACD,GAlBI,CAAP;;AAoBD,CA7BM;;AA+BP,OAAO,IAAMC,uBAAuB,GAAG,SAA1BA,uBAA0B;AACrCpB,IADqC;AAErCC,EAFqC;AAGrCT,QAHqC;AAIrCU,gBAJqC;AAKrCC,KALqC;AAMlC,KADHA,KACG,cADHA,KACG,GADK,KACL;AACH,SAAO,IAAIZ,SAAJ;AACLC,EAAAA,QADK;AAEL,YAAAK,QAAQ,EAAI;AACV,QAAMO,OAAO,GAAGa,IAAI,CAACC,KAAL,CAAWlB,IAAI,GAAG,CAACC,EAAE,GAAGD,IAAN,IAAcH,QAAhC,CAAhB;AACAK,IAAAA,gBAAgB,CAAC,WAAD,cAAwBE,OAAxB,GAAkCD,KAAlC,OAAhB;AACD,GALI;AAML,YAAA5B,SAAS,EAAI;AACXA,IAAAA,SAAS,CAACuB,KAAV;AACD,GARI,CAAP;;AAUD,CAjBM","sourcesContent":["import { ColorFactory } from '../../lib/styles/ColorFactory';\r\n\r\nexport class SpinnerFallbackAnimationRunner {\r\n private interval: ReturnType<typeof rafInterval> | null = null;\r\n\r\n constructor(private animations: Animation[], private FPS: number) {\r\n this.start();\r\n }\r\n\r\n public start = () => {\r\n this.animations.forEach(animation => animation.start());\r\n this.interval = rafInterval(() => {\r\n this.animations.forEach(animation => animation.step());\r\n }, this.FPS);\r\n };\r\n\r\n public stop = () => {\r\n if (this.interval) {\r\n this.interval.clear();\r\n this.animations.forEach(animation => animation.finish());\r\n }\r\n };\r\n}\r\n\r\nconst rafInterval = (fn: () => void, delay: number) => {\r\n let lastcall = 0;\r\n let cleared = false;\r\n let rafId = 0;\r\n\r\n const interval = () => {\r\n if (cleared) return;\r\n const timestamp = new Date().getTime();\r\n if (!lastcall) lastcall = timestamp;\r\n if (timestamp - lastcall > delay) {\r\n fn();\r\n lastcall = timestamp;\r\n }\r\n rafId = requestAnimationFrame(interval);\r\n };\r\n interval();\r\n\r\n return {\r\n clear: () => {\r\n cleared = true;\r\n cancelAnimationFrame(rafId);\r\n },\r\n };\r\n};\r\n\r\nclass Animation {\r\n private startTime = 0;\r\n private isFinished = false;\r\n\r\n constructor(\r\n private duration: number,\r\n private onProgress: (progress: number) => void,\r\n private onFinish?: (animation: Animation) => void,\r\n ) {}\r\n\r\n public step = () => {\r\n if (this.isFinished) return;\r\n const timestamp = new Date().getTime();\r\n if (!this.startTime) this.startTime = timestamp;\r\n const progress = (timestamp - this.startTime) / this.duration;\r\n\r\n this.onProgress(progress);\r\n\r\n if (progress >= 1) {\r\n this.finish();\r\n }\r\n };\r\n\r\n public reset = () => {\r\n this.startTime = 0;\r\n this.isFinished = false;\r\n };\r\n\r\n public finish = () => {\r\n this.isFinished = true;\r\n this.onFinish && this.onFinish(this);\r\n };\r\n\r\n public start = () => {\r\n if (!this.isFinished) {\r\n this.step();\r\n }\r\n };\r\n}\r\n\r\nexport const createOffsetAnimation = (\r\n from: number,\r\n to: number,\r\n duration: number,\r\n setStyleProperty: CSSStyleDeclaration['setProperty'],\r\n units = '',\r\n) => {\r\n return new Animation(\r\n duration,\r\n progress => {\r\n const current = from + (to - from) * progress;\r\n setStyleProperty('stroke-dashoffset', `${current}${units}`);\r\n },\r\n animation => {\r\n animation.reset();\r\n },\r\n );\r\n};\r\n\r\nexport const createLengthAnimation = (\r\n from: number[],\r\n to: number[],\r\n duration: number,\r\n setStyleProperty: CSSStyleDeclaration['setProperty'],\r\n units = '',\r\n) => {\r\n let reverse = false;\r\n return new Animation(\r\n duration,\r\n progress => {\r\n const p = reverse ? 1 - progress : progress;\r\n const current = [from[0] + (to[0] - from[0]) * p, from[1] + (to[1] - from[1]) * p];\r\n setStyleProperty('stroke-dasharray', `${current[0]}${units} ${current[1]}${units}`);\r\n },\r\n animation => {\r\n reverse = !reverse;\r\n animation.reset();\r\n },\r\n );\r\n};\r\n\r\nexport const createColorAnimation = (\r\n colors: string[],\r\n duration: number,\r\n setStyleProperty: CSSStyleDeclaration['setProperty'],\r\n) => {\r\n const rgbColors = colors.map(color => ColorFactory.create(color).rgb);\r\n let currentIndex = 0;\r\n let nextIndex = 1;\r\n\r\n return new Animation(\r\n duration,\r\n progress => {\r\n const from = rgbColors[currentIndex];\r\n const to = rgbColors[nextIndex];\r\n if (from && to) {\r\n const current = [\r\n Math.round(from[0] + (to[0] - from[0]) * progress),\r\n Math.round(from[1] + (to[1] - from[1]) * progress),\r\n Math.round(from[2] + (to[2] - from[2]) * progress),\r\n ];\r\n setStyleProperty('stroke', `rgb(${current})`);\r\n }\r\n },\r\n animation => {\r\n animation.reset();\r\n currentIndex = nextIndex;\r\n nextIndex = (nextIndex + 1) % colors.length;\r\n },\r\n );\r\n};\r\n\r\nexport const createRotationAnimation = (\r\n from: number,\r\n to: number,\r\n duration: number,\r\n setStyleProperty: CSSStyleDeclaration['setProperty'],\r\n units = 'deg',\r\n) => {\r\n return new Animation(\r\n duration,\r\n progress => {\r\n const current = Math.round(from + (to - from) * progress);\r\n setStyleProperty('transform', `rotate(${current}${units})`);\r\n },\r\n animation => {\r\n animation.reset();\r\n },\r\n );\r\n};\r\n"]}
1
+ {"version":3,"sources":["SpinnerFallbackAnimation.ts"],"names":["ColorFactory","SpinnerFallbackAnimationRunner","animations","FPS","interval","start","forEach","animation","rafInterval","step","stop","clear","finish","fn","delay","lastcall","cleared","rafId","timestamp","Date","getTime","requestAnimationFrame","cancelAnimationFrame","Animation","duration","onProgress","onFinish","startTime","isFinished","progress","reset","createOffsetAnimation","from","to","setStyleProperty","units","current","createLengthAnimation","reverse","p","createColorAnimation","colors","rgbColors","map","color","create","rgb","currentIndex","nextIndex","Math","round","length","createRotationAnimation"],"mappings":"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","sourcesContent":["import { ColorFactory } from '../../lib/styles/ColorFactory';\n\nexport class SpinnerFallbackAnimationRunner {\n private interval: ReturnType<typeof rafInterval> | null = null;\n\n constructor(private animations: Animation[], private FPS: number) {\n this.start();\n }\n\n public start = () => {\n this.animations.forEach(animation => animation.start());\n this.interval = rafInterval(() => {\n this.animations.forEach(animation => animation.step());\n }, this.FPS);\n };\n\n public stop = () => {\n if (this.interval) {\n this.interval.clear();\n this.animations.forEach(animation => animation.finish());\n }\n };\n}\n\nconst rafInterval = (fn: () => void, delay: number) => {\n let lastcall = 0;\n let cleared = false;\n let rafId = 0;\n\n const interval = () => {\n if (cleared) return;\n const timestamp = new Date().getTime();\n if (!lastcall) lastcall = timestamp;\n if (timestamp - lastcall > delay) {\n fn();\n lastcall = timestamp;\n }\n rafId = requestAnimationFrame(interval);\n };\n interval();\n\n return {\n clear: () => {\n cleared = true;\n cancelAnimationFrame(rafId);\n },\n };\n};\n\nclass Animation {\n private startTime = 0;\n private isFinished = false;\n\n constructor(\n private duration: number,\n private onProgress: (progress: number) => void,\n private onFinish?: (animation: Animation) => void,\n ) {}\n\n public step = () => {\n if (this.isFinished) return;\n const timestamp = new Date().getTime();\n if (!this.startTime) this.startTime = timestamp;\n const progress = (timestamp - this.startTime) / this.duration;\n\n this.onProgress(progress);\n\n if (progress >= 1) {\n this.finish();\n }\n };\n\n public reset = () => {\n this.startTime = 0;\n this.isFinished = false;\n };\n\n public finish = () => {\n this.isFinished = true;\n this.onFinish && this.onFinish(this);\n };\n\n public start = () => {\n if (!this.isFinished) {\n this.step();\n }\n };\n}\n\nexport const createOffsetAnimation = (\n from: number,\n to: number,\n duration: number,\n setStyleProperty: CSSStyleDeclaration['setProperty'],\n units = '',\n) => {\n return new Animation(\n duration,\n progress => {\n const current = from + (to - from) * progress;\n setStyleProperty('stroke-dashoffset', `${current}${units}`);\n },\n animation => {\n animation.reset();\n },\n );\n};\n\nexport const createLengthAnimation = (\n from: number[],\n to: number[],\n duration: number,\n setStyleProperty: CSSStyleDeclaration['setProperty'],\n units = '',\n) => {\n let reverse = false;\n return new Animation(\n duration,\n progress => {\n const p = reverse ? 1 - progress : progress;\n const current = [from[0] + (to[0] - from[0]) * p, from[1] + (to[1] - from[1]) * p];\n setStyleProperty('stroke-dasharray', `${current[0]}${units} ${current[1]}${units}`);\n },\n animation => {\n reverse = !reverse;\n animation.reset();\n },\n );\n};\n\nexport const createColorAnimation = (\n colors: string[],\n duration: number,\n setStyleProperty: CSSStyleDeclaration['setProperty'],\n) => {\n const rgbColors = colors.map(color => ColorFactory.create(color).rgb);\n let currentIndex = 0;\n let nextIndex = 1;\n\n return new Animation(\n duration,\n progress => {\n const from = rgbColors[currentIndex];\n const to = rgbColors[nextIndex];\n if (from && to) {\n const current = [\n Math.round(from[0] + (to[0] - from[0]) * progress),\n Math.round(from[1] + (to[1] - from[1]) * progress),\n Math.round(from[2] + (to[2] - from[2]) * progress),\n ];\n setStyleProperty('stroke', `rgb(${current})`);\n }\n },\n animation => {\n animation.reset();\n currentIndex = nextIndex;\n nextIndex = (nextIndex + 1) % colors.length;\n },\n );\n};\n\nexport const createRotationAnimation = (\n from: number,\n to: number,\n duration: number,\n setStyleProperty: CSSStyleDeclaration['setProperty'],\n units = 'deg',\n) => {\n return new Animation(\n duration,\n progress => {\n const current = Math.round(from + (to - from) * progress);\n setStyleProperty('transform', `rotate(${current}${units})`);\n },\n animation => {\n animation.reset();\n },\n );\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,WAAd","sourcesContent":["export * from './Spinner';\r\n"]}
1
+ {"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,WAAd","sourcesContent":["export * from './Spinner';\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["LocaleHelper","componentsLocales","en_GB","ru_RU","SpinnerLocaleHelper"],"mappings":"AAAA,SAASA,YAAT,QAA6B,kCAA7B;;AAEA,SAAUC,iBAAiB,IAAIC,KAA/B,QAA4C,cAA5C;AACA,SAAUD,iBAAiB,IAAIE,KAA/B,QAA4C,cAA5C;;;AAGA,cAAc,SAAd;;AAEA,OAAO,IAAMC,mBAAmB,GAAG,IAAIJ,YAAJ,CAAgC;AACjEG,EAAAA,KAAK,EAALA,KADiE;AAEjED,EAAAA,KAAK,EAALA,KAFiE,EAAhC,CAA5B","sourcesContent":["import { LocaleHelper } from '../../../lib/locale/LocaleHelper';\r\n\r\nimport { componentsLocales as en_GB } from './locales/en';\r\nimport { componentsLocales as ru_RU } from './locales/ru';\r\nimport { SpinnerLocale } from './types';\r\n\r\nexport * from './types';\r\n\r\nexport const SpinnerLocaleHelper = new LocaleHelper<SpinnerLocale>({\r\n ru_RU,\r\n en_GB,\r\n});\r\n"]}
1
+ {"version":3,"sources":["index.ts"],"names":["LocaleHelper","componentsLocales","en_GB","ru_RU","SpinnerLocaleHelper"],"mappings":"AAAA,SAASA,YAAT,QAA6B,kCAA7B;;AAEA,SAAUC,iBAAiB,IAAIC,KAA/B,QAA4C,cAA5C;AACA,SAAUD,iBAAiB,IAAIE,KAA/B,QAA4C,cAA5C;;;AAGA,cAAc,SAAd;;AAEA,OAAO,IAAMC,mBAAmB,GAAG,IAAIJ,YAAJ,CAAgC;AACjEG,EAAAA,KAAK,EAALA,KADiE;AAEjED,EAAAA,KAAK,EAALA,KAFiE,EAAhC,CAA5B","sourcesContent":["import { LocaleHelper } from '../../../lib/locale/LocaleHelper';\n\nimport { componentsLocales as en_GB } from './locales/en';\nimport { componentsLocales as ru_RU } from './locales/ru';\nimport { SpinnerLocale } from './types';\n\nexport * from './types';\n\nexport const SpinnerLocaleHelper = new LocaleHelper<SpinnerLocale>({\n ru_RU,\n en_GB,\n});\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["en.ts"],"names":["componentsLocales","loading"],"mappings":";;AAEA,OAAO,IAAMA,iBAAgC,GAAG;AAC9CC,EAAAA,OAAO,EAAE,SADqC,EAAzC","sourcesContent":["import { SpinnerLocale } from '../types';\r\n\r\nexport const componentsLocales: SpinnerLocale = {\r\n loading: 'Loading',\r\n};\r\n"]}
1
+ {"version":3,"sources":["en.ts"],"names":["componentsLocales","loading"],"mappings":";;AAEA,OAAO,IAAMA,iBAAgC,GAAG;AAC9CC,EAAAA,OAAO,EAAE,SADqC,EAAzC","sourcesContent":["import { SpinnerLocale } from '../types';\n\nexport const componentsLocales: SpinnerLocale = {\n loading: 'Loading',\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["ru.ts"],"names":["componentsLocales","loading"],"mappings":";;AAEA,OAAO,IAAMA,iBAAgC,GAAG;AAC9CC,EAAAA,OAAO,EAAE,UADqC,EAAzC","sourcesContent":["import { SpinnerLocale } from '../types';\r\n\r\nexport const componentsLocales: SpinnerLocale = {\r\n loading: 'Загрузка',\r\n};\r\n"]}
1
+ {"version":3,"sources":["ru.ts"],"names":["componentsLocales","loading"],"mappings":";;AAEA,OAAO,IAAMA,iBAAgC,GAAG;AAC9CC,EAAAA,OAAO,EAAE,UADqC,EAAzC","sourcesContent":["import { SpinnerLocale } from '../types';\n\nexport const componentsLocales: SpinnerLocale = {\n loading: 'Загрузка',\n};\n"]}
@@ -198,13 +198,13 @@ Sticky.__KONTUR_REACT_UI__ = 'Sticky';
198
198
  Sticky.propTypes = {
199
199
  children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
200
200
 
201
- /**
202
- * Функция, которая возвращает DOM-элемент, который нельзя пересекать.
201
+ /**
202
+ * Функция, которая возвращает DOM-элемент, который нельзя пересекать.
203
203
  */
204
204
  getStop: PropTypes.func,
205
205
 
206
- /**
207
- * Отступ от границы в пикселях
206
+ /**
207
+ * Отступ от границы в пикселях
208
208
  */
209
209
  offset: PropTypes.number,
210
210
  side: PropTypes.oneOf(['top', 'bottom']).isRequired
@@ -1 +1 @@
1
- {"version":3,"sources":["Sticky.tsx"],"names":["React","PropTypes","shallowEqual","cn","LayoutEvents","isFunction","ZIndex","CommonWrapper","jsStyles","MAX_REFLOW_RETRIES","Sticky","state","fixed","deltaHeight","stopped","relativeTop","wrapper","inner","layoutSubscription","remove","reflowCounter","refWrapper","ref","refInner","reflow","document","documentElement","Error","windowHeight","window","innerHeight","clientHeight","getBoundingClientRect","top","bottom","left","width","height","props","offset","getStop","side","prevFixed","prevHeight","setState","stop","stopRect","outerHeight","componentDidMount","addListener","componentWillUnmount","componentDidUpdate","prevProps","prevState","emit","render","children","innerStyle","container","Component","__KONTUR_REACT_UI__","propTypes","oneOfType","node","func","number","oneOf","isRequired","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport shallowEqual from 'shallowequal';\r\nimport cn from 'classnames';\r\n\r\nimport * as LayoutEvents from '../../lib/LayoutEvents';\r\nimport { Nullable } from '../../typings/utility-types';\r\nimport { isFunction } from '../../lib/utils';\r\nimport { ZIndex } from '../../internal/ZIndex';\r\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\r\n\r\nimport { jsStyles } from './Sticky.styles';\r\n\r\nconst MAX_REFLOW_RETRIES = 5;\r\n\r\nexport interface StickyProps extends CommonProps {\r\n side: 'top' | 'bottom';\r\n /**\r\n * Отступ в пикселях от края экрана, на сколько сдвигается элемент в залипшем состоянии\r\n * @default 0\r\n */\r\n offset: number;\r\n getStop?: () => Nullable<HTMLElement>;\r\n children?: React.ReactNode | ((fixed: boolean) => React.ReactNode);\r\n}\r\n\r\nexport interface StickyState {\r\n fixed: boolean;\r\n deltaHeight: number;\r\n height?: number;\r\n width?: number;\r\n left?: number;\r\n stopped: boolean;\r\n relativeTop: number;\r\n}\r\n\r\nexport class Sticky extends React.Component<StickyProps, StickyState> {\r\n public static __KONTUR_REACT_UI__ = 'Sticky';\r\n\r\n public static propTypes = {\r\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\r\n\r\n /**\r\n * Функция, которая возвращает DOM-элемент, который нельзя пересекать.\r\n */\r\n getStop: PropTypes.func,\r\n\r\n /**\r\n * Отступ от границы в пикселях\r\n */\r\n offset: PropTypes.number,\r\n\r\n side: PropTypes.oneOf(['top', 'bottom']).isRequired,\r\n };\r\n\r\n public static defaultProps = { offset: 0 };\r\n\r\n public state: StickyState = {\r\n fixed: false,\r\n deltaHeight: 0,\r\n stopped: false,\r\n relativeTop: 0,\r\n };\r\n\r\n private wrapper: Nullable<HTMLElement>;\r\n private inner: Nullable<HTMLElement>;\r\n private layoutSubscription: { remove: Nullable<() => void> } = { remove: null };\r\n private reflowCounter = 0;\r\n\r\n public componentDidMount() {\r\n this.reflow();\r\n\r\n this.layoutSubscription = LayoutEvents.addListener(this.reflow);\r\n }\r\n\r\n public componentWillUnmount() {\r\n if (this.layoutSubscription.remove) {\r\n this.layoutSubscription.remove();\r\n }\r\n }\r\n\r\n public componentDidUpdate(prevProps: StickyProps, prevState: StickyState) {\r\n if (!shallowEqual(prevProps, this.props) || !shallowEqual(prevState, this.state)) {\r\n if (this.reflowCounter < MAX_REFLOW_RETRIES) {\r\n LayoutEvents.emit();\r\n this.reflowCounter += 1;\r\n return;\r\n }\r\n }\r\n this.reflowCounter = 0;\r\n }\r\n\r\n public render() {\r\n let { children } = this.props;\r\n const { side, offset } = this.props;\r\n const { fixed, stopped, relativeTop, deltaHeight, width, height, left } = this.state;\r\n const innerStyle: React.CSSProperties = {};\r\n\r\n if (fixed) {\r\n if (stopped) {\r\n innerStyle.top = relativeTop;\r\n innerStyle[side === 'top' ? 'marginTop' : 'marginBottom'] = deltaHeight;\r\n } else {\r\n innerStyle.width = width;\r\n innerStyle[side] = offset;\r\n innerStyle.left = left;\r\n }\r\n }\r\n\r\n if (isFunction(children)) {\r\n children = children(fixed);\r\n }\r\n\r\n return (\r\n <CommonWrapper {...this.props}>\r\n <div ref={this.refWrapper} className={jsStyles.wrapper()}>\r\n <ZIndex\r\n priority=\"Sticky\"\r\n applyZIndex={fixed}\r\n className={cn(jsStyles.inner(), {\r\n [jsStyles.fixed()]: fixed && !stopped,\r\n [jsStyles.stopped()]: stopped,\r\n })}\r\n style={innerStyle}\r\n wrapperRef={this.refInner}\r\n >\r\n <div className={jsStyles.container()}>{children}</div>\r\n </ZIndex>\r\n {fixed && !stopped ? <div style={{ width, height }} /> : null}\r\n </div>\r\n </CommonWrapper>\r\n );\r\n }\r\n\r\n private refWrapper = (ref: Nullable<HTMLElement>) => (this.wrapper = ref);\r\n\r\n private refInner = (ref: Nullable<HTMLElement>) => (this.inner = ref);\r\n\r\n private reflow = () => {\r\n const { documentElement } = document;\r\n\r\n if (!documentElement) {\r\n throw Error('There is no \"documentElement\" in document');\r\n }\r\n\r\n const windowHeight = window.innerHeight || documentElement.clientHeight;\r\n if (!this.wrapper || !this.inner) {\r\n return;\r\n }\r\n const { top, bottom, left } = this.wrapper.getBoundingClientRect();\r\n const { width, height } = this.inner.getBoundingClientRect();\r\n const { offset, getStop, side } = this.props;\r\n const { fixed: prevFixed, height: prevHeight = height } = this.state;\r\n const fixed = side === 'top' ? top < offset : bottom > windowHeight - offset;\r\n\r\n this.setState({ fixed, left });\r\n\r\n if (fixed && !prevFixed) {\r\n this.setState({ width, height });\r\n }\r\n\r\n if (fixed) {\r\n const stop = getStop && getStop();\r\n if (stop) {\r\n const deltaHeight = prevHeight - height;\r\n const stopRect = stop.getBoundingClientRect();\r\n const outerHeight = height + offset;\r\n let stopped = false;\r\n let relativeTop = 0;\r\n\r\n if (side === 'top') {\r\n stopped = stopRect.top - outerHeight < 0;\r\n relativeTop = stopRect.top - prevHeight - top;\r\n } else {\r\n stopped = stopRect.bottom + outerHeight > windowHeight;\r\n relativeTop = stopRect.bottom - top;\r\n }\r\n\r\n this.setState({ relativeTop, deltaHeight, stopped });\r\n }\r\n }\r\n };\r\n}\r\n"]}
1
+ {"version":3,"sources":["Sticky.tsx"],"names":["React","PropTypes","shallowEqual","cn","LayoutEvents","isFunction","ZIndex","CommonWrapper","jsStyles","MAX_REFLOW_RETRIES","Sticky","state","fixed","deltaHeight","stopped","relativeTop","wrapper","inner","layoutSubscription","remove","reflowCounter","refWrapper","ref","refInner","reflow","document","documentElement","Error","windowHeight","window","innerHeight","clientHeight","getBoundingClientRect","top","bottom","left","width","height","props","offset","getStop","side","prevFixed","prevHeight","setState","stop","stopRect","outerHeight","componentDidMount","addListener","componentWillUnmount","componentDidUpdate","prevProps","prevState","emit","render","children","innerStyle","container","Component","__KONTUR_REACT_UI__","propTypes","oneOfType","node","func","number","oneOf","isRequired","defaultProps"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport shallowEqual from 'shallowequal';\nimport cn from 'classnames';\n\nimport * as LayoutEvents from '../../lib/LayoutEvents';\nimport { Nullable } from '../../typings/utility-types';\nimport { isFunction } from '../../lib/utils';\nimport { ZIndex } from '../../internal/ZIndex';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\n\nimport { jsStyles } from './Sticky.styles';\n\nconst MAX_REFLOW_RETRIES = 5;\n\nexport interface StickyProps extends CommonProps {\n side: 'top' | 'bottom';\n /**\n * Отступ в пикселях от края экрана, на сколько сдвигается элемент в залипшем состоянии\n * @default 0\n */\n offset: number;\n getStop?: () => Nullable<HTMLElement>;\n children?: React.ReactNode | ((fixed: boolean) => React.ReactNode);\n}\n\nexport interface StickyState {\n fixed: boolean;\n deltaHeight: number;\n height?: number;\n width?: number;\n left?: number;\n stopped: boolean;\n relativeTop: number;\n}\n\nexport class Sticky extends React.Component<StickyProps, StickyState> {\n public static __KONTUR_REACT_UI__ = 'Sticky';\n\n public static propTypes = {\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n\n /**\n * Функция, которая возвращает DOM-элемент, который нельзя пересекать.\n */\n getStop: PropTypes.func,\n\n /**\n * Отступ от границы в пикселях\n */\n offset: PropTypes.number,\n\n side: PropTypes.oneOf(['top', 'bottom']).isRequired,\n };\n\n public static defaultProps = { offset: 0 };\n\n public state: StickyState = {\n fixed: false,\n deltaHeight: 0,\n stopped: false,\n relativeTop: 0,\n };\n\n private wrapper: Nullable<HTMLElement>;\n private inner: Nullable<HTMLElement>;\n private layoutSubscription: { remove: Nullable<() => void> } = { remove: null };\n private reflowCounter = 0;\n\n public componentDidMount() {\n this.reflow();\n\n this.layoutSubscription = LayoutEvents.addListener(this.reflow);\n }\n\n public componentWillUnmount() {\n if (this.layoutSubscription.remove) {\n this.layoutSubscription.remove();\n }\n }\n\n public componentDidUpdate(prevProps: StickyProps, prevState: StickyState) {\n if (!shallowEqual(prevProps, this.props) || !shallowEqual(prevState, this.state)) {\n if (this.reflowCounter < MAX_REFLOW_RETRIES) {\n LayoutEvents.emit();\n this.reflowCounter += 1;\n return;\n }\n }\n this.reflowCounter = 0;\n }\n\n public render() {\n let { children } = this.props;\n const { side, offset } = this.props;\n const { fixed, stopped, relativeTop, deltaHeight, width, height, left } = this.state;\n const innerStyle: React.CSSProperties = {};\n\n if (fixed) {\n if (stopped) {\n innerStyle.top = relativeTop;\n innerStyle[side === 'top' ? 'marginTop' : 'marginBottom'] = deltaHeight;\n } else {\n innerStyle.width = width;\n innerStyle[side] = offset;\n innerStyle.left = left;\n }\n }\n\n if (isFunction(children)) {\n children = children(fixed);\n }\n\n return (\n <CommonWrapper {...this.props}>\n <div ref={this.refWrapper} className={jsStyles.wrapper()}>\n <ZIndex\n priority=\"Sticky\"\n applyZIndex={fixed}\n className={cn(jsStyles.inner(), {\n [jsStyles.fixed()]: fixed && !stopped,\n [jsStyles.stopped()]: stopped,\n })}\n style={innerStyle}\n wrapperRef={this.refInner}\n >\n <div className={jsStyles.container()}>{children}</div>\n </ZIndex>\n {fixed && !stopped ? <div style={{ width, height }} /> : null}\n </div>\n </CommonWrapper>\n );\n }\n\n private refWrapper = (ref: Nullable<HTMLElement>) => (this.wrapper = ref);\n\n private refInner = (ref: Nullable<HTMLElement>) => (this.inner = ref);\n\n public reflow = () => {\n const { documentElement } = document;\n\n if (!documentElement) {\n throw Error('There is no \"documentElement\" in document');\n }\n\n const windowHeight = window.innerHeight || documentElement.clientHeight;\n if (!this.wrapper || !this.inner) {\n return;\n }\n const { top, bottom, left } = this.wrapper.getBoundingClientRect();\n const { width, height } = this.inner.getBoundingClientRect();\n const { offset, getStop, side } = this.props;\n const { fixed: prevFixed, height: prevHeight = height } = this.state;\n const fixed = side === 'top' ? top < offset : bottom > windowHeight - offset;\n\n this.setState({ fixed, left });\n\n if (fixed && !prevFixed) {\n this.setState({ width, height });\n }\n\n if (fixed) {\n const stop = getStop && getStop();\n if (stop) {\n const deltaHeight = prevHeight - height;\n const stopRect = stop.getBoundingClientRect();\n const outerHeight = height + offset;\n let stopped = false;\n let relativeTop = 0;\n\n if (side === 'top') {\n stopped = stopRect.top - outerHeight < 0;\n relativeTop = stopRect.top - prevHeight - top;\n } else {\n stopped = stopRect.bottom + outerHeight > windowHeight;\n relativeTop = stopRect.bottom - top;\n }\n\n this.setState({ relativeTop, deltaHeight, stopped });\n }\n }\n };\n}\n"]}
@@ -49,5 +49,5 @@ export declare class Sticky extends React.Component<StickyProps, StickyState> {
49
49
  render(): JSX.Element;
50
50
  private refWrapper;
51
51
  private refInner;
52
- private reflow;
52
+ reflow: () => void;
53
53
  }
@@ -1,27 +1,27 @@
1
- ```jsx harmony
2
- const style = {
3
- padding: 10,
4
- background: '#f99',
5
- };
6
-
7
- let stop = null;
8
-
9
- <div>
10
- <Sticky side="top" getStop={() => stop}>
11
- {fixed => (
12
- <div style={style}>
13
- Small loan of a million dollars
14
- {fixed ? ' fixed' : <div>not fixed</div>}
15
- </div>
16
- )}
17
- </Sticky>
18
- Great
19
- <div style={{ height: 1000 }} />
20
- <div ref={el => (stop = el)} style={{ borderTop: '1px solid #000' }} />
21
- <div style={{ height: 1000 }} />
22
- <Sticky side="bottom" getStop={() => stop} offset={20}>
23
- <div style={style}>Make America Great Again</div>
24
- </Sticky>
25
- <div style={{ height: 100 }} />
26
- </div>;
27
- ```
1
+ ```jsx harmony
2
+ const style = {
3
+ padding: 10,
4
+ background: '#f99',
5
+ };
6
+
7
+ let stop = null;
8
+
9
+ <div>
10
+ <Sticky side="top" getStop={() => stop}>
11
+ {fixed => (
12
+ <div style={style}>
13
+ Small loan of a million dollars
14
+ {fixed ? ' fixed' : <div>not fixed</div>}
15
+ </div>
16
+ )}
17
+ </Sticky>
18
+ Great
19
+ <div style={{ height: 1000 }} />
20
+ <div ref={el => (stop = el)} style={{ borderTop: '1px solid #000' }} />
21
+ <div style={{ height: 1000 }} />
22
+ <Sticky side="bottom" getStop={() => stop} offset={20}>
23
+ <div style={style}>Make America Great Again</div>
24
+ </Sticky>
25
+ <div style={{ height: 100 }} />
26
+ </div>;
27
+ ```
@@ -1 +1 @@
1
- {"version":3,"sources":["Sticky.styles.ts"],"names":["css","memoizeStyle","styles","wrapper","inner","fixed","stopped","container","jsStyles"],"mappings":"8/BAAA,SAASA,GAAT,EAAcC,YAAd,QAAkC,2BAAlC;;AAEA,IAAMC,MAAM,GAAG;AACbC,EAAAA,OADa,qBACH;AACR,WAAOH,GAAP;;;AAGD,GALY;AAMbI,EAAAA,KANa,mBAML;AACN,WAAOJ,GAAP;;;;AAID,GAXY;;AAabK,EAAAA,KAba,mBAaL;AACN,WAAOL,GAAP;;;AAGD,GAjBY;;AAmBbM,EAAAA,OAnBa,qBAmBH;AACR,WAAON,GAAP;;;AAGD,GAvBY;;AAyBbO,EAAAA,SAzBa,uBAyBD;AACV,WAAOP,GAAP;;;;AAID,GA9BY,EAAf;;;AAiCA,OAAO,IAAMQ,QAAQ,GAAGP,YAAY,CAACC,MAAD,CAA7B","sourcesContent":["import { css, memoizeStyle } from '../../lib/theming/Emotion';\r\n\r\nconst styles = {\r\n wrapper() {\r\n return css`\r\n display: flex;\r\n `;\r\n },\r\n inner() {\r\n return css`\r\n display: flex;\r\n width: 100%;\r\n `;\r\n },\r\n\r\n fixed() {\r\n return css`\r\n position: fixed;\r\n `;\r\n },\r\n\r\n stopped() {\r\n return css`\r\n position: relative;\r\n `;\r\n },\r\n\r\n container() {\r\n return css`\r\n flex: auto;\r\n width: 100%;\r\n `;\r\n },\r\n};\r\n\r\nexport const jsStyles = memoizeStyle(styles);\r\n"]}
1
+ {"version":3,"sources":["Sticky.styles.ts"],"names":["css","memoizeStyle","styles","wrapper","inner","fixed","stopped","container","jsStyles"],"mappings":"8/BAAA,SAASA,GAAT,EAAcC,YAAd,QAAkC,2BAAlC;;AAEA,IAAMC,MAAM,GAAG;AACbC,EAAAA,OADa,qBACH;AACR,WAAOH,GAAP;;;AAGD,GALY;AAMbI,EAAAA,KANa,mBAML;AACN,WAAOJ,GAAP;;;;AAID,GAXY;;AAabK,EAAAA,KAba,mBAaL;AACN,WAAOL,GAAP;;;AAGD,GAjBY;;AAmBbM,EAAAA,OAnBa,qBAmBH;AACR,WAAON,GAAP;;;AAGD,GAvBY;;AAyBbO,EAAAA,SAzBa,uBAyBD;AACV,WAAOP,GAAP;;;;AAID,GA9BY,EAAf;;;AAiCA,OAAO,IAAMQ,QAAQ,GAAGP,YAAY,CAACC,MAAD,CAA7B","sourcesContent":["import { css, memoizeStyle } from '../../lib/theming/Emotion';\n\nconst styles = {\n wrapper() {\n return css`\n display: flex;\n `;\n },\n inner() {\n return css`\n display: flex;\n width: 100%;\n `;\n },\n\n fixed() {\n return css`\n position: fixed;\n `;\n },\n\n stopped() {\n return css`\n position: relative;\n `;\n },\n\n container() {\n return css`\n flex: auto;\n width: 100%;\n `;\n },\n};\n\nexport const jsStyles = memoizeStyle(styles);\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,UAAd","sourcesContent":["export * from './Sticky';\r\n"]}
1
+ {"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,UAAd","sourcesContent":["export * from './Sticky';\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["Switcher.tsx"],"names":["React","PropTypes","cn","isKeyArrowHorizontal","isKeyArrowLeft","isKeyEnter","Group","Button","ThemeContext","CommonWrapper","jsStyles","getSwitcherTheme","Switcher","state","focusedIndex","theme","selectItem","value","props","onValueChange","_extractPropsFromItem","item","label","_extractValuesFromItems","items","map","move","step","selectedIndex","length","_focus","index","setState","handleKey","e","preventDefault","_handleFocus","currentIndex","indexOf","_handleBlur","_renderItems","i","buttonProps","checked","visuallyFocused","onClick","disableFocus","size","disabled","getLabelSizeClassName","labelLarge","labelMedium","labelSmall","render","renderMain","listClassName","error","inputProps","type","onKeyDown","onFocus","onBlur","className","input","lableClassName","wrap","Component","__KONTUR_REACT_UI__","propTypes","bool","oneOfType","arrayOf","string","shape","isRequired","func"],"mappings":"gIAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,SAAP,MAAsB,YAAtB;AACA,OAAOC,EAAP,MAAe,YAAf;;AAEA,SAASC,oBAAT,EAA+BC,cAA/B,EAA+CC,UAA/C,QAAiE,uCAAjE;AACA,SAASC,KAAT,QAAsB,UAAtB;AACA,SAASC,MAAT,QAAmC,WAAnC;;AAEA,SAASC,YAAT,QAA6B,gCAA7B;;AAEA,SAAsBC,aAAtB,QAA2C,8BAA3C;;AAEA,SAASC,QAAT,QAAyB,mBAAzB;AACA,SAASC,gBAAT,QAAiC,iBAAjC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiCA,WAAaC,QAAb;;;;;;;;;;;;;;;;;;;;AAoBSC,IAAAA,KApBT,GAoBgC;AAC5BC,MAAAA,YAAY,EAAE,IADc,EApBhC;;;AAwBUC,IAAAA,KAxBV;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmEUC,IAAAA,UAnEV,GAmEuB,UAACC,KAAD,EAAmB;AACtC,UAAI,MAAKC,KAAL,CAAWC,aAAf,EAA8B;AAC5B,cAAKD,KAAL,CAAWC,aAAX,CAAyBF,KAAzB;AACD;AACF,KAvEH;;AAyEUG,IAAAA,qBAzEV,GAyEkC,UAACC,IAAD,EAA+C;AAC7E,aAAO,OAAOA,IAAP,KAAgB,QAAhB,GAA2BA,IAA3B,GAAkC,EAAEC,KAAK,EAAED,IAAT,EAAeJ,KAAK,EAAEI,IAAtB,EAAzC;AACD,KA3EH;;AA6EUE,IAAAA,uBA7EV,GA6EoC,YAAgB;AAChD,aAAO,MAAKL,KAAL,CAAWM,KAAX,CAAiBC,GAAjB,CAAqB,UAAAJ,IAAI,EAAI;AAChB,cAAKD,qBAAL,CAA2BC,IAA3B,CADgB,CAC1BJ,KAD0B,yBAC1BA,KAD0B;AAElC,eAAOA,KAAP;AACD,OAHM,CAAP;AAID,KAlFH;;AAoFUS,IAAAA,IApFV,GAoFiB,UAACC,IAAD,EAAkB;AAC/B,UAAIC,aAAa,GAAG,MAAKf,KAAL,CAAWC,YAA/B;;AAEA,UAAI,OAAOc,aAAP,KAAyB,QAA7B,EAAuC;AACrC;AACD;;AAED,UAAMJ,KAAK,GAAG,MAAKD,uBAAL,EAAd;;AAEAK,MAAAA,aAAa,IAAID,IAAjB;;AAEA,UAAIC,aAAa,GAAG,CAApB,EAAuB;AACrBA,QAAAA,aAAa,GAAGJ,KAAK,CAACK,MAAN,GAAe,CAA/B;AACD,OAFD,MAEO,IAAID,aAAa,IAAIJ,KAAK,CAACK,MAA3B,EAAmC;AACxCD,QAAAA,aAAa,GAAG,CAAhB;AACD;;AAED,YAAKE,MAAL,CAAYF,aAAZ;AACD,KAtGH;;AAwGUE,IAAAA,MAxGV,GAwGmB,UAACC,KAAD,EAAmB;AAClC,YAAKC,QAAL,CAAc,EAAElB,YAAY,EAAEiB,KAAhB,EAAd;AACD,KA1GH;;AA4GUE,IAAAA,SA5GV,GA4GsB,UAACC,CAAD,EAA8C;AAChE,UAAMpB,YAAY,GAAG,MAAKD,KAAL,CAAWC,YAAhC;AACA,UAAI,OAAOA,YAAP,KAAwB,QAA5B,EAAsC;AACpC;AACD;;AAED,UAAIT,UAAU,CAAC6B,CAAD,CAAd,EAAmB;AACjB,YAAI,MAAKhB,KAAL,CAAWC,aAAf,EAA8B;AACV,gBAAKC,qBAAL,CAA2B,MAAKF,KAAL,CAAWM,KAAX,CAAiBV,YAAjB,CAA3B,CADU,CACpBG,MADoB,0BACpBA,KADoB;AAE5B,gBAAKD,UAAL,CAAgBC,MAAhB;AACD;AACD;AACD;;AAED,UAAId,oBAAoB,CAAC+B,CAAD,CAAxB,EAA6B;AAC3BA,QAAAA,CAAC,CAACC,cAAF;AACA,cAAKT,IAAL,CAAUtB,cAAc,CAAC8B,CAAD,CAAd,GAAoB,CAAC,CAArB,GAAyB,CAAnC;AACD;AACF,KA9HH;;AAgIUE,IAAAA,YAhIV,GAgIyB,YAAM;AACnBnB,MAAAA,KADmB,GACT,MAAKC,KADI,CACnBD,KADmB;;AAG3B,UAAMO,KAAK,GAAG,MAAKD,uBAAL,EAAd;AACA,UAAMc,YAAY,GAAG,UAAIb,KAAJ,EAAWc,OAAX,CAAmBrB,KAAnB,CAArB;AACA,UAAMc,KAAK,GAAGM,YAAY,GAAG,CAAC,CAAhB,GAAoBA,YAApB,GAAmC,CAAjD;;AAEA,YAAKL,QAAL,CAAc,EAAElB,YAAY,EAAEiB,KAAhB,EAAd;AACD,KAxIH;;AA0IUQ,IAAAA,WA1IV,GA0IwB,YAAM;AAC1B,YAAKP,QAAL,CAAc,EAAElB,YAAY,EAAE,IAAhB,EAAd;AACD,KA5IH;;AA8IU0B,IAAAA,YA9IV,GA8IyB,YAAM;AAC3B,aAAO,MAAKtB,KAAL,CAAWM,KAAX,CAAiBC,GAAjB,CAAqB,UAACJ,IAAD,EAAOoB,CAAP,EAAa;AACd,cAAKrB,qBAAL,CAA2BC,IAA3B,CADc,CAC/BC,KAD+B,0BAC/BA,KAD+B,CACxBL,KADwB,0BACxBA,KADwB;AAEvC,YAAMyB,WAAW,GAAG;AAClBC,UAAAA,OAAO,EAAE,MAAKzB,KAAL,CAAWD,KAAX,KAAqBA,KADZ;AAElB2B,UAAAA,eAAe,EAAE,MAAK/B,KAAL,CAAWC,YAAX,KAA4B2B,CAF3B;AAGlBI,UAAAA,OAAO,EAAE,mBAAM;AACb,kBAAK7B,UAAL,CAAgBC,KAAhB;AACD,WALiB;AAMlB6B,UAAAA,YAAY,EAAE,IANI;AAOlBC,UAAAA,IAAI,EAAE,MAAK7B,KAAL,CAAW6B,IAPC;AAQlBC,UAAAA,QAAQ,EAAE,MAAK9B,KAAL,CAAW8B,QARH,EAApB;;AAUA;AACE,8BAAC,MAAD,aAAQ,GAAG,EAAE/B,KAAb,IAAwByB,WAAxB;AACGpB,UAAAA,KADH,CADF;;;AAKD,OAjBM,CAAP;AAkBD,KAjKH;;AAmKU2B,IAAAA,qBAnKV,GAmKkC,YAAc;AAC5C,cAAQ,MAAK/B,KAAL,CAAW6B,IAAnB;AACE,aAAK,OAAL;AACE,iBAAOrC,QAAQ,CAACwC,UAAT,CAAoB,MAAKnC,KAAzB,CAAP;AACF,aAAK,QAAL;AACE,iBAAOL,QAAQ,CAACyC,WAAT,CAAqB,MAAKpC,KAA1B,CAAP;AACF,aAAK,OAAL;AACA;AACE,iBAAOL,QAAQ,CAAC0C,UAAT,CAAoB,MAAKrC,KAAzB,CAAP,CAPJ;;AASD,KA7KH,sDA0BSsC,MA1BT,GA0BE,kBAAgB,mBACd,oBACE,oBAAC,YAAD,CAAc,QAAd,QACG,UAAAtC,KAAK,EAAI,CACR,MAAI,CAACA,KAAL,GAAaJ,gBAAgB,CAACI,KAAD,CAA7B,CACA,oBAAO,oBAAC,YAAD,CAAc,QAAd,IAAuB,KAAK,EAAE,MAAI,CAACA,KAAnC,IAA2C,MAAI,CAACuC,UAAL,EAA3C,CAAP,CACD,CAJH,CADF,CAQD,CAnCH,QAqCUA,UArCV,GAqCE,sBAAqB,SACnB,IAAMC,aAAa,GAAGrD,EAAE,gBACrBQ,QAAQ,CAAC8C,KAAT,CAAe,KAAKzC,KAApB,CADqB,IACQ,CAAC,CAAC,KAAKG,KAAL,CAAWsC,KADrB,OAAxB,CAIA,IAAMC,UAAU,GAAG,EACjBC,IAAI,EAAE,UADW,EAEjBC,SAAS,EAAE,KAAK1B,SAFC,EAGjB2B,OAAO,EAAE,KAAKxB,YAHG,EAIjByB,MAAM,EAAE,KAAKtB,WAJI,EAKjBuB,SAAS,EAAEpD,QAAQ,CAACqD,KAAT,EALM,EAAnB,CAQA,IAAMC,cAAc,GAAG9D,EAAE,CAACQ,QAAQ,CAACY,KAAT,EAAD,EAAmB,KAAK2B,qBAAL,EAAnB,CAAzB,CAEA,oBACE,oBAAC,aAAD,EAAmB,KAAK/B,KAAxB,eACE,iCACG,KAAKA,KAAL,CAAWI,KAAX,gBAAmB,6BAAK,SAAS,EAAE0C,cAAhB,IAAiC,KAAK9C,KAAL,CAAWI,KAA5C,CAAnB,GAA8E,IADjF,eAEE,6BAAK,SAAS,EAAEZ,QAAQ,CAACuD,IAAT,EAAhB,iBACE,6BAAWR,UAAX,CADF,eAEE,6BAAK,SAAS,EAAEF,aAAhB,iBACE,oBAAC,KAAD,QAAQ,KAAKf,YAAL,EAAR,CADF,CAFF,CAFF,CADF,CADF,CAaD,CAjEH,mBAA8BxC,KAAK,CAACkE,SAApC,EAAatD,Q,CACGuD,mB,GAAsB,U,CADzBvD,Q,CAGGwD,S,GAAY,EACxBZ,KAAK,EAAEvD,SAAS,CAACoE,IADO,EAExBrB,QAAQ,EAAE/C,SAAS,CAACoE,IAFI,EAGxB7C,KAAK,EAAEvB,SAAS,CAACqE,SAAV,CAAoB,CACzBrE,SAAS,CAACsE,OAAV,CAAkBtE,SAAS,CAACuE,MAA5B,CADyB,EAEzBvE,SAAS,CAACsE,OAAV,CACEtE,SAAS,CAACwE,KAAV,CAAgB,EACdnD,KAAK,EAAErB,SAAS,CAACuE,MADH,EAEdvD,KAAK,EAAEhB,SAAS,CAACuE,MAFH,EAAhB,CADF,CAFyB,CAApB,EAQJE,UAXqB,EAYxBpD,KAAK,EAAErB,SAAS,CAACuE,MAZO,EAaxBvD,KAAK,EAAEhB,SAAS,CAACuE,MAbO,EAcxBrD,aAAa,EAAElB,SAAS,CAAC0E,IAdD,E","sourcesContent":["import React from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport cn from 'classnames';\r\n\r\nimport { isKeyArrowHorizontal, isKeyArrowLeft, isKeyEnter } from '../../lib/events/keyboard/identifiers';\r\nimport { Group } from '../Group';\r\nimport { Button, ButtonSize } from '../Button';\r\nimport { Nullable } from '../../typings/utility-types';\r\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\r\nimport { Theme } from '../../lib/theming/Theme';\r\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\r\n\r\nimport { jsStyles } from './Switcher.styles';\r\nimport { getSwitcherTheme } from './switcherTheme';\r\n\r\nexport type SwitcherSize = ButtonSize;\r\n\r\nexport interface SwitcherProps extends CommonProps {\r\n /**\r\n * Список строк или список элементов типа `{ label: string, value: string }`\r\n */\r\n items: Array<string | SwitcherItem>;\r\n\r\n value?: string;\r\n\r\n onValueChange?: (value: string) => void;\r\n\r\n label?: string;\r\n\r\n error?: boolean;\r\n\r\n /** Размер */\r\n size?: SwitcherSize;\r\n\r\n disabled?: boolean;\r\n}\r\n\r\nexport interface SwitcherState {\r\n focusedIndex: Nullable<number>;\r\n}\r\n\r\ninterface SwitcherItem {\r\n label: string;\r\n value: string;\r\n}\r\n\r\nexport class Switcher extends React.Component<SwitcherProps, SwitcherState> {\r\n public static __KONTUR_REACT_UI__ = 'Switcher';\r\n\r\n public static propTypes = {\r\n error: PropTypes.bool,\r\n disabled: PropTypes.bool,\r\n items: PropTypes.oneOfType([\r\n PropTypes.arrayOf(PropTypes.string),\r\n PropTypes.arrayOf(\r\n PropTypes.shape({\r\n label: PropTypes.string,\r\n value: PropTypes.string,\r\n }),\r\n ),\r\n ]).isRequired,\r\n label: PropTypes.string,\r\n value: PropTypes.string,\r\n onValueChange: PropTypes.func,\r\n };\r\n\r\n public state: SwitcherState = {\r\n focusedIndex: null,\r\n };\r\n\r\n private theme!: Theme;\r\n\r\n public render() {\r\n return (\r\n <ThemeContext.Consumer>\r\n {theme => {\r\n this.theme = getSwitcherTheme(theme);\r\n return <ThemeContext.Provider value={this.theme}>{this.renderMain()}</ThemeContext.Provider>;\r\n }}\r\n </ThemeContext.Consumer>\r\n );\r\n }\r\n\r\n private renderMain() {\r\n const listClassName = cn({\r\n [jsStyles.error(this.theme)]: !!this.props.error,\r\n });\r\n\r\n const inputProps = {\r\n type: 'checkbox',\r\n onKeyDown: this.handleKey,\r\n onFocus: this._handleFocus,\r\n onBlur: this._handleBlur,\r\n className: jsStyles.input(),\r\n };\r\n\r\n const lableClassName = cn(jsStyles.label(), this.getLabelSizeClassName());\r\n\r\n return (\r\n <CommonWrapper {...this.props}>\r\n <div>\r\n {this.props.label ? <div className={lableClassName}>{this.props.label}</div> : null}\r\n <div className={jsStyles.wrap()}>\r\n <input {...inputProps} />\r\n <div className={listClassName}>\r\n <Group>{this._renderItems()}</Group>\r\n </div>\r\n </div>\r\n </div>\r\n </CommonWrapper>\r\n );\r\n }\r\n\r\n private selectItem = (value: string) => {\r\n if (this.props.onValueChange) {\r\n this.props.onValueChange(value);\r\n }\r\n };\r\n\r\n private _extractPropsFromItem = (item: string | SwitcherItem): SwitcherItem => {\r\n return typeof item === 'object' ? item : { label: item, value: item };\r\n };\r\n\r\n private _extractValuesFromItems = (): string[] => {\r\n return this.props.items.map(item => {\r\n const { value } = this._extractPropsFromItem(item);\r\n return value;\r\n });\r\n };\r\n\r\n private move = (step: number) => {\r\n let selectedIndex = this.state.focusedIndex;\r\n\r\n if (typeof selectedIndex !== 'number') {\r\n return;\r\n }\r\n\r\n const items = this._extractValuesFromItems();\r\n\r\n selectedIndex += step;\r\n\r\n if (selectedIndex < 0) {\r\n selectedIndex = items.length - 1;\r\n } else if (selectedIndex >= items.length) {\r\n selectedIndex = 0;\r\n }\r\n\r\n this._focus(selectedIndex);\r\n };\r\n\r\n private _focus = (index: number) => {\r\n this.setState({ focusedIndex: index });\r\n };\r\n\r\n private handleKey = (e: React.KeyboardEvent<HTMLInputElement>) => {\r\n const focusedIndex = this.state.focusedIndex;\r\n if (typeof focusedIndex !== 'number') {\r\n return;\r\n }\r\n\r\n if (isKeyEnter(e)) {\r\n if (this.props.onValueChange) {\r\n const { value } = this._extractPropsFromItem(this.props.items[focusedIndex]);\r\n this.selectItem(value);\r\n }\r\n return;\r\n }\r\n\r\n if (isKeyArrowHorizontal(e)) {\r\n e.preventDefault();\r\n this.move(isKeyArrowLeft(e) ? -1 : 1);\r\n }\r\n };\r\n\r\n private _handleFocus = () => {\r\n const { value } = this.props;\r\n\r\n const items = this._extractValuesFromItems();\r\n const currentIndex = [...items].indexOf(value as string);\r\n const index = currentIndex > -1 ? currentIndex : 0;\r\n\r\n this.setState({ focusedIndex: index });\r\n };\r\n\r\n private _handleBlur = () => {\r\n this.setState({ focusedIndex: null });\r\n };\r\n\r\n private _renderItems = () => {\r\n return this.props.items.map((item, i) => {\r\n const { label, value } = this._extractPropsFromItem(item);\r\n const buttonProps = {\r\n checked: this.props.value === value,\r\n visuallyFocused: this.state.focusedIndex === i,\r\n onClick: () => {\r\n this.selectItem(value);\r\n },\r\n disableFocus: true,\r\n size: this.props.size,\r\n disabled: this.props.disabled,\r\n };\r\n return (\r\n <Button key={value} {...buttonProps}>\r\n {label}\r\n </Button>\r\n );\r\n });\r\n };\r\n\r\n private getLabelSizeClassName = (): string => {\r\n switch (this.props.size) {\r\n case 'large':\r\n return jsStyles.labelLarge(this.theme);\r\n case 'medium':\r\n return jsStyles.labelMedium(this.theme);\r\n case 'small':\r\n default:\r\n return jsStyles.labelSmall(this.theme);\r\n }\r\n };\r\n}\r\n"]}
1
+ {"version":3,"sources":["Switcher.tsx"],"names":["React","PropTypes","cn","isKeyArrowHorizontal","isKeyArrowLeft","isKeyEnter","Group","Button","ThemeContext","CommonWrapper","jsStyles","getSwitcherTheme","Switcher","state","focusedIndex","theme","selectItem","value","props","onValueChange","_extractPropsFromItem","item","label","_extractValuesFromItems","items","map","move","step","selectedIndex","length","_focus","index","setState","handleKey","e","preventDefault","_handleFocus","currentIndex","indexOf","_handleBlur","_renderItems","i","buttonProps","checked","visuallyFocused","onClick","disableFocus","size","disabled","getLabelSizeClassName","labelLarge","labelMedium","labelSmall","render","renderMain","listClassName","error","inputProps","type","onKeyDown","onFocus","onBlur","className","input","lableClassName","wrap","Component","__KONTUR_REACT_UI__","propTypes","bool","oneOfType","arrayOf","string","shape","isRequired","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport cn from 'classnames';\n\nimport { isKeyArrowHorizontal, isKeyArrowLeft, isKeyEnter } from '../../lib/events/keyboard/identifiers';\nimport { Group } from '../Group';\nimport { Button, ButtonSize } from '../Button';\nimport { Nullable } from '../../typings/utility-types';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { CommonProps, CommonWrapper } from '../../internal/CommonWrapper';\n\nimport { jsStyles } from './Switcher.styles';\nimport { getSwitcherTheme } from './switcherTheme';\n\nexport type SwitcherSize = ButtonSize;\n\nexport interface SwitcherProps extends CommonProps {\n /**\n * Список строк или список элементов типа `{ label: string, value: string }`\n */\n items: Array<string | SwitcherItem>;\n\n value?: string;\n\n onValueChange?: (value: string) => void;\n\n label?: string;\n\n error?: boolean;\n\n /** Размер */\n size?: SwitcherSize;\n\n disabled?: boolean;\n}\n\nexport interface SwitcherState {\n focusedIndex: Nullable<number>;\n}\n\ninterface SwitcherItem {\n label: string;\n value: string;\n}\n\nexport class Switcher extends React.Component<SwitcherProps, SwitcherState> {\n public static __KONTUR_REACT_UI__ = 'Switcher';\n\n public static propTypes = {\n error: PropTypes.bool,\n disabled: PropTypes.bool,\n items: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.string),\n PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string,\n value: PropTypes.string,\n }),\n ),\n ]).isRequired,\n label: PropTypes.string,\n value: PropTypes.string,\n onValueChange: PropTypes.func,\n };\n\n public state: SwitcherState = {\n focusedIndex: null,\n };\n\n private theme!: Theme;\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {theme => {\n this.theme = getSwitcherTheme(theme);\n return <ThemeContext.Provider value={this.theme}>{this.renderMain()}</ThemeContext.Provider>;\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const listClassName = cn({\n [jsStyles.error(this.theme)]: !!this.props.error,\n });\n\n const inputProps = {\n type: 'checkbox',\n onKeyDown: this.handleKey,\n onFocus: this._handleFocus,\n onBlur: this._handleBlur,\n className: jsStyles.input(),\n };\n\n const lableClassName = cn(jsStyles.label(), this.getLabelSizeClassName());\n\n return (\n <CommonWrapper {...this.props}>\n <div>\n {this.props.label ? <div className={lableClassName}>{this.props.label}</div> : null}\n <div className={jsStyles.wrap()}>\n <input {...inputProps} />\n <div className={listClassName}>\n <Group>{this._renderItems()}</Group>\n </div>\n </div>\n </div>\n </CommonWrapper>\n );\n }\n\n private selectItem = (value: string) => {\n if (this.props.onValueChange) {\n this.props.onValueChange(value);\n }\n };\n\n private _extractPropsFromItem = (item: string | SwitcherItem): SwitcherItem => {\n return typeof item === 'object' ? item : { label: item, value: item };\n };\n\n private _extractValuesFromItems = (): string[] => {\n return this.props.items.map(item => {\n const { value } = this._extractPropsFromItem(item);\n return value;\n });\n };\n\n private move = (step: number) => {\n let selectedIndex = this.state.focusedIndex;\n\n if (typeof selectedIndex !== 'number') {\n return;\n }\n\n const items = this._extractValuesFromItems();\n\n selectedIndex += step;\n\n if (selectedIndex < 0) {\n selectedIndex = items.length - 1;\n } else if (selectedIndex >= items.length) {\n selectedIndex = 0;\n }\n\n this._focus(selectedIndex);\n };\n\n private _focus = (index: number) => {\n this.setState({ focusedIndex: index });\n };\n\n private handleKey = (e: React.KeyboardEvent<HTMLInputElement>) => {\n const focusedIndex = this.state.focusedIndex;\n if (typeof focusedIndex !== 'number') {\n return;\n }\n\n if (isKeyEnter(e)) {\n if (this.props.onValueChange) {\n const { value } = this._extractPropsFromItem(this.props.items[focusedIndex]);\n this.selectItem(value);\n }\n return;\n }\n\n if (isKeyArrowHorizontal(e)) {\n e.preventDefault();\n this.move(isKeyArrowLeft(e) ? -1 : 1);\n }\n };\n\n private _handleFocus = () => {\n const { value } = this.props;\n\n const items = this._extractValuesFromItems();\n const currentIndex = [...items].indexOf(value as string);\n const index = currentIndex > -1 ? currentIndex : 0;\n\n this.setState({ focusedIndex: index });\n };\n\n private _handleBlur = () => {\n this.setState({ focusedIndex: null });\n };\n\n private _renderItems = () => {\n return this.props.items.map((item, i) => {\n const { label, value } = this._extractPropsFromItem(item);\n const buttonProps = {\n checked: this.props.value === value,\n visuallyFocused: this.state.focusedIndex === i,\n onClick: () => {\n this.selectItem(value);\n },\n disableFocus: true,\n size: this.props.size,\n disabled: this.props.disabled,\n };\n return (\n <Button key={value} {...buttonProps}>\n {label}\n </Button>\n );\n });\n };\n\n private getLabelSizeClassName = (): string => {\n switch (this.props.size) {\n case 'large':\n return jsStyles.labelLarge(this.theme);\n case 'medium':\n return jsStyles.labelMedium(this.theme);\n case 'small':\n default:\n return jsStyles.labelSmall(this.theme);\n }\n };\n}\n"]}