@skbkontur/react-ui 6.0.8 → 6.1.1-9752b.0

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 (814) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/components/Autocomplete/Autocomplete.js +15 -4
  3. package/components/Autocomplete/Autocomplete.js.map +1 -1
  4. package/components/Autocomplete/Autocomplete.styles.js.map +1 -1
  5. package/components/Autocomplete/getAutocompleteTheme.js.map +1 -1
  6. package/components/Autocomplete/index.js.map +1 -1
  7. package/components/Autocomplete/locale/index.js.map +1 -1
  8. package/components/Autocomplete/locale/locales/en.js.map +1 -1
  9. package/components/Autocomplete/locale/locales/ru.js.map +1 -1
  10. package/components/Autocomplete/locale/types.js.map +1 -1
  11. package/components/Button/ArrowLeftIcon.js.map +1 -1
  12. package/components/Button/ArrowRightIcon.js.map +1 -1
  13. package/components/Button/Button.d.ts +1 -1
  14. package/components/Button/Button.js +5 -4
  15. package/components/Button/Button.js.map +1 -1
  16. package/components/Button/Button.mixins.js.map +1 -1
  17. package/components/Button/Button.styles.js.map +1 -1
  18. package/components/Button/ButtonArrow.js.map +1 -1
  19. package/components/Button/ButtonIcon.js.map +1 -1
  20. package/components/Button/ButtonIcon.styles.js.map +1 -1
  21. package/components/Button/LoadingButtonIcon.js.map +1 -1
  22. package/components/Button/getInnerLinkTheme.js.map +1 -1
  23. package/components/Button/index.js.map +1 -1
  24. package/components/Calendar/Calendar.js.map +1 -1
  25. package/components/Calendar/Calendar.styles.js.map +1 -1
  26. package/components/Calendar/CalendarContext.js.map +1 -1
  27. package/components/Calendar/CalendarDateShape.js.map +1 -1
  28. package/components/Calendar/CalendarDay.js +3 -0
  29. package/components/Calendar/CalendarDay.js.map +1 -1
  30. package/components/Calendar/CalendarScrollEvents.js.map +1 -1
  31. package/components/Calendar/CalendarUtils.js.map +1 -1
  32. package/components/Calendar/DayCellView.js.map +1 -1
  33. package/components/Calendar/DayCellView.styles.d.ts +1 -0
  34. package/components/Calendar/DayCellView.styles.js +6 -3
  35. package/components/Calendar/DayCellView.styles.js.map +1 -1
  36. package/components/Calendar/DayCellViewModel.js.map +1 -1
  37. package/components/Calendar/Month.js.map +1 -1
  38. package/components/Calendar/MonthView.js.map +1 -1
  39. package/components/Calendar/MonthView.styles.js.map +1 -1
  40. package/components/Calendar/MonthViewModel.js.map +1 -1
  41. package/components/Calendar/config.js.map +1 -1
  42. package/components/Calendar/index.js.map +1 -1
  43. package/components/Calendar/locale/locales/en.js.map +1 -1
  44. package/components/Calendar/locale/locales/ru.js.map +1 -1
  45. package/components/Calendar/locale/types.js.map +1 -1
  46. package/components/Center/Center.js.map +1 -1
  47. package/components/Center/Center.styles.js.map +1 -1
  48. package/components/Center/index.js.map +1 -1
  49. package/components/Checkbox/Checkbox.js.map +1 -1
  50. package/components/Checkbox/Checkbox.mixins.js.map +1 -1
  51. package/components/Checkbox/Checkbox.styles.js.map +1 -1
  52. package/components/Checkbox/CheckedIcon.js.map +1 -1
  53. package/components/Checkbox/IndeterminateIcon.js.map +1 -1
  54. package/components/Checkbox/index.js.map +1 -1
  55. package/components/ComboBox/ComboBox.js.map +1 -1
  56. package/components/ComboBox/index.js.map +1 -1
  57. package/components/CurrencyInput/CurrencyHelper.js.map +1 -1
  58. package/components/CurrencyInput/CurrencyInput.js.map +1 -1
  59. package/components/CurrencyInput/CurrencyInputHelper.js.map +1 -1
  60. package/components/CurrencyInput/CurrencyInputKeyboardActions.js.map +1 -1
  61. package/components/CurrencyInput/CursorHelper.js.map +1 -1
  62. package/components/CurrencyInput/SelectionHelper.js.map +1 -1
  63. package/components/CurrencyInput/constants.js.map +1 -1
  64. package/components/CurrencyInput/index.js.map +1 -1
  65. package/components/CurrencyLabel/CurrencyLabel.js.map +1 -1
  66. package/components/CurrencyLabel/index.js.map +1 -1
  67. package/components/DateInput/CalendarIcon.js.map +1 -1
  68. package/components/DateInput/DateFragmentsView.js.map +1 -1
  69. package/components/DateInput/DateFragmentsView.styles.js.map +1 -1
  70. package/components/DateInput/DateInput.js.map +1 -1
  71. package/components/DateInput/DateInput.styles.js.map +1 -1
  72. package/components/DateInput/helpers/DateInputKeyboardActions.js.map +1 -1
  73. package/components/DateInput/helpers/InternalDateMediator.js.map +1 -1
  74. package/components/DateInput/helpers/inputNumber.js.map +1 -1
  75. package/components/DateInput/index.js.map +1 -1
  76. package/components/DatePicker/DatePicker.js.map +1 -1
  77. package/components/DatePicker/DatePicker.styles.js.map +1 -1
  78. package/components/DatePicker/MobilePicker.js +1 -1
  79. package/components/DatePicker/MobilePicker.js.map +1 -1
  80. package/components/DatePicker/MobilePicker.styles.js.map +1 -1
  81. package/components/DatePicker/getMobilePickerTheme.js.map +1 -1
  82. package/components/DatePicker/index.js.map +1 -1
  83. package/components/DatePicker/locale/index.js.map +1 -1
  84. package/components/DatePicker/locale/locales/en.js.map +1 -1
  85. package/components/DatePicker/locale/locales/ru.js.map +1 -1
  86. package/components/DatePicker/locale/types.js.map +1 -1
  87. package/components/DateRangePicker/DateRangePicker.js +1 -1
  88. package/components/DateRangePicker/DateRangePicker.js.map +1 -1
  89. package/components/DateRangePicker/DateRangePicker.styles.js.map +1 -1
  90. package/components/DateRangePicker/DateRangePickerContext.js.map +1 -1
  91. package/components/DateRangePicker/DateRangePickerInput.js.map +1 -1
  92. package/components/DateRangePicker/DateRangePickerSeparator.js.map +1 -1
  93. package/components/DateRangePicker/DateRangePickerTheme.js.map +1 -1
  94. package/components/DateRangePicker/helpers/getStateForValue.js.map +1 -1
  95. package/components/DateRangePicker/helpers/validateDateRangePicker.js.map +1 -1
  96. package/components/DateRangePicker/index.js.map +1 -1
  97. package/components/DateRangePicker/locale/index.js.map +1 -1
  98. package/components/DateRangePicker/locale/locales/en.js.map +1 -1
  99. package/components/DateRangePicker/locale/locales/ru.js.map +1 -1
  100. package/components/DateRangePicker/locale/types.js.map +1 -1
  101. package/components/Dropdown/Dropdown.js.map +1 -1
  102. package/components/Dropdown/getDropdownTheme.js.map +1 -1
  103. package/components/Dropdown/index.js.map +1 -1
  104. package/components/DropdownMenu/DropdownMenu.js.map +1 -1
  105. package/components/DropdownMenu/getDropdownMenuTheme.js.map +1 -1
  106. package/components/DropdownMenu/index.js.map +1 -1
  107. package/components/FileUploader/FileUploader.js.map +1 -1
  108. package/components/FileUploader/FileUploader.mixins.js.map +1 -1
  109. package/components/FileUploader/FileUploader.styles.js.map +1 -1
  110. package/components/FileUploader/FileUploaderControlContext.js.map +1 -1
  111. package/components/FileUploader/FileUploaderControlProvider.js.map +1 -1
  112. package/components/FileUploader/FileUploaderFile.js.map +1 -1
  113. package/components/FileUploader/FileUploaderFile.styles.js.map +1 -1
  114. package/components/FileUploader/FileUploaderFileList/FileUploaderFileList.js.map +1 -1
  115. package/components/FileUploader/FileUploaderFileList/FileUploaderFileList.styles.js.map +1 -1
  116. package/components/FileUploader/FileUploaderFileStatusIcon.js.map +1 -1
  117. package/components/FileUploader/FileUploaderFileTypeIcon.js.map +1 -1
  118. package/components/FileUploader/FileUploaderFileValidationResult.js.map +1 -1
  119. package/components/FileUploader/fileUtils.js.map +1 -1
  120. package/components/FileUploader/hooks/useControlLocale.js.map +1 -1
  121. package/components/FileUploader/hooks/useFileUploaderSize.js.map +1 -1
  122. package/components/FileUploader/hooks/useUpload.js.map +1 -1
  123. package/components/FileUploader/icons/DeleteIcon.js.map +1 -1
  124. package/components/FileUploader/icons/UploadIcon.js.map +1 -1
  125. package/components/FileUploader/icons/row/ArchiveIcon.js.map +1 -1
  126. package/components/FileUploader/icons/row/DocTextIcon.js.map +1 -1
  127. package/components/FileUploader/icons/row/FolderIcon.js.map +1 -1
  128. package/components/FileUploader/icons/row/MarkupIcon.js.map +1 -1
  129. package/components/FileUploader/icons/row/PdfIcon.js.map +1 -1
  130. package/components/FileUploader/icons/row/PictureIcon.js.map +1 -1
  131. package/components/FileUploader/icons/row/PresentationIcon.js.map +1 -1
  132. package/components/FileUploader/icons/row/RowUploadIcon.js.map +1 -1
  133. package/components/FileUploader/icons/row/TableIcon.js.map +1 -1
  134. package/components/FileUploader/icons/row/TextIcon.js.map +1 -1
  135. package/components/FileUploader/icons/row/ValidationErrorIcon.js.map +1 -1
  136. package/components/FileUploader/icons/row/ValidationWarningIcon.js.map +1 -1
  137. package/components/FileUploader/icons/tile/ArchiveIcon.js.map +1 -1
  138. package/components/FileUploader/icons/tile/DocTextIcon.js.map +1 -1
  139. package/components/FileUploader/icons/tile/FolderIcon.js.map +1 -1
  140. package/components/FileUploader/icons/tile/MarkupIcon.js.map +1 -1
  141. package/components/FileUploader/icons/tile/PdfIcon.js.map +1 -1
  142. package/components/FileUploader/icons/tile/PictureIcon.js.map +1 -1
  143. package/components/FileUploader/icons/tile/PresentationIcon.js.map +1 -1
  144. package/components/FileUploader/icons/tile/TableIcon.js.map +1 -1
  145. package/components/FileUploader/icons/tile/TextIcon.js.map +1 -1
  146. package/components/FileUploader/icons/tile/TileUploadIcon.js.map +1 -1
  147. package/components/FileUploader/icons/tile/ValidationErrorIcon.js.map +1 -1
  148. package/components/FileUploader/icons/tile/ValidationWarningIcon.js.map +1 -1
  149. package/components/FileUploader/index.js.map +1 -1
  150. package/components/FileUploader/locale/index.js.map +1 -1
  151. package/components/FileUploader/locale/locales/en.js.map +1 -1
  152. package/components/FileUploader/locale/locales/ru.js.map +1 -1
  153. package/components/FileUploader/locale/types.js.map +1 -1
  154. package/components/FileUploader/withFileUploaderControlProvider.js.map +1 -1
  155. package/components/FxInput/FxInput.js.map +1 -1
  156. package/components/FxInput/FxInputRestoreBtn.js +1 -1
  157. package/components/FxInput/FxInputRestoreBtn.js.map +1 -1
  158. package/components/FxInput/MathFunctionIcon.js.map +1 -1
  159. package/components/FxInput/UndoIcon.js.map +1 -1
  160. package/components/FxInput/index.js.map +1 -1
  161. package/components/Gapped/Gapped.js.map +1 -1
  162. package/components/Gapped/index.js.map +1 -1
  163. package/components/GlobalLoader/GlobalLoader.js.map +1 -1
  164. package/components/GlobalLoader/GlobalLoaderView.js.map +1 -1
  165. package/components/GlobalLoader/GlobalLoaderView.styles.js.map +1 -1
  166. package/components/GlobalLoader/index.js.map +1 -1
  167. package/components/GlobalLoader/useParams.js.map +1 -1
  168. package/components/Group/Group.js.map +1 -1
  169. package/components/Group/Group.styles.js.map +1 -1
  170. package/components/Group/index.js.map +1 -1
  171. package/components/Hint/Hint.js.map +1 -1
  172. package/components/Hint/Hint.styles.js.map +1 -1
  173. package/components/Hint/index.js.map +1 -1
  174. package/components/Input/Input.d.ts +19 -1
  175. package/components/Input/Input.js +10 -3
  176. package/components/Input/Input.js.map +1 -1
  177. package/components/Input/Input.styles.js.map +1 -1
  178. package/components/Input/Input.typings.js.map +1 -1
  179. package/components/Input/InputLayout/InputLayout.d.ts +3 -1
  180. package/components/Input/InputLayout/InputLayout.js +5 -2
  181. package/components/Input/InputLayout/InputLayout.js.map +1 -1
  182. package/components/Input/InputLayout/InputLayout.styles.d.ts +6 -0
  183. package/components/Input/InputLayout/InputLayout.styles.js +19 -1
  184. package/components/Input/InputLayout/InputLayout.styles.js.map +1 -1
  185. package/components/Input/InputLayout/InputLayoutAside.d.ts +2 -0
  186. package/components/Input/InputLayout/InputLayoutAside.js +2 -2
  187. package/components/Input/InputLayout/InputLayoutAside.js.map +1 -1
  188. package/components/Input/InputLayout/InputLayoutAsideCounter.d.ts +11 -0
  189. package/components/Input/InputLayout/InputLayoutAsideCounter.js +74 -0
  190. package/components/Input/InputLayout/InputLayoutAsideCounter.js.map +1 -0
  191. package/components/Input/InputLayout/InputLayoutAsideIcon.js.map +1 -1
  192. package/components/Input/InputLayout/InputLayoutAsideText.js.map +1 -1
  193. package/components/Input/InputLayout/InputLayoutContext.js.map +1 -1
  194. package/components/Input/index.js.map +1 -1
  195. package/components/Kebab/Kebab.js.map +1 -1
  196. package/components/Kebab/Kebab.styles.js.map +1 -1
  197. package/components/Kebab/KebabIcon.js.map +1 -1
  198. package/components/Kebab/index.js.map +1 -1
  199. package/components/Link/Link.js.map +1 -1
  200. package/components/Link/Link.mixins.js.map +1 -1
  201. package/components/Link/Link.styles.js.map +1 -1
  202. package/components/Link/LinkIcon.js.map +1 -1
  203. package/components/Link/index.js.map +1 -1
  204. package/components/Loader/Loader.d.ts +12 -4
  205. package/components/Loader/Loader.js +18 -7
  206. package/components/Loader/Loader.js.map +1 -1
  207. package/components/Loader/Loader.styles.js.map +1 -1
  208. package/components/Loader/index.js.map +1 -1
  209. package/components/MaskedInput/ColorableInputElement/ColorableInputElement.js.map +1 -1
  210. package/components/MaskedInput/ColorableInputElement/ColorableInputElement.styles.js.map +1 -1
  211. package/components/MaskedInput/ColorableInputElement/index.js.map +1 -1
  212. package/components/MaskedInput/FixedIMaskInput.js.map +1 -1
  213. package/components/MaskedInput/MaskedInput.helpers.js.map +1 -1
  214. package/components/MaskedInput/MaskedInput.js.map +1 -1
  215. package/components/MaskedInput/MaskedInput.styles.js.map +1 -1
  216. package/components/MaskedInput/index.js.map +1 -1
  217. package/components/MenuFooter/MenuFooter.js.map +1 -1
  218. package/components/MenuFooter/MenuFooter.mixins.js.map +1 -1
  219. package/components/MenuFooter/MenuFooter.styles.js.map +1 -1
  220. package/components/MenuFooter/index.js.map +1 -1
  221. package/components/MenuHeader/MenuHeader.js.map +1 -1
  222. package/components/MenuHeader/MenuHeader.mixins.js.map +1 -1
  223. package/components/MenuHeader/MenuHeader.styles.js.map +1 -1
  224. package/components/MenuHeader/index.js.map +1 -1
  225. package/components/MenuItem/MenuItem.d.ts +1 -0
  226. package/components/MenuItem/MenuItem.js +17 -1
  227. package/components/MenuItem/MenuItem.js.map +1 -1
  228. package/components/MenuItem/MenuItem.mixins.js.map +1 -1
  229. package/components/MenuItem/MenuItem.styles.d.ts +3 -0
  230. package/components/MenuItem/MenuItem.styles.js +25 -16
  231. package/components/MenuItem/MenuItem.styles.js.map +1 -1
  232. package/components/MenuItem/index.js.map +1 -1
  233. package/components/MenuSeparator/MenuSeparator.js.map +1 -1
  234. package/components/MenuSeparator/MenuSeparator.styles.js.map +1 -1
  235. package/components/MenuSeparator/index.js.map +1 -1
  236. package/components/MiniModal/MiniModal.js.map +1 -1
  237. package/components/MiniModal/MiniModal.styles.js.map +1 -1
  238. package/components/MiniModal/MiniModalBody.js.map +1 -1
  239. package/components/MiniModal/MiniModalFooter.js.map +1 -1
  240. package/components/MiniModal/MiniModalHeader.js.map +1 -1
  241. package/components/MiniModal/MiniModalIndent.js.map +1 -1
  242. package/components/MiniModal/getMiniModalTheme.js.map +1 -1
  243. package/components/MiniModal/index.js.map +1 -1
  244. package/components/Modal/Modal.js.map +1 -1
  245. package/components/Modal/Modal.styles.js.map +1 -1
  246. package/components/Modal/ModalBody.js.map +1 -1
  247. package/components/Modal/ModalClose.js.map +1 -1
  248. package/components/Modal/ModalContext.js.map +1 -1
  249. package/components/Modal/ModalFooter.js.map +1 -1
  250. package/components/Modal/ModalHeader.js.map +1 -1
  251. package/components/Modal/ModalSeparator.js.map +1 -1
  252. package/components/Modal/getModalBodyTheme.js.map +1 -1
  253. package/components/Modal/getModalTheme.js.map +1 -1
  254. package/components/Modal/index.js.map +1 -1
  255. package/components/Modal/locale/index.js.map +1 -1
  256. package/components/Modal/locale/locales/en.js.map +1 -1
  257. package/components/Modal/locale/locales/ru.js.map +1 -1
  258. package/components/Modal/locale/types.js.map +1 -1
  259. package/components/Paging/DotsIcon.js.map +1 -1
  260. package/components/Paging/ForwardIcon.js.map +1 -1
  261. package/components/Paging/NavigationHelper.js.map +1 -1
  262. package/components/Paging/Paging.js.map +1 -1
  263. package/components/Paging/Paging.styles.js.map +1 -1
  264. package/components/Paging/PagingDefaultComponent.js.map +1 -1
  265. package/components/Paging/PagingHelper.js.map +1 -1
  266. package/components/Paging/index.js.map +1 -1
  267. package/components/Paging/locale/index.js.map +1 -1
  268. package/components/Paging/locale/locales/en.js.map +1 -1
  269. package/components/Paging/locale/locales/ru.js.map +1 -1
  270. package/components/Paging/locale/types.js.map +1 -1
  271. package/components/PasswordInput/ClosedIcon.js.map +1 -1
  272. package/components/PasswordInput/OpenedIcon.js.map +1 -1
  273. package/components/PasswordInput/PasswordInput.js.map +1 -1
  274. package/components/PasswordInput/PasswordInput.styles.js.map +1 -1
  275. package/components/PasswordInput/PasswordInputIcon.js.map +1 -1
  276. package/components/PasswordInput/index.js.map +1 -1
  277. package/components/PasswordInput/locale/index.js.map +1 -1
  278. package/components/PasswordInput/locale/locales/en.js.map +1 -1
  279. package/components/PasswordInput/locale/locales/ru.js.map +1 -1
  280. package/components/PasswordInput/locale/types.js.map +1 -1
  281. package/components/Radio/Radio.js.map +1 -1
  282. package/components/Radio/Radio.mixins.js.map +1 -1
  283. package/components/Radio/Radio.styles.js.map +1 -1
  284. package/components/Radio/index.js.map +1 -1
  285. package/components/RadioGroup/Prevent.js.map +1 -1
  286. package/components/RadioGroup/RadioGroup.js.map +1 -1
  287. package/components/RadioGroup/RadioGroup.styles.js.map +1 -1
  288. package/components/RadioGroup/RadioGroupContext.js.map +1 -1
  289. package/components/RadioGroup/index.js.map +1 -1
  290. package/components/ResponsiveLayout/ResponsiveLayout.js.map +1 -1
  291. package/components/ResponsiveLayout/ResponsiveLayoutEvents.js.map +1 -1
  292. package/components/ResponsiveLayout/decorator.js.map +1 -1
  293. package/components/ResponsiveLayout/index.js.map +1 -1
  294. package/components/ResponsiveLayout/types.js.map +1 -1
  295. package/components/ResponsiveLayout/useResponsiveLayout.js.map +1 -1
  296. package/components/ScrollContainer/ScrollBar.js.map +1 -1
  297. package/components/ScrollContainer/ScrollContainer.constants.js.map +1 -1
  298. package/components/ScrollContainer/ScrollContainer.helpers.js.map +1 -1
  299. package/components/ScrollContainer/ScrollContainer.js.map +1 -1
  300. package/components/ScrollContainer/ScrollContainer.styles.js.map +1 -1
  301. package/components/ScrollContainer/index.js.map +1 -1
  302. package/components/Select/ArrowDownIcon.js.map +1 -1
  303. package/components/Select/Item.js.map +1 -1
  304. package/components/Select/Select.js +11 -1
  305. package/components/Select/Select.js.map +1 -1
  306. package/components/Select/Select.styles.js.map +1 -1
  307. package/components/Select/index.js.map +1 -1
  308. package/components/Select/locale/index.js.map +1 -1
  309. package/components/Select/locale/locales/en.js.map +1 -1
  310. package/components/Select/locale/locales/ru.js.map +1 -1
  311. package/components/Select/locale/types.js.map +1 -1
  312. package/components/Select/selectTheme.js.map +1 -1
  313. package/components/Select/tids.js.map +1 -1
  314. package/components/SidePage/SidePage.js.map +1 -1
  315. package/components/SidePage/SidePage.styles.js.map +1 -1
  316. package/components/SidePage/SidePageBody.js.map +1 -1
  317. package/components/SidePage/SidePageCloseButton.js.map +1 -1
  318. package/components/SidePage/SidePageContainer.js.map +1 -1
  319. package/components/SidePage/SidePageContext.js.map +1 -1
  320. package/components/SidePage/SidePageFooter.js.map +1 -1
  321. package/components/SidePage/SidePageHeader.js.map +1 -1
  322. package/components/SidePage/index.js.map +1 -1
  323. package/components/SidePage/locale/index.js.map +1 -1
  324. package/components/SidePage/locale/locales/en.js.map +1 -1
  325. package/components/SidePage/locale/locales/ru.js.map +1 -1
  326. package/components/SidePage/locale/types.js.map +1 -1
  327. package/components/SingleToast/SingleToast.d.ts +9 -6
  328. package/components/SingleToast/SingleToast.js +9 -6
  329. package/components/SingleToast/SingleToast.js.map +1 -1
  330. package/components/SingleToast/index.js.map +1 -1
  331. package/components/Spinner/Spinner.d.ts +23 -33
  332. package/components/Spinner/Spinner.js +23 -19
  333. package/components/Spinner/Spinner.js.map +1 -1
  334. package/components/Spinner/Spinner.styles.d.ts +0 -3
  335. package/components/Spinner/Spinner.styles.js +6 -15
  336. package/components/Spinner/Spinner.styles.js.map +1 -1
  337. package/components/Spinner/index.js.map +1 -1
  338. package/components/Sticky/Sticky.js.map +1 -1
  339. package/components/Sticky/Sticky.styles.js.map +1 -1
  340. package/components/Sticky/index.js.map +1 -1
  341. package/components/Switcher/Switcher.js +1 -0
  342. package/components/Switcher/Switcher.js.map +1 -1
  343. package/components/Switcher/Switcher.styles.js.map +1 -1
  344. package/components/Switcher/helpers.js.map +1 -1
  345. package/components/Switcher/index.js.map +1 -1
  346. package/components/Switcher/switcherTheme.js.map +1 -1
  347. package/components/Tabs/Indicator.js.map +1 -1
  348. package/components/Tabs/Indicator.styles.js.map +1 -1
  349. package/components/Tabs/Tab.js.map +1 -1
  350. package/components/Tabs/Tab.styles.js.map +1 -1
  351. package/components/Tabs/Tabs.js.map +1 -1
  352. package/components/Tabs/Tabs.styles.js.map +1 -1
  353. package/components/Tabs/TabsContext.js.map +1 -1
  354. package/components/Tabs/helpers.js.map +1 -1
  355. package/components/Tabs/index.js.map +1 -1
  356. package/components/Textarea/Textarea.js +1 -1
  357. package/components/Textarea/Textarea.js.map +1 -1
  358. package/components/Textarea/Textarea.mixins.js.map +1 -1
  359. package/components/Textarea/Textarea.styles.d.ts +1 -0
  360. package/components/Textarea/Textarea.styles.js +7 -4
  361. package/components/Textarea/Textarea.styles.js.map +1 -1
  362. package/components/Textarea/TextareaCounter.d.ts +2 -0
  363. package/components/Textarea/TextareaCounter.js +22 -4
  364. package/components/Textarea/TextareaCounter.js.map +1 -1
  365. package/components/Textarea/TextareaHelpers.js.map +1 -1
  366. package/components/Textarea/TextareaWithSafari17Workaround.js.map +1 -1
  367. package/components/Textarea/index.js.map +1 -1
  368. package/components/Toast/Toast.d.ts +13 -14
  369. package/components/Toast/Toast.js +3 -3
  370. package/components/Toast/Toast.js.map +1 -1
  371. package/components/Toast/Toast.styles.js.map +1 -1
  372. package/components/Toast/ToastView.d.ts +8 -5
  373. package/components/Toast/ToastView.js +28 -8
  374. package/components/Toast/ToastView.js.map +1 -1
  375. package/components/Toast/ToastView.styles.d.ts +7 -0
  376. package/components/Toast/ToastView.styles.js +30 -8
  377. package/components/Toast/ToastView.styles.js.map +1 -1
  378. package/components/Toast/index.js.map +1 -1
  379. package/components/Toast/locale/index.js.map +1 -1
  380. package/components/Toast/locale/locales/en.js.map +1 -1
  381. package/components/Toast/locale/locales/ru.js.map +1 -1
  382. package/components/Toast/locale/types.js.map +1 -1
  383. package/components/Toggle/Toggle.js.map +1 -1
  384. package/components/Toggle/Toggle.mixins.js.map +1 -1
  385. package/components/Toggle/Toggle.styles.js.map +1 -1
  386. package/components/Toggle/index.js.map +1 -1
  387. package/components/Token/Token.js.map +1 -1
  388. package/components/Token/Token.mixins.js.map +1 -1
  389. package/components/Token/Token.styles.js.map +1 -1
  390. package/components/Token/TokenView.js.map +1 -1
  391. package/components/Token/index.js.map +1 -1
  392. package/components/Token/locale/index.js.map +1 -1
  393. package/components/Token/locale/locales/en.js.map +1 -1
  394. package/components/Token/locale/locales/ru.js.map +1 -1
  395. package/components/Token/locale/types.js.map +1 -1
  396. package/components/TokenInput/TextWidthHelper.js.map +1 -1
  397. package/components/TokenInput/TokenInput.d.ts +18 -2
  398. package/components/TokenInput/TokenInput.js +236 -79
  399. package/components/TokenInput/TokenInput.js.map +1 -1
  400. package/components/TokenInput/TokenInput.mixins.js.map +1 -1
  401. package/components/TokenInput/TokenInput.styles.d.ts +1 -0
  402. package/components/TokenInput/TokenInput.styles.js +12 -9
  403. package/components/TokenInput/TokenInput.styles.js.map +1 -1
  404. package/components/TokenInput/TokenInputMenu.d.ts +2 -1
  405. package/components/TokenInput/TokenInputMenu.js +1 -1
  406. package/components/TokenInput/TokenInputMenu.js.map +1 -1
  407. package/components/TokenInput/TokenInputMobileMenu.d.ts +25 -0
  408. package/components/TokenInput/TokenInputMobileMenu.js +40 -0
  409. package/components/TokenInput/TokenInputMobileMenu.js.map +1 -0
  410. package/components/TokenInput/TokenInputReducer.d.ts +2 -0
  411. package/components/TokenInput/TokenInputReducer.js +14 -0
  412. package/components/TokenInput/TokenInputReducer.js.map +1 -1
  413. package/components/TokenInput/index.js.map +1 -1
  414. package/components/TokenInput/locale/index.js.map +1 -1
  415. package/components/TokenInput/locale/locales/en.js.map +1 -1
  416. package/components/TokenInput/locale/locales/ru.js.map +1 -1
  417. package/components/TokenInput/locale/types.js.map +1 -1
  418. package/components/Tooltip/Tooltip.d.ts +4 -0
  419. package/components/Tooltip/Tooltip.js +50 -11
  420. package/components/Tooltip/Tooltip.js.map +1 -1
  421. package/components/Tooltip/Tooltip.styles.js.map +1 -1
  422. package/components/Tooltip/index.js.map +1 -1
  423. package/components/TooltipMenu/TooltipMenu.js.map +1 -1
  424. package/components/TooltipMenu/index.js.map +1 -1
  425. package/hooks/useDrop.js.map +1 -1
  426. package/hooks/useEffectWithoutInitCall.js.map +1 -1
  427. package/hooks/useMemoObject.js.map +1 -1
  428. package/index.js.map +1 -1
  429. package/internal/ClearCrossIcon/ClearCrossIcon.js.map +1 -1
  430. package/internal/ClearCrossIcon/ClearCrossIcon.styles.js.map +1 -1
  431. package/internal/ClearCrossIcon/CrossIcon.js.map +1 -1
  432. package/internal/CloseButtonIcon/CloseButtonIcon.js +1 -1
  433. package/internal/CloseButtonIcon/CloseButtonIcon.js.map +1 -1
  434. package/internal/CloseButtonIcon/CloseButtonIcon.styles.js.map +1 -1
  435. package/internal/CloseButtonIcon/CrossIcon.js.map +1 -1
  436. package/internal/CommonWrapper/CommonWrapper.js +5 -0
  437. package/internal/CommonWrapper/CommonWrapper.js.map +1 -1
  438. package/internal/CommonWrapper/index.js.map +1 -1
  439. package/internal/CommonWrapper/types.js.map +1 -1
  440. package/internal/CommonWrapper/utils/extractCommonProps.js.map +1 -1
  441. package/internal/CommonWrapper/utils/getCommonVisualStateDataAttributes.js.map +1 -1
  442. package/internal/CommonWrapper/utils/getVisualStateDataAttributes.js.map +1 -1
  443. package/internal/CommonWrapper/utils/tryGetBoolean.js.map +1 -1
  444. package/internal/CustomComboBox/ArrowDownIcon.js.map +1 -1
  445. package/internal/CustomComboBox/ComboBoxMenu.js +1 -1
  446. package/internal/CustomComboBox/ComboBoxMenu.js.map +1 -1
  447. package/internal/CustomComboBox/ComboBoxView.js +13 -2
  448. package/internal/CustomComboBox/ComboBoxView.js.map +1 -1
  449. package/internal/CustomComboBox/CustomComboBox.js.map +1 -1
  450. package/internal/CustomComboBox/CustomComboBox.styles.js.map +1 -1
  451. package/internal/CustomComboBox/CustomComboBoxReducer.js.map +1 -1
  452. package/internal/CustomComboBox/CustomComboBoxTypes.js.map +1 -1
  453. package/internal/CustomComboBox/getComboBoxTheme.js.map +1 -1
  454. package/internal/CustomComboBox/index.js.map +1 -1
  455. package/internal/CustomComboBox/locale/index.js.map +1 -1
  456. package/internal/CustomComboBox/locale/locales/en.js.map +1 -1
  457. package/internal/CustomComboBox/locale/locales/ru.js.map +1 -1
  458. package/internal/CustomComboBox/locale/types.js.map +1 -1
  459. package/internal/CustomComboBox/tids.js.map +1 -1
  460. package/internal/DateSelect/DateSelect.js.map +1 -1
  461. package/internal/DateSelect/DateSelect.styles.js.map +1 -1
  462. package/internal/DateSelect/index.js.map +1 -1
  463. package/internal/DateSelect/locale/index.js.map +1 -1
  464. package/internal/DateSelect/locale/locales/en.js.map +1 -1
  465. package/internal/DateSelect/locale/locales/ru.js.map +1 -1
  466. package/internal/DateSelect/locale/types.js.map +1 -1
  467. package/internal/FocusControlWrapper/FocusControlWrapper.js.map +1 -1
  468. package/internal/FocusControlWrapper/index.js.map +1 -1
  469. package/internal/FocusControlWrapper/useFocusControl.js.map +1 -1
  470. package/internal/FocusTrap/FocusTrap.js.map +1 -1
  471. package/internal/FocusTrap/index.js.map +1 -1
  472. package/internal/HideBodyVerticalScroll/HideBodyVerticalScroll.js.map +1 -1
  473. package/internal/HideBodyVerticalScroll/index.js.map +1 -1
  474. package/internal/InputLikeText/InputLikeText.d.ts +1 -1
  475. package/internal/InputLikeText/InputLikeText.js.map +1 -1
  476. package/internal/InputLikeText/InputLikeText.styles.js.map +1 -1
  477. package/internal/InputLikeText/index.js.map +1 -1
  478. package/internal/InternalTextareaWithLayout/InternalTextareaWithLayout.js.map +1 -1
  479. package/internal/InternalTextareaWithLayout/InternalTextareaWithLayout.styles.js.map +1 -1
  480. package/internal/MaskCharLowLine/MaskCharLowLine.js.map +1 -1
  481. package/internal/MaskCharLowLine/MaskCharLowLine.styles.js.map +1 -1
  482. package/internal/MaskCharLowLine/index.js.map +1 -1
  483. package/internal/Menu/Menu.js +3 -0
  484. package/internal/Menu/Menu.js.map +1 -1
  485. package/internal/Menu/Menu.styles.d.ts +1 -0
  486. package/internal/Menu/Menu.styles.js +13 -10
  487. package/internal/Menu/Menu.styles.js.map +1 -1
  488. package/internal/Menu/MenuContext.js.map +1 -1
  489. package/internal/Menu/MenuNavigation.js.map +1 -1
  490. package/internal/Menu/index.js.map +1 -1
  491. package/internal/MenuMessage/MenuMessage.js +17 -1
  492. package/internal/MenuMessage/MenuMessage.js.map +1 -1
  493. package/internal/MenuMessage/MenuMessage.styles.d.ts +3 -0
  494. package/internal/MenuMessage/MenuMessage.styles.js +13 -4
  495. package/internal/MenuMessage/MenuMessage.styles.js.map +1 -1
  496. package/internal/MenuMessage/index.js.map +1 -1
  497. package/internal/MobilePopup/MobilePopup.d.ts +8 -0
  498. package/internal/MobilePopup/MobilePopup.js +34 -11
  499. package/internal/MobilePopup/MobilePopup.js.map +1 -1
  500. package/internal/MobilePopup/MobilePopup.styles.d.ts +7 -0
  501. package/internal/MobilePopup/MobilePopup.styles.js +34 -10
  502. package/internal/MobilePopup/MobilePopup.styles.js.map +1 -1
  503. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.d.ts +8 -1
  504. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.js +18 -1
  505. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.js.map +1 -1
  506. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.styles.d.ts +3 -0
  507. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.styles.js +14 -4
  508. package/internal/MobilePopup/MobilePopupFooter/MobilePopupFooter.styles.js.map +1 -1
  509. package/internal/MobilePopup/MobilePopupFooter/index.js.map +1 -1
  510. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.d.ts +4 -0
  511. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.js +48 -11
  512. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.js.map +1 -1
  513. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.styles.d.ts +6 -0
  514. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.styles.js +28 -8
  515. package/internal/MobilePopup/MobilePopupHeader/MobilePopupHeader.styles.js.map +1 -1
  516. package/internal/MobilePopup/MobilePopupHeader/index.js.map +1 -1
  517. package/internal/MobilePopup/index.js.map +1 -1
  518. package/internal/NativeDateInput/NativeDateInput.js.map +1 -1
  519. package/internal/NativeDateInput/NativeDateInput.styles.js.map +1 -1
  520. package/internal/NativeDateInput/index.js.map +1 -1
  521. package/internal/NativeDateInput/utils.js.map +1 -1
  522. package/internal/Popup/Popup.d.ts +9 -3
  523. package/internal/Popup/Popup.js +117 -15
  524. package/internal/Popup/Popup.js.map +1 -1
  525. package/internal/Popup/Popup.styles.js +1 -1
  526. package/internal/Popup/Popup.styles.js.map +1 -1
  527. package/internal/Popup/PopupHelper.d.ts +4 -0
  528. package/internal/Popup/PopupHelper.js +8 -0
  529. package/internal/Popup/PopupHelper.js.map +1 -1
  530. package/internal/Popup/PopupPin.d.ts +19 -4
  531. package/internal/Popup/PopupPin.js +109 -8
  532. package/internal/Popup/PopupPin.js.map +1 -1
  533. package/internal/Popup/PopupPin.styles.d.ts +2 -0
  534. package/internal/Popup/PopupPin.styles.js +11 -5
  535. package/internal/Popup/PopupPin.styles.js.map +1 -1
  536. package/internal/Popup/index.js.map +1 -1
  537. package/internal/Popup/types.js.map +1 -1
  538. package/internal/PopupMenu/PopupMenu.js.map +1 -1
  539. package/internal/PopupMenu/PopupMenu.styles.js.map +1 -1
  540. package/internal/PopupMenu/index.js.map +1 -1
  541. package/internal/PopupMenu/tids.js.map +1 -1
  542. package/internal/PopupMenu/validatePositions.js.map +1 -1
  543. package/internal/RenderContainer/RenderContainer.js.map +1 -1
  544. package/internal/RenderContainer/RenderContainerTypes.js.map +1 -1
  545. package/internal/RenderContainer/RenderInnerContainer.js.map +1 -1
  546. package/internal/RenderContainer/index.js.map +1 -1
  547. package/internal/RenderLayer/RenderLayer.js.map +1 -1
  548. package/internal/RenderLayer/index.js.map +1 -1
  549. package/internal/ResizeDetector/ResizeDetector.js.map +1 -1
  550. package/internal/ResizeDetector/ResizeDetector.styles.js.map +1 -1
  551. package/internal/ResizeDetector/index.js.map +1 -1
  552. package/internal/SpinnerIcon/SpinnerIcon.d.ts +3 -3
  553. package/internal/SpinnerIcon/SpinnerIcon.js +4 -4
  554. package/internal/SpinnerIcon/SpinnerIcon.js.map +1 -1
  555. package/internal/SpinnerIcon/SpinnerIcon.styles.js.map +1 -1
  556. package/internal/TextWidthHelper/TextWidthHelper.js.map +1 -1
  557. package/internal/TextWidthHelper/TextWidthHelper.styles.js.map +1 -1
  558. package/internal/ZIndex/ZIndex.js.map +1 -1
  559. package/internal/ZIndex/ZIndexStorage.js.map +1 -1
  560. package/internal/ZIndex/index.js.map +1 -1
  561. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light.js.map +1 -1
  562. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light.js.map +1 -1
  563. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular.js.map +1 -1
  564. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light.js.map +1 -1
  565. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light.js.map +1 -1
  566. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular.js.map +1 -1
  567. package/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light.js.map +1 -1
  568. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular.js.map +1 -1
  569. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular.js.map +1 -1
  570. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular.js.map +1 -1
  571. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light.js.map +1 -1
  572. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light.js.map +1 -1
  573. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular.js.map +1 -1
  574. package/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular.js.map +1 -1
  575. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light.js.map +1 -1
  576. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light.js.map +1 -1
  577. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular.js.map +1 -1
  578. package/internal/icons2022/BaseIcon.js.map +1 -1
  579. package/internal/icons2022/BaseIcon.styles.js.map +1 -1
  580. package/internal/icons2022/CalendarIcon/CalendarIcon16Light.js.map +1 -1
  581. package/internal/icons2022/CalendarIcon/CalendarIcon20Light.js.map +1 -1
  582. package/internal/icons2022/CalendarIcon/CalendarIcon24Regular.js.map +1 -1
  583. package/internal/icons2022/CheckAIcon/CheckAIcon16Solid.js.map +1 -1
  584. package/internal/icons2022/CheckAIcon/CheckAIcon20Solid.js.map +1 -1
  585. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light.js.map +1 -1
  586. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light.js.map +1 -1
  587. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular.js.map +1 -1
  588. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light.js.map +1 -1
  589. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light.js.map +1 -1
  590. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular.js.map +1 -1
  591. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon16Solid.js.map +1 -1
  592. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon20Solid.js.map +1 -1
  593. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon24Regular.js.map +1 -1
  594. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon24Solid.js.map +1 -1
  595. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon32Regular.js.map +1 -1
  596. package/internal/icons2022/FileTypeArchiveIcon/ArchiveIcon64Regular.js.map +1 -1
  597. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon16Solid.js.map +1 -1
  598. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon20Solid.js.map +1 -1
  599. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon24Regular.js.map +1 -1
  600. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon24Solid.js.map +1 -1
  601. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon32Regular.js.map +1 -1
  602. package/internal/icons2022/FileTypeDocTextIcon/DocTextIcon64Regular.js.map +1 -1
  603. package/internal/icons2022/FileTypeFolderIcon/FolderIcon16Solid.js.map +1 -1
  604. package/internal/icons2022/FileTypeFolderIcon/FolderIcon20Solid.js.map +1 -1
  605. package/internal/icons2022/FileTypeFolderIcon/FolderIcon24Regular.js.map +1 -1
  606. package/internal/icons2022/FileTypeFolderIcon/FolderIcon24Solid.js.map +1 -1
  607. package/internal/icons2022/FileTypeFolderIcon/FolderIcon32Regular.js.map +1 -1
  608. package/internal/icons2022/FileTypeFolderIcon/FolderIcon64Regular.js.map +1 -1
  609. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon16Solid.js.map +1 -1
  610. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon20Solid.js.map +1 -1
  611. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon24Regular.js.map +1 -1
  612. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon24Solid.js.map +1 -1
  613. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon32Regular.js.map +1 -1
  614. package/internal/icons2022/FileTypeMarkupIcon/MarkupIcon64Regular.js.map +1 -1
  615. package/internal/icons2022/FileTypePdfIcon/PdfIcon16Solid.js.map +1 -1
  616. package/internal/icons2022/FileTypePdfIcon/PdfIcon20Solid.js.map +1 -1
  617. package/internal/icons2022/FileTypePdfIcon/PdfIcon24Regular.js.map +1 -1
  618. package/internal/icons2022/FileTypePdfIcon/PdfIcon24Solid.js.map +1 -1
  619. package/internal/icons2022/FileTypePdfIcon/PdfIcon32Regular.js.map +1 -1
  620. package/internal/icons2022/FileTypePdfIcon/PdfIcon64Regular.js.map +1 -1
  621. package/internal/icons2022/FileTypePictureIcon/PictureIcon16Solid.js.map +1 -1
  622. package/internal/icons2022/FileTypePictureIcon/PictureIcon20Solid.js.map +1 -1
  623. package/internal/icons2022/FileTypePictureIcon/PictureIcon24Regular.js.map +1 -1
  624. package/internal/icons2022/FileTypePictureIcon/PictureIcon24Solid.js.map +1 -1
  625. package/internal/icons2022/FileTypePictureIcon/PictureIcon32Regular.js.map +1 -1
  626. package/internal/icons2022/FileTypePictureIcon/PictureIcon64Regular.js.map +1 -1
  627. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon16Solid.js.map +1 -1
  628. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon20Solid.js.map +1 -1
  629. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon24Regular.js.map +1 -1
  630. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon24Solid.js.map +1 -1
  631. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon32Regular.js.map +1 -1
  632. package/internal/icons2022/FileTypePresentationIcon/PresentationIcon64Regular.js.map +1 -1
  633. package/internal/icons2022/FileTypeTableIcon/TableIcon16Solid.js.map +1 -1
  634. package/internal/icons2022/FileTypeTableIcon/TableIcon20Solid.js.map +1 -1
  635. package/internal/icons2022/FileTypeTableIcon/TableIcon24Regular.js.map +1 -1
  636. package/internal/icons2022/FileTypeTableIcon/TableIcon24Solid.js.map +1 -1
  637. package/internal/icons2022/FileTypeTableIcon/TableIcon32Regular.js.map +1 -1
  638. package/internal/icons2022/FileTypeTableIcon/TableIcon64Regular.js.map +1 -1
  639. package/internal/icons2022/FileTypeTextIcon/TextIcon16Solid.js.map +1 -1
  640. package/internal/icons2022/FileTypeTextIcon/TextIcon20Solid.js.map +1 -1
  641. package/internal/icons2022/FileTypeTextIcon/TextIcon24Regular.js.map +1 -1
  642. package/internal/icons2022/FileTypeTextIcon/TextIcon24Solid.js.map +1 -1
  643. package/internal/icons2022/FileTypeTextIcon/TextIcon32Regular.js.map +1 -1
  644. package/internal/icons2022/FileTypeTextIcon/TextIcon64Regular.js.map +1 -1
  645. package/internal/icons2022/InfoCircleIcon/InfoCircleIcon64Regular.js.map +1 -1
  646. package/internal/icons2022/LoadingIcon.js +1 -1
  647. package/internal/icons2022/LoadingIcon.js.map +1 -1
  648. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light.js.map +1 -1
  649. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light.js.map +1 -1
  650. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular.js.map +1 -1
  651. package/internal/icons2022/NetUploadIcon/NetUploadIcon16Light.js.map +1 -1
  652. package/internal/icons2022/NetUploadIcon/NetUploadIcon20Regular.js.map +1 -1
  653. package/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular.js.map +1 -1
  654. package/internal/icons2022/NetUploadIcon/NetUploadIcon32Regular.js.map +1 -1
  655. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Light.d.ts +2 -0
  656. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Light.js +21 -0
  657. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Light.js.map +1 -0
  658. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid.js.map +1 -1
  659. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon20Regular.d.ts +2 -0
  660. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon20Regular.js +21 -0
  661. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon20Regular.js.map +1 -0
  662. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon24Regular.d.ts +2 -0
  663. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon24Regular.js +21 -0
  664. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon24Regular.js.map +1 -0
  665. package/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid.js.map +1 -1
  666. package/internal/icons2022/UiMenuDots3HIcon/UiMenuDots3HIcon16Regular.js.map +1 -1
  667. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light.js.map +1 -1
  668. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular.js.map +1 -1
  669. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular.js.map +1 -1
  670. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon16Solid.js.map +1 -1
  671. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon20Solid.js.map +1 -1
  672. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon24Regular.js.map +1 -1
  673. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon24Solid.js.map +1 -1
  674. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon32Regular.js.map +1 -1
  675. package/internal/icons2022/WarningTriangleIcon/WarningTriangleIcon64Regular.js.map +1 -1
  676. package/internal/icons2022/XCircleIcon/XCircleIcon16Solid.js.map +1 -1
  677. package/internal/icons2022/XCircleIcon/XCircleIcon20Solid.js.map +1 -1
  678. package/internal/icons2022/XCircleIcon/XCircleIcon24Regular.js.map +1 -1
  679. package/internal/icons2022/XCircleIcon/XCircleIcon24Solid.js.map +1 -1
  680. package/internal/icons2022/XCircleIcon/XCircleIcon32Regular.js.map +1 -1
  681. package/internal/icons2022/XCircleIcon/XCircleIcon64Regular.js.map +1 -1
  682. package/internal/icons2022/XIcon/XIcon16Light.js.map +1 -1
  683. package/internal/icons2022/XIcon/XIcon20Light.js.map +1 -1
  684. package/internal/icons2022/XIcon/XIcon20Regular.js.map +1 -1
  685. package/internal/icons2022/XIcon/XIcon24Regular.js.map +1 -1
  686. package/internal/icons2022/iconConstants.js.map +1 -1
  687. package/internal/icons2022/iconSizer.js.map +1 -1
  688. package/internal/react-focus-lock/Combination.js.map +1 -1
  689. package/internal/react-focus-lock/FocusGuard.js.map +1 -1
  690. package/internal/react-focus-lock/Lock.js.map +1 -1
  691. package/internal/react-focus-lock/Trap.js.map +1 -1
  692. package/internal/react-focus-lock/constants.js.map +1 -1
  693. package/internal/react-focus-lock/index.js.map +1 -1
  694. package/internal/react-focus-lock/medium.js.map +1 -1
  695. package/internal/react-focus-lock/scope.js.map +1 -1
  696. package/internal/react-focus-lock/util.js.map +1 -1
  697. package/internal/themes/BasicTheme.d.ts +83 -4
  698. package/internal/themes/BasicTheme.js +186 -5
  699. package/internal/themes/BasicTheme.js.map +1 -1
  700. package/internal/themes/DarkTheme6_0.js.map +1 -1
  701. package/internal/themes/DarkTheme6_1.d.ts +1 -0
  702. package/internal/themes/DarkTheme6_1.js +41 -0
  703. package/internal/themes/DarkTheme6_1.js.map +1 -0
  704. package/internal/themes/LightTheme6_0.js.map +1 -1
  705. package/internal/themes/LightTheme6_1.d.ts +1 -0
  706. package/internal/themes/LightTheme6_1.js +39 -0
  707. package/internal/themes/LightTheme6_1.js.map +1 -0
  708. package/lib/ConditionalHandler.js.map +1 -1
  709. package/lib/InstanceWithAnchorElement.js.map +1 -1
  710. package/lib/LayoutEvents.js.map +1 -1
  711. package/lib/ModalStack.js.map +1 -1
  712. package/lib/Upgrades.js.map +1 -1
  713. package/lib/animation/index.js.map +1 -1
  714. package/lib/animation/presets.js.map +1 -1
  715. package/lib/animation/stepper.js.map +1 -1
  716. package/lib/blink.js.map +1 -1
  717. package/lib/callChildRef/callChildRef.js.map +1 -1
  718. package/lib/chars.js.map +1 -1
  719. package/lib/client.js.map +1 -1
  720. package/lib/createPropsGetter.js.map +1 -1
  721. package/lib/currentEnvironment.js.map +1 -1
  722. package/lib/date/InternalDate.js.map +1 -1
  723. package/lib/date/InternalDateCalculator.js.map +1 -1
  724. package/lib/date/InternalDateGetter.js.map +1 -1
  725. package/lib/date/InternalDateSetter.js.map +1 -1
  726. package/lib/date/InternalDateTransformer.js.map +1 -1
  727. package/lib/date/InternalDateValidator.js.map +1 -1
  728. package/lib/date/comparison.js.map +1 -1
  729. package/lib/date/constants.js.map +1 -1
  730. package/lib/date/localeSets.js.map +1 -1
  731. package/lib/date/types.js.map +1 -1
  732. package/lib/delay.js.map +1 -1
  733. package/lib/dom/getDOMRect.js.map +1 -1
  734. package/lib/dom/getParentOrShadowHost.js.map +1 -1
  735. package/lib/dom/getScrollWidth.js.map +1 -1
  736. package/lib/dom/scrollYCenterIntoNearestScrollable.js.map +1 -1
  737. package/lib/dom/selectionHelpers.js.map +1 -1
  738. package/lib/dom/tabbableHelpers.js.map +1 -1
  739. package/lib/events/MouseDrag.js.map +1 -1
  740. package/lib/events/fixFirefoxModifiedClickOnLabel.js.map +1 -1
  741. package/lib/events/keyListener.js.map +1 -1
  742. package/lib/events/keyboard/KeyboardEventCodes.js.map +1 -1
  743. package/lib/events/keyboard/KeyboardMapKeys.js.map +1 -1
  744. package/lib/events/keyboard/extractCode.js.map +1 -1
  745. package/lib/events/keyboard/identifiers.js.map +1 -1
  746. package/lib/extractKeyboardAction.js.map +1 -1
  747. package/lib/featureFlagsContext/FeatureFlagsHelpers.js.map +1 -1
  748. package/lib/featureFlagsContext/ReactUIFeatureFlagsContext.js.map +1 -1
  749. package/lib/featureFlagsContext/index.js.map +1 -1
  750. package/lib/filterProps.js.map +1 -1
  751. package/lib/forwardRefAndName.js.map +1 -1
  752. package/lib/getElementRef.js.map +1 -1
  753. package/lib/getMenuPositions.js.map +1 -1
  754. package/lib/globalObject.js.map +1 -1
  755. package/lib/isInstanceOf.js.map +1 -1
  756. package/lib/listenFocusOutside.js.map +1 -1
  757. package/lib/locale/LocaleContext.js.map +1 -1
  758. package/lib/locale/LocaleHelper.js.map +1 -1
  759. package/lib/locale/constants.js.map +1 -1
  760. package/lib/locale/decorators.js.map +1 -1
  761. package/lib/locale/index.js.map +1 -1
  762. package/lib/locale/types.js.map +1 -1
  763. package/lib/locale/useLocaleForControl.js.map +1 -1
  764. package/lib/memo.js.map +1 -1
  765. package/lib/mergeRefs.js.map +1 -1
  766. package/lib/needsPolyfillPlaceholder.js.map +1 -1
  767. package/lib/pluralize.js.map +1 -1
  768. package/lib/react-is.js.map +1 -1
  769. package/lib/reactGetTextContent.js.map +1 -1
  770. package/lib/renderEnvironment/RenderEnvironmentContext.js.map +1 -1
  771. package/lib/renderEnvironment/RenderEnvironmentDecorator.js.map +1 -1
  772. package/lib/renderEnvironment/index.js.map +1 -1
  773. package/lib/rootNode/getRootNode.js.map +1 -1
  774. package/lib/rootNode/index.js.map +1 -1
  775. package/lib/rootNode/rootNodeDecorator.js.map +1 -1
  776. package/lib/scrollInputCaretIntoView.js.map +1 -1
  777. package/lib/size/SizeControlContext.js.map +1 -1
  778. package/lib/size/SizeDecorator.js.map +1 -1
  779. package/lib/size/constants.js.map +1 -1
  780. package/lib/size/index.js.map +1 -1
  781. package/lib/size/useSizeControl.js.map +1 -1
  782. package/lib/stringUtils.js.map +1 -1
  783. package/lib/styles/ColorFactory.js.map +1 -1
  784. package/lib/styles/ColorFunctions.js.map +1 -1
  785. package/lib/styles/ColorHelpers.js.map +1 -1
  786. package/lib/styles/ColorKeywords.js.map +1 -1
  787. package/lib/styles/ColorObject.js.map +1 -1
  788. package/lib/styles/DimensionFunctions.js.map +1 -1
  789. package/lib/styles/Mixins.js.map +1 -1
  790. package/lib/styles/UiFont.js.map +1 -1
  791. package/lib/styles/getLabGrotesqueBaselineCompensation.js.map +1 -1
  792. package/lib/taskWithDelayAndMinimalDuration.js.map +1 -1
  793. package/lib/theming/AnimationKeyframes.js.map +1 -1
  794. package/lib/theming/Emotion.js.map +1 -1
  795. package/lib/theming/Theme.js.map +1 -1
  796. package/lib/theming/ThemeContext.js.map +1 -1
  797. package/lib/theming/ThemeFactory.js.map +1 -1
  798. package/lib/theming/ThemeHelpers.js.map +1 -1
  799. package/lib/theming/ThemeVersions.js.map +1 -1
  800. package/lib/theming/themes/DarkTheme.d.ts +1 -0
  801. package/lib/theming/themes/DarkTheme.js +3 -1
  802. package/lib/theming/themes/DarkTheme.js.map +1 -1
  803. package/lib/theming/themes/LightTheme.d.ts +1 -0
  804. package/lib/theming/themes/LightTheme.js +3 -1
  805. package/lib/theming/themes/LightTheme.js.map +1 -1
  806. package/lib/theming/useTheme.js.map +1 -1
  807. package/lib/toKebabCase.js.map +1 -1
  808. package/lib/typeGuards.js.map +1 -1
  809. package/lib/types/button-link.js.map +1 -1
  810. package/lib/types/polymorphic-component.js.map +1 -1
  811. package/lib/types/props.js.map +1 -1
  812. package/lib/uidUtils.js.map +1 -1
  813. package/lib/utils.js.map +1 -1
  814. package/package.json +1 -1
@@ -1,64 +1,54 @@
1
1
  import React from 'react';
2
2
  import type { CommonProps } from '../../internal/CommonWrapper/index.js';
3
3
  import type { TGetRootNode } from '../../lib/rootNode/index.js';
4
+ import type { SizeProp } from '../../lib/types/props.js';
4
5
  declare const types: readonly ["big", "mini", "normal"];
6
+ /**
7
+ * @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу `SizeContext`. Они будут удалены в `7.0`.
8
+ * @see {@link SizeProp} */
5
9
  export type SpinnerType = (typeof types)[number];
6
10
  export interface SpinnerProps extends CommonProps {
7
- /**
8
- * Подпись спиннера
9
- */
11
+ /** Подпись спиннера */
10
12
  caption?: React.ReactNode;
11
- /**
12
- * Размер индикатора и текста
13
- *
14
- * @default normal
15
- */
13
+ /** Размер спиннера
14
+ * @default small */
15
+ size?: SizeProp;
16
+ /** Размер спиннера
17
+ * @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу нового `SizeContext`. Они будут удалены в `7.0`.
18
+ * @see {@link size} */
16
19
  type?: SpinnerType;
17
- /**
18
- * Одноцветный режим. Удобная альтернатива пропа `dimmed`
19
- */
20
- color?: React.CSSProperties['color'];
21
- /**
22
- * Уменьшает размер индикатора для работы в строках. Если задан, то размер индикитора из `type` игнорируется
23
- *
24
- * @default false
25
- */
20
+ /** Уменьшает размер индикатора для работы в строках. Если задан, то размер спиннера из `size` игнорируется
21
+ * @default false */
26
22
  inline?: boolean;
27
- /**
28
- * Толщина индикатора в пикселях.
29
- *
30
- * @default 2
31
- */
23
+ /** Толщина индикатора в пикселях.
24
+ * @default 2 */
32
25
  width?: number;
33
- /**
34
- * Одноцветный режим. Цвет спиннера не переливается. Можно кастомизировать переменной `spinnerDimmedColor`
35
- *
36
- * @default false
37
- */
26
+ /** Цвет спиннера в одноцветном режиме. Альтернатива пропа `dimmed` */
27
+ color?: React.CSSProperties['color'];
28
+ /** Включает одноцветный режим, в котором цвет спиннера не переливается. Можно кастомизировать переменной `spinnerDimmedColor`
29
+ * @default false */
38
30
  dimmed?: boolean;
39
31
  }
40
32
  export declare const SpinnerDataTids: {
41
33
  readonly root: "Spinner__root";
42
34
  };
43
- type DefaultProps = Required<Pick<SpinnerProps, 'type'>>;
44
- /**
45
- * Зацикленный индикатор, не отображающий прогресс выполнения задачи.
46
- */
35
+ /** Зацикленный индикатор, не отображающий прогресс выполнения задачи */
47
36
  export declare class Spinner extends React.Component<SpinnerProps> {
48
37
  static __KONTUR_REACT_UI__: string;
49
38
  static displayName: string;
50
- static defaultProps: DefaultProps;
51
- private getProps;
39
+ /** @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу `SizeContext`. Они будут удалены в `7.0`. */
52
40
  static Types: Record<SpinnerType, SpinnerType>;
53
41
  private emotion;
54
42
  private cx;
55
43
  private styles;
56
44
  private theme;
45
+ private size;
57
46
  getRootNode: TGetRootNode;
58
47
  private setRootNode;
59
48
  render(): React.JSX.Element;
60
49
  private renderMain;
61
50
  private renderSpinner;
62
51
  private renderCaption;
52
+ private typeToSize;
63
53
  }
64
54
  export {};
@@ -42,35 +42,41 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
42
42
  import React from 'react';
43
43
  import { CommonWrapper } from '../../internal/CommonWrapper/index.js';
44
44
  import { SpinnerIcon } from '../../internal/SpinnerIcon/SpinnerIcon.js';
45
- import { createPropsGetter } from '../../lib/createPropsGetter.js';
46
45
  import { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';
47
46
  import { rootNode } from '../../lib/rootNode/index.js';
47
+ import { withSize } from '../../lib/size/SizeDecorator.js';
48
48
  import { ThemeContext } from '../../lib/theming/ThemeContext.js';
49
49
  import { getStyles } from './Spinner.styles.js';
50
50
  var types = ['big', 'mini', 'normal'];
51
51
  export var SpinnerDataTids = {
52
52
  root: 'Spinner__root',
53
53
  };
54
- /**
55
- * Зацикленный индикатор, не отображающий прогресс выполнения задачи.
56
- */
54
+ /** Зацикленный индикатор, не отображающий прогресс выполнения задачи */
57
55
  var Spinner = /** @class */ (function (_super) {
58
56
  __extends(Spinner, _super);
59
57
  function Spinner() {
60
58
  var _this = _super !== null && _super.apply(this, arguments) || this;
61
- _this.getProps = createPropsGetter(Spinner_1.defaultProps);
62
- _this.renderSpinner = function (type, dimmed, inline) {
59
+ _this.renderSpinner = function (size, dimmed, inline) {
63
60
  var _a;
64
- return (React.createElement(SpinnerIcon, { size: type, className: _this.cx((_a = {},
61
+ return (React.createElement(SpinnerIcon, { size: size, className: _this.cx((_a = {},
65
62
  _a[_this.styles.circle(_this.theme)] = !dimmed && !_this.props.color,
66
63
  _a[_this.styles.circleDimmedColor(_this.theme)] = dimmed,
67
64
  _a[_this.styles.circleWithoutColorAnimation()] = dimmed || !!_this.props.color,
68
65
  _a)), width: _this.props.width, color: _this.props.color, inline: inline }));
69
66
  };
70
- _this.renderCaption = function (type, caption) { return (React.createElement("span", { className: _this.cx(_this.styles[type](_this.theme), _this.styles.captionColor(_this.theme)) }, caption)); };
67
+ _this.renderCaption = function (size, caption) { return (React.createElement("span", { className: _this.cx(_this.styles[size](_this.theme), _this.styles.captionColor(_this.theme)) }, caption)); };
68
+ _this.typeToSize = function (type) {
69
+ switch (type) {
70
+ case 'mini':
71
+ return 'small';
72
+ case 'normal':
73
+ return 'medium';
74
+ case 'big':
75
+ return 'large';
76
+ }
77
+ };
71
78
  return _this;
72
79
  }
73
- Spinner_1 = Spinner;
74
80
  Spinner.prototype.render = function () {
75
81
  var _this = this;
76
82
  this.styles = getStyles(this.emotion);
@@ -80,26 +86,24 @@ var Spinner = /** @class */ (function (_super) {
80
86
  }));
81
87
  };
82
88
  Spinner.prototype.renderMain = function () {
83
- var _a = this.props, _b = _a.caption, caption = _b === void 0 ? null : _b, dimmed = _a.dimmed, inline = _a.inline;
84
- var type = this.getProps().type;
89
+ var _a = this.props, _b = _a.caption, caption = _b === void 0 ? null : _b, size = _a.size, type = _a.type, dimmed = _a.dimmed, inline = _a.inline;
90
+ var parsedSize = size || !type ? this.size : this.typeToSize(type);
85
91
  return (React.createElement(CommonWrapper, __assign({ rootNodeRef: this.setRootNode }, this.props),
86
92
  React.createElement("div", { "data-tid": SpinnerDataTids.root, className: this.styles.spinner() },
87
- React.createElement("span", { className: this.styles.inner() }, this.renderSpinner(type, dimmed, inline)),
88
- caption && this.renderCaption(type, caption))));
93
+ React.createElement("span", { className: this.styles.inner() }, this.renderSpinner(parsedSize, dimmed, inline)),
94
+ caption && this.renderCaption(parsedSize, caption))));
89
95
  };
90
- var Spinner_1;
91
96
  Spinner.__KONTUR_REACT_UI__ = 'Spinner';
92
97
  Spinner.displayName = 'Spinner';
93
- Spinner.defaultProps = {
94
- type: 'normal',
95
- };
98
+ /** @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу `SizeContext`. Они будут удалены в `7.0`. */
96
99
  Spinner.Types = Object.assign.apply(Object, __spreadArray([{}], types.map(function (type) {
97
100
  var _a;
98
101
  return (_a = {}, _a[type] = type, _a);
99
102
  }), false));
100
- Spinner = Spinner_1 = __decorate([
103
+ Spinner = __decorate([
101
104
  withRenderEnvironment,
102
- rootNode
105
+ rootNode,
106
+ withSize
103
107
  ], Spinner);
104
108
  return Spinner;
105
109
  }(React.Component));
@@ -1 +1 @@
1
- {"version":3,"file":"Spinner.js","sourceRoot":"","sources":["../../../components/Spinner/Spinner.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport React from 'react';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { SpinnerIcon } from '../../internal/SpinnerIcon/SpinnerIcon.js';\nimport { createPropsGetter } from '../../lib/createPropsGetter.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport { getStyles } from './Spinner.styles.js';\n\nconst types = ['big', 'mini', 'normal'] as const;\n\nexport type SpinnerType = (typeof types)[number];\n\nexport interface SpinnerProps extends CommonProps {\n /**\n * Подпись спиннера\n */\n caption?: React.ReactNode;\n\n /**\n * Размер индикатора и текста\n *\n * @default normal\n */\n type?: SpinnerType;\n\n /**\n * Одноцветный режим. Удобная альтернатива пропа `dimmed`\n */\n color?: React.CSSProperties['color'];\n\n /**\n * Уменьшает размер индикатора для работы в строках. Если задан, то размер индикитора из `type` игнорируется\n *\n * @default false\n */\n inline?: boolean;\n\n /**\n * Толщина индикатора в пикселях.\n *\n * @default 2\n */\n width?: number;\n\n /**\n * Одноцветный режим. Цвет спиннера не переливается. Можно кастомизировать переменной `spinnerDimmedColor`\n *\n * @default false\n */\n dimmed?: boolean;\n}\n\nexport const SpinnerDataTids = {\n root: 'Spinner__root',\n} as const;\n\ntype DefaultProps = Required<Pick<SpinnerProps, 'type'>>;\n\n/**\n * Зацикленный индикатор, не отображающий прогресс выполнения задачи.\n */\n@withRenderEnvironment\n@rootNode\nexport class Spinner extends React.Component<SpinnerProps> {\n public static __KONTUR_REACT_UI__ = 'Spinner';\n public static displayName = 'Spinner';\n\n public static defaultProps: DefaultProps = {\n type: 'normal',\n };\n\n private getProps = createPropsGetter(Spinner.defaultProps);\n\n public static Types: Record<SpinnerType, SpinnerType> = Object.assign({}, ...types.map((type) => ({ [type]: type })));\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { caption = null, dimmed, inline } = this.props;\n const type = this.getProps().type;\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={SpinnerDataTids.root} className={this.styles.spinner()}>\n <span className={this.styles.inner()}>{this.renderSpinner(type, dimmed, inline)}</span>\n {caption && this.renderCaption(type, caption)}\n </div>\n </CommonWrapper>\n );\n }\n\n private renderSpinner = (type: SpinnerType, dimmed?: boolean, inline?: boolean) => {\n return (\n <SpinnerIcon\n size={type}\n className={this.cx({\n [this.styles.circle(this.theme)]: !dimmed && !this.props.color,\n [this.styles.circleDimmedColor(this.theme)]: dimmed,\n [this.styles.circleWithoutColorAnimation()]: dimmed || !!this.props.color,\n })}\n width={this.props.width}\n color={this.props.color}\n inline={inline}\n />\n );\n };\n\n private renderCaption = (type: SpinnerType, caption: React.ReactNode) => (\n <span className={this.cx(this.styles[type](this.theme), this.styles.captionColor(this.theme))}>{caption}</span>\n );\n}\n"]}
1
+ {"version":3,"file":"Spinner.js","sourceRoot":"","sources":["Spinner.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport React from 'react';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { SpinnerIcon } from '../../internal/SpinnerIcon/SpinnerIcon.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport { withSize } from '../../lib/size/SizeDecorator.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport type { SizeProp } from '../../lib/types/props.js';\nimport { getStyles } from './Spinner.styles.js';\n\nconst types = ['big', 'mini', 'normal'] as const;\n\n/**\n * @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу `SizeContext`. Они будут удалены в `7.0`.\n * @see {@link SizeProp} */\nexport type SpinnerType = (typeof types)[number];\n\nexport interface SpinnerProps extends CommonProps {\n /** Подпись спиннера */\n caption?: React.ReactNode;\n\n /** Размер спиннера\n * @default small */\n size?: SizeProp;\n\n /** Размер спиннера\n * @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу нового `SizeContext`. Они будут удалены в `7.0`.\n * @see {@link size} */\n type?: SpinnerType;\n\n /** Уменьшает размер индикатора для работы в строках. Если задан, то размер спиннера из `size` игнорируется\n * @default false */\n inline?: boolean;\n\n /** Толщина индикатора в пикселях.\n * @default 2 */\n width?: number;\n\n /** Цвет спиннера в одноцветном режиме. Альтернатива пропа `dimmed` */\n color?: React.CSSProperties['color'];\n\n /** Включает одноцветный режим, в котором цвет спиннера не переливается. Можно кастомизировать переменной `spinnerDimmedColor`\n * @default false */\n dimmed?: boolean;\n}\n\nexport const SpinnerDataTids = {\n root: 'Spinner__root',\n} as const;\n\n/** Зацикленный индикатор, не отображающий прогресс выполнения задачи */\n@withRenderEnvironment\n@rootNode\n@withSize\nexport class Spinner extends React.Component<SpinnerProps> {\n public static __KONTUR_REACT_UI__ = 'Spinner';\n public static displayName = 'Spinner';\n\n /** @deprecated Начиная с версии `6.1`, тип и проп устарели в пользу `SizeContext`. Они будут удалены в `7.0`. */\n public static Types: Record<SpinnerType, SpinnerType> = Object.assign({}, ...types.map((type) => ({ [type]: type })));\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n private size!: SizeProp;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const { caption = null, size, type, dimmed, inline } = this.props;\n const parsedSize = size || !type ? this.size : this.typeToSize(type);\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={SpinnerDataTids.root} className={this.styles.spinner()}>\n <span className={this.styles.inner()}>{this.renderSpinner(parsedSize, dimmed, inline)}</span>\n {caption && this.renderCaption(parsedSize, caption)}\n </div>\n </CommonWrapper>\n );\n }\n\n private renderSpinner = (size: SizeProp, dimmed?: boolean, inline?: boolean) => {\n return (\n <SpinnerIcon\n size={size}\n className={this.cx({\n [this.styles.circle(this.theme)]: !dimmed && !this.props.color,\n [this.styles.circleDimmedColor(this.theme)]: dimmed,\n [this.styles.circleWithoutColorAnimation()]: dimmed || !!this.props.color,\n })}\n width={this.props.width}\n color={this.props.color}\n inline={inline}\n />\n );\n };\n\n private renderCaption = (size: SizeProp, caption: React.ReactNode) => (\n <span className={this.cx(this.styles[size](this.theme), this.styles.captionColor(this.theme))}>{caption}</span>\n );\n\n private typeToSize = (type: SpinnerType) => {\n switch (type) {\n case 'mini':\n return 'small';\n case 'normal':\n return 'medium';\n case 'big':\n return 'large';\n }\n };\n}\n"]}
@@ -5,11 +5,8 @@ export declare const getStyles: import("../../lib/theming/Emotion.js").StylesGet
5
5
  circleWithoutColorAnimation(): string;
6
6
  captionColor(t: Theme): string;
7
7
  inline(): string;
8
- mini(t: Theme): string;
9
8
  small(t: Theme): string;
10
- normal(t: Theme): string;
11
9
  medium(t: Theme): string;
12
- big(t: Theme): string;
13
10
  large(t: Theme): string;
14
11
  spinner(): string;
15
12
  inner(): string;
@@ -22,31 +22,22 @@ export var getStyles = memoizeGetStyles(function (emotion) {
22
22
  inline: function () {
23
23
  return emotion.css(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n font-size: inherit;\n line-height: inherit;\n "], ["\n font-size: inherit;\n line-height: inherit;\n "])));
24
24
  },
25
- mini: function (t) {
26
- return emotion.css(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n margin-left: ", ";\n font-size: ", ";\n line-height: ", ";\n "], ["\n margin-left: ", ";\n font-size: ", ";\n line-height: ", ";\n "])), t.spinnerCaptionGapSmall, t.spinnerFontSizeSmall, t.spinnerLineHeightSmall);
27
- },
28
25
  small: function (t) {
29
- return emotion.css(templateObject_7 || (templateObject_7 = __makeTemplateObject(["\n margin: ", ";\n font-size: ", ";\n line-height: ", ";\n "], ["\n margin: ", ";\n font-size: ", ";\n line-height: ", ";\n "])), t.spinnerCaptionMarginSmall, t.spinnerFontSizeSmall, t.spinnerLineHeightSmall);
30
- },
31
- normal: function (t) {
32
- return emotion.css(templateObject_8 || (templateObject_8 = __makeTemplateObject(["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "], ["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "])), t.spinnerFontSizeMedium, t.spinnerLineHeightMedium, t.spinnerCaptionGapMedium);
26
+ return emotion.css(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n margin-left: ", ";\n font-size: ", ";\n line-height: ", ";\n "], ["\n margin-left: ", ";\n font-size: ", ";\n line-height: ", ";\n "])), t.spinnerCaptionGapSmall, t.spinnerFontSizeSmall, t.spinnerLineHeightSmall);
33
27
  },
34
28
  medium: function (t) {
35
- return emotion.css(templateObject_9 || (templateObject_9 = __makeTemplateObject(["\n margin: ", ";\n font-size: ", ";\n line-height: ", ";\n "], ["\n margin: ", ";\n font-size: ", ";\n line-height: ", ";\n "])), t.spinnerCaptionMarginMedium, t.spinnerFontSizeMedium, t.spinnerLineHeightMedium);
36
- },
37
- big: function (t) {
38
- return emotion.css(templateObject_10 || (templateObject_10 = __makeTemplateObject(["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "], ["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "])), t.spinnerFontSizeLarge, t.spinnerLineHeightLarge, t.spinnerCaptionGapLarge);
29
+ return emotion.css(templateObject_7 || (templateObject_7 = __makeTemplateObject(["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "], ["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "])), t.spinnerFontSizeMedium, t.spinnerLineHeightMedium, t.spinnerCaptionGapMedium);
39
30
  },
40
31
  large: function (t) {
41
- return emotion.css(templateObject_11 || (templateObject_11 = __makeTemplateObject(["\n font-size: ", ";\n line-height: ", ";\n margin: ", ";\n "], ["\n font-size: ", ";\n line-height: ", ";\n margin: ", ";\n "])), t.spinnerFontSizeLarge, t.spinnerLineHeightLarge, t.spinnerCaptionMarginLarge);
32
+ return emotion.css(templateObject_8 || (templateObject_8 = __makeTemplateObject(["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "], ["\n display: block;\n font-size: ", ";\n line-height: ", ";\n margin-top: ", ";\n "])), t.spinnerFontSizeLarge, t.spinnerLineHeightLarge, t.spinnerCaptionGapLarge);
42
33
  },
43
34
  spinner: function () {
44
- return emotion.css(templateObject_12 || (templateObject_12 = __makeTemplateObject(["\n display: inline-block;\n text-align: center;\n line-height: normal;\n "], ["\n display: inline-block;\n text-align: center;\n line-height: normal;\n "])));
35
+ return emotion.css(templateObject_9 || (templateObject_9 = __makeTemplateObject(["\n display: inline-block;\n text-align: center;\n line-height: normal;\n "], ["\n display: inline-block;\n text-align: center;\n line-height: normal;\n "])));
45
36
  },
46
37
  inner: function () {
47
- return emotion.css(templateObject_13 || (templateObject_13 = __makeTemplateObject(["\n display: inline-block;\n "], ["\n display: inline-block;\n "])));
38
+ return emotion.css(templateObject_10 || (templateObject_10 = __makeTemplateObject(["\n display: inline-block;\n "], ["\n display: inline-block;\n "])));
48
39
  },
49
40
  };
50
41
  });
51
- var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10, templateObject_11, templateObject_12, templateObject_13;
42
+ var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7, templateObject_8, templateObject_9, templateObject_10;
52
43
  //# sourceMappingURL=Spinner.styles.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Spinner.styles.js","sourceRoot":"","sources":["../../../components/Spinner/Spinner.styles.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { getAnimationKeyframes } from '../../lib/theming/AnimationKeyframes.js';\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles((emotion: Emotion) => {\n const AnimationKeyframes = getAnimationKeyframes(emotion);\n return {\n circle(t: Theme) {\n return emotion.css`\n stroke: ${t.spinnerColor};\n\n animation:\n ${AnimationKeyframes.spinnerCircleOffset()} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength()} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate()} 2s linear infinite,\n ${AnimationKeyframes.spinnerColor(t)} 6s ease-in-out infinite;\n `;\n },\n circleDimmedColor(t: Theme) {\n return emotion.css`\n stroke: ${t.spinnerDimmedColor};\n `;\n },\n circleWithoutColorAnimation() {\n return emotion.css`\n animation:\n ${AnimationKeyframes.spinnerCircleOffset()} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength()} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate()} 2s linear infinite;\n `;\n },\n\n captionColor(t: Theme) {\n return emotion.css`\n color: ${t.spinnerCaptionColor};\n `;\n },\n\n inline() {\n return emotion.css`\n font-size: inherit;\n line-height: inherit;\n `;\n },\n\n mini(t: Theme) {\n return emotion.css`\n margin-left: ${t.spinnerCaptionGapSmall};\n font-size: ${t.spinnerFontSizeSmall};\n line-height: ${t.spinnerLineHeightSmall};\n `;\n },\n\n small(t: Theme) {\n return emotion.css`\n margin: ${t.spinnerCaptionMarginSmall};\n font-size: ${t.spinnerFontSizeSmall};\n line-height: ${t.spinnerLineHeightSmall};\n `;\n },\n\n normal(t: Theme) {\n return emotion.css`\n display: block;\n font-size: ${t.spinnerFontSizeMedium};\n line-height: ${t.spinnerLineHeightMedium};\n margin-top: ${t.spinnerCaptionGapMedium};\n `;\n },\n\n medium(t: Theme) {\n return emotion.css`\n margin: ${t.spinnerCaptionMarginMedium};\n font-size: ${t.spinnerFontSizeMedium};\n line-height: ${t.spinnerLineHeightMedium};\n `;\n },\n\n big(t: Theme) {\n return emotion.css`\n display: block;\n font-size: ${t.spinnerFontSizeLarge};\n line-height: ${t.spinnerLineHeightLarge};\n margin-top: ${t.spinnerCaptionGapLarge};\n `;\n },\n\n large(t: Theme) {\n return emotion.css`\n font-size: ${t.spinnerFontSizeLarge};\n line-height: ${t.spinnerLineHeightLarge};\n margin: ${t.spinnerCaptionMarginLarge};\n `;\n },\n\n spinner() {\n return emotion.css`\n display: inline-block;\n text-align: center;\n line-height: normal;\n `;\n },\n\n inner() {\n return emotion.css`\n display: inline-block;\n `;\n },\n };\n});\n"]}
1
+ {"version":3,"file":"Spinner.styles.js","sourceRoot":"","sources":["Spinner.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,OAAgB;IACzD,IAAM,kBAAkB,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC1D,OAAO;QACL,MAAM,YAAC,CAAQ;YACb,OAAO,OAAO,CAAC,GAAG,2TAAA,oBACN,EAAc,iCAGtB,EAAwC,0DACxC,EAAwC,8DACxC,EAAwC,gCACxC,EAAkC,iCACvC,KAPa,CAAC,CAAC,YAAY,EAGtB,kBAAkB,CAAC,mBAAmB,EAAE,EACxC,kBAAkB,CAAC,mBAAmB,EAAE,EACxC,kBAAkB,CAAC,mBAAmB,EAAE,EACxC,kBAAkB,CAAC,YAAY,CAAC,CAAC,CAAC,EACtC;QACF,CAAC;QACD,iBAAiB,YAAC,CAAQ;YACxB,OAAO,OAAO,CAAC,GAAG,oGAAA,oBACN,EAAoB,WAC/B,KADW,CAAC,CAAC,kBAAkB,EAC9B;QACJ,CAAC;QACD,2BAA2B;YACzB,OAAO,OAAO,CAAC,GAAG,qQAAA,kCAEZ,EAAwC,4DACxC,EAAwC,gEACxC,EAAwC,8BAC7C,KAHK,kBAAkB,CAAC,mBAAmB,EAAE,EACxC,kBAAkB,CAAC,mBAAmB,EAAE,EACxC,kBAAkB,CAAC,mBAAmB,EAAE,EAC5C;QACJ,CAAC;QAED,YAAY,YAAC,CAAQ;YACnB,OAAO,OAAO,CAAC,GAAG,mGAAA,mBACP,EAAqB,WAC/B,KADU,CAAC,CAAC,mBAAmB,EAC9B;QACJ,CAAC;QAED,MAAM;YACJ,OAAO,OAAO,CAAC,GAAG,yIAAA,sEAGjB,KAAC;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,OAAO,CAAC,GAAG,+JAAA,yBACD,EAAwB,wBAC1B,EAAsB,0BACpB,EAAwB,WACxC,KAHgB,CAAC,CAAC,sBAAsB,EAC1B,CAAC,CAAC,oBAAoB,EACpB,CAAC,CAAC,sBAAsB,EACvC;QACJ,CAAC;QAED,MAAM,YAAC,CAAQ;YACb,OAAO,OAAO,CAAC,GAAG,uLAAA,gDAEH,EAAuB,0BACrB,EAAyB,yBAC1B,EAAyB,WACxC,KAHc,CAAC,CAAC,qBAAqB,EACrB,CAAC,CAAC,uBAAuB,EAC1B,CAAC,CAAC,uBAAuB,EACvC;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,OAAO,CAAC,GAAG,uLAAA,gDAEH,EAAsB,0BACpB,EAAwB,yBACzB,EAAwB,WACvC,KAHc,CAAC,CAAC,oBAAoB,EACpB,CAAC,CAAC,sBAAsB,EACzB,CAAC,CAAC,sBAAsB,EACtC;QACJ,CAAC;QAED,OAAO;YACL,OAAO,OAAO,CAAC,GAAG,wKAAA,qGAIjB,KAAC;QACJ,CAAC;QAED,KAAK;YACH,OAAO,OAAO,CAAC,GAAG,+GAAA,0CAEjB,KAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { getAnimationKeyframes } from '../../lib/theming/AnimationKeyframes.js';\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles((emotion: Emotion) => {\n const AnimationKeyframes = getAnimationKeyframes(emotion);\n return {\n circle(t: Theme) {\n return emotion.css`\n stroke: ${t.spinnerColor};\n\n animation:\n ${AnimationKeyframes.spinnerCircleOffset()} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength()} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate()} 2s linear infinite,\n ${AnimationKeyframes.spinnerColor(t)} 6s ease-in-out infinite;\n `;\n },\n circleDimmedColor(t: Theme) {\n return emotion.css`\n stroke: ${t.spinnerDimmedColor};\n `;\n },\n circleWithoutColorAnimation() {\n return emotion.css`\n animation:\n ${AnimationKeyframes.spinnerCircleOffset()} 1s cubic-bezier(0.5, 0.2, 0.5, 0.8) infinite,\n ${AnimationKeyframes.spinnerCircleLength()} 2s cubic-bezier(0.36, 0.14, 0.38, 0.69) infinite,\n ${AnimationKeyframes.spinnerCircleRotate()} 2s linear infinite;\n `;\n },\n\n captionColor(t: Theme) {\n return emotion.css`\n color: ${t.spinnerCaptionColor};\n `;\n },\n\n inline() {\n return emotion.css`\n font-size: inherit;\n line-height: inherit;\n `;\n },\n\n small(t: Theme) {\n return emotion.css`\n margin-left: ${t.spinnerCaptionGapSmall};\n font-size: ${t.spinnerFontSizeSmall};\n line-height: ${t.spinnerLineHeightSmall};\n `;\n },\n\n medium(t: Theme) {\n return emotion.css`\n display: block;\n font-size: ${t.spinnerFontSizeMedium};\n line-height: ${t.spinnerLineHeightMedium};\n margin-top: ${t.spinnerCaptionGapMedium};\n `;\n },\n\n large(t: Theme) {\n return emotion.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 emotion.css`\n display: inline-block;\n text-align: center;\n line-height: normal;\n `;\n },\n\n inner() {\n return emotion.css`\n display: inline-block;\n `;\n },\n };\n});\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/Spinner/index.tsx"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC","sourcesContent":["export * from './Spinner.js';\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC","sourcesContent":["export * from './Spinner.js';\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Sticky.js","sourceRoot":"","sources":["../../../components/Sticky/Sticky.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport React from 'react';\nimport shallowEqual from 'shallowequal';\nimport warning from 'warning';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { ZIndex } from '../../internal/ZIndex/index.js';\nimport { createPropsGetter } from '../../lib/createPropsGetter.js';\nimport { getDOMRect } from '../../lib/dom/getDOMRect.js';\nimport type { GlobalObject } from '../../lib/globalObject.js';\nimport * as LayoutEvents from '../../lib/LayoutEvents.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport { isFunction } from '../../lib/utils.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { getStyles } from './Sticky.styles.js';\n\nconst MAX_REFLOW_RETRIES = 5;\n\nexport interface StickyProps extends Omit<CommonProps, 'children'> {\n /** Край, к которому будет закреплен элемент. */\n side: 'top' | 'bottom';\n\n /** Отступ от края экрана в пикселях, на который сдвигается элемент в закреплённом состоянии.\n * @default 0 */\n offset?: number;\n\n /** Задаёт функцию, которая возвращает DOM-элемент, который нельзя пересекать. */\n getStop?: () => Nullable<HTMLElement>;\n\n /** @ignore */\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 const StickyDataTids = {\n root: 'Sticky__root',\n} as const;\n\ntype DefaultProps = Required<Pick<StickyProps, 'offset'>>;\n\n/**\n * `Sticky` позволяет закреплять элемент интерфейса в определенной позиции на экране при прокрутке страницы.\n * Это полезно для создания «прилипающих» элементов, которые должны оставаться видимыми при прокрутке содержимого.\n */\n@withRenderEnvironment\n@rootNode\nexport class Sticky extends React.Component<StickyProps, StickyState> {\n public static __KONTUR_REACT_UI__ = 'Sticky';\n public static displayName = 'Sticky';\n\n public static defaultProps: DefaultProps = { offset: 0 };\n\n private getProps = createPropsGetter(Sticky.defaultProps);\n\n public state: StickyState = {\n fixed: false,\n deltaHeight: 0,\n stopped: false,\n relativeTop: 0,\n };\n\n private globalObject!: GlobalObject;\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private wrapper: Nullable<HTMLElement>;\n private inner: Nullable<HTMLElement>;\n private layoutSubscription: { remove: Nullable<() => void> } = { remove: null };\n private reflowCounter = 0;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n this.reflow();\n\n this.layoutSubscription = LayoutEvents.addListener(this.reflow, this.globalObject);\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 this.reflow();\n this.reflowCounter += 1;\n return;\n }\n }\n this.reflowCounter = 0;\n }\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n return this.renderMain();\n }\n\n private renderMain() {\n let { children } = this.props;\n const { side } = this.props;\n const offset = this.getProps().offset;\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 rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={StickyDataTids.root} ref={this.refWrapper} className={this.styles.wrapper()}>\n <ZIndex\n priority=\"Sticky\"\n applyZIndex={fixed}\n className={this.cx(this.styles.inner(), {\n [this.styles.fixed()]: fixed && !stopped,\n [this.styles.stopped()]: stopped,\n })}\n style={innerStyle}\n wrapperRef={this.refInner}\n >\n <div className={this.styles.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>) => {\n this.wrapper = ref;\n };\n\n private refInner = (ref: Nullable<HTMLElement>) => {\n this.inner = ref;\n };\n\n /**\n * Пересчитать габариты и позицию залипшего элемента\n *\n * @public\n */\n public reflow = (): void => {\n if (!this.globalObject.document?.documentElement) {\n warning(false, 'There is no \"documentElement\" in document');\n return;\n }\n\n const windowHeight = this.globalObject.innerHeight || this.globalObject.document.documentElement.clientHeight;\n if (!this.wrapper || !this.inner) {\n return;\n }\n const { top, bottom, left, width } = getDOMRect(this.wrapper);\n const { height } = getDOMRect(this.inner);\n const { getStop, side } = this.props;\n const { fixed: prevFixed, height: prevHeight = height } = this.state;\n const offset = this.getProps().offset;\n const fixed = side === 'top' ? Math.ceil(top) < offset : Math.floor(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 this.setState({ width });\n const stop = getStop && getStop();\n if (stop) {\n const deltaHeight = prevHeight - height;\n const stopRect = getDOMRect(stop);\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"]}
1
+ {"version":3,"file":"Sticky.js","sourceRoot":"","sources":["Sticky.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport React from 'react';\nimport shallowEqual from 'shallowequal';\nimport warning from 'warning';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { ZIndex } from '../../internal/ZIndex/index.js';\nimport { createPropsGetter } from '../../lib/createPropsGetter.js';\nimport { getDOMRect } from '../../lib/dom/getDOMRect.js';\nimport type { GlobalObject } from '../../lib/globalObject.js';\nimport * as LayoutEvents from '../../lib/LayoutEvents.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport { isFunction } from '../../lib/utils.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { getStyles } from './Sticky.styles.js';\n\nconst MAX_REFLOW_RETRIES = 5;\n\nexport interface StickyProps extends Omit<CommonProps, 'children'> {\n /** Край, к которому будет закреплен элемент. */\n side: 'top' | 'bottom';\n\n /** Отступ от края экрана в пикселях, на который сдвигается элемент в закреплённом состоянии.\n * @default 0 */\n offset?: number;\n\n /** Задаёт функцию, которая возвращает DOM-элемент, который нельзя пересекать. */\n getStop?: () => Nullable<HTMLElement>;\n\n /** @ignore */\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 const StickyDataTids = {\n root: 'Sticky__root',\n} as const;\n\ntype DefaultProps = Required<Pick<StickyProps, 'offset'>>;\n\n/**\n * `Sticky` позволяет закреплять элемент интерфейса в определенной позиции на экране при прокрутке страницы.\n * Это полезно для создания «прилипающих» элементов, которые должны оставаться видимыми при прокрутке содержимого.\n */\n@withRenderEnvironment\n@rootNode\nexport class Sticky extends React.Component<StickyProps, StickyState> {\n public static __KONTUR_REACT_UI__ = 'Sticky';\n public static displayName = 'Sticky';\n\n public static defaultProps: DefaultProps = { offset: 0 };\n\n private getProps = createPropsGetter(Sticky.defaultProps);\n\n public state: StickyState = {\n fixed: false,\n deltaHeight: 0,\n stopped: false,\n relativeTop: 0,\n };\n\n private globalObject!: GlobalObject;\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private wrapper: Nullable<HTMLElement>;\n private inner: Nullable<HTMLElement>;\n private layoutSubscription: { remove: Nullable<() => void> } = { remove: null };\n private reflowCounter = 0;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n this.reflow();\n\n this.layoutSubscription = LayoutEvents.addListener(this.reflow, this.globalObject);\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 this.reflow();\n this.reflowCounter += 1;\n return;\n }\n }\n this.reflowCounter = 0;\n }\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n return this.renderMain();\n }\n\n private renderMain() {\n let { children } = this.props;\n const { side } = this.props;\n const offset = this.getProps().offset;\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 rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={StickyDataTids.root} ref={this.refWrapper} className={this.styles.wrapper()}>\n <ZIndex\n priority=\"Sticky\"\n applyZIndex={fixed}\n className={this.cx(this.styles.inner(), {\n [this.styles.fixed()]: fixed && !stopped,\n [this.styles.stopped()]: stopped,\n })}\n style={innerStyle}\n wrapperRef={this.refInner}\n >\n <div className={this.styles.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>) => {\n this.wrapper = ref;\n };\n\n private refInner = (ref: Nullable<HTMLElement>) => {\n this.inner = ref;\n };\n\n /**\n * Пересчитать габариты и позицию залипшего элемента\n *\n * @public\n */\n public reflow = (): void => {\n if (!this.globalObject.document?.documentElement) {\n warning(false, 'There is no \"documentElement\" in document');\n return;\n }\n\n const windowHeight = this.globalObject.innerHeight || this.globalObject.document.documentElement.clientHeight;\n if (!this.wrapper || !this.inner) {\n return;\n }\n const { top, bottom, left, width } = getDOMRect(this.wrapper);\n const { height } = getDOMRect(this.inner);\n const { getStop, side } = this.props;\n const { fixed: prevFixed, height: prevHeight = height } = this.state;\n const offset = this.getProps().offset;\n const fixed = side === 'top' ? Math.ceil(top) < offset : Math.floor(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 this.setState({ width });\n const stop = getStop && getStop();\n if (stop) {\n const deltaHeight = prevHeight - height;\n const stopRect = getDOMRect(stop);\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"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Sticky.styles.js","sourceRoot":"","sources":["../../../components/Sticky/Sticky.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,OAAO;YACL,OAAO,GAAG,iGAAA,8BAET,KAAC;QACJ,CAAC;QACD,KAAK;YACH,OAAO,GAAG,qHAAA,kDAGT,KAAC;QACJ,CAAC;QAED,KAAK;YACH,OAAO,GAAG,mGAAA,gCAET,KAAC;QACJ,CAAC;QAED,OAAO;YACL,OAAO,GAAG,sGAAA,mCAET,KAAC;QACJ,CAAC;QAED,SAAS;YACP,OAAO,GAAG,kHAAA,+CAGT,KAAC;QACJ,CAAC;KACF,CAAC;AA/B8D,CA+B9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\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"]}
1
+ {"version":3,"file":"Sticky.styles.js","sourceRoot":"","sources":["Sticky.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,OAAO;YACL,OAAO,GAAG,iGAAA,8BAET,KAAC;QACJ,CAAC;QACD,KAAK;YACH,OAAO,GAAG,qHAAA,kDAGT,KAAC;QACJ,CAAC;QAED,KAAK;YACH,OAAO,GAAG,mGAAA,gCAET,KAAC;QACJ,CAAC;QAED,OAAO;YACL,OAAO,GAAG,sGAAA,mCAET,KAAC;QACJ,CAAC;QAED,SAAS;YACP,OAAO,GAAG,kHAAA,+CAGT,KAAC;QACJ,CAAC;KACF,CAAC;AA/B8D,CA+B9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\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"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/Sticky/index.tsx"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC","sourcesContent":["export * from './Sticky.js';\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC","sourcesContent":["export * from './Sticky.js';\n"]}
@@ -137,6 +137,7 @@ var Switcher = /** @class */ (function (_super) {
137
137
  var _a = _this._extractPropsFromItem(item), ariaLabel = _a["aria-label"], label = _a.label, itemValue = _a.value, customButtonProps = _a.buttonProps;
138
138
  var isChecked = value === itemValue;
139
139
  var commonButtonProps = {
140
+ use: 'default',
140
141
  'aria-checked': isChecked,
141
142
  role: role,
142
143
  checked: isChecked,
@@ -1 +1 @@
1
- {"version":3,"file":"Switcher.js","sourceRoot":"","sources":["../../../components/Switcher/Switcher.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport type { HTMLAttributes } from 'react';\nimport React from 'react';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { isKeyArrowHorizontal, isKeyArrowLeft, isKeyEnter } from '../../lib/events/keyboard/identifiers.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport type { SizeProp } from '../../lib/types/props.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { Button } from '../Button/index.js';\nimport type { ButtonProps } from '../Button/index.js';\nimport { Group, getButtonCorners } from '../Group/index.js';\nimport { mod } from './helpers.js';\nimport { getStyles } from './Switcher.styles.js';\nimport { getSwitcherTheme } from './switcherTheme.js';\n\nexport type SwitcherItems = string | SwitcherItem;\n\nexport const SwitcherDataTids = {\n root: 'Switcher__root',\n} as const;\n\nexport interface SwitcherProps extends Pick<HTMLAttributes<unknown>, 'role'>, CommonProps {\n /** Задает список элементов в свитчере. Это массив строк или объектов типа `{ label: string, value: string, buttonProps?: Partial<ButtonProps> }` */\n items: SwitcherItems[];\n\n /** Значение свитчера. */\n value?: string;\n\n /** Событие изменения значения свитчера (value). */\n onValueChange?: (value: string) => void;\n\n /** Подпись около свитчера. */\n caption?: string;\n\n /** Переводит свитчер в состояние ошибки. */\n error?: boolean;\n\n /** Размер свитчера. */\n size?: SizeProp;\n\n /** Ширина свитчера. С этим пропом элементы внутри автоматически равномерно растянутся. */\n width?: React.CSSProperties['width'];\n\n /** Блокирует свитчер. */\n disabled?: boolean;\n\n /** Задает функцию отрисовки элемента. Параметр `renderDefault` - это встроенная дефолтная функция отрисовки элемента, которую можно вызывать в `renderItem`. */\n renderItem?: (\n label: string,\n value: string,\n buttonProps: ButtonProps,\n renderDefault: () => React.ReactNode,\n ariaLabel?: string,\n ) => React.ReactNode;\n}\n\ntype DefaultProps = Required<Pick<SwitcherProps, 'role'>>;\n\nexport interface SwitcherState {\n focusedIndex: Nullable<number>;\n}\n\ninterface SwitcherItem {\n value: string;\n label: string;\n 'aria-label'?: string;\n buttonProps?: Partial<ButtonProps>;\n}\n\n/**\n * Переключатель — это замена группе радиокнопок. Переключатель меньше по высоте, это позволяет делать формы компактнее.\n */\n@withRenderEnvironment\n@rootNode\nexport class Switcher extends React.Component<SwitcherProps, SwitcherState> {\n public static __KONTUR_REACT_UI__ = 'Switcher';\n public static displayName = 'Switcher';\n\n public static defaultProps: DefaultProps = {\n role: 'switch',\n };\n\n public state: SwitcherState = {\n focusedIndex: null,\n };\n\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\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 inputProps = {\n type: 'checkbox',\n onKeyDown: this.handleKey,\n onFocus: this._handleFocus,\n onBlur: this._handleBlur,\n className: this.styles.input(),\n };\n const items = <Group width={'100%'}>{this._renderItems()}</Group>;\n\n const captionClassName = this.cx(this.styles.caption(this.theme), this.getLabelSizeClassName());\n const wrapperClassName = this.cx(this.styles.wrap(), {\n [this.styles.error(this.theme)]: this.props.error,\n [this.styles.wrapCustomWidth()]: this.props.width !== undefined,\n });\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={SwitcherDataTids.root} className={this.styles.root()} style={{ width: this.props.width }}>\n {this.props.caption ? <div className={captionClassName}>{this.props.caption}</div> : null}\n <div className={wrapperClassName}>\n <input {...inputProps} />\n {items}\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 _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, buttonProps } = this._extractPropsFromItem(this.props.items[focusedIndex]);\n if (!buttonProps?.disabled) {\n this.selectItem(value);\n }\n }\n return;\n }\n\n if (isKeyArrowHorizontal(e)) {\n e.preventDefault();\n this.move(isKeyArrowLeft(e));\n }\n };\n\n private move = (left: boolean) => {\n const selectedIndex = this.state.focusedIndex;\n\n if (typeof selectedIndex !== 'number') {\n return;\n }\n const newFocusedIndex = this._getNextFocusedIndex(left, selectedIndex);\n this._focus(newFocusedIndex);\n };\n\n private _getNextFocusedIndex = (left: boolean, focusedIndex: number): number => {\n const { items, disabled } = this.props;\n if (disabled) {\n return focusedIndex;\n }\n\n for (let i = 1; i < items.length; i++) {\n const index = mod(focusedIndex + (left ? -i : i), items.length);\n const { buttonProps } = this._extractPropsFromItem(items[index]);\n if (!buttonProps?.disabled) {\n return index;\n }\n }\n return focusedIndex;\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 const { items, value, size, width, disabled, role, renderItem } = this.props;\n\n return items.map((item, i) => {\n const {\n 'aria-label': ariaLabel,\n label,\n value: itemValue,\n buttonProps: customButtonProps,\n } = this._extractPropsFromItem(item);\n\n const isChecked = value === itemValue;\n const commonButtonProps = {\n 'aria-checked': isChecked,\n role,\n checked: isChecked,\n visuallyFocused: this.state.focusedIndex === i,\n onClick: () => {\n this.selectItem(itemValue);\n },\n disableFocus: true,\n size,\n disabled,\n corners: getButtonCorners(i === 0, i === items.length - 1),\n };\n\n const buttonProps = {\n ...commonButtonProps,\n ...customButtonProps,\n };\n\n if (!buttonProps.width && width) {\n buttonProps.width = '100%';\n }\n\n const renderDefault = () => this.renderDefaultItem(label, itemValue, buttonProps, ariaLabel);\n return renderItem ? renderItem(label, itemValue, buttonProps, renderDefault, ariaLabel) : renderDefault();\n });\n };\n\n private renderDefaultItem = (label: string, value: string, buttonProps: ButtonProps, ariaLabel?: string) => (\n <Button aria-label={ariaLabel} key={value} {...buttonProps}>\n {label}\n </Button>\n );\n\n private getLabelSizeClassName = (): string => {\n switch (this.props.size) {\n case 'large':\n return this.styles.captionLarge(this.theme);\n case 'medium':\n return this.styles.captionMedium(this.theme);\n case 'small':\n default:\n return this.styles.captionSmall(this.theme);\n }\n };\n}\n"]}
1
+ {"version":3,"file":"Switcher.js","sourceRoot":"","sources":["Switcher.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport type { HTMLAttributes } from 'react';\nimport React from 'react';\n\nimport type { CommonProps } from '../../internal/CommonWrapper/index.js';\nimport { CommonWrapper } from '../../internal/CommonWrapper/index.js';\nimport { isKeyArrowHorizontal, isKeyArrowLeft, isKeyEnter } from '../../lib/events/keyboard/identifiers.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { rootNode } from '../../lib/rootNode/index.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport type { SizeProp } from '../../lib/types/props.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { Button } from '../Button/index.js';\nimport type { ButtonProps } from '../Button/index.js';\nimport { Group, getButtonCorners } from '../Group/index.js';\nimport { mod } from './helpers.js';\nimport { getStyles } from './Switcher.styles.js';\nimport { getSwitcherTheme } from './switcherTheme.js';\n\nexport type SwitcherItems = string | SwitcherItem;\n\nexport const SwitcherDataTids = {\n root: 'Switcher__root',\n} as const;\n\nexport interface SwitcherProps extends Pick<HTMLAttributes<unknown>, 'role'>, CommonProps {\n /** Задает список элементов в свитчере. Это массив строк или объектов типа `{ label: string, value: string, buttonProps?: Partial<ButtonProps> }` */\n items: SwitcherItems[];\n\n /** Значение свитчера. */\n value?: string;\n\n /** Событие изменения значения свитчера (value). */\n onValueChange?: (value: string) => void;\n\n /** Подпись около свитчера. */\n caption?: string;\n\n /** Переводит свитчер в состояние ошибки. */\n error?: boolean;\n\n /** Размер свитчера. */\n size?: SizeProp;\n\n /** Ширина свитчера. С этим пропом элементы внутри автоматически равномерно растянутся. */\n width?: React.CSSProperties['width'];\n\n /** Блокирует свитчер. */\n disabled?: boolean;\n\n /** Задает функцию отрисовки элемента. Параметр `renderDefault` - это встроенная дефолтная функция отрисовки элемента, которую можно вызывать в `renderItem`. */\n renderItem?: (\n label: string,\n value: string,\n buttonProps: ButtonProps,\n renderDefault: () => React.ReactNode,\n ariaLabel?: string,\n ) => React.ReactNode;\n}\n\ntype DefaultProps = Required<Pick<SwitcherProps, 'role'>>;\n\nexport interface SwitcherState {\n focusedIndex: Nullable<number>;\n}\n\ninterface SwitcherItem {\n value: string;\n label: string;\n 'aria-label'?: string;\n buttonProps?: Partial<ButtonProps>;\n}\n\n/**\n * Переключатель — это замена группе радиокнопок. Переключатель меньше по высоте, это позволяет делать формы компактнее.\n */\n@withRenderEnvironment\n@rootNode\nexport class Switcher extends React.Component<SwitcherProps, SwitcherState> {\n public static __KONTUR_REACT_UI__ = 'Switcher';\n public static displayName = 'Switcher';\n\n public static defaultProps: DefaultProps = {\n role: 'switch',\n };\n\n public state: SwitcherState = {\n focusedIndex: null,\n };\n\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\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 inputProps = {\n type: 'checkbox',\n onKeyDown: this.handleKey,\n onFocus: this._handleFocus,\n onBlur: this._handleBlur,\n className: this.styles.input(),\n };\n const items = <Group width={'100%'}>{this._renderItems()}</Group>;\n\n const captionClassName = this.cx(this.styles.caption(this.theme), this.getLabelSizeClassName());\n const wrapperClassName = this.cx(this.styles.wrap(), {\n [this.styles.error(this.theme)]: this.props.error,\n [this.styles.wrapCustomWidth()]: this.props.width !== undefined,\n });\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <div data-tid={SwitcherDataTids.root} className={this.styles.root()} style={{ width: this.props.width }}>\n {this.props.caption ? <div className={captionClassName}>{this.props.caption}</div> : null}\n <div className={wrapperClassName}>\n <input {...inputProps} />\n {items}\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 _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, buttonProps } = this._extractPropsFromItem(this.props.items[focusedIndex]);\n if (!buttonProps?.disabled) {\n this.selectItem(value);\n }\n }\n return;\n }\n\n if (isKeyArrowHorizontal(e)) {\n e.preventDefault();\n this.move(isKeyArrowLeft(e));\n }\n };\n\n private move = (left: boolean) => {\n const selectedIndex = this.state.focusedIndex;\n\n if (typeof selectedIndex !== 'number') {\n return;\n }\n const newFocusedIndex = this._getNextFocusedIndex(left, selectedIndex);\n this._focus(newFocusedIndex);\n };\n\n private _getNextFocusedIndex = (left: boolean, focusedIndex: number): number => {\n const { items, disabled } = this.props;\n if (disabled) {\n return focusedIndex;\n }\n\n for (let i = 1; i < items.length; i++) {\n const index = mod(focusedIndex + (left ? -i : i), items.length);\n const { buttonProps } = this._extractPropsFromItem(items[index]);\n if (!buttonProps?.disabled) {\n return index;\n }\n }\n return focusedIndex;\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 const { items, value, size, width, disabled, role, renderItem } = this.props;\n\n return items.map((item, i) => {\n const {\n 'aria-label': ariaLabel,\n label,\n value: itemValue,\n buttonProps: customButtonProps,\n } = this._extractPropsFromItem(item);\n\n const isChecked = value === itemValue;\n const commonButtonProps = {\n use: 'default',\n 'aria-checked': isChecked,\n role,\n checked: isChecked,\n visuallyFocused: this.state.focusedIndex === i,\n onClick: () => {\n this.selectItem(itemValue);\n },\n disableFocus: true,\n size,\n disabled,\n corners: getButtonCorners(i === 0, i === items.length - 1),\n } satisfies ButtonProps;\n\n const buttonProps = {\n ...commonButtonProps,\n ...customButtonProps,\n };\n\n if (!buttonProps.width && width) {\n buttonProps.width = '100%';\n }\n\n const renderDefault = () => this.renderDefaultItem(label, itemValue, buttonProps, ariaLabel);\n return renderItem ? renderItem(label, itemValue, buttonProps, renderDefault, ariaLabel) : renderDefault();\n });\n };\n\n private renderDefaultItem = (label: string, value: string, buttonProps: ButtonProps, ariaLabel?: string) => (\n <Button aria-label={ariaLabel} key={value} {...buttonProps}>\n {label}\n </Button>\n );\n\n private getLabelSizeClassName = (): string => {\n switch (this.props.size) {\n case 'large':\n return this.styles.captionLarge(this.theme);\n case 'medium':\n return this.styles.captionMedium(this.theme);\n case 'small':\n default:\n return this.styles.captionSmall(this.theme);\n }\n };\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Switcher.styles.js","sourceRoot":"","sources":["../../../components/Switcher/Switcher.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,IAAI;YACF,OAAO,GAAG,yJAAA,sFAIT,KAAC;QACJ,CAAC;QAED,IAAI;YACF,OAAO,GAAG,wIAAA,qEAGT,KAAC;QACJ,CAAC;QAED,eAAe;YACb,OAAO,GAAG,gGAAA,6BAET,KAAC;QACJ,CAAC;QAED,KAAK;YACH,OAAO,GAAG,4JAAA,yFAKT,KAAC;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,4JAAA,iBACC,EAAmB,sEAG7B,KAHU,CAAC,CAAC,iBAAiB,EAG5B;QACJ,CAAC;QAED,YAAY,YAAC,CAAQ;YACnB,OAAO,GAAG,wJAAA,wBACQ,EAAyB,sBAC5B,EAA8B,wBAC5B,EAAgC,SAChD,KAHiB,CAAC,CAAC,uBAAuB,EAC5B,CAAC,CAAC,4BAA4B,EAC5B,CAAC,CAAC,8BAA8B,EAC/C;QACJ,CAAC;QAED,aAAa,YAAC,CAAQ;YACpB,OAAO,GAAG,wJAAA,wBACQ,EAA0B,sBAC7B,EAA+B,wBAC7B,EAAiC,SACjD,KAHiB,CAAC,CAAC,wBAAwB,EAC7B,CAAC,CAAC,6BAA6B,EAC7B,CAAC,CAAC,+BAA+B,EAChD;QACJ,CAAC;QAED,YAAY,YAAC,CAAQ;YACnB,OAAO,GAAG,wJAAA,wBACQ,EAAyB,sBAC5B,EAA8B,wBAC5B,EAAgC,SAChD,KAHiB,CAAC,CAAC,uBAAuB,EAC5B,CAAC,CAAC,4BAA4B,EAC5B,CAAC,CAAC,8BAA8B,EAC/C;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,GAAG,gYAAA,mQAYW,EAAsB,+BACnB,EAAsB,GAAI,EAAkB,kBAEnE,KAHoB,CAAC,CAAC,oBAAoB,EACnB,CAAC,CAAC,oBAAoB,EAAI,CAAC,CAAC,gBAAgB,EAElE;QACJ,CAAC;KACF,CAAC;AAjF8D,CAiF9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\n root() {\n return css`\n display: flex;\n align-items: center;\n line-height: normal;\n `;\n },\n\n wrap() {\n return css`\n display: inline-block;\n vertical-align: middle;\n `;\n },\n\n wrapCustomWidth() {\n return css`\n flex-grow: 1;\n `;\n },\n\n input() {\n return css`\n height: 0;\n opacity: 0;\n position: absolute;\n width: 0;\n `;\n },\n\n caption(t: Theme) {\n return css`\n color: ${t.switcherTextColor};\n vertical-align: middle;\n display: inline-block;\n `;\n },\n\n captionSmall(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapSmall};\n font-size: ${t.switcherCaptionFontSizeSmall};\n line-height: ${t.switcherCaptionLineHeightSmall};\n `;\n },\n\n captionMedium(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapMedium};\n font-size: ${t.switcherCaptionFontSizeMedium};\n line-height: ${t.switcherCaptionLineHeightMedium};\n `;\n },\n\n captionLarge(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapLarge};\n font-size: ${t.switcherCaptionFontSizeLarge};\n line-height: ${t.switcherCaptionLineHeightLarge};\n `;\n },\n\n error(t: Theme) {\n return css`\n position: relative;\n\n &:before {\n content: '';\n position: absolute;\n pointer-events: none;\n top: 1px;\n right: 1px;\n bottom: 1px;\n left: 1px;\n z-index: 1;\n border-radius: ${t.switcherBorderRadius};\n box-shadow: 0 0 0 ${t.switcherOutlineWidth} ${t.borderColorError};\n }\n `;\n },\n}));\n"]}
1
+ {"version":3,"file":"Switcher.styles.js","sourceRoot":"","sources":["Switcher.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,IAAI;YACF,OAAO,GAAG,yJAAA,sFAIT,KAAC;QACJ,CAAC;QAED,IAAI;YACF,OAAO,GAAG,wIAAA,qEAGT,KAAC;QACJ,CAAC;QAED,eAAe;YACb,OAAO,GAAG,gGAAA,6BAET,KAAC;QACJ,CAAC;QAED,KAAK;YACH,OAAO,GAAG,4JAAA,yFAKT,KAAC;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,4JAAA,iBACC,EAAmB,sEAG7B,KAHU,CAAC,CAAC,iBAAiB,EAG5B;QACJ,CAAC;QAED,YAAY,YAAC,CAAQ;YACnB,OAAO,GAAG,wJAAA,wBACQ,EAAyB,sBAC5B,EAA8B,wBAC5B,EAAgC,SAChD,KAHiB,CAAC,CAAC,uBAAuB,EAC5B,CAAC,CAAC,4BAA4B,EAC5B,CAAC,CAAC,8BAA8B,EAC/C;QACJ,CAAC;QAED,aAAa,YAAC,CAAQ;YACpB,OAAO,GAAG,wJAAA,wBACQ,EAA0B,sBAC7B,EAA+B,wBAC7B,EAAiC,SACjD,KAHiB,CAAC,CAAC,wBAAwB,EAC7B,CAAC,CAAC,6BAA6B,EAC7B,CAAC,CAAC,+BAA+B,EAChD;QACJ,CAAC;QAED,YAAY,YAAC,CAAQ;YACnB,OAAO,GAAG,wJAAA,wBACQ,EAAyB,sBAC5B,EAA8B,wBAC5B,EAAgC,SAChD,KAHiB,CAAC,CAAC,uBAAuB,EAC5B,CAAC,CAAC,4BAA4B,EAC5B,CAAC,CAAC,8BAA8B,EAC/C;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,GAAG,gYAAA,mQAYW,EAAsB,+BACnB,EAAsB,GAAI,EAAkB,kBAEnE,KAHoB,CAAC,CAAC,oBAAoB,EACnB,CAAC,CAAC,oBAAoB,EAAI,CAAC,CAAC,gBAAgB,EAElE;QACJ,CAAC;KACF,CAAC;AAjF8D,CAiF9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\n root() {\n return css`\n display: flex;\n align-items: center;\n line-height: normal;\n `;\n },\n\n wrap() {\n return css`\n display: inline-block;\n vertical-align: middle;\n `;\n },\n\n wrapCustomWidth() {\n return css`\n flex-grow: 1;\n `;\n },\n\n input() {\n return css`\n height: 0;\n opacity: 0;\n position: absolute;\n width: 0;\n `;\n },\n\n caption(t: Theme) {\n return css`\n color: ${t.switcherTextColor};\n vertical-align: middle;\n display: inline-block;\n `;\n },\n\n captionSmall(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapSmall};\n font-size: ${t.switcherCaptionFontSizeSmall};\n line-height: ${t.switcherCaptionLineHeightSmall};\n `;\n },\n\n captionMedium(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapMedium};\n font-size: ${t.switcherCaptionFontSizeMedium};\n line-height: ${t.switcherCaptionLineHeightMedium};\n `;\n },\n\n captionLarge(t: Theme) {\n return css`\n margin-right: ${t.switcherCaptionGapLarge};\n font-size: ${t.switcherCaptionFontSizeLarge};\n line-height: ${t.switcherCaptionLineHeightLarge};\n `;\n },\n\n error(t: Theme) {\n return css`\n position: relative;\n\n &:before {\n content: '';\n position: absolute;\n pointer-events: none;\n top: 1px;\n right: 1px;\n bottom: 1px;\n left: 1px;\n z-index: 1;\n border-radius: ${t.switcherBorderRadius};\n box-shadow: 0 0 0 ${t.switcherOutlineWidth} ${t.borderColorError};\n }\n `;\n },\n}));\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../components/Switcher/helpers.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,IAAM,GAAG,GAAG,UAAC,CAAS,EAAE,GAAW,IAAa,OAAA,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAvB,CAAuB,CAAC","sourcesContent":["export const mod = (n: number, mod: number): number => ((n % mod) + mod) % mod;\n"]}
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["helpers.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,IAAM,GAAG,GAAG,UAAC,CAAS,EAAE,GAAW,IAAa,OAAA,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAvB,CAAuB,CAAC","sourcesContent":["export const mod = (n: number, mod: number): number => ((n % mod) + mod) % mod;\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../components/Switcher/index.tsx"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC","sourcesContent":["export * from './Switcher.js';\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["index.tsx"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC","sourcesContent":["export * from './Switcher.js';\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"switcherTheme.js","sourceRoot":"","sources":["../../../components/Switcher/switcherTheme.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAEjE,MAAM,CAAC,IAAM,gBAAgB,GAAG,UAAC,KAAY;IAC3C,OAAO,YAAY,CAAC,MAAM,CACxB;QACE,cAAc,EAAE,KAAK,CAAC,yBAAyB;QAC/C,sBAAsB,EAAE,KAAK,CAAC,iCAAiC;QAC/D,wBAAwB,EAAE,KAAK,CAAC,mCAAmC;QAEnE,kBAAkB,EAAE,KAAK,CAAC,6BAA6B;QACvD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,oBAAoB,EAAE,KAAK,CAAC,+BAA+B;QAE3D,mBAAmB,EAAE,KAAK,CAAC,8BAA8B;QACzD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,qBAAqB,EAAE,KAAK,CAAC,gCAAgC;QAE7D,kBAAkB,EAAE,KAAK,CAAC,6BAA6B;QACvD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,oBAAoB,EAAE,KAAK,CAAC,+BAA+B;KAC5D,EACD,KAAK,CACN,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeFactory } from '../../lib/theming/ThemeFactory.js';\n\nexport const getSwitcherTheme = (theme: Theme): Theme => {\n return ThemeFactory.create(\n {\n btnBorderWidth: theme.switcherButtonBorderWidth,\n btnDisabledBorderColor: theme.switcherButtonDisabledBorderColor,\n btnCheckedDisabledShadow: theme.switcherButtonCheckedDisabledShadow,\n\n btnLineHeightSmall: theme.switcherButtonLineHeightSmall,\n btnFontSizeSmall: theme.switcherButtonFontSizeSmall,\n btnPaddingXSmall: theme.switcherButtonPaddingXSmall,\n btnPaddingYSmall: theme.switcherButtonPaddingYSmall,\n btnBorderRadiusSmall: theme.switcherButtonBorderRadiusSmall,\n\n btnLineHeightMedium: theme.switcherButtonLineHeightMedium,\n btnFontSizeMedium: theme.switcherButtonFontSizeMedium,\n btnPaddingXMedium: theme.switcherButtonPaddingXMedium,\n btnPaddingYMedium: theme.switcherButtonPaddingYMedium,\n btnBorderRadiusMedium: theme.switcherButtonBorderRadiusMedium,\n\n btnLineHeightLarge: theme.switcherButtonLineHeightLarge,\n btnFontSizeLarge: theme.switcherButtonFontSizeLarge,\n btnPaddingXLarge: theme.switcherButtonPaddingXLarge,\n btnPaddingYLarge: theme.switcherButtonPaddingYLarge,\n btnBorderRadiusLarge: theme.switcherButtonBorderRadiusLarge,\n },\n theme,\n );\n};\n"]}
1
+ {"version":3,"file":"switcherTheme.js","sourceRoot":"","sources":["switcherTheme.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AAEjE,MAAM,CAAC,IAAM,gBAAgB,GAAG,UAAC,KAAY;IAC3C,OAAO,YAAY,CAAC,MAAM,CACxB;QACE,cAAc,EAAE,KAAK,CAAC,yBAAyB;QAC/C,sBAAsB,EAAE,KAAK,CAAC,iCAAiC;QAC/D,wBAAwB,EAAE,KAAK,CAAC,mCAAmC;QAEnE,kBAAkB,EAAE,KAAK,CAAC,6BAA6B;QACvD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,oBAAoB,EAAE,KAAK,CAAC,+BAA+B;QAE3D,mBAAmB,EAAE,KAAK,CAAC,8BAA8B;QACzD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,iBAAiB,EAAE,KAAK,CAAC,4BAA4B;QACrD,qBAAqB,EAAE,KAAK,CAAC,gCAAgC;QAE7D,kBAAkB,EAAE,KAAK,CAAC,6BAA6B;QACvD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,gBAAgB,EAAE,KAAK,CAAC,2BAA2B;QACnD,oBAAoB,EAAE,KAAK,CAAC,+BAA+B;KAC5D,EACD,KAAK,CACN,CAAC;AACJ,CAAC,CAAC","sourcesContent":["import type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeFactory } from '../../lib/theming/ThemeFactory.js';\n\nexport const getSwitcherTheme = (theme: Theme): Theme => {\n return ThemeFactory.create(\n {\n btnBorderWidth: theme.switcherButtonBorderWidth,\n btnDisabledBorderColor: theme.switcherButtonDisabledBorderColor,\n btnCheckedDisabledShadow: theme.switcherButtonCheckedDisabledShadow,\n\n btnLineHeightSmall: theme.switcherButtonLineHeightSmall,\n btnFontSizeSmall: theme.switcherButtonFontSizeSmall,\n btnPaddingXSmall: theme.switcherButtonPaddingXSmall,\n btnPaddingYSmall: theme.switcherButtonPaddingYSmall,\n btnBorderRadiusSmall: theme.switcherButtonBorderRadiusSmall,\n\n btnLineHeightMedium: theme.switcherButtonLineHeightMedium,\n btnFontSizeMedium: theme.switcherButtonFontSizeMedium,\n btnPaddingXMedium: theme.switcherButtonPaddingXMedium,\n btnPaddingYMedium: theme.switcherButtonPaddingYMedium,\n btnBorderRadiusMedium: theme.switcherButtonBorderRadiusMedium,\n\n btnLineHeightLarge: theme.switcherButtonLineHeightLarge,\n btnFontSizeLarge: theme.switcherButtonFontSizeLarge,\n btnPaddingXLarge: theme.switcherButtonPaddingXLarge,\n btnPaddingYLarge: theme.switcherButtonPaddingYLarge,\n btnBorderRadiusLarge: theme.switcherButtonBorderRadiusLarge,\n },\n theme,\n );\n};\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Indicator.js","sourceRoot":"","sources":["../../../components/Tabs/Indicator.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport throttle from 'lodash.throttle';\nimport React from 'react';\n\nimport { getDOMRect } from '../../lib/dom/getDOMRect.js';\nimport type { GlobalObject } from '../../lib/globalObject.js';\nimport { isInstanceOf } from '../../lib/isInstanceOf.js';\nimport * as LayoutEvents from '../../lib/LayoutEvents.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { getRootNode, rootNode } from '../../lib/rootNode/index.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { getStyles } from './Indicator.styles.js';\nimport type { TabIndicators } from './Tab.js';\nimport { TabsDataTids } from './Tabs.js';\nimport { TabsContext } from './TabsContext.js';\nimport type { TabsContextType } from './TabsContext.js';\n\nexport interface IndicatorProps {\n className?: string;\n tabUpdates: {\n on: (x0: () => void) => () => void;\n };\n vertical: boolean;\n}\n\nexport interface IndicatorState {\n styles: React.CSSProperties;\n}\n\n@withRenderEnvironment\n@rootNode\nexport class Indicator extends React.Component<IndicatorProps, IndicatorState> {\n public static contextType = TabsContext;\n public context: TabsContextType = this.context;\n\n public state: IndicatorState = {\n styles: {},\n };\n\n private globalObject!: GlobalObject;\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n\n private eventListener: Nullable<{\n remove: () => void;\n }> = null;\n\n private removeTabUpdatesListener: Nullable<() => void> = null;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n this.eventListener = LayoutEvents.addListener(this.reflow, this.globalObject);\n this.removeTabUpdatesListener = this.props.tabUpdates.on(this.reflow);\n this.reflow();\n }\n\n public componentWillUnmount() {\n this.reflow.cancel();\n\n if (this.eventListener) {\n this.eventListener.remove();\n }\n if (this.removeTabUpdatesListener) {\n this.removeTabUpdatesListener();\n }\n }\n\n public componentDidUpdate() {\n this.reflow();\n }\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\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 { getTab, activeTab } = this.context;\n const node = getTab(activeTab);\n const indicators: TabIndicators = (node && node.getIndicators && node.getIndicators()) || {\n error: false,\n warning: false,\n success: false,\n primary: false,\n disabled: false,\n };\n return (\n <div\n data-tid={TabsDataTids.indicatorRoot}\n className={this.cx(\n this.styles.root(this.theme),\n indicators.primary && this.styles.primary(this.theme),\n indicators.success && this.styles.success(this.theme),\n indicators.warning && this.styles.warning(this.theme),\n indicators.error && this.styles.error(this.theme),\n this.props.className,\n )}\n style={this.state.styles}\n ref={this.setRootNode}\n />\n );\n }\n\n private reflow = throttle(() => {\n const { getTab, activeTab } = this.context;\n const node = getTab(activeTab);\n const nodeStyles = this.getStyles(node);\n const stylesUpdated = ['left', 'top', 'width', 'height'].some(\n (prop) => nodeStyles[prop as keyof React.CSSProperties] !== this.state.styles[prop as keyof React.CSSProperties],\n );\n if (stylesUpdated) {\n this.setState({ styles: nodeStyles });\n }\n }, 100);\n\n private getStyles(node: any): React.CSSProperties {\n const htmlNode = getRootNode(node);\n\n if (isInstanceOf(htmlNode, this.globalObject.HTMLElement)) {\n const rect = getDOMRect(htmlNode);\n if (this.props.vertical) {\n return {\n width: this.theme.tabBorderWidth,\n left: htmlNode.offsetLeft,\n top: htmlNode.offsetTop,\n height: rect.bottom - rect.top,\n };\n }\n\n const tabBorderWidth = parseInt(this.theme.tabBorderWidth, 10) || 0;\n return {\n left: htmlNode.offsetLeft,\n top: htmlNode.offsetHeight + htmlNode.offsetTop - tabBorderWidth,\n width: rect.right - rect.left,\n };\n }\n\n return {};\n }\n}\n"]}
1
+ {"version":3,"file":"Indicator.js","sourceRoot":"","sources":["Indicator.tsx"],"names":[],"mappings":"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","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\nimport throttle from 'lodash.throttle';\nimport React from 'react';\n\nimport { getDOMRect } from '../../lib/dom/getDOMRect.js';\nimport type { GlobalObject } from '../../lib/globalObject.js';\nimport { isInstanceOf } from '../../lib/isInstanceOf.js';\nimport * as LayoutEvents from '../../lib/LayoutEvents.js';\nimport { withRenderEnvironment } from '../../lib/renderEnvironment/index.js';\nimport type { TGetRootNode, TSetRootNode } from '../../lib/rootNode/index.js';\nimport { getRootNode, rootNode } from '../../lib/rootNode/index.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\nimport { ThemeContext } from '../../lib/theming/ThemeContext.js';\nimport type { Nullable } from '../../typings/utility-types.js';\nimport { getStyles } from './Indicator.styles.js';\nimport type { TabIndicators } from './Tab.js';\nimport { TabsDataTids } from './Tabs.js';\nimport { TabsContext } from './TabsContext.js';\nimport type { TabsContextType } from './TabsContext.js';\n\nexport interface IndicatorProps {\n className?: string;\n tabUpdates: {\n on: (x0: () => void) => () => void;\n };\n vertical: boolean;\n}\n\nexport interface IndicatorState {\n styles: React.CSSProperties;\n}\n\n@withRenderEnvironment\n@rootNode\nexport class Indicator extends React.Component<IndicatorProps, IndicatorState> {\n public static contextType = TabsContext;\n public context: TabsContextType = this.context;\n\n public state: IndicatorState = {\n styles: {},\n };\n\n private globalObject!: GlobalObject;\n private emotion!: Emotion;\n private cx!: Emotion['cx'];\n private styles!: ReturnType<typeof getStyles>;\n private theme!: Theme;\n\n private eventListener: Nullable<{\n remove: () => void;\n }> = null;\n\n private removeTabUpdatesListener: Nullable<() => void> = null;\n public getRootNode!: TGetRootNode;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n this.eventListener = LayoutEvents.addListener(this.reflow, this.globalObject);\n this.removeTabUpdatesListener = this.props.tabUpdates.on(this.reflow);\n this.reflow();\n }\n\n public componentWillUnmount() {\n this.reflow.cancel();\n\n if (this.eventListener) {\n this.eventListener.remove();\n }\n if (this.removeTabUpdatesListener) {\n this.removeTabUpdatesListener();\n }\n }\n\n public componentDidUpdate() {\n this.reflow();\n }\n\n public render(): React.JSX.Element {\n this.styles = getStyles(this.emotion);\n\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 { getTab, activeTab } = this.context;\n const node = getTab(activeTab);\n const indicators: TabIndicators = (node && node.getIndicators && node.getIndicators()) || {\n error: false,\n warning: false,\n success: false,\n primary: false,\n disabled: false,\n };\n return (\n <div\n data-tid={TabsDataTids.indicatorRoot}\n className={this.cx(\n this.styles.root(this.theme),\n indicators.primary && this.styles.primary(this.theme),\n indicators.success && this.styles.success(this.theme),\n indicators.warning && this.styles.warning(this.theme),\n indicators.error && this.styles.error(this.theme),\n this.props.className,\n )}\n style={this.state.styles}\n ref={this.setRootNode}\n />\n );\n }\n\n private reflow = throttle(() => {\n const { getTab, activeTab } = this.context;\n const node = getTab(activeTab);\n const nodeStyles = this.getStyles(node);\n const stylesUpdated = ['left', 'top', 'width', 'height'].some(\n (prop) => nodeStyles[prop as keyof React.CSSProperties] !== this.state.styles[prop as keyof React.CSSProperties],\n );\n if (stylesUpdated) {\n this.setState({ styles: nodeStyles });\n }\n }, 100);\n\n private getStyles(node: any): React.CSSProperties {\n const htmlNode = getRootNode(node);\n\n if (isInstanceOf(htmlNode, this.globalObject.HTMLElement)) {\n const rect = getDOMRect(htmlNode);\n if (this.props.vertical) {\n return {\n width: this.theme.tabBorderWidth,\n left: htmlNode.offsetLeft,\n top: htmlNode.offsetTop,\n height: rect.bottom - rect.top,\n };\n }\n\n const tabBorderWidth = parseInt(this.theme.tabBorderWidth, 10) || 0;\n return {\n left: htmlNode.offsetLeft,\n top: htmlNode.offsetHeight + htmlNode.offsetTop - tabBorderWidth,\n width: rect.right - rect.left,\n };\n }\n\n return {};\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Indicator.styles.js","sourceRoot":"","sources":["../../../components/Tabs/Indicator.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,IAAI,YAAC,CAAQ;YACX,OAAO,GAAG,sNAAA,sBACM,EAAe,mBACnB,EAAgB,2FAGT,EAA0B,SAC5C,KALe,CAAC,CAAC,aAAa,EACnB,CAAC,CAAC,cAAc,EAGT,CAAC,CAAC,wBAAwB,EAC3C;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,GAAG,oGAAA,sBACM,EAAe,SAC9B,KADe,CAAC,CAAC,aAAa,EAC7B;QACJ,CAAC;KACF,CAAC;AAlC8D,CAkC9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\n root(t: Theme) {\n return css`\n background: ${t.tabColorFocus};\n height: ${t.tabBorderWidth};\n position: absolute;\n transition: all 0.2s ease-out;\n border-radius: ${t.tabIndicatorBorderRadius};\n `;\n },\n\n primary(t: Theme) {\n return css`\n background: ${t.tabColorPrimary};\n `;\n },\n\n success(t: Theme) {\n return css`\n background: ${t.tabColorSuccess};\n `;\n },\n\n warning(t: Theme) {\n return css`\n background: ${t.tabColorWarning};\n `;\n },\n\n error(t: Theme) {\n return css`\n background: ${t.tabColorError};\n `;\n },\n}));\n"]}
1
+ {"version":3,"file":"Indicator.styles.js","sourceRoot":"","sources":["Indicator.styles.ts"],"names":[],"mappings":";;;;AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,MAAM,CAAC,IAAM,SAAS,GAAG,gBAAgB,CAAC,UAAC,EAAgB;QAAd,GAAG,SAAA;IAAgB,OAAA,CAAC;QAC/D,IAAI,YAAC,CAAQ;YACX,OAAO,GAAG,sNAAA,sBACM,EAAe,mBACnB,EAAgB,2FAGT,EAA0B,SAC5C,KALe,CAAC,CAAC,aAAa,EACnB,CAAC,CAAC,cAAc,EAGT,CAAC,CAAC,wBAAwB,EAC3C;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,OAAO,YAAC,CAAQ;YACd,OAAO,GAAG,oGAAA,sBACM,EAAiB,SAChC,KADe,CAAC,CAAC,eAAe,EAC/B;QACJ,CAAC;QAED,KAAK,YAAC,CAAQ;YACZ,OAAO,GAAG,oGAAA,sBACM,EAAe,SAC9B,KADe,CAAC,CAAC,aAAa,EAC7B;QACJ,CAAC;KACF,CAAC;AAlC8D,CAkC9D,CAAC,CAAC","sourcesContent":["import type { Emotion } from '@emotion/css/create-instance';\n\nimport { memoizeGetStyles } from '../../lib/theming/Emotion.js';\nimport type { Theme } from '../../lib/theming/Theme.js';\n\nexport const getStyles = memoizeGetStyles(({ css }: Emotion) => ({\n root(t: Theme) {\n return css`\n background: ${t.tabColorFocus};\n height: ${t.tabBorderWidth};\n position: absolute;\n transition: all 0.2s ease-out;\n border-radius: ${t.tabIndicatorBorderRadius};\n `;\n },\n\n primary(t: Theme) {\n return css`\n background: ${t.tabColorPrimary};\n `;\n },\n\n success(t: Theme) {\n return css`\n background: ${t.tabColorSuccess};\n `;\n },\n\n warning(t: Theme) {\n return css`\n background: ${t.tabColorWarning};\n `;\n },\n\n error(t: Theme) {\n return css`\n background: ${t.tabColorError};\n `;\n },\n}));\n"]}