@skbkontur/react-ui 4.13.4 → 4.14.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 (1102) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/cjs/components/Autocomplete/Autocomplete.js +5 -8
  3. package/cjs/components/Autocomplete/Autocomplete.js.map +1 -1
  4. package/cjs/components/Autocomplete/getAutocompleteTheme.d.ts +2 -0
  5. package/cjs/components/Autocomplete/getAutocompleteTheme.js +11 -0
  6. package/cjs/components/Autocomplete/getAutocompleteTheme.js.map +1 -0
  7. package/cjs/components/Button/ArrowLeftIcon.d.ts +3 -0
  8. package/cjs/components/Button/ArrowLeftIcon.js +15 -0
  9. package/cjs/components/Button/ArrowLeftIcon.js.map +1 -0
  10. package/cjs/components/Button/ArrowRightIcon.d.ts +3 -0
  11. package/cjs/components/Button/ArrowRightIcon.js +15 -0
  12. package/cjs/components/Button/ArrowRightIcon.js.map +1 -0
  13. package/cjs/components/Button/Button.d.ts +8 -4
  14. package/cjs/components/Button/Button.js +66 -5
  15. package/cjs/components/Button/Button.js.map +1 -1
  16. package/cjs/components/Button/Button.md +42 -8
  17. package/cjs/components/Button/Button.mixins.js +15 -6
  18. package/cjs/components/Button/Button.mixins.js.map +1 -1
  19. package/cjs/components/Button/Button.styles.d.ts +30 -0
  20. package/cjs/components/Button/Button.styles.js +344 -68
  21. package/cjs/components/Button/Button.styles.js.map +1 -1
  22. package/cjs/components/Button/ButtonArrow.d.ts +8 -0
  23. package/cjs/components/Button/ButtonArrow.js +100 -0
  24. package/cjs/components/Button/ButtonArrow.js.map +1 -0
  25. package/cjs/components/Button/ButtonIcon.d.ts +7 -0
  26. package/cjs/components/Button/ButtonIcon.js +69 -0
  27. package/cjs/components/Button/ButtonIcon.js.map +1 -0
  28. package/cjs/components/Button/getInnerLinkTheme.d.ts +2 -0
  29. package/cjs/components/Button/getInnerLinkTheme.js +16 -0
  30. package/cjs/components/Button/getInnerLinkTheme.js.map +1 -0
  31. package/cjs/components/Checkbox/Checkbox.js +35 -14
  32. package/cjs/components/Checkbox/Checkbox.js.map +1 -1
  33. package/cjs/components/Checkbox/Checkbox.styles.d.ts +1 -0
  34. package/cjs/components/Checkbox/Checkbox.styles.js +9 -5
  35. package/cjs/components/Checkbox/Checkbox.styles.js.map +1 -1
  36. package/cjs/components/Checkbox/CheckedIcon.d.ts +3 -0
  37. package/cjs/components/Checkbox/CheckedIcon.js +14 -0
  38. package/cjs/components/Checkbox/CheckedIcon.js.map +1 -0
  39. package/cjs/components/Checkbox/IndeterminateIcon.d.ts +3 -0
  40. package/cjs/components/Checkbox/IndeterminateIcon.js +13 -0
  41. package/cjs/components/Checkbox/IndeterminateIcon.js.map +1 -0
  42. package/cjs/components/CurrencyInput/CurrencyInputKeyboardActions.d.ts +1 -1
  43. package/cjs/components/DateInput/CalendarIcon.d.ts +3 -0
  44. package/cjs/components/DateInput/CalendarIcon.js +15 -0
  45. package/cjs/components/DateInput/CalendarIcon.js.map +1 -0
  46. package/cjs/components/DateInput/DateInput.js +4 -5
  47. package/cjs/components/DateInput/DateInput.js.map +1 -1
  48. package/cjs/components/DatePicker/DatePicker.d.ts +1 -0
  49. package/cjs/components/DatePicker/DatePicker.js +12 -2
  50. package/cjs/components/DatePicker/DatePicker.js.map +1 -1
  51. package/cjs/components/DatePicker/Picker.js +20 -1
  52. package/cjs/components/DatePicker/Picker.js.map +1 -1
  53. package/cjs/components/DatePicker/Picker.styles.js +3 -2
  54. package/cjs/components/DatePicker/Picker.styles.js.map +1 -1
  55. package/cjs/components/Dropdown/Dropdown.js +4 -12
  56. package/cjs/components/Dropdown/Dropdown.js.map +1 -1
  57. package/cjs/components/Dropdown/getDropdownTheme.d.ts +2 -0
  58. package/cjs/components/Dropdown/getDropdownTheme.js +12 -0
  59. package/cjs/components/Dropdown/getDropdownTheme.js.map +1 -0
  60. package/cjs/components/DropdownMenu/DropdownMenu.js +4 -14
  61. package/cjs/components/DropdownMenu/DropdownMenu.js.map +1 -1
  62. package/cjs/components/DropdownMenu/getDropdownMenuTheme.d.ts +2 -0
  63. package/cjs/components/DropdownMenu/getDropdownMenuTheme.js +11 -0
  64. package/cjs/components/DropdownMenu/getDropdownMenuTheme.js.map +1 -0
  65. package/cjs/components/FileUploader/FileUploader.js +41 -29
  66. package/cjs/components/FileUploader/FileUploader.js.map +1 -1
  67. package/cjs/components/FileUploader/FileUploader.styles.d.ts +7 -2
  68. package/cjs/components/FileUploader/FileUploader.styles.js +76 -43
  69. package/cjs/components/FileUploader/FileUploader.styles.js.map +1 -1
  70. package/cjs/components/FileUploader/UploadIcon.d.ts +3 -0
  71. package/cjs/components/FileUploader/UploadIcon.js +15 -0
  72. package/cjs/components/FileUploader/UploadIcon.js.map +1 -0
  73. package/cjs/components/FxInput/FxInput.d.ts +1 -0
  74. package/cjs/components/FxInput/FxInput.js +39 -12
  75. package/cjs/components/FxInput/FxInput.js.map +1 -1
  76. package/cjs/components/FxInput/FxInputRestoreBtn.d.ts +5 -0
  77. package/cjs/components/FxInput/FxInputRestoreBtn.js +75 -0
  78. package/cjs/components/FxInput/FxInputRestoreBtn.js.map +1 -0
  79. package/cjs/components/FxInput/MathFunctionIcon.d.ts +3 -0
  80. package/cjs/components/FxInput/MathFunctionIcon.js +15 -0
  81. package/cjs/components/FxInput/MathFunctionIcon.js.map +1 -0
  82. package/cjs/components/FxInput/UndoIcon.d.ts +3 -0
  83. package/cjs/components/FxInput/UndoIcon.js +15 -0
  84. package/cjs/components/FxInput/UndoIcon.js.map +1 -0
  85. package/cjs/components/Group/Group.d.ts +2 -0
  86. package/cjs/components/Group/Group.js +30 -7
  87. package/cjs/components/Group/Group.js.map +1 -1
  88. package/cjs/components/Input/Input.d.ts +23 -7
  89. package/cjs/components/Input/Input.js +106 -15
  90. package/cjs/components/Input/Input.js.map +1 -1
  91. package/cjs/components/Input/Input.md +49 -0
  92. package/cjs/components/Input/Input.styles.d.ts +1 -0
  93. package/cjs/components/Input/Input.styles.js +52 -42
  94. package/cjs/components/Input/Input.styles.js.map +1 -1
  95. package/cjs/components/Input/InputLayout/InputLayout.d.ts +10 -0
  96. package/cjs/components/Input/InputLayout/InputLayout.js +32 -0
  97. package/cjs/components/Input/InputLayout/InputLayout.js.map +1 -0
  98. package/cjs/components/Input/InputLayout/InputLayout.styles.d.ts +11 -0
  99. package/cjs/components/Input/InputLayout/InputLayout.styles.js +47 -0
  100. package/cjs/components/Input/InputLayout/InputLayout.styles.js.map +1 -0
  101. package/cjs/components/Input/InputLayout/InputLayoutAside.d.ts +8 -0
  102. package/cjs/components/Input/InputLayout/InputLayoutAside.js +30 -0
  103. package/cjs/components/Input/InputLayout/InputLayoutAside.js.map +1 -0
  104. package/cjs/components/Input/InputLayout/InputLayoutAsideIcon.d.ts +7 -0
  105. package/cjs/components/Input/InputLayout/InputLayoutAsideIcon.js +61 -0
  106. package/cjs/components/Input/InputLayout/InputLayoutAsideIcon.js.map +1 -0
  107. package/cjs/components/Input/InputLayout/InputLayoutAsideText.d.ts +6 -0
  108. package/cjs/components/Input/InputLayout/InputLayoutAsideText.js +27 -0
  109. package/cjs/components/Input/InputLayout/InputLayoutAsideText.js.map +1 -0
  110. package/cjs/components/Input/InputLayout/InputLayoutContext.d.ts +9 -0
  111. package/cjs/components/Input/InputLayout/InputLayoutContext.js +17 -0
  112. package/cjs/components/Input/InputLayout/InputLayoutContext.js.map +1 -0
  113. package/cjs/components/Input/InputLayout/PolyfillPlaceholder.d.ts +10 -0
  114. package/cjs/components/Input/InputLayout/PolyfillPlaceholder.js +46 -0
  115. package/cjs/components/Input/InputLayout/PolyfillPlaceholder.js.map +1 -0
  116. package/cjs/components/Kebab/Kebab.d.ts +2 -1
  117. package/cjs/components/Kebab/Kebab.js +51 -20
  118. package/cjs/components/Kebab/Kebab.js.map +1 -1
  119. package/cjs/components/Kebab/Kebab.styles.d.ts +8 -4
  120. package/cjs/components/Kebab/Kebab.styles.js +52 -21
  121. package/cjs/components/Kebab/Kebab.styles.js.map +1 -1
  122. package/cjs/components/Kebab/KebabIcon.d.ts +3 -0
  123. package/cjs/components/Kebab/KebabIcon.js +15 -0
  124. package/cjs/components/Kebab/KebabIcon.js.map +1 -0
  125. package/cjs/components/Link/Link.d.ts +20 -4
  126. package/cjs/components/Link/Link.js +87 -27
  127. package/cjs/components/Link/Link.js.map +1 -1
  128. package/cjs/components/Link/Link.md +11 -0
  129. package/cjs/components/Link/Link.mixins.d.ts +2 -0
  130. package/cjs/components/Link/Link.mixins.js +20 -2
  131. package/cjs/components/Link/Link.mixins.js.map +1 -1
  132. package/cjs/components/Link/Link.styles.d.ts +9 -0
  133. package/cjs/components/Link/Link.styles.js +99 -17
  134. package/cjs/components/Link/Link.styles.js.map +1 -1
  135. package/cjs/components/Loader/Loader.d.ts +4 -4
  136. package/cjs/components/Loader/Loader.js +6 -6
  137. package/cjs/components/Loader/Loader.js.map +1 -1
  138. package/cjs/components/Loader/Loader.styles.js +2 -1
  139. package/cjs/components/Loader/Loader.styles.js.map +1 -1
  140. package/cjs/components/MenuItem/MenuItem.styles.js +9 -4
  141. package/cjs/components/MenuItem/MenuItem.styles.js.map +1 -1
  142. package/cjs/components/MenuSeparator/MenuSeparator.styles.js +2 -2
  143. package/cjs/components/MenuSeparator/MenuSeparator.styles.js.map +1 -1
  144. package/cjs/components/Modal/Modal.js +3 -2
  145. package/cjs/components/Modal/Modal.js.map +1 -1
  146. package/cjs/components/Modal/Modal.styles.d.ts +4 -1
  147. package/cjs/components/Modal/Modal.styles.js +37 -14
  148. package/cjs/components/Modal/Modal.styles.js.map +1 -1
  149. package/cjs/components/Modal/ModalBody.js +3 -2
  150. package/cjs/components/Modal/ModalBody.js.map +1 -1
  151. package/cjs/components/Modal/ModalClose.js +6 -2
  152. package/cjs/components/Modal/ModalClose.js.map +1 -1
  153. package/cjs/components/Modal/ModalFooter.js +13 -9
  154. package/cjs/components/Modal/ModalFooter.js.map +1 -1
  155. package/cjs/components/Modal/ModalHeader.js +20 -14
  156. package/cjs/components/Modal/ModalHeader.js.map +1 -1
  157. package/cjs/components/Modal/ModalSeparator.d.ts +5 -0
  158. package/cjs/components/Modal/ModalSeparator.js +21 -0
  159. package/cjs/components/Modal/ModalSeparator.js.map +1 -0
  160. package/cjs/components/Modal/getModalBodyTheme.d.ts +2 -0
  161. package/cjs/components/Modal/getModalBodyTheme.js +11 -0
  162. package/cjs/components/Modal/getModalBodyTheme.js.map +1 -0
  163. package/cjs/components/Modal/getModalTheme.d.ts +2 -0
  164. package/cjs/components/Modal/getModalTheme.js +11 -0
  165. package/cjs/components/Modal/getModalTheme.js.map +1 -0
  166. package/cjs/components/Paging/ForwardIcon.d.ts +3 -0
  167. package/cjs/components/Paging/ForwardIcon.js +15 -0
  168. package/cjs/components/Paging/ForwardIcon.js.map +1 -0
  169. package/cjs/components/Paging/Paging.js +21 -6
  170. package/cjs/components/Paging/Paging.js.map +1 -1
  171. package/cjs/components/Paging/Paging.styles.js +5 -4
  172. package/cjs/components/Paging/Paging.styles.js.map +1 -1
  173. package/cjs/components/PasswordInput/ClosedIcon.d.ts +3 -0
  174. package/cjs/components/PasswordInput/ClosedIcon.js +15 -0
  175. package/cjs/components/PasswordInput/ClosedIcon.js.map +1 -0
  176. package/cjs/components/PasswordInput/OpenedIcon.d.ts +3 -0
  177. package/cjs/components/PasswordInput/OpenedIcon.js +15 -0
  178. package/cjs/components/PasswordInput/OpenedIcon.js.map +1 -0
  179. package/cjs/components/PasswordInput/PasswordInput.js +8 -1
  180. package/cjs/components/PasswordInput/PasswordInput.js.map +1 -1
  181. package/cjs/components/PasswordInput/PasswordInputIcon.d.ts +5 -3
  182. package/cjs/components/PasswordInput/PasswordInputIcon.js +8 -3
  183. package/cjs/components/PasswordInput/PasswordInputIcon.js.map +1 -1
  184. package/cjs/components/Radio/Radio.styles.js +1 -1
  185. package/cjs/components/Radio/Radio.styles.js.map +1 -1
  186. package/cjs/components/Select/ArrowDownIcon.d.ts +3 -0
  187. package/cjs/components/Select/ArrowDownIcon.js +15 -0
  188. package/cjs/components/Select/ArrowDownIcon.js.map +1 -0
  189. package/cjs/components/Select/Select.js +15 -2
  190. package/cjs/components/Select/Select.js.map +1 -1
  191. package/cjs/components/SidePage/SidePage.styles.js +3 -2
  192. package/cjs/components/SidePage/SidePage.styles.js.map +1 -1
  193. package/cjs/components/SidePage/SidePageFooter.js +9 -1
  194. package/cjs/components/SidePage/SidePageFooter.js.map +1 -1
  195. package/cjs/components/SidePage/SidePageHeader.d.ts +3 -0
  196. package/cjs/components/SidePage/SidePageHeader.js +20 -1
  197. package/cjs/components/SidePage/SidePageHeader.js.map +1 -1
  198. package/cjs/components/Spinner/Spinner.d.ts +4 -4
  199. package/cjs/components/Spinner/Spinner.js +2 -6
  200. package/cjs/components/Spinner/Spinner.js.map +1 -1
  201. package/cjs/components/Spinner/Spinner.styles.d.ts +3 -0
  202. package/cjs/components/Spinner/Spinner.styles.js +29 -5
  203. package/cjs/components/Spinner/Spinner.styles.js.map +1 -1
  204. package/cjs/components/Tabs/Indicator.styles.js +3 -2
  205. package/cjs/components/Tabs/Indicator.styles.js.map +1 -1
  206. package/cjs/components/Textarea/Textarea.js +1 -0
  207. package/cjs/components/Textarea/Textarea.js.map +1 -1
  208. package/cjs/components/Textarea/Textarea.styles.d.ts +1 -0
  209. package/cjs/components/Textarea/Textarea.styles.js +21 -13
  210. package/cjs/components/Textarea/Textarea.styles.js.map +1 -1
  211. package/cjs/components/Textarea/TextareaCounter.js +15 -6
  212. package/cjs/components/Textarea/TextareaCounter.js.map +1 -1
  213. package/cjs/components/Toast/Toast.md +2 -2
  214. package/cjs/components/Toast/ToastView.js +18 -0
  215. package/cjs/components/Toast/ToastView.js.map +1 -1
  216. package/cjs/components/Toast/ToastView.styles.js +11 -3
  217. package/cjs/components/Toast/ToastView.styles.js.map +1 -1
  218. package/cjs/components/Toggle/Toggle.d.ts +5 -1
  219. package/cjs/components/Toggle/Toggle.js +13 -2
  220. package/cjs/components/Toggle/Toggle.js.map +1 -1
  221. package/cjs/components/Toggle/Toggle.styles.d.ts +3 -0
  222. package/cjs/components/Toggle/Toggle.styles.js +119 -31
  223. package/cjs/components/Toggle/Toggle.styles.js.map +1 -1
  224. package/cjs/components/Token/Token.js +12 -1
  225. package/cjs/components/Token/Token.js.map +1 -1
  226. package/cjs/components/Token/Token.styles.d.ts +6 -0
  227. package/cjs/components/Token/Token.styles.js +67 -10
  228. package/cjs/components/Token/Token.styles.js.map +1 -1
  229. package/cjs/components/TokenInput/TokenInput.d.ts +1 -0
  230. package/cjs/components/TokenInput/TokenInput.js +6 -1
  231. package/cjs/components/TokenInput/TokenInput.js.map +1 -1
  232. package/cjs/components/TokenInput/TokenInput.styles.d.ts +1 -0
  233. package/cjs/components/TokenInput/TokenInput.styles.js +21 -12
  234. package/cjs/components/TokenInput/TokenInput.styles.js.map +1 -1
  235. package/cjs/components/TokenInput/TokenInputMenu.js +3 -1
  236. package/cjs/components/TokenInput/TokenInputMenu.js.map +1 -1
  237. package/cjs/components/Tooltip/Tooltip.js +15 -1
  238. package/cjs/components/Tooltip/Tooltip.js.map +1 -1
  239. package/cjs/components/Tooltip/Tooltip.styles.js +3 -3
  240. package/cjs/components/Tooltip/Tooltip.styles.js.map +1 -1
  241. package/cjs/internal/Calendar/DayCellView.js +13 -2
  242. package/cjs/internal/Calendar/DayCellView.js.map +1 -1
  243. package/cjs/internal/Calendar/DayCellView.styles.d.ts +5 -0
  244. package/cjs/internal/Calendar/DayCellView.styles.js +20 -2
  245. package/cjs/internal/Calendar/DayCellView.styles.js.map +1 -1
  246. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.d.ts +35 -0
  247. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.js +98 -0
  248. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.js.map +1 -0
  249. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.styles.d.ts +7 -0
  250. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.styles.js +41 -0
  251. package/cjs/internal/CloseButtonIcon/CloseButtonIcon.styles.js.map +1 -0
  252. package/cjs/internal/CloseButtonIcon/CrossIcon.d.ts +3 -0
  253. package/cjs/internal/CloseButtonIcon/CrossIcon.js +14 -0
  254. package/cjs/internal/CloseButtonIcon/CrossIcon.js.map +1 -0
  255. package/cjs/internal/CustomComboBox/ArrowDownIcon.d.ts +3 -0
  256. package/cjs/internal/CustomComboBox/ArrowDownIcon.js +15 -0
  257. package/cjs/internal/CustomComboBox/ArrowDownIcon.js.map +1 -0
  258. package/cjs/internal/CustomComboBox/ComboBoxMenu.js +1 -1
  259. package/cjs/internal/CustomComboBox/ComboBoxMenu.js.map +1 -1
  260. package/cjs/internal/CustomComboBox/ComboBoxView.d.ts +2 -0
  261. package/cjs/internal/CustomComboBox/ComboBoxView.js +27 -4
  262. package/cjs/internal/CustomComboBox/ComboBoxView.js.map +1 -1
  263. package/cjs/internal/CustomComboBox/getComboBoxTheme.d.ts +2 -0
  264. package/cjs/internal/CustomComboBox/getComboBoxTheme.js +11 -0
  265. package/cjs/internal/CustomComboBox/getComboBoxTheme.js.map +1 -0
  266. package/cjs/internal/DateSelect/DateSelect.d.ts +1 -0
  267. package/cjs/internal/DateSelect/DateSelect.js +30 -2
  268. package/cjs/internal/DateSelect/DateSelect.js.map +1 -1
  269. package/cjs/internal/DateSelect/DateSelect.styles.d.ts +1 -0
  270. package/cjs/internal/DateSelect/DateSelect.styles.js +23 -16
  271. package/cjs/internal/DateSelect/DateSelect.styles.js.map +1 -1
  272. package/cjs/internal/FileUploaderControl/FileUploaderFile/DeleteIcon.d.ts +3 -0
  273. package/cjs/internal/FileUploaderControl/FileUploaderFile/DeleteIcon.js +15 -0
  274. package/cjs/internal/FileUploaderControl/FileUploaderFile/DeleteIcon.js.map +1 -0
  275. package/cjs/internal/FileUploaderControl/FileUploaderFile/ErrorIcon.d.ts +3 -0
  276. package/cjs/internal/FileUploaderControl/FileUploaderFile/ErrorIcon.js +15 -0
  277. package/cjs/internal/FileUploaderControl/FileUploaderFile/ErrorIcon.js.map +1 -0
  278. package/cjs/internal/FileUploaderControl/FileUploaderFile/FileUploaderFile.js +11 -27
  279. package/cjs/internal/FileUploaderControl/FileUploaderFile/FileUploaderFile.js.map +1 -1
  280. package/cjs/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon.d.ts +12 -0
  281. package/cjs/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon.js +58 -0
  282. package/cjs/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon.js.map +1 -0
  283. package/cjs/internal/FileUploaderControl/FileUploaderFile/OkIcon.d.ts +3 -0
  284. package/cjs/internal/FileUploaderControl/FileUploaderFile/OkIcon.js +15 -0
  285. package/cjs/internal/FileUploaderControl/FileUploaderFile/OkIcon.js.map +1 -0
  286. package/cjs/internal/InputLikeText/InputLikeText.js +21 -5
  287. package/cjs/internal/InputLikeText/InputLikeText.js.map +1 -1
  288. package/cjs/internal/InternalMenu/InternalMenu.styles.js +2 -2
  289. package/cjs/internal/InternalMenu/InternalMenu.styles.js.map +1 -1
  290. package/cjs/internal/Menu/Menu.js +11 -1
  291. package/cjs/internal/Menu/Menu.js.map +1 -1
  292. package/cjs/internal/Menu/Menu.styles.js +4 -3
  293. package/cjs/internal/Menu/Menu.styles.js.map +1 -1
  294. package/cjs/internal/ThemePlayground/constants.js +2 -1
  295. package/cjs/internal/ThemePlayground/constants.js.map +1 -1
  296. package/cjs/internal/ThemeShowcase/VariablesCollector.d.ts +1 -1
  297. package/cjs/internal/icons/SpinnerIcon.d.ts +20 -14
  298. package/cjs/internal/icons/SpinnerIcon.js +12 -1
  299. package/cjs/internal/icons/SpinnerIcon.js.map +1 -1
  300. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light.d.ts +2 -0
  301. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light.js +14 -0
  302. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light.js.map +1 -0
  303. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light.d.ts +2 -0
  304. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light.js +14 -0
  305. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light.js.map +1 -0
  306. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular.d.ts +2 -0
  307. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular.js +14 -0
  308. package/cjs/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular.js.map +1 -0
  309. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light.d.ts +2 -0
  310. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light.js +14 -0
  311. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light.js.map +1 -0
  312. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light.d.ts +2 -0
  313. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light.js +14 -0
  314. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light.js.map +1 -0
  315. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular.d.ts +2 -0
  316. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular.js +14 -0
  317. package/cjs/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular.js.map +1 -0
  318. package/cjs/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light.d.ts +2 -0
  319. package/cjs/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light.js +12 -0
  320. package/cjs/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light.js.map +1 -0
  321. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular.d.ts +2 -0
  322. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular.js +14 -0
  323. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular.js.map +1 -0
  324. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular.d.ts +2 -0
  325. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular.js +14 -0
  326. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular.js.map +1 -0
  327. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular.d.ts +2 -0
  328. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular.js +14 -0
  329. package/cjs/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular.js.map +1 -0
  330. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light.d.ts +2 -0
  331. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light.js +14 -0
  332. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light.js.map +1 -0
  333. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light.d.ts +2 -0
  334. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light.js +14 -0
  335. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light.js.map +1 -0
  336. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular.d.ts +2 -0
  337. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular.js +14 -0
  338. package/cjs/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular.js.map +1 -0
  339. package/cjs/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular.d.ts +2 -0
  340. package/cjs/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular.js +14 -0
  341. package/cjs/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular.js.map +1 -0
  342. package/cjs/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular.d.ts +2 -0
  343. package/cjs/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular.js +15 -0
  344. package/cjs/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular.js.map +1 -0
  345. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light.d.ts +2 -0
  346. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light.js +18 -0
  347. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light.js.map +1 -0
  348. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light.d.ts +2 -0
  349. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light.js +18 -0
  350. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light.js.map +1 -0
  351. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular.d.ts +2 -0
  352. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular.js +18 -0
  353. package/cjs/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular.js.map +1 -0
  354. package/cjs/internal/icons2022/BaseIcon.d.ts +11 -0
  355. package/cjs/internal/icons2022/BaseIcon.js +40 -0
  356. package/cjs/internal/icons2022/BaseIcon.js.map +1 -0
  357. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon16Light.d.ts +2 -0
  358. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon16Light.js +24 -0
  359. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon16Light.js.map +1 -0
  360. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon20Light.d.ts +2 -0
  361. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon20Light.js +24 -0
  362. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon20Light.js.map +1 -0
  363. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon24Regular.d.ts +2 -0
  364. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon24Regular.js +26 -0
  365. package/cjs/internal/icons2022/CalendarIcon/CalendarIcon24Regular.js.map +1 -0
  366. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Light.d.ts +2 -0
  367. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Light.js +12 -0
  368. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Light.js.map +1 -0
  369. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Regular.d.ts +2 -0
  370. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Regular.js +12 -0
  371. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Regular.js.map +1 -0
  372. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Solid.d.ts +2 -0
  373. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Solid.js +12 -0
  374. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon16Solid.js.map +1 -0
  375. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Light.d.ts +2 -0
  376. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Light.js +12 -0
  377. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Light.js.map +1 -0
  378. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Solid.d.ts +2 -0
  379. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Solid.js +12 -0
  380. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon20Solid.js.map +1 -0
  381. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon24Regular.d.ts +2 -0
  382. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon24Regular.js +12 -0
  383. package/cjs/internal/icons2022/CheckAIcon/CheckAIcon24Regular.js.map +1 -0
  384. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light.d.ts +2 -0
  385. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light.js +14 -0
  386. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light.js.map +1 -0
  387. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light.d.ts +2 -0
  388. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light.js +14 -0
  389. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light.js.map +1 -0
  390. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular.d.ts +2 -0
  391. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular.js +14 -0
  392. package/cjs/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular.js.map +1 -0
  393. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light.d.ts +2 -0
  394. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light.js +21 -0
  395. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light.js.map +1 -0
  396. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light.d.ts +2 -0
  397. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light.js +21 -0
  398. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light.js.map +1 -0
  399. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular.d.ts +2 -0
  400. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular.js +23 -0
  401. package/cjs/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular.js.map +1 -0
  402. package/cjs/internal/icons2022/LoadingIcon.d.ts +4 -0
  403. package/cjs/internal/icons2022/LoadingIcon.js +44 -0
  404. package/cjs/internal/icons2022/LoadingIcon.js.map +1 -0
  405. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light.d.ts +2 -0
  406. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light.js +15 -0
  407. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light.js.map +1 -0
  408. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light.d.ts +2 -0
  409. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light.js +15 -0
  410. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light.js.map +1 -0
  411. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular.d.ts +2 -0
  412. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular.js +15 -0
  413. package/cjs/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular.js.map +1 -0
  414. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light.d.ts +2 -0
  415. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light.js +19 -0
  416. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light.js.map +1 -0
  417. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular.d.ts +2 -0
  418. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular.js +19 -0
  419. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular.js.map +1 -0
  420. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light.d.ts +2 -0
  421. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light.js +19 -0
  422. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light.js.map +1 -0
  423. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular.d.ts +2 -0
  424. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular.js +19 -0
  425. package/cjs/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular.js.map +1 -0
  426. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon16Light.d.ts +2 -0
  427. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon16Light.js +15 -0
  428. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon16Light.js.map +1 -0
  429. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon20Light.d.ts +2 -0
  430. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon20Light.js +15 -0
  431. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon20Light.js.map +1 -0
  432. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular.d.ts +2 -0
  433. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular.js +15 -0
  434. package/cjs/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular.js.map +1 -0
  435. package/cjs/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid.d.ts +2 -0
  436. package/cjs/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid.js +18 -0
  437. package/cjs/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid.js.map +1 -0
  438. package/cjs/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular.d.ts +2 -0
  439. package/cjs/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular.js +18 -0
  440. package/cjs/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular.js.map +1 -0
  441. package/cjs/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid.d.ts +2 -0
  442. package/cjs/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid.js +14 -0
  443. package/cjs/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid.js.map +1 -0
  444. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light.d.ts +2 -0
  445. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light.js +16 -0
  446. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light.js.map +1 -0
  447. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular.d.ts +2 -0
  448. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular.js +16 -0
  449. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular.js.map +1 -0
  450. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular.d.ts +2 -0
  451. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular.js +16 -0
  452. package/cjs/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular.js.map +1 -0
  453. package/cjs/internal/icons2022/XIcon/XIcon16Light.d.ts +2 -0
  454. package/cjs/internal/icons2022/XIcon/XIcon16Light.js +12 -0
  455. package/cjs/internal/icons2022/XIcon/XIcon16Light.js.map +1 -0
  456. package/cjs/internal/icons2022/XIcon/XIcon16Regular.d.ts +2 -0
  457. package/cjs/internal/icons2022/XIcon/XIcon16Regular.js +12 -0
  458. package/cjs/internal/icons2022/XIcon/XIcon16Regular.js.map +1 -0
  459. package/cjs/internal/icons2022/XIcon/XIcon20Light.d.ts +2 -0
  460. package/cjs/internal/icons2022/XIcon/XIcon20Light.js +12 -0
  461. package/cjs/internal/icons2022/XIcon/XIcon20Light.js.map +1 -0
  462. package/cjs/internal/icons2022/XIcon/XIcon20Regular.d.ts +2 -0
  463. package/cjs/internal/icons2022/XIcon/XIcon20Regular.js +12 -0
  464. package/cjs/internal/icons2022/XIcon/XIcon20Regular.js.map +1 -0
  465. package/cjs/internal/icons2022/XIcon/XIcon24Regular.d.ts +2 -0
  466. package/cjs/internal/icons2022/XIcon/XIcon24Regular.js +12 -0
  467. package/cjs/internal/icons2022/XIcon/XIcon24Regular.js.map +1 -0
  468. package/cjs/internal/icons2022/iconConstants.d.ts +8 -0
  469. package/cjs/internal/icons2022/iconConstants.js +11 -0
  470. package/cjs/internal/icons2022/iconConstants.js.map +1 -0
  471. package/cjs/internal/icons2022/iconSizer.d.ts +11 -0
  472. package/cjs/internal/icons2022/iconSizer.js +33 -0
  473. package/cjs/internal/icons2022/iconSizer.js.map +1 -0
  474. package/cjs/internal/themes/DarkTheme.d.ts +2 -0
  475. package/cjs/internal/themes/DarkTheme.js +7 -5
  476. package/cjs/internal/themes/DarkTheme.js.map +1 -1
  477. package/cjs/internal/themes/DefaultTheme.d.ts +138 -1
  478. package/cjs/internal/themes/DefaultTheme.js +257 -19
  479. package/cjs/internal/themes/DefaultTheme.js.map +1 -1
  480. package/cjs/internal/themes/NotFlat.d.ts +1 -0
  481. package/cjs/internal/themes/NotFlat.js +2 -1
  482. package/cjs/internal/themes/NotFlat.js.map +1 -1
  483. package/cjs/internal/themes/Theme2022.d.ts +234 -19
  484. package/cjs/internal/themes/Theme2022.js +462 -64
  485. package/cjs/internal/themes/Theme2022.js.map +1 -1
  486. package/cjs/internal/themes/Theme2022Dark.d.ts +190 -1
  487. package/cjs/internal/themes/Theme2022Dark.js +344 -4
  488. package/cjs/internal/themes/Theme2022Dark.js.map +1 -1
  489. package/cjs/lib/chars.d.ts +8 -0
  490. package/cjs/lib/chars.js +8 -0
  491. package/cjs/lib/chars.js.map +1 -0
  492. package/cjs/lib/theming/ThemeHelpers.d.ts +6 -0
  493. package/cjs/lib/theming/ThemeHelpers.js +21 -1
  494. package/cjs/lib/theming/ThemeHelpers.js.map +1 -1
  495. package/cjs/lib/theming/themes/Theme2022.d.ts +1 -1
  496. package/cjs/lib/theming/themes/Theme2022.js +2 -1
  497. package/cjs/lib/theming/themes/Theme2022.js.map +1 -1
  498. package/cjs/lib/theming/themes/Theme2022Dark.js +1 -1
  499. package/cjs/lib/theming/themes/Theme2022Dark.js.map +1 -1
  500. package/cjs/lib/utils.d.ts +2 -0
  501. package/cjs/lib/utils.js +15 -2
  502. package/cjs/lib/utils.js.map +1 -1
  503. package/components/Autocomplete/Autocomplete/Autocomplete.js +6 -4
  504. package/components/Autocomplete/Autocomplete/Autocomplete.js.map +1 -1
  505. package/components/Autocomplete/getAutocompleteTheme/getAutocompleteTheme.js +6 -0
  506. package/components/Autocomplete/getAutocompleteTheme/getAutocompleteTheme.js.map +1 -0
  507. package/components/Autocomplete/getAutocompleteTheme/package.json +6 -0
  508. package/components/Autocomplete/getAutocompleteTheme.d.ts +2 -0
  509. package/components/Button/ArrowLeftIcon/ArrowLeftIcon.js +17 -0
  510. package/components/Button/ArrowLeftIcon/ArrowLeftIcon.js.map +1 -0
  511. package/components/Button/ArrowLeftIcon/package.json +6 -0
  512. package/components/Button/ArrowLeftIcon.d.ts +3 -0
  513. package/components/Button/ArrowRightIcon/ArrowRightIcon.js +17 -0
  514. package/components/Button/ArrowRightIcon/ArrowRightIcon.js.map +1 -0
  515. package/components/Button/ArrowRightIcon/package.json +6 -0
  516. package/components/Button/ArrowRightIcon.d.ts +3 -0
  517. package/components/Button/Button/Button.js +99 -68
  518. package/components/Button/Button/Button.js.map +1 -1
  519. package/components/Button/Button.d.ts +8 -4
  520. package/components/Button/Button.md +42 -8
  521. package/components/Button/Button.mixins/Button.mixins.js +3 -3
  522. package/components/Button/Button.mixins/Button.mixins.js.map +1 -1
  523. package/components/Button/Button.styles/Button.styles.js +147 -62
  524. package/components/Button/Button.styles/Button.styles.js.map +1 -1
  525. package/components/Button/Button.styles.d.ts +30 -0
  526. package/components/Button/ButtonArrow/ButtonArrow.js +72 -0
  527. package/components/Button/ButtonArrow/ButtonArrow.js.map +1 -0
  528. package/components/Button/ButtonArrow/package.json +6 -0
  529. package/components/Button/ButtonArrow.d.ts +8 -0
  530. package/components/Button/ButtonIcon/ButtonIcon.js +61 -0
  531. package/components/Button/ButtonIcon/ButtonIcon.js.map +1 -0
  532. package/components/Button/ButtonIcon/package.json +6 -0
  533. package/components/Button/ButtonIcon.d.ts +7 -0
  534. package/components/Button/getInnerLinkTheme/getInnerLinkTheme.js +11 -0
  535. package/components/Button/getInnerLinkTheme/getInnerLinkTheme.js.map +1 -0
  536. package/components/Button/getInnerLinkTheme/package.json +6 -0
  537. package/components/Button/getInnerLinkTheme.d.ts +2 -0
  538. package/components/Checkbox/Checkbox/Checkbox.js +24 -8
  539. package/components/Checkbox/Checkbox/Checkbox.js.map +1 -1
  540. package/components/Checkbox/Checkbox.styles/Checkbox.styles.js +8 -5
  541. package/components/Checkbox/Checkbox.styles/Checkbox.styles.js.map +1 -1
  542. package/components/Checkbox/Checkbox.styles.d.ts +1 -0
  543. package/components/Checkbox/CheckedIcon/CheckedIcon.js +18 -0
  544. package/components/Checkbox/CheckedIcon/CheckedIcon.js.map +1 -0
  545. package/components/Checkbox/CheckedIcon/package.json +6 -0
  546. package/components/Checkbox/CheckedIcon.d.ts +3 -0
  547. package/components/Checkbox/IndeterminateIcon/IndeterminateIcon.js +21 -0
  548. package/components/Checkbox/IndeterminateIcon/IndeterminateIcon.js.map +1 -0
  549. package/components/Checkbox/IndeterminateIcon/package.json +6 -0
  550. package/components/Checkbox/IndeterminateIcon.d.ts +3 -0
  551. package/components/CurrencyInput/CurrencyInputKeyboardActions.d.ts +1 -1
  552. package/components/DateInput/CalendarIcon/CalendarIcon.js +23 -0
  553. package/components/DateInput/CalendarIcon/CalendarIcon.js.map +1 -0
  554. package/components/DateInput/CalendarIcon/package.json +6 -0
  555. package/components/DateInput/CalendarIcon.d.ts +3 -0
  556. package/components/DateInput/DateInput/DateInput.js +6 -1
  557. package/components/DateInput/DateInput/DateInput.js.map +1 -1
  558. package/components/DatePicker/DatePicker/DatePicker.js +10 -4
  559. package/components/DatePicker/DatePicker/DatePicker.js.map +1 -1
  560. package/components/DatePicker/DatePicker.d.ts +1 -0
  561. package/components/DatePicker/Picker/Picker.js +17 -0
  562. package/components/DatePicker/Picker/Picker.js.map +1 -1
  563. package/components/DatePicker/Picker.styles/Picker.styles.js +1 -1
  564. package/components/DatePicker/Picker.styles/Picker.styles.js.map +1 -1
  565. package/components/Dropdown/Dropdown/Dropdown.js +4 -8
  566. package/components/Dropdown/Dropdown/Dropdown.js.map +1 -1
  567. package/components/Dropdown/getDropdownTheme/getDropdownTheme.js +7 -0
  568. package/components/Dropdown/getDropdownTheme/getDropdownTheme.js.map +1 -0
  569. package/components/Dropdown/getDropdownTheme/package.json +6 -0
  570. package/components/Dropdown/getDropdownTheme.d.ts +2 -0
  571. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js +2 -4
  572. package/components/DropdownMenu/DropdownMenu/DropdownMenu.js.map +1 -1
  573. package/components/DropdownMenu/getDropdownMenuTheme/getDropdownMenuTheme.js +6 -0
  574. package/components/DropdownMenu/getDropdownMenuTheme/getDropdownMenuTheme.js.map +1 -0
  575. package/components/DropdownMenu/getDropdownMenuTheme/package.json +6 -0
  576. package/components/DropdownMenu/getDropdownMenuTheme.d.ts +2 -0
  577. package/components/FileUploader/FileUploader/FileUploader.js +26 -13
  578. package/components/FileUploader/FileUploader/FileUploader.js.map +1 -1
  579. package/components/FileUploader/FileUploader.styles/FileUploader.styles.js +44 -34
  580. package/components/FileUploader/FileUploader.styles/FileUploader.styles.js.map +1 -1
  581. package/components/FileUploader/FileUploader.styles.d.ts +7 -2
  582. package/components/FileUploader/UploadIcon/UploadIcon.js +23 -0
  583. package/components/FileUploader/UploadIcon/UploadIcon.js.map +1 -0
  584. package/components/FileUploader/UploadIcon/package.json +6 -0
  585. package/components/FileUploader/UploadIcon.d.ts +3 -0
  586. package/components/FxInput/FxInput/FxInput.js +42 -13
  587. package/components/FxInput/FxInput/FxInput.js.map +1 -1
  588. package/components/FxInput/FxInput.d.ts +1 -0
  589. package/components/FxInput/FxInputRestoreBtn/FxInputRestoreBtn.js +62 -0
  590. package/components/FxInput/FxInputRestoreBtn/FxInputRestoreBtn.js.map +1 -0
  591. package/components/FxInput/FxInputRestoreBtn/package.json +6 -0
  592. package/components/FxInput/FxInputRestoreBtn.d.ts +5 -0
  593. package/components/FxInput/MathFunctionIcon/MathFunctionIcon.js +17 -0
  594. package/components/FxInput/MathFunctionIcon/MathFunctionIcon.js.map +1 -0
  595. package/components/FxInput/MathFunctionIcon/package.json +6 -0
  596. package/components/FxInput/MathFunctionIcon.d.ts +3 -0
  597. package/components/FxInput/UndoIcon/UndoIcon.js +17 -0
  598. package/components/FxInput/UndoIcon/UndoIcon.js.map +1 -0
  599. package/components/FxInput/UndoIcon/package.json +6 -0
  600. package/components/FxInput/UndoIcon.d.ts +3 -0
  601. package/components/Group/Group/Group.js +29 -6
  602. package/components/Group/Group/Group.js.map +1 -1
  603. package/components/Group/Group.d.ts +2 -0
  604. package/components/Input/Input/Input.js +93 -17
  605. package/components/Input/Input/Input.js.map +1 -1
  606. package/components/Input/Input.d.ts +23 -7
  607. package/components/Input/Input.md +49 -0
  608. package/components/Input/Input.styles/Input.styles.js +44 -41
  609. package/components/Input/Input.styles/Input.styles.js.map +1 -1
  610. package/components/Input/Input.styles.d.ts +1 -0
  611. package/components/Input/InputLayout/InputLayout/InputLayout.js +34 -0
  612. package/components/Input/InputLayout/InputLayout/InputLayout.js.map +1 -0
  613. package/components/Input/InputLayout/InputLayout/package.json +6 -0
  614. package/components/Input/InputLayout/InputLayout.d.ts +10 -0
  615. package/components/Input/InputLayout/InputLayout.styles/InputLayout.styles.js +32 -0
  616. package/components/Input/InputLayout/InputLayout.styles/InputLayout.styles.js.map +1 -0
  617. package/components/Input/InputLayout/InputLayout.styles/package.json +6 -0
  618. package/components/Input/InputLayout/InputLayout.styles.d.ts +11 -0
  619. package/components/Input/InputLayout/InputLayoutAside/InputLayoutAside.js +28 -0
  620. package/components/Input/InputLayout/InputLayoutAside/InputLayoutAside.js.map +1 -0
  621. package/components/Input/InputLayout/InputLayoutAside/package.json +6 -0
  622. package/components/Input/InputLayout/InputLayoutAside.d.ts +8 -0
  623. package/components/Input/InputLayout/InputLayoutAsideIcon/InputLayoutAsideIcon.js +51 -0
  624. package/components/Input/InputLayout/InputLayoutAsideIcon/InputLayoutAsideIcon.js.map +1 -0
  625. package/components/Input/InputLayout/InputLayoutAsideIcon/package.json +6 -0
  626. package/components/Input/InputLayout/InputLayoutAsideIcon.d.ts +7 -0
  627. package/components/Input/InputLayout/InputLayoutAsideText/InputLayoutAsideText.js +18 -0
  628. package/components/Input/InputLayout/InputLayoutAsideText/InputLayoutAsideText.js.map +1 -0
  629. package/components/Input/InputLayout/InputLayoutAsideText/package.json +6 -0
  630. package/components/Input/InputLayout/InputLayoutAsideText.d.ts +6 -0
  631. package/components/Input/InputLayout/InputLayoutContext/InputLayoutContext.js +7 -0
  632. package/components/Input/InputLayout/InputLayoutContext/InputLayoutContext.js.map +1 -0
  633. package/components/Input/InputLayout/InputLayoutContext/package.json +6 -0
  634. package/components/Input/InputLayout/InputLayoutContext.d.ts +9 -0
  635. package/components/Input/InputLayout/PolyfillPlaceholder/PolyfillPlaceholder.js +33 -0
  636. package/components/Input/InputLayout/PolyfillPlaceholder/PolyfillPlaceholder.js.map +1 -0
  637. package/components/Input/InputLayout/PolyfillPlaceholder/package.json +6 -0
  638. package/components/Input/InputLayout/PolyfillPlaceholder.d.ts +10 -0
  639. package/components/Kebab/Kebab/Kebab.js +40 -17
  640. package/components/Kebab/Kebab/Kebab.js.map +1 -1
  641. package/components/Kebab/Kebab.d.ts +2 -1
  642. package/components/Kebab/Kebab.styles/Kebab.styles.js +26 -14
  643. package/components/Kebab/Kebab.styles/Kebab.styles.js.map +1 -1
  644. package/components/Kebab/Kebab.styles.d.ts +8 -4
  645. package/components/Kebab/KebabIcon/KebabIcon.js +17 -0
  646. package/components/Kebab/KebabIcon/KebabIcon.js.map +1 -0
  647. package/components/Kebab/KebabIcon/package.json +6 -0
  648. package/components/Kebab/KebabIcon.d.ts +3 -0
  649. package/components/Link/Link/Link.js +50 -18
  650. package/components/Link/Link/Link.js.map +1 -1
  651. package/components/Link/Link.d.ts +20 -4
  652. package/components/Link/Link.md +11 -0
  653. package/components/Link/Link.mixins/Link.mixins.js +6 -0
  654. package/components/Link/Link.mixins/Link.mixins.js.map +1 -1
  655. package/components/Link/Link.mixins.d.ts +2 -0
  656. package/components/Link/Link.styles/Link.styles.js +35 -14
  657. package/components/Link/Link.styles/Link.styles.js.map +1 -1
  658. package/components/Link/Link.styles.d.ts +9 -0
  659. package/components/Loader/Loader/Loader.js +3 -4
  660. package/components/Loader/Loader/Loader.js.map +1 -1
  661. package/components/Loader/Loader.d.ts +4 -4
  662. package/components/Loader/Loader.styles/Loader.styles.js +1 -1
  663. package/components/Loader/Loader.styles/Loader.styles.js.map +1 -1
  664. package/components/MenuItem/MenuItem.styles/MenuItem.styles.js +2 -2
  665. package/components/MenuItem/MenuItem.styles/MenuItem.styles.js.map +1 -1
  666. package/components/MenuSeparator/MenuSeparator.styles/MenuSeparator.styles.js +1 -1
  667. package/components/MenuSeparator/MenuSeparator.styles/MenuSeparator.styles.js.map +1 -1
  668. package/components/Modal/Modal/Modal.js +5 -2
  669. package/components/Modal/Modal/Modal.js.map +1 -1
  670. package/components/Modal/Modal.styles/Modal.styles.js +17 -8
  671. package/components/Modal/Modal.styles/Modal.styles.js.map +1 -1
  672. package/components/Modal/Modal.styles.d.ts +4 -1
  673. package/components/Modal/ModalBody/ModalBody.js +5 -2
  674. package/components/Modal/ModalBody/ModalBody.js.map +1 -1
  675. package/components/Modal/ModalClose/ModalClose.js +4 -1
  676. package/components/Modal/ModalClose/ModalClose.js.map +1 -1
  677. package/components/Modal/ModalFooter/ModalFooter.js +6 -5
  678. package/components/Modal/ModalFooter/ModalFooter.js.map +1 -1
  679. package/components/Modal/ModalHeader/ModalHeader.js +6 -5
  680. package/components/Modal/ModalHeader/ModalHeader.js.map +1 -1
  681. package/components/Modal/ModalSeparator/ModalSeparator.js +13 -0
  682. package/components/Modal/ModalSeparator/ModalSeparator.js.map +1 -0
  683. package/components/Modal/ModalSeparator/package.json +6 -0
  684. package/components/Modal/ModalSeparator.d.ts +5 -0
  685. package/components/Modal/getModalBodyTheme/getModalBodyTheme.js +6 -0
  686. package/components/Modal/getModalBodyTheme/getModalBodyTheme.js.map +1 -0
  687. package/components/Modal/getModalBodyTheme/package.json +6 -0
  688. package/components/Modal/getModalBodyTheme.d.ts +2 -0
  689. package/components/Modal/getModalTheme/getModalTheme.js +6 -0
  690. package/components/Modal/getModalTheme/getModalTheme.js.map +1 -0
  691. package/components/Modal/getModalTheme/package.json +6 -0
  692. package/components/Modal/getModalTheme.d.ts +2 -0
  693. package/components/Paging/ForwardIcon/ForwardIcon.js +23 -0
  694. package/components/Paging/ForwardIcon/ForwardIcon.js.map +1 -0
  695. package/components/Paging/ForwardIcon/package.json +6 -0
  696. package/components/Paging/ForwardIcon.d.ts +3 -0
  697. package/components/Paging/Paging/Paging.js +14 -6
  698. package/components/Paging/Paging/Paging.js.map +1 -1
  699. package/components/Paging/Paging.styles/Paging.styles.js +3 -3
  700. package/components/Paging/Paging.styles/Paging.styles.js.map +1 -1
  701. package/components/PasswordInput/ClosedIcon/ClosedIcon.js +17 -0
  702. package/components/PasswordInput/ClosedIcon/ClosedIcon.js.map +1 -0
  703. package/components/PasswordInput/ClosedIcon/package.json +6 -0
  704. package/components/PasswordInput/ClosedIcon.d.ts +3 -0
  705. package/components/PasswordInput/OpenedIcon/OpenedIcon.js +17 -0
  706. package/components/PasswordInput/OpenedIcon/OpenedIcon.js.map +1 -0
  707. package/components/PasswordInput/OpenedIcon/package.json +6 -0
  708. package/components/PasswordInput/OpenedIcon.d.ts +3 -0
  709. package/components/PasswordInput/PasswordInput/PasswordInput.js +4 -1
  710. package/components/PasswordInput/PasswordInput/PasswordInput.js.map +1 -1
  711. package/components/PasswordInput/PasswordInputIcon/PasswordInputIcon.js +14 -3
  712. package/components/PasswordInput/PasswordInputIcon/PasswordInputIcon.js.map +1 -1
  713. package/components/PasswordInput/PasswordInputIcon.d.ts +5 -3
  714. package/components/Radio/Radio.styles/Radio.styles.js +1 -1
  715. package/components/Radio/Radio.styles/Radio.styles.js.map +1 -1
  716. package/components/Select/ArrowDownIcon/ArrowDownIcon.js +23 -0
  717. package/components/Select/ArrowDownIcon/ArrowDownIcon.js.map +1 -0
  718. package/components/Select/ArrowDownIcon/package.json +6 -0
  719. package/components/Select/ArrowDownIcon.d.ts +3 -0
  720. package/components/Select/Select/Select.js +13 -3
  721. package/components/Select/Select/Select.js.map +1 -1
  722. package/components/SidePage/SidePage.styles/SidePage.styles.js +1 -1
  723. package/components/SidePage/SidePage.styles/SidePage.styles.js.map +1 -1
  724. package/components/SidePage/SidePageFooter/SidePageFooter.js +11 -1
  725. package/components/SidePage/SidePageFooter/SidePageFooter.js.map +1 -1
  726. package/components/SidePage/SidePageHeader/SidePageHeader.js +18 -2
  727. package/components/SidePage/SidePageHeader/SidePageHeader.js.map +1 -1
  728. package/components/SidePage/SidePageHeader.d.ts +3 -0
  729. package/components/Spinner/Spinner/Spinner.js +7 -7
  730. package/components/Spinner/Spinner/Spinner.js.map +1 -1
  731. package/components/Spinner/Spinner.d.ts +4 -4
  732. package/components/Spinner/Spinner.styles/Spinner.styles.js +14 -5
  733. package/components/Spinner/Spinner.styles/Spinner.styles.js.map +1 -1
  734. package/components/Spinner/Spinner.styles.d.ts +3 -0
  735. package/components/Tabs/Indicator.styles/Indicator.styles.js +1 -1
  736. package/components/Tabs/Indicator.styles/Indicator.styles.js.map +1 -1
  737. package/components/Textarea/Textarea/Textarea.js +1 -1
  738. package/components/Textarea/Textarea/Textarea.js.map +1 -1
  739. package/components/Textarea/Textarea.styles/Textarea.styles.js +15 -12
  740. package/components/Textarea/Textarea.styles/Textarea.styles.js.map +1 -1
  741. package/components/Textarea/Textarea.styles.d.ts +1 -0
  742. package/components/Textarea/TextareaCounter/TextareaCounter.js +12 -5
  743. package/components/Textarea/TextareaCounter/TextareaCounter.js.map +1 -1
  744. package/components/Toast/Toast.md +2 -2
  745. package/components/Toast/ToastView/ToastView.js +17 -0
  746. package/components/Toast/ToastView/ToastView.js.map +1 -1
  747. package/components/Toast/ToastView.styles/ToastView.styles.js +3 -1
  748. package/components/Toast/ToastView.styles/ToastView.styles.js.map +1 -1
  749. package/components/Toggle/Toggle/Toggle.js +9 -5
  750. package/components/Toggle/Toggle/Toggle.js.map +1 -1
  751. package/components/Toggle/Toggle.d.ts +5 -1
  752. package/components/Toggle/Toggle.styles/Toggle.styles.js +29 -20
  753. package/components/Toggle/Toggle.styles/Toggle.styles.js.map +1 -1
  754. package/components/Toggle/Toggle.styles.d.ts +3 -0
  755. package/components/Token/Token/Token.js +21 -13
  756. package/components/Token/Token/Token.js.map +1 -1
  757. package/components/Token/Token.styles/Token.styles.js +28 -10
  758. package/components/Token/Token.styles/Token.styles.js.map +1 -1
  759. package/components/Token/Token.styles.d.ts +6 -0
  760. package/components/TokenInput/TokenInput/TokenInput.js +6 -2
  761. package/components/TokenInput/TokenInput/TokenInput.js.map +1 -1
  762. package/components/TokenInput/TokenInput.d.ts +1 -0
  763. package/components/TokenInput/TokenInput.styles/TokenInput.styles.js +15 -12
  764. package/components/TokenInput/TokenInput.styles/TokenInput.styles.js.map +1 -1
  765. package/components/TokenInput/TokenInput.styles.d.ts +1 -0
  766. package/components/TokenInput/TokenInputMenu/TokenInputMenu.js +2 -1
  767. package/components/TokenInput/TokenInputMenu/TokenInputMenu.js.map +1 -1
  768. package/components/Tooltip/Tooltip/Tooltip.js +11 -2
  769. package/components/Tooltip/Tooltip/Tooltip.js.map +1 -1
  770. package/components/Tooltip/Tooltip.styles/Tooltip.styles.js +1 -1
  771. package/components/Tooltip/Tooltip.styles/Tooltip.styles.js.map +1 -1
  772. package/internal/Calendar/DayCellView/DayCellView.js +10 -3
  773. package/internal/Calendar/DayCellView/DayCellView.js.map +1 -1
  774. package/internal/Calendar/DayCellView.styles/DayCellView.styles.js +11 -2
  775. package/internal/Calendar/DayCellView.styles/DayCellView.styles.js.map +1 -1
  776. package/internal/Calendar/DayCellView.styles.d.ts +5 -0
  777. package/internal/CloseButtonIcon/CloseButtonIcon/CloseButtonIcon.js +66 -0
  778. package/internal/CloseButtonIcon/CloseButtonIcon/CloseButtonIcon.js.map +1 -0
  779. package/internal/CloseButtonIcon/CloseButtonIcon/package.json +6 -0
  780. package/internal/CloseButtonIcon/CloseButtonIcon.d.ts +35 -0
  781. package/internal/CloseButtonIcon/CloseButtonIcon.styles/CloseButtonIcon.styles.js +20 -0
  782. package/internal/CloseButtonIcon/CloseButtonIcon.styles/CloseButtonIcon.styles.js.map +1 -0
  783. package/internal/CloseButtonIcon/CloseButtonIcon.styles/package.json +6 -0
  784. package/internal/CloseButtonIcon/CloseButtonIcon.styles.d.ts +7 -0
  785. package/internal/CloseButtonIcon/CrossIcon/CrossIcon.js +18 -0
  786. package/internal/CloseButtonIcon/CrossIcon/CrossIcon.js.map +1 -0
  787. package/internal/CloseButtonIcon/CrossIcon/package.json +6 -0
  788. package/internal/CloseButtonIcon/CrossIcon.d.ts +3 -0
  789. package/internal/CustomComboBox/ArrowDownIcon/ArrowDownIcon.js +17 -0
  790. package/internal/CustomComboBox/ArrowDownIcon/ArrowDownIcon.js.map +1 -0
  791. package/internal/CustomComboBox/ArrowDownIcon/package.json +6 -0
  792. package/internal/CustomComboBox/ArrowDownIcon.d.ts +3 -0
  793. package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js +2 -1
  794. package/internal/CustomComboBox/ComboBoxMenu/ComboBoxMenu.js.map +1 -1
  795. package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js +30 -2
  796. package/internal/CustomComboBox/ComboBoxView/ComboBoxView.js.map +1 -1
  797. package/internal/CustomComboBox/ComboBoxView.d.ts +2 -0
  798. package/internal/CustomComboBox/getComboBoxTheme/getComboBoxTheme.js +6 -0
  799. package/internal/CustomComboBox/getComboBoxTheme/getComboBoxTheme.js.map +1 -0
  800. package/internal/CustomComboBox/getComboBoxTheme/package.json +6 -0
  801. package/internal/CustomComboBox/getComboBoxTheme.d.ts +2 -0
  802. package/internal/DateSelect/DateSelect/DateSelect.js +36 -2
  803. package/internal/DateSelect/DateSelect/DateSelect.js.map +1 -1
  804. package/internal/DateSelect/DateSelect.d.ts +1 -0
  805. package/internal/DateSelect/DateSelect.styles/DateSelect.styles.js +19 -16
  806. package/internal/DateSelect/DateSelect.styles/DateSelect.styles.js.map +1 -1
  807. package/internal/DateSelect/DateSelect.styles.d.ts +1 -0
  808. package/internal/FileUploaderControl/FileUploaderFile/DeleteIcon/DeleteIcon.js +23 -0
  809. package/internal/FileUploaderControl/FileUploaderFile/DeleteIcon/DeleteIcon.js.map +1 -0
  810. package/internal/FileUploaderControl/FileUploaderFile/DeleteIcon/package.json +6 -0
  811. package/internal/FileUploaderControl/FileUploaderFile/DeleteIcon.d.ts +3 -0
  812. package/internal/FileUploaderControl/FileUploaderFile/ErrorIcon/ErrorIcon.js +23 -0
  813. package/internal/FileUploaderControl/FileUploaderFile/ErrorIcon/ErrorIcon.js.map +1 -0
  814. package/internal/FileUploaderControl/FileUploaderFile/ErrorIcon/package.json +6 -0
  815. package/internal/FileUploaderControl/FileUploaderFile/ErrorIcon.d.ts +3 -0
  816. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFile/FileUploaderFile.js +8 -34
  817. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFile/FileUploaderFile.js.map +1 -1
  818. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon/FileUploaderFileStatusIcon.js +60 -0
  819. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon/FileUploaderFileStatusIcon.js.map +1 -0
  820. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon/package.json +6 -0
  821. package/internal/FileUploaderControl/FileUploaderFile/FileUploaderFileStatusIcon.d.ts +12 -0
  822. package/internal/FileUploaderControl/FileUploaderFile/OkIcon/OkIcon.js +23 -0
  823. package/internal/FileUploaderControl/FileUploaderFile/OkIcon/OkIcon.js.map +1 -0
  824. package/internal/FileUploaderControl/FileUploaderFile/OkIcon/package.json +6 -0
  825. package/internal/FileUploaderControl/FileUploaderFile/OkIcon.d.ts +3 -0
  826. package/internal/InputLikeText/InputLikeText/InputLikeText.js +24 -8
  827. package/internal/InputLikeText/InputLikeText/InputLikeText.js.map +1 -1
  828. package/internal/InternalMenu/InternalMenu.styles/InternalMenu.styles.js +1 -1
  829. package/internal/InternalMenu/InternalMenu.styles/InternalMenu.styles.js.map +1 -1
  830. package/internal/Menu/Menu/Menu.js +8 -1
  831. package/internal/Menu/Menu/Menu.js.map +1 -1
  832. package/internal/Menu/Menu.styles/Menu.styles.js +2 -2
  833. package/internal/Menu/Menu.styles/Menu.styles.js.map +1 -1
  834. package/internal/ThemePlayground/constants/constants.js +3 -0
  835. package/internal/ThemePlayground/constants/constants.js.map +1 -1
  836. package/internal/ThemeShowcase/VariablesCollector.d.ts +1 -1
  837. package/internal/icons/SpinnerIcon/SpinnerIcon.js +9 -1
  838. package/internal/icons/SpinnerIcon/SpinnerIcon.js.map +1 -1
  839. package/internal/icons/SpinnerIcon.d.ts +20 -14
  840. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light/ArrowALeftIcon16Light.js +11 -0
  841. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light/ArrowALeftIcon16Light.js.map +1 -0
  842. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light/package.json +6 -0
  843. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light.d.ts +2 -0
  844. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light/ArrowALeftIcon20Light.js +12 -0
  845. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light/ArrowALeftIcon20Light.js.map +1 -0
  846. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light/package.json +6 -0
  847. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light.d.ts +2 -0
  848. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular/ArrowALeftIcon24Regular.js +12 -0
  849. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular/ArrowALeftIcon24Regular.js.map +1 -0
  850. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular/package.json +6 -0
  851. package/internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular.d.ts +2 -0
  852. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light/ArrowARightIcon16Light.js +11 -0
  853. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light/ArrowARightIcon16Light.js.map +1 -0
  854. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light/package.json +6 -0
  855. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light.d.ts +2 -0
  856. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light/ArrowARightIcon20Light.js +12 -0
  857. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light/ArrowARightIcon20Light.js.map +1 -0
  858. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light/package.json +6 -0
  859. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light.d.ts +2 -0
  860. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular/ArrowARightIcon24Regular.js +12 -0
  861. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular/ArrowARightIcon24Regular.js.map +1 -0
  862. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular/package.json +6 -0
  863. package/internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular.d.ts +2 -0
  864. package/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light/ArrowAUp16Light.js +11 -0
  865. package/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light/ArrowAUp16Light.js.map +1 -0
  866. package/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light/package.json +6 -0
  867. package/internal/icons2022/ArrowAUpIcon/ArrowAUp16Light.d.ts +2 -0
  868. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular/ArrowCDownIcon16Regular.js +11 -0
  869. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular/ArrowCDownIcon16Regular.js.map +1 -0
  870. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular/package.json +6 -0
  871. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon16Regular.d.ts +2 -0
  872. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular/ArrowCDownIcon20Regular.js +12 -0
  873. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular/ArrowCDownIcon20Regular.js.map +1 -0
  874. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular/package.json +6 -0
  875. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon20Regular.d.ts +2 -0
  876. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular/ArrowCDownIcon24Regular.js +12 -0
  877. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular/ArrowCDownIcon24Regular.js.map +1 -0
  878. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular/package.json +6 -0
  879. package/internal/icons2022/ArrowCDownIcon/ArrowCDownIcon24Regular.d.ts +2 -0
  880. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light/ArrowCRightIcon16Light.js +11 -0
  881. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light/ArrowCRightIcon16Light.js.map +1 -0
  882. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light/package.json +6 -0
  883. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon16Light.d.ts +2 -0
  884. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light/ArrowCRightIcon20Light.js +12 -0
  885. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light/ArrowCRightIcon20Light.js.map +1 -0
  886. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light/package.json +6 -0
  887. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon20Light.d.ts +2 -0
  888. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular/ArrowCRightIcon24Regular.js +12 -0
  889. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular/ArrowCRightIcon24Regular.js.map +1 -0
  890. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular/package.json +6 -0
  891. package/internal/icons2022/ArrowCRightIcon/ArrowCRightIcon24Regular.d.ts +2 -0
  892. package/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular/ArrowCUpIcon16Regular.js +11 -0
  893. package/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular/ArrowCUpIcon16Regular.js.map +1 -0
  894. package/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular/package.json +6 -0
  895. package/internal/icons2022/ArrowCUpIcon/ArrowCUpIcon16Regular.d.ts +2 -0
  896. package/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular/ArrowCollapseCVOpenIcon16Regular.js +13 -0
  897. package/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular/ArrowCollapseCVOpenIcon16Regular.js.map +1 -0
  898. package/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular/package.json +6 -0
  899. package/internal/icons2022/ArrowCollapseCVOpenIcon/ArrowCollapseCVOpenIcon16Regular.d.ts +2 -0
  900. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light/ArrowShapeDRadiusUpLeftIcon16Light.js +13 -0
  901. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light/ArrowShapeDRadiusUpLeftIcon16Light.js.map +1 -0
  902. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light/package.json +6 -0
  903. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon16Light.d.ts +2 -0
  904. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light/ArrowShapeDRadiusUpLeftIcon20Light.js +14 -0
  905. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light/ArrowShapeDRadiusUpLeftIcon20Light.js.map +1 -0
  906. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light/package.json +6 -0
  907. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon20Light.d.ts +2 -0
  908. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular/ArrowShapeDRadiusUpLeftIcon24Regular.js +14 -0
  909. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular/ArrowShapeDRadiusUpLeftIcon24Regular.js.map +1 -0
  910. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular/package.json +6 -0
  911. package/internal/icons2022/ArrowShapeDRadiusUpLeftIcon/ArrowShapeDRadiusUpLeftIcon24Regular.d.ts +2 -0
  912. package/internal/icons2022/BaseIcon/BaseIcon.js +31 -0
  913. package/internal/icons2022/BaseIcon/BaseIcon.js.map +1 -0
  914. package/internal/icons2022/BaseIcon/package.json +6 -0
  915. package/internal/icons2022/BaseIcon.d.ts +11 -0
  916. package/internal/icons2022/CalendarIcon/CalendarIcon16Light/CalendarIcon16Light.js +29 -0
  917. package/internal/icons2022/CalendarIcon/CalendarIcon16Light/CalendarIcon16Light.js.map +1 -0
  918. package/internal/icons2022/CalendarIcon/CalendarIcon16Light/package.json +6 -0
  919. package/internal/icons2022/CalendarIcon/CalendarIcon16Light.d.ts +2 -0
  920. package/internal/icons2022/CalendarIcon/CalendarIcon20Light/CalendarIcon20Light.js +30 -0
  921. package/internal/icons2022/CalendarIcon/CalendarIcon20Light/CalendarIcon20Light.js.map +1 -0
  922. package/internal/icons2022/CalendarIcon/CalendarIcon20Light/package.json +6 -0
  923. package/internal/icons2022/CalendarIcon/CalendarIcon20Light.d.ts +2 -0
  924. package/internal/icons2022/CalendarIcon/CalendarIcon24Regular/CalendarIcon24Regular.js +30 -0
  925. package/internal/icons2022/CalendarIcon/CalendarIcon24Regular/CalendarIcon24Regular.js.map +1 -0
  926. package/internal/icons2022/CalendarIcon/CalendarIcon24Regular/package.json +6 -0
  927. package/internal/icons2022/CalendarIcon/CalendarIcon24Regular.d.ts +2 -0
  928. package/internal/icons2022/CheckAIcon/CheckAIcon16Light/CheckAIcon16Light.js +11 -0
  929. package/internal/icons2022/CheckAIcon/CheckAIcon16Light/CheckAIcon16Light.js.map +1 -0
  930. package/internal/icons2022/CheckAIcon/CheckAIcon16Light/package.json +6 -0
  931. package/internal/icons2022/CheckAIcon/CheckAIcon16Light.d.ts +2 -0
  932. package/internal/icons2022/CheckAIcon/CheckAIcon16Regular/CheckAIcon16Regular.js +11 -0
  933. package/internal/icons2022/CheckAIcon/CheckAIcon16Regular/CheckAIcon16Regular.js.map +1 -0
  934. package/internal/icons2022/CheckAIcon/CheckAIcon16Regular/package.json +6 -0
  935. package/internal/icons2022/CheckAIcon/CheckAIcon16Regular.d.ts +2 -0
  936. package/internal/icons2022/CheckAIcon/CheckAIcon16Solid/CheckAIcon16Solid.js +11 -0
  937. package/internal/icons2022/CheckAIcon/CheckAIcon16Solid/CheckAIcon16Solid.js.map +1 -0
  938. package/internal/icons2022/CheckAIcon/CheckAIcon16Solid/package.json +6 -0
  939. package/internal/icons2022/CheckAIcon/CheckAIcon16Solid.d.ts +2 -0
  940. package/internal/icons2022/CheckAIcon/CheckAIcon20Light/CheckAIcon20Light.js +12 -0
  941. package/internal/icons2022/CheckAIcon/CheckAIcon20Light/CheckAIcon20Light.js.map +1 -0
  942. package/internal/icons2022/CheckAIcon/CheckAIcon20Light/package.json +6 -0
  943. package/internal/icons2022/CheckAIcon/CheckAIcon20Light.d.ts +2 -0
  944. package/internal/icons2022/CheckAIcon/CheckAIcon20Solid/CheckAIcon20Solid.js +12 -0
  945. package/internal/icons2022/CheckAIcon/CheckAIcon20Solid/CheckAIcon20Solid.js.map +1 -0
  946. package/internal/icons2022/CheckAIcon/CheckAIcon20Solid/package.json +6 -0
  947. package/internal/icons2022/CheckAIcon/CheckAIcon20Solid.d.ts +2 -0
  948. package/internal/icons2022/CheckAIcon/CheckAIcon24Regular/CheckAIcon24Regular.js +12 -0
  949. package/internal/icons2022/CheckAIcon/CheckAIcon24Regular/CheckAIcon24Regular.js.map +1 -0
  950. package/internal/icons2022/CheckAIcon/CheckAIcon24Regular/package.json +6 -0
  951. package/internal/icons2022/CheckAIcon/CheckAIcon24Regular.d.ts +2 -0
  952. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light/EyeClosedIcon16Light.js +11 -0
  953. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light/EyeClosedIcon16Light.js.map +1 -0
  954. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light/package.json +6 -0
  955. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon16Light.d.ts +2 -0
  956. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light/EyeClosedIcon20Light.js +12 -0
  957. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light/EyeClosedIcon20Light.js.map +1 -0
  958. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light/package.json +6 -0
  959. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon20Light.d.ts +2 -0
  960. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular/EyeClosedIcon24Regular.js +12 -0
  961. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular/EyeClosedIcon24Regular.js.map +1 -0
  962. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular/package.json +6 -0
  963. package/internal/icons2022/EyeClosedIcon/EyeClosedIcon24Regular.d.ts +2 -0
  964. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light/EyeOpenIcon16Light.js +17 -0
  965. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light/EyeOpenIcon16Light.js.map +1 -0
  966. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light/package.json +6 -0
  967. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon16Light.d.ts +2 -0
  968. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light/EyeOpenIcon20Light.js +18 -0
  969. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light/EyeOpenIcon20Light.js.map +1 -0
  970. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light/package.json +6 -0
  971. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon20Light.d.ts +2 -0
  972. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular/EyeOpenIcon24Regular.js +18 -0
  973. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular/EyeOpenIcon24Regular.js.map +1 -0
  974. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular/package.json +6 -0
  975. package/internal/icons2022/EyeOpenIcon/EyeOpenIcon24Regular.d.ts +2 -0
  976. package/internal/icons2022/LoadingIcon/LoadingIcon.js +43 -0
  977. package/internal/icons2022/LoadingIcon/LoadingIcon.js.map +1 -0
  978. package/internal/icons2022/LoadingIcon/package.json +6 -0
  979. package/internal/icons2022/LoadingIcon.d.ts +4 -0
  980. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light/MathFunctionIcon16Light.js +13 -0
  981. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light/MathFunctionIcon16Light.js.map +1 -0
  982. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light/package.json +6 -0
  983. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon16Light.d.ts +2 -0
  984. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light/MathFunctionIcon20Light.js +14 -0
  985. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light/MathFunctionIcon20Light.js.map +1 -0
  986. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light/package.json +6 -0
  987. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon20Light.d.ts +2 -0
  988. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular/MathFunctionIcon24Regular.js +14 -0
  989. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular/MathFunctionIcon24Regular.js.map +1 -0
  990. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular/package.json +6 -0
  991. package/internal/icons2022/MathFunctionIcon/MathFunctionIcon24Regular.d.ts +2 -0
  992. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light/MinusCircleIcon16Light.js +15 -0
  993. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light/MinusCircleIcon16Light.js.map +1 -0
  994. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light/package.json +6 -0
  995. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Light.d.ts +2 -0
  996. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular/MinusCircleIcon16Regular.js +15 -0
  997. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular/MinusCircleIcon16Regular.js.map +1 -0
  998. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular/package.json +6 -0
  999. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon16Regular.d.ts +2 -0
  1000. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light/MinusCircleIcon20Light.js +16 -0
  1001. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light/MinusCircleIcon20Light.js.map +1 -0
  1002. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light/package.json +6 -0
  1003. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon20Light.d.ts +2 -0
  1004. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular/MinusCircleIcon24Regular.js +16 -0
  1005. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular/MinusCircleIcon24Regular.js.map +1 -0
  1006. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular/package.json +6 -0
  1007. package/internal/icons2022/MinusCircleIcon/MinusCircleIcon24Regular.d.ts +2 -0
  1008. package/internal/icons2022/NetUploadIcon/NetUploadIcon16Light/NetUploadIcon16Light.js +13 -0
  1009. package/internal/icons2022/NetUploadIcon/NetUploadIcon16Light/NetUploadIcon16Light.js.map +1 -0
  1010. package/internal/icons2022/NetUploadIcon/NetUploadIcon16Light/package.json +6 -0
  1011. package/internal/icons2022/NetUploadIcon/NetUploadIcon16Light.d.ts +2 -0
  1012. package/internal/icons2022/NetUploadIcon/NetUploadIcon20Light/NetUploadIcon20Light.js +14 -0
  1013. package/internal/icons2022/NetUploadIcon/NetUploadIcon20Light/NetUploadIcon20Light.js.map +1 -0
  1014. package/internal/icons2022/NetUploadIcon/NetUploadIcon20Light/package.json +6 -0
  1015. package/internal/icons2022/NetUploadIcon/NetUploadIcon20Light.d.ts +2 -0
  1016. package/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular/NetUploadIcon24Regular.js +14 -0
  1017. package/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular/NetUploadIcon24Regular.js.map +1 -0
  1018. package/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular/package.json +6 -0
  1019. package/internal/icons2022/NetUploadIcon/NetUploadIcon24Regular.d.ts +2 -0
  1020. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid/QuestionCircleIcon16Solid.js +13 -0
  1021. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid/QuestionCircleIcon16Solid.js.map +1 -0
  1022. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid/package.json +6 -0
  1023. package/internal/icons2022/QuestionCircleIcon/QuestionCircleIcon16Solid.d.ts +2 -0
  1024. package/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular/SearchLoupeIcon16Regular.js +13 -0
  1025. package/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular/SearchLoupeIcon16Regular.js.map +1 -0
  1026. package/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular/package.json +6 -0
  1027. package/internal/icons2022/SearchLoupeIcon/SearchLoupeIcon16Regular.d.ts +2 -0
  1028. package/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid/ShapeSquareIcon16Solid.js +11 -0
  1029. package/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid/ShapeSquareIcon16Solid.js.map +1 -0
  1030. package/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid/package.json +6 -0
  1031. package/internal/icons2022/ShapeSquareIcon/ShapeSquareIcon16Solid.d.ts +2 -0
  1032. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light/UiMenuDotsThreeVIcon16Light.js +15 -0
  1033. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light/UiMenuDotsThreeVIcon16Light.js.map +1 -0
  1034. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light/package.json +6 -0
  1035. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon16Light.d.ts +2 -0
  1036. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular/UiMenuDotsThreeVIcon20Regular.js +16 -0
  1037. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular/UiMenuDotsThreeVIcon20Regular.js.map +1 -0
  1038. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular/package.json +6 -0
  1039. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon20Regular.d.ts +2 -0
  1040. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular/UiMenuDotsThreeVIcon24Regular.js +16 -0
  1041. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular/UiMenuDotsThreeVIcon24Regular.js.map +1 -0
  1042. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular/package.json +6 -0
  1043. package/internal/icons2022/UiMenuDotsThreeVIcon/UiMenuDotsThreeVIcon24Regular.d.ts +2 -0
  1044. package/internal/icons2022/XIcon/XIcon16Light/XIcon16Light.js +11 -0
  1045. package/internal/icons2022/XIcon/XIcon16Light/XIcon16Light.js.map +1 -0
  1046. package/internal/icons2022/XIcon/XIcon16Light/package.json +6 -0
  1047. package/internal/icons2022/XIcon/XIcon16Light.d.ts +2 -0
  1048. package/internal/icons2022/XIcon/XIcon16Regular/XIcon16Regular.js +11 -0
  1049. package/internal/icons2022/XIcon/XIcon16Regular/XIcon16Regular.js.map +1 -0
  1050. package/internal/icons2022/XIcon/XIcon16Regular/package.json +6 -0
  1051. package/internal/icons2022/XIcon/XIcon16Regular.d.ts +2 -0
  1052. package/internal/icons2022/XIcon/XIcon20Light/XIcon20Light.js +12 -0
  1053. package/internal/icons2022/XIcon/XIcon20Light/XIcon20Light.js.map +1 -0
  1054. package/internal/icons2022/XIcon/XIcon20Light/package.json +6 -0
  1055. package/internal/icons2022/XIcon/XIcon20Light.d.ts +2 -0
  1056. package/internal/icons2022/XIcon/XIcon20Regular/XIcon20Regular.js +12 -0
  1057. package/internal/icons2022/XIcon/XIcon20Regular/XIcon20Regular.js.map +1 -0
  1058. package/internal/icons2022/XIcon/XIcon20Regular/package.json +6 -0
  1059. package/internal/icons2022/XIcon/XIcon20Regular.d.ts +2 -0
  1060. package/internal/icons2022/XIcon/XIcon24Regular/XIcon24Regular.js +12 -0
  1061. package/internal/icons2022/XIcon/XIcon24Regular/XIcon24Regular.js.map +1 -0
  1062. package/internal/icons2022/XIcon/XIcon24Regular/package.json +6 -0
  1063. package/internal/icons2022/XIcon/XIcon24Regular.d.ts +2 -0
  1064. package/internal/icons2022/iconConstants/iconConstants.js +7 -0
  1065. package/internal/icons2022/iconConstants/iconConstants.js.map +1 -0
  1066. package/internal/icons2022/iconConstants/package.json +6 -0
  1067. package/internal/icons2022/iconConstants.d.ts +8 -0
  1068. package/internal/icons2022/iconSizer/iconSizer.js +39 -0
  1069. package/internal/icons2022/iconSizer/iconSizer.js.map +1 -0
  1070. package/internal/icons2022/iconSizer/package.json +6 -0
  1071. package/internal/icons2022/iconSizer.d.ts +11 -0
  1072. package/internal/themes/DarkTheme/DarkTheme.js +3 -3
  1073. package/internal/themes/DarkTheme/DarkTheme.js.map +1 -1
  1074. package/internal/themes/DarkTheme.d.ts +2 -0
  1075. package/internal/themes/DefaultTheme/DefaultTheme.js +318 -25
  1076. package/internal/themes/DefaultTheme/DefaultTheme.js.map +1 -1
  1077. package/internal/themes/DefaultTheme.d.ts +138 -1
  1078. package/internal/themes/NotFlat/NotFlat.js +1 -0
  1079. package/internal/themes/NotFlat/NotFlat.js.map +1 -1
  1080. package/internal/themes/NotFlat.d.ts +1 -0
  1081. package/internal/themes/Theme2022/Theme2022.js +430 -20
  1082. package/internal/themes/Theme2022/Theme2022.js.map +1 -1
  1083. package/internal/themes/Theme2022.d.ts +234 -19
  1084. package/internal/themes/Theme2022Dark/Theme2022Dark.js +287 -2
  1085. package/internal/themes/Theme2022Dark/Theme2022Dark.js.map +1 -1
  1086. package/internal/themes/Theme2022Dark.d.ts +190 -1
  1087. package/lib/chars/chars.js +8 -0
  1088. package/lib/chars/chars.js.map +1 -0
  1089. package/lib/chars/package.json +6 -0
  1090. package/lib/chars.d.ts +8 -0
  1091. package/lib/theming/ThemeHelpers/ThemeHelpers.js +18 -0
  1092. package/lib/theming/ThemeHelpers/ThemeHelpers.js.map +1 -1
  1093. package/lib/theming/ThemeHelpers.d.ts +6 -0
  1094. package/lib/theming/themes/Theme2022/Theme2022.js +2 -1
  1095. package/lib/theming/themes/Theme2022/Theme2022.js.map +1 -1
  1096. package/lib/theming/themes/Theme2022.d.ts +1 -1
  1097. package/lib/theming/themes/Theme2022Dark/Theme2022Dark.js +2 -2
  1098. package/lib/theming/themes/Theme2022Dark/Theme2022Dark.js.map +1 -1
  1099. package/lib/utils/utils.js +2 -1
  1100. package/lib/utils/utils.js.map +1 -1
  1101. package/lib/utils.d.ts +2 -0
  1102. package/package.json +2 -2
package/CHANGELOG.md CHANGED
@@ -3,6 +3,23 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [4.14.0](https://github.com/skbkontur/retail-ui/compare/@skbkontur/react-ui@4.13.4...@skbkontur/react-ui@4.14.0) (2023-05-30)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * **ComboBox:** set as=div for MenuMessage ([#3162](https://github.com/skbkontur/retail-ui/issues/3162)) ([87a84b6](https://github.com/skbkontur/retail-ui/commit/87a84b67ebe79711f3fbad39566575343da73847))
12
+
13
+
14
+ ### Features
15
+
16
+ * **Input:** support new types (#IF-290) ([#3129](https://github.com/skbkontur/retail-ui/issues/3129)) ([c478aab](https://github.com/skbkontur/retail-ui/commit/c478aab0f2198bdadc22f8a6c726534f87270454)), closes [#IF-290](https://github.com/skbkontur/retail-ui/issues/IF-290)
17
+ * **theme:** add full support for THEME_2022 ([#3045](https://github.com/skbkontur/retail-ui/issues/3045)) ([6dac5a4](https://github.com/skbkontur/retail-ui/commit/6dac5a49c4c8aed6fcd8a83ce6fd65d7da211690))
18
+
19
+
20
+
21
+
22
+
6
23
  ## [4.13.4](https://github.com/skbkontur/retail-ui/compare/@skbkontur/react-ui@4.13.3...@skbkontur/react-ui@4.13.4) (2023-04-14)
7
24
 
8
25
 
@@ -24,7 +24,8 @@ var _rootNode = require("../../lib/rootNode");
24
24
  var _getDOMRect = require("../../lib/dom/getDOMRect");
25
25
 
26
26
  var _Autocomplete = require("./Autocomplete.styles");
27
- var _locale = require("./locale");var _excluded = ["onValueChange", "onKeyDown", "onFocus", "onBlur", "renderItem", "disablePortal", "hasShadow", "menuAlign", "menuMaxHeight", "preventWindowScroll", "source", "width", "mobileMenuHeaderText"];var _dec, _class, _class2, _temp;
27
+ var _locale = require("./locale");
28
+ var _getAutocompleteTheme = require("./getAutocompleteTheme");var _excluded = ["onValueChange", "onKeyDown", "onFocus", "onBlur", "renderItem", "disablePortal", "hasShadow", "menuAlign", "menuMaxHeight", "preventWindowScroll", "source", "width", "mobileMenuHeaderText"];var _dec, _class, _class2, _temp;
28
29
 
29
30
  function match(pattern, items) {
30
31
  if (!pattern || !items) {
@@ -196,6 +197,8 @@ Autocomplete = (_dec = (0, _decorators.locale)('Autocomplete', _locale.Autocompl
196
197
 
197
198
 
198
199
 
200
+
201
+
199
202
 
200
203
 
201
204
 
@@ -278,12 +281,6 @@ Autocomplete = (_dec = (0, _decorators.locale)('Autocomplete', _locale.Autocompl
278
281
 
279
282
 
280
283
 
281
-
282
-
283
-
284
-
285
-
286
-
287
284
 
288
285
 
289
286
 
@@ -508,7 +505,7 @@ Autocomplete = (_dec = (0, _decorators.locale)('Autocomplete', _locale.Autocompl
508
505
  * @public
509
506
  */_proto.focus = function focus() {if (this.input) {this.input.focus();}} /**
510
507
  * @public
511
- */;_proto.blur = function blur() {this.handleBlur();};_proto.componentDidUpdate = function componentDidUpdate(prevProps) {if (prevProps.value !== this.props.value) {this.updateItems(this.props.value || '');}};_proto.render = function render() {var _this2 = this;return /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Consumer, null, function (theme) {_this2.theme = theme;return /*#__PURE__*/_react.default.createElement(_CommonWrapper.CommonWrapper, (0, _extends2.default)({ rootNodeRef: _this2.setRootNode }, _this2.props), _this2.renderMain);});};_proto.renderHints = function renderHints() {var items = this.state.items;if (!this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.enterValue);}if ((items == null ? void 0 : items.length) === 0 && this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.notFound);}if ((0, _utils.isNullable)(items) && this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.updateValue);}return null;};_proto.renderMenu = function renderMenu() {var items = this.state.items;var _this$getProps = this.getProps(),menuMaxHeight = _this$getProps.menuMaxHeight,hasShadow = _this$getProps.hasShadow,menuWidth = _this$getProps.menuWidth,width = _this$getProps.width,preventWindowScroll = _this$getProps.preventWindowScroll,menuAlign = _this$getProps.menuAlign,disablePortal = _this$getProps.disablePortal,menuPos = _this$getProps.menuPos;var menuProps = { ref: this.refMenu, maxHeight: menuMaxHeight, hasShadow: hasShadow, width: menuWidth || width && (0, _getDOMRect.getDOMRect)(this.rootSpan).width, preventWindowScroll: preventWindowScroll };if (!items || items.length === 0) {return null;}return /*#__PURE__*/_react.default.createElement(_DropdownContainer.DropdownContainer, { offsetY: 1, getParent: this.getAnchor, align: menuAlign, disablePortal: disablePortal, menuPos: menuPos }, /*#__PURE__*/_react.default.createElement(_Menu.Menu, menuProps, this.getItems()));};_proto.handleMenuItemClick = function handleMenuItemClick(i) {var _this3 = this;return function (event) {return _this3.handleItemClick(event, i);};};_proto.handleItemClick = function handleItemClick(event, index) {if (event.button) {return;}event.preventDefault();this.choose(index);};_proto.choose = function choose(index) {if (!this.state.items) {return;}var value = this.state.items[index];this.opened = false;this.setState({ selected: -1, items: null });this.fireChange(value);this.blur();};_proto.updateItems = function updateItems(value) {var _this4 = this;if (!this.opened) {return;}var pattern = value.trim();var source = this.props.source;if (!source) {return;}var promise;this.requestId += 1;var expectingId = this.requestId;if (typeof source === 'function') {promise = source(pattern);} else {promise = match(pattern, source);}promise.then(function (items) {if (_this4.opened && expectingId === _this4.requestId) {_this4.setState({ items: items, selected: -1 });}});};_proto.fireChange = function fireChange(value) {if (this.props.onValueChange) {this.props.onValueChange(value);}};return Autocomplete;}(_react.default.Component), _class2.__KONTUR_REACT_UI__ = 'Autocomplete', _class2.propTypes = { /**
508
+ */;_proto.blur = function blur() {this.handleBlur();};_proto.componentDidUpdate = function componentDidUpdate(prevProps) {if (prevProps.value !== this.props.value) {this.updateItems(this.props.value || '');}};_proto.render = function render() {var _this2 = this;return /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Consumer, null, function (theme) {_this2.theme = (0, _getAutocompleteTheme.getAutocompleteTheme)(theme);return /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Provider, { value: _this2.theme }, /*#__PURE__*/_react.default.createElement(_CommonWrapper.CommonWrapper, (0, _extends2.default)({ rootNodeRef: _this2.setRootNode }, _this2.props), _this2.renderMain));});};_proto.renderHints = function renderHints() {var items = this.state.items;if (!this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.enterValue);}if ((items == null ? void 0 : items.length) === 0 && this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.notFound);}if ((0, _utils.isNullable)(items) && this.props.value) {return /*#__PURE__*/_react.default.createElement(_MenuMessage.MenuMessage, null, this.locale.updateValue);}return null;};_proto.renderMenu = function renderMenu() {var items = this.state.items;var _this$getProps = this.getProps(),menuMaxHeight = _this$getProps.menuMaxHeight,hasShadow = _this$getProps.hasShadow,menuWidth = _this$getProps.menuWidth,width = _this$getProps.width,preventWindowScroll = _this$getProps.preventWindowScroll,menuAlign = _this$getProps.menuAlign,disablePortal = _this$getProps.disablePortal,menuPos = _this$getProps.menuPos;var menuProps = { ref: this.refMenu, maxHeight: menuMaxHeight, hasShadow: hasShadow, width: menuWidth || width && (0, _getDOMRect.getDOMRect)(this.rootSpan).width, preventWindowScroll: preventWindowScroll };if (!items || items.length === 0) {return null;}return /*#__PURE__*/_react.default.createElement(_DropdownContainer.DropdownContainer, { getParent: this.getAnchor, align: menuAlign, disablePortal: disablePortal, menuPos: menuPos }, /*#__PURE__*/_react.default.createElement(_Menu.Menu, menuProps, this.getItems()));};_proto.handleMenuItemClick = function handleMenuItemClick(i) {var _this3 = this;return function (event) {return _this3.handleItemClick(event, i);};};_proto.handleItemClick = function handleItemClick(event, index) {if (event.button) {return;}event.preventDefault();this.choose(index);};_proto.choose = function choose(index) {if (!this.state.items) {return;}var value = this.state.items[index];this.opened = false;this.setState({ selected: -1, items: null });this.fireChange(value);this.blur();};_proto.updateItems = function updateItems(value) {var _this4 = this;if (!this.opened) {return;}var pattern = value.trim();var source = this.props.source;if (!source) {return;}var promise;this.requestId += 1;var expectingId = this.requestId;if (typeof source === 'function') {promise = source(pattern);} else {promise = match(pattern, source);}promise.then(function (items) {if (_this4.opened && expectingId === _this4.requestId) {_this4.setState({ items: items, selected: -1 });}});};_proto.fireChange = function fireChange(value) {if (this.props.onValueChange) {this.props.onValueChange(value);}};return Autocomplete;}(_react.default.Component), _class2.__KONTUR_REACT_UI__ = 'Autocomplete', _class2.propTypes = { /**
512
509
  * Функция для отрисовки элемента в выпадающем списке. Единственный аргумент
513
510
  * — *item*.
514
511
  */renderItem: _propTypes.default.func, /**
@@ -1 +1 @@
1
- {"version":3,"sources":["Autocomplete.tsx"],"names":["match","pattern","items","Promise","resolve","lowerCasedPattern","toLowerCase","itemsMatchingPattern","filter","item","includes","renderItem","AutocompleteDataTids","root","Autocomplete","AutocompleteLocaleHelper","responsiveLayout","rootNode","state","selected","focused","isMobileOpened","opened","input","requestId","getProps","defaultProps","renderMain","props","isMobile","isMobileLayout","onValueChange","onKeyDown","onFocus","onBlur","_renderItem","disablePortal","hasShadow","menuAlign","menuMaxHeight","preventWindowScroll","source","width","theme","inputWidth","mobileMenuHeaderText","rest","inputProps","handleValueChange","handleKeyDown","handleFocus","ref","refInput","handleBlur","handleClickOutside","styles","refRootSpan","renderMobileMenu","renderMenu","autoFocus","onKeyPress","handleKeyPressMobile","value","placeholder","locale","enterValue","handleCloseMobile","refMobilePopup","refMenu","mobilePopup","close","length","getItems","renderHints","map","i","handleMenuItemClick","fireChange","setState","e","key","event","blur","preventDefault","menu","up","down","enter","getAnchor","el","span","rootSpan","focus","componentDidUpdate","prevProps","updateItems","render","setRootNode","notFound","updateValue","menuWidth","menuPos","menuProps","maxHeight","handleItemClick","index","button","choose","trim","promise","expectingId","then","React","Component","__KONTUR_REACT_UI__","propTypes","PropTypes","func","oneOfType","array","size"],"mappings":"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","sourcesContent":["// TODO: Enable this rule in functional components.\n/* eslint-disable @typescript-eslint/no-unused-vars */\nimport React, { KeyboardEvent } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { MenuMessage } from '../../internal/MenuMessage';\nimport { locale } from '../../lib/locale/decorators';\nimport { isNullable } from '../../lib/utils';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { isKeyArrowDown, isKeyArrowUp, isKeyEnter, isKeyEscape } from '../../lib/events/keyboard/identifiers';\nimport { Input, InputProps } from '../Input';\nimport { DropdownContainer, DropdownContainerProps } from '../../internal/DropdownContainer';\nimport { Menu } from '../../internal/Menu';\nimport { MenuItem } from '../MenuItem';\nimport { RenderLayer } from '../../internal/RenderLayer';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\nimport { Nullable, Override } from '../../typings/utility-types';\nimport { fixClickFocusIE } from '../../lib/events/fixClickFocusIE';\nimport { CommonProps, CommonWrapper, CommonWrapperRestProps } from '../../internal/CommonWrapper';\nimport { MobilePopup } from '../../internal/MobilePopup';\nimport { responsiveLayout } from '../ResponsiveLayout/decorator';\nimport { getRootNode, rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { getDOMRect } from '../../lib/dom/getDOMRect';\n\nimport { styles } from './Autocomplete.styles';\nimport { AutocompleteLocale, AutocompleteLocaleHelper } from './locale';\n\nfunction match(pattern: string, items: string[]) {\n if (!pattern || !items) {\n return Promise.resolve([]);\n }\n\n const lowerCasedPattern = pattern.toLowerCase();\n const itemsMatchingPattern = items.filter((item) => {\n return item.toLowerCase().includes(lowerCasedPattern);\n });\n\n return Promise.resolve(itemsMatchingPattern);\n}\n\nfunction renderItem(item: any) {\n return item;\n}\n\nexport interface AutocompleteProps\n extends CommonProps,\n Pick<DropdownContainerProps, 'menuPos'>,\n Override<\n InputProps,\n {\n /** Функция отрисовки элемента меню */\n renderItem?: (item: string) => React.ReactNode;\n /** Промис, резолвящий элементы меню */\n source?: string[] | ((patter: string) => Promise<string[]>);\n /** Отключает использование портала */\n disablePortal?: boolean;\n /** Отрисовка тени у выпадающего меню */\n hasShadow?: boolean;\n /** Выравнивание выпадающего меню */\n menuAlign?: 'left' | 'right';\n /** Максимальная высота меню */\n menuMaxHeight?: number | string;\n /** Ширина меню */\n menuWidth?: number | string;\n /** Отключить скролл окна, когда меню открыто */\n preventWindowScroll?: boolean;\n /** Вызывается при изменении `value` */\n onValueChange: (value: string) => void;\n /** onBlur */\n onBlur?: () => void;\n /** Размер инпута */\n size?: InputProps['size'];\n /** value */\n value: string;\n /**\n * Текст заголовка выпадающего меню в мобильной версии\n */\n mobileMenuHeaderText?: string;\n }\n > {}\n\nexport interface AutocompleteState {\n items: Nullable<string[]>;\n selected: number;\n focused: boolean;\n isMobileOpened: boolean;\n}\n\nexport const AutocompleteDataTids = {\n root: 'Autocomplete__root',\n} as const;\n\ntype DefaultProps = Required<\n Pick<\n AutocompleteProps,\n 'renderItem' | 'size' | 'disablePortal' | 'hasShadow' | 'menuMaxHeight' | 'menuAlign' | 'preventWindowScroll'\n >\n>;\n\n/**\n * Стандартный инпут с подсказками.\n *\n * Все свойства передаются во внутренний *Input*.\n */\n@responsiveLayout\n@rootNode\n@locale('Autocomplete', AutocompleteLocaleHelper)\nexport class Autocomplete extends React.Component<AutocompleteProps, AutocompleteState> {\n public static __KONTUR_REACT_UI__ = 'Autocomplete';\n\n public static propTypes = {\n /**\n * Функция для отрисовки элемента в выпадающем списке. Единственный аргумент\n * — *item*.\n */\n renderItem: PropTypes.func,\n\n /**\n * Если передан массив, то совпадения ищутся по этому массиву.\n *\n * Если передается функция, то она должна возвращать thenable, который\n * резолвится уже отфильтрованным массивом. Возвращенный thenable может\n * иметь метод cancel, который будет вызван при отмене поиска (пользователь\n * изменил строку поиска, автокомплит потерял фокус).\n * ```\n * function(pattern) {\n * return service.findAll(pattern);\n * }\n * ```\n */\n source: PropTypes.oneOfType([PropTypes.array, PropTypes.func]),\n };\n\n public static defaultProps: DefaultProps = {\n renderItem,\n size: 'small',\n disablePortal: false,\n hasShadow: true,\n menuMaxHeight: 300,\n menuAlign: 'left',\n preventWindowScroll: true,\n };\n\n public state: AutocompleteState = {\n items: null,\n selected: -1,\n focused: false,\n isMobileOpened: false,\n };\n\n private theme!: Theme;\n private readonly locale!: AutocompleteLocale;\n private isMobileLayout!: boolean;\n private opened = false;\n private input: Nullable<Input> = null;\n private menu: Nullable<Menu>;\n private rootSpan: Nullable<HTMLSpanElement>;\n private mobilePopup: Nullable<MobilePopup>;\n\n private requestId = 0;\n\n private getProps = createPropsGetter(Autocomplete.defaultProps);\n private setRootNode!: TSetRootNode;\n\n /**\n * @public\n */\n public focus() {\n if (this.input) {\n this.input.focus();\n }\n }\n\n /**\n * @public\n */\n public blur() {\n this.handleBlur();\n }\n\n public componentDidUpdate(prevProps: AutocompleteProps) {\n if (prevProps.value !== this.props.value) {\n this.updateItems(this.props.value || '');\n }\n }\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n {this.renderMain}\n </CommonWrapper>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n public renderMain = (props: CommonWrapperRestProps<AutocompleteProps>) => {\n const { focused } = this.state;\n\n const isMobile = this.isMobileLayout;\n\n const {\n onValueChange,\n onKeyDown,\n onFocus,\n onBlur,\n renderItem: _renderItem,\n disablePortal,\n hasShadow,\n menuAlign,\n menuMaxHeight,\n preventWindowScroll,\n source,\n width = this.theme.inputWidth,\n mobileMenuHeaderText,\n ...rest\n } = props;\n\n const inputProps = {\n ...rest,\n width: '100%',\n onValueChange: this.handleValueChange,\n onKeyDown: this.handleKeyDown,\n onFocus: this.handleFocus,\n ref: this.refInput,\n };\n\n return (\n <RenderLayer onFocusOutside={this.handleBlur} onClickOutside={this.handleClickOutside} active={focused}>\n <span\n data-tid={AutocompleteDataTids.root}\n className={styles.root(this.theme)}\n style={{ width }}\n ref={this.refRootSpan}\n >\n <Input {...inputProps} />\n {isMobile ? this.renderMobileMenu() : this.renderMenu()}\n </span>\n </RenderLayer>\n );\n };\n\n private renderHints(): React.ReactNode {\n const items = this.state.items;\n\n if (!this.props.value) {\n return <MenuMessage>{this.locale.enterValue}</MenuMessage>;\n }\n\n if (items?.length === 0 && this.props.value) {\n return <MenuMessage>{this.locale.notFound}</MenuMessage>;\n }\n\n if (isNullable(items) && this.props.value) {\n return <MenuMessage>{this.locale.updateValue}</MenuMessage>;\n }\n\n return null;\n }\n\n private renderMenu(): React.ReactNode {\n const items = this.state.items;\n const { menuMaxHeight, hasShadow, menuWidth, width, preventWindowScroll, menuAlign, disablePortal, menuPos } =\n this.getProps();\n const menuProps = {\n ref: this.refMenu,\n maxHeight: menuMaxHeight,\n hasShadow,\n width: menuWidth || (width && getDOMRect(this.rootSpan).width),\n preventWindowScroll,\n };\n if (!items || items.length === 0) {\n return null;\n }\n\n return (\n <DropdownContainer\n offsetY={1}\n getParent={this.getAnchor}\n align={menuAlign}\n disablePortal={disablePortal}\n menuPos={menuPos}\n >\n <Menu {...menuProps}>{this.getItems()}</Menu>\n </DropdownContainer>\n );\n }\n\n private renderMobileMenu = () => {\n const inputProps: InputProps = {\n autoFocus: true,\n width: '100%',\n onValueChange: this.handleValueChange,\n onKeyPress: this.handleKeyPressMobile,\n value: this.props.value,\n placeholder: this.locale.enterValue,\n };\n\n const items = this.state.items;\n\n return (\n <MobilePopup\n headerChildComponent={<Input {...inputProps} />}\n caption={this.props.mobileMenuHeaderText}\n opened={this.state.isMobileOpened}\n onCloseRequest={this.handleCloseMobile}\n ref={this.refMobilePopup}\n >\n <Menu ref={this.refMenu} onItemClick={this.mobilePopup?.close} disableScrollContainer maxHeight={'auto'}>\n {items && items.length > 0 && this.getItems()}\n {this.renderHints()}\n </Menu>\n </MobilePopup>\n );\n };\n\n private getItems = () => {\n const items = this.state.items;\n const isMobile = this.isMobileLayout;\n\n return items\n ? items.map((item, i) => {\n return (\n <MenuItem onClick={this.handleMenuItemClick(i)} key={i} isMobile={isMobile}>\n {this.getProps().renderItem(item)}\n </MenuItem>\n );\n })\n : null;\n };\n\n private handleValueChange = (value: string) => {\n this.opened = true;\n\n this.fireChange(value);\n };\n\n private handleCloseMobile = () => {\n this.setState({\n isMobileOpened: false,\n });\n\n this.handleBlur();\n };\n\n private handleKeyPressMobile = (e: KeyboardEvent) => {\n if (e.key === 'Enter') {\n this.mobilePopup?.close();\n }\n };\n\n private handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.isMobileLayout) {\n this.setState({ isMobileOpened: true });\n }\n\n if (this.state.focused) {\n return;\n }\n\n this.setState({ focused: true });\n\n if (this.props.onFocus) {\n this.props.onFocus(event);\n }\n };\n\n private handleBlur = () => {\n if (!this.state.focused) {\n return;\n }\n\n this.opened = false;\n this.setState({ items: null, focused: false });\n\n if (this.input) {\n this.input.blur();\n }\n\n if (this.props.onBlur) {\n this.props.onBlur();\n }\n };\n\n private handleClickOutside = (e: Event) => {\n fixClickFocusIE(e);\n this.handleBlur();\n };\n\n private handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (this.props.onKeyDown) {\n this.props.onKeyDown(e);\n }\n switch (true) {\n case isKeyEscape(e):\n e.preventDefault();\n this.setState({ items: null });\n return;\n case isKeyArrowUp(e):\n e.preventDefault();\n if (this.menu) {\n this.menu.up();\n }\n return;\n case isKeyArrowDown(e):\n e.preventDefault();\n if (this.menu) {\n this.menu.down();\n }\n return;\n case isKeyEnter(e):\n e.preventDefault(); // To prevent form submission.\n if (this.menu) {\n this.menu.enter(e);\n }\n return;\n }\n };\n\n private handleMenuItemClick(i: number) {\n return (event: React.SyntheticEvent<HTMLElement>) => this.handleItemClick(event, i);\n }\n\n private getAnchor = () => {\n return getRootNode(this);\n };\n\n private handleItemClick(event: React.SyntheticEvent<HTMLElement> | React.MouseEvent<HTMLElement>, index: number) {\n if ((event as React.MouseEvent<HTMLElement>).button) {\n return;\n }\n\n event.preventDefault();\n this.choose(index);\n }\n\n private choose(index: number) {\n if (!this.state.items) {\n return;\n }\n\n const value = this.state.items[index];\n this.opened = false;\n this.setState({\n selected: -1,\n items: null,\n });\n\n this.fireChange(value);\n this.blur();\n }\n\n private updateItems(value: string) {\n if (!this.opened) {\n return;\n }\n const pattern = value.trim();\n const source = this.props.source;\n\n if (!source) {\n return;\n }\n\n let promise;\n this.requestId += 1;\n const expectingId = this.requestId;\n if (typeof source === 'function') {\n promise = source(pattern);\n } else {\n promise = match(pattern, source);\n }\n promise.then((items) => {\n if (this.opened && expectingId === this.requestId) {\n this.setState({\n items,\n selected: -1,\n });\n }\n });\n }\n\n private fireChange(value: string) {\n if (this.props.onValueChange) {\n this.props.onValueChange(value);\n }\n }\n\n private refInput = (el: Input | null) => {\n this.input = el;\n };\n\n private refMenu = (menu: Menu | null) => {\n this.menu = menu;\n };\n\n private refRootSpan = (span: HTMLSpanElement) => {\n this.rootSpan = span;\n };\n\n private refMobilePopup = (mobilePopup: MobilePopup | null) => {\n this.mobilePopup = mobilePopup;\n };\n}\n"]}
1
+ {"version":3,"sources":["Autocomplete.tsx"],"names":["match","pattern","items","Promise","resolve","lowerCasedPattern","toLowerCase","itemsMatchingPattern","filter","item","includes","renderItem","AutocompleteDataTids","root","Autocomplete","AutocompleteLocaleHelper","responsiveLayout","rootNode","state","selected","focused","isMobileOpened","opened","input","requestId","getProps","defaultProps","renderMain","props","isMobile","isMobileLayout","onValueChange","onKeyDown","onFocus","onBlur","_renderItem","disablePortal","hasShadow","menuAlign","menuMaxHeight","preventWindowScroll","source","width","theme","inputWidth","mobileMenuHeaderText","rest","inputProps","handleValueChange","handleKeyDown","handleFocus","ref","refInput","handleBlur","handleClickOutside","styles","refRootSpan","renderMobileMenu","renderMenu","autoFocus","onKeyPress","handleKeyPressMobile","value","placeholder","locale","enterValue","handleCloseMobile","refMobilePopup","refMenu","mobilePopup","close","length","getItems","renderHints","map","i","handleMenuItemClick","fireChange","setState","e","key","event","blur","preventDefault","menu","up","down","enter","getAnchor","el","span","rootSpan","focus","componentDidUpdate","prevProps","updateItems","render","setRootNode","notFound","updateValue","menuWidth","menuPos","menuProps","maxHeight","handleItemClick","index","button","choose","trim","promise","expectingId","then","React","Component","__KONTUR_REACT_UI__","propTypes","PropTypes","func","oneOfType","array","size"],"mappings":"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","sourcesContent":["// TODO: Enable this rule in functional components.\n/* eslint-disable @typescript-eslint/no-unused-vars */\nimport React, { KeyboardEvent } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { MenuMessage } from '../../internal/MenuMessage';\nimport { locale } from '../../lib/locale/decorators';\nimport { isNullable } from '../../lib/utils';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Theme } from '../../lib/theming/Theme';\nimport { isKeyArrowDown, isKeyArrowUp, isKeyEnter, isKeyEscape } from '../../lib/events/keyboard/identifiers';\nimport { Input, InputProps } from '../Input';\nimport { DropdownContainer, DropdownContainerProps } from '../../internal/DropdownContainer';\nimport { Menu } from '../../internal/Menu';\nimport { MenuItem } from '../MenuItem';\nimport { RenderLayer } from '../../internal/RenderLayer';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\nimport { Nullable, Override } from '../../typings/utility-types';\nimport { fixClickFocusIE } from '../../lib/events/fixClickFocusIE';\nimport { CommonProps, CommonWrapper, CommonWrapperRestProps } from '../../internal/CommonWrapper';\nimport { MobilePopup } from '../../internal/MobilePopup';\nimport { responsiveLayout } from '../ResponsiveLayout/decorator';\nimport { getRootNode, rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { getDOMRect } from '../../lib/dom/getDOMRect';\n\nimport { styles } from './Autocomplete.styles';\nimport { AutocompleteLocale, AutocompleteLocaleHelper } from './locale';\nimport { getAutocompleteTheme } from './getAutocompleteTheme';\n\nfunction match(pattern: string, items: string[]) {\n if (!pattern || !items) {\n return Promise.resolve([]);\n }\n\n const lowerCasedPattern = pattern.toLowerCase();\n const itemsMatchingPattern = items.filter((item) => {\n return item.toLowerCase().includes(lowerCasedPattern);\n });\n\n return Promise.resolve(itemsMatchingPattern);\n}\n\nfunction renderItem(item: any) {\n return item;\n}\n\nexport interface AutocompleteProps\n extends CommonProps,\n Pick<DropdownContainerProps, 'menuPos'>,\n Override<\n InputProps,\n {\n /** Функция отрисовки элемента меню */\n renderItem?: (item: string) => React.ReactNode;\n /** Промис, резолвящий элементы меню */\n source?: string[] | ((patter: string) => Promise<string[]>);\n /** Отключает использование портала */\n disablePortal?: boolean;\n /** Отрисовка тени у выпадающего меню */\n hasShadow?: boolean;\n /** Выравнивание выпадающего меню */\n menuAlign?: 'left' | 'right';\n /** Максимальная высота меню */\n menuMaxHeight?: number | string;\n /** Ширина меню */\n menuWidth?: number | string;\n /** Отключить скролл окна, когда меню открыто */\n preventWindowScroll?: boolean;\n /** Вызывается при изменении `value` */\n onValueChange: (value: string) => void;\n /** onBlur */\n onBlur?: () => void;\n /** Размер инпута */\n size?: InputProps['size'];\n /** value */\n value: string;\n /**\n * Текст заголовка выпадающего меню в мобильной версии\n */\n mobileMenuHeaderText?: string;\n }\n > {}\n\nexport interface AutocompleteState {\n items: Nullable<string[]>;\n selected: number;\n focused: boolean;\n isMobileOpened: boolean;\n}\n\nexport const AutocompleteDataTids = {\n root: 'Autocomplete__root',\n} as const;\n\ntype DefaultProps = Required<\n Pick<\n AutocompleteProps,\n 'renderItem' | 'size' | 'disablePortal' | 'hasShadow' | 'menuMaxHeight' | 'menuAlign' | 'preventWindowScroll'\n >\n>;\n\n/**\n * Стандартный инпут с подсказками.\n *\n * Все свойства передаются во внутренний *Input*.\n */\n@responsiveLayout\n@rootNode\n@locale('Autocomplete', AutocompleteLocaleHelper)\nexport class Autocomplete extends React.Component<AutocompleteProps, AutocompleteState> {\n public static __KONTUR_REACT_UI__ = 'Autocomplete';\n\n public static propTypes = {\n /**\n * Функция для отрисовки элемента в выпадающем списке. Единственный аргумент\n * — *item*.\n */\n renderItem: PropTypes.func,\n\n /**\n * Если передан массив, то совпадения ищутся по этому массиву.\n *\n * Если передается функция, то она должна возвращать thenable, который\n * резолвится уже отфильтрованным массивом. Возвращенный thenable может\n * иметь метод cancel, который будет вызван при отмене поиска (пользователь\n * изменил строку поиска, автокомплит потерял фокус).\n * ```\n * function(pattern) {\n * return service.findAll(pattern);\n * }\n * ```\n */\n source: PropTypes.oneOfType([PropTypes.array, PropTypes.func]),\n };\n\n public static defaultProps: DefaultProps = {\n renderItem,\n size: 'small',\n disablePortal: false,\n hasShadow: true,\n menuMaxHeight: 300,\n menuAlign: 'left',\n preventWindowScroll: true,\n };\n\n public state: AutocompleteState = {\n items: null,\n selected: -1,\n focused: false,\n isMobileOpened: false,\n };\n\n private theme!: Theme;\n private readonly locale!: AutocompleteLocale;\n private isMobileLayout!: boolean;\n private opened = false;\n private input: Nullable<Input> = null;\n private menu: Nullable<Menu>;\n private rootSpan: Nullable<HTMLSpanElement>;\n private mobilePopup: Nullable<MobilePopup>;\n\n private requestId = 0;\n\n private getProps = createPropsGetter(Autocomplete.defaultProps);\n private setRootNode!: TSetRootNode;\n\n /**\n * @public\n */\n public focus() {\n if (this.input) {\n this.input.focus();\n }\n }\n\n /**\n * @public\n */\n public blur() {\n this.handleBlur();\n }\n\n public componentDidUpdate(prevProps: AutocompleteProps) {\n if (prevProps.value !== this.props.value) {\n this.updateItems(this.props.value || '');\n }\n }\n\n public render() {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = getAutocompleteTheme(theme);\n return (\n <ThemeContext.Provider value={this.theme}>\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n {this.renderMain}\n </CommonWrapper>\n </ThemeContext.Provider>\n );\n }}\n </ThemeContext.Consumer>\n );\n }\n public renderMain = (props: CommonWrapperRestProps<AutocompleteProps>) => {\n const { focused } = this.state;\n\n const isMobile = this.isMobileLayout;\n\n const {\n onValueChange,\n onKeyDown,\n onFocus,\n onBlur,\n renderItem: _renderItem,\n disablePortal,\n hasShadow,\n menuAlign,\n menuMaxHeight,\n preventWindowScroll,\n source,\n width = this.theme.inputWidth,\n mobileMenuHeaderText,\n ...rest\n } = props;\n\n const inputProps = {\n ...rest,\n width: '100%',\n onValueChange: this.handleValueChange,\n onKeyDown: this.handleKeyDown,\n onFocus: this.handleFocus,\n ref: this.refInput,\n };\n\n return (\n <RenderLayer onFocusOutside={this.handleBlur} onClickOutside={this.handleClickOutside} active={focused}>\n <span\n data-tid={AutocompleteDataTids.root}\n className={styles.root(this.theme)}\n style={{ width }}\n ref={this.refRootSpan}\n >\n <Input {...inputProps} />\n {isMobile ? this.renderMobileMenu() : this.renderMenu()}\n </span>\n </RenderLayer>\n );\n };\n\n private renderHints(): React.ReactNode {\n const items = this.state.items;\n\n if (!this.props.value) {\n return <MenuMessage>{this.locale.enterValue}</MenuMessage>;\n }\n\n if (items?.length === 0 && this.props.value) {\n return <MenuMessage>{this.locale.notFound}</MenuMessage>;\n }\n\n if (isNullable(items) && this.props.value) {\n return <MenuMessage>{this.locale.updateValue}</MenuMessage>;\n }\n\n return null;\n }\n\n private renderMenu(): React.ReactNode {\n const items = this.state.items;\n const { menuMaxHeight, hasShadow, menuWidth, width, preventWindowScroll, menuAlign, disablePortal, menuPos } =\n this.getProps();\n const menuProps = {\n ref: this.refMenu,\n maxHeight: menuMaxHeight,\n hasShadow,\n width: menuWidth || (width && getDOMRect(this.rootSpan).width),\n preventWindowScroll,\n };\n if (!items || items.length === 0) {\n return null;\n }\n\n return (\n <DropdownContainer getParent={this.getAnchor} align={menuAlign} disablePortal={disablePortal} menuPos={menuPos}>\n <Menu {...menuProps}>{this.getItems()}</Menu>\n </DropdownContainer>\n );\n }\n\n private renderMobileMenu = () => {\n const inputProps: InputProps = {\n autoFocus: true,\n width: '100%',\n onValueChange: this.handleValueChange,\n onKeyPress: this.handleKeyPressMobile,\n value: this.props.value,\n placeholder: this.locale.enterValue,\n };\n\n const items = this.state.items;\n\n return (\n <MobilePopup\n headerChildComponent={<Input {...inputProps} />}\n caption={this.props.mobileMenuHeaderText}\n opened={this.state.isMobileOpened}\n onCloseRequest={this.handleCloseMobile}\n ref={this.refMobilePopup}\n >\n <Menu ref={this.refMenu} onItemClick={this.mobilePopup?.close} disableScrollContainer maxHeight={'auto'}>\n {items && items.length > 0 && this.getItems()}\n {this.renderHints()}\n </Menu>\n </MobilePopup>\n );\n };\n\n private getItems = () => {\n const items = this.state.items;\n const isMobile = this.isMobileLayout;\n\n return items\n ? items.map((item, i) => {\n return (\n <MenuItem onClick={this.handleMenuItemClick(i)} key={i} isMobile={isMobile}>\n {this.getProps().renderItem(item)}\n </MenuItem>\n );\n })\n : null;\n };\n\n private handleValueChange = (value: string) => {\n this.opened = true;\n\n this.fireChange(value);\n };\n\n private handleCloseMobile = () => {\n this.setState({\n isMobileOpened: false,\n });\n\n this.handleBlur();\n };\n\n private handleKeyPressMobile = (e: KeyboardEvent) => {\n if (e.key === 'Enter') {\n this.mobilePopup?.close();\n }\n };\n\n private handleFocus = (event: React.FocusEvent<HTMLInputElement>) => {\n if (this.isMobileLayout) {\n this.setState({ isMobileOpened: true });\n }\n\n if (this.state.focused) {\n return;\n }\n\n this.setState({ focused: true });\n\n if (this.props.onFocus) {\n this.props.onFocus(event);\n }\n };\n\n private handleBlur = () => {\n if (!this.state.focused) {\n return;\n }\n\n this.opened = false;\n this.setState({ items: null, focused: false });\n\n if (this.input) {\n this.input.blur();\n }\n\n if (this.props.onBlur) {\n this.props.onBlur();\n }\n };\n\n private handleClickOutside = (e: Event) => {\n fixClickFocusIE(e);\n this.handleBlur();\n };\n\n private handleKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (this.props.onKeyDown) {\n this.props.onKeyDown(e);\n }\n switch (true) {\n case isKeyEscape(e):\n e.preventDefault();\n this.setState({ items: null });\n return;\n case isKeyArrowUp(e):\n e.preventDefault();\n if (this.menu) {\n this.menu.up();\n }\n return;\n case isKeyArrowDown(e):\n e.preventDefault();\n if (this.menu) {\n this.menu.down();\n }\n return;\n case isKeyEnter(e):\n e.preventDefault(); // To prevent form submission.\n if (this.menu) {\n this.menu.enter(e);\n }\n return;\n }\n };\n\n private handleMenuItemClick(i: number) {\n return (event: React.SyntheticEvent<HTMLElement>) => this.handleItemClick(event, i);\n }\n\n private getAnchor = () => {\n return getRootNode(this);\n };\n\n private handleItemClick(event: React.SyntheticEvent<HTMLElement> | React.MouseEvent<HTMLElement>, index: number) {\n if ((event as React.MouseEvent<HTMLElement>).button) {\n return;\n }\n\n event.preventDefault();\n this.choose(index);\n }\n\n private choose(index: number) {\n if (!this.state.items) {\n return;\n }\n\n const value = this.state.items[index];\n this.opened = false;\n this.setState({\n selected: -1,\n items: null,\n });\n\n this.fireChange(value);\n this.blur();\n }\n\n private updateItems(value: string) {\n if (!this.opened) {\n return;\n }\n const pattern = value.trim();\n const source = this.props.source;\n\n if (!source) {\n return;\n }\n\n let promise;\n this.requestId += 1;\n const expectingId = this.requestId;\n if (typeof source === 'function') {\n promise = source(pattern);\n } else {\n promise = match(pattern, source);\n }\n promise.then((items) => {\n if (this.opened && expectingId === this.requestId) {\n this.setState({\n items,\n selected: -1,\n });\n }\n });\n }\n\n private fireChange(value: string) {\n if (this.props.onValueChange) {\n this.props.onValueChange(value);\n }\n }\n\n private refInput = (el: Input | null) => {\n this.input = el;\n };\n\n private refMenu = (menu: Menu | null) => {\n this.menu = menu;\n };\n\n private refRootSpan = (span: HTMLSpanElement) => {\n this.rootSpan = span;\n };\n\n private refMobilePopup = (mobilePopup: MobilePopup | null) => {\n this.mobilePopup = mobilePopup;\n };\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import { Theme } from '../../lib/theming/Theme';
2
+ export declare const getAutocompleteTheme: (theme: Theme) => Theme;
@@ -0,0 +1,11 @@
1
+ "use strict";exports.__esModule = true;exports.getAutocompleteTheme = void 0;var _ThemeFactory = require("../../lib/theming/ThemeFactory");
2
+
3
+
4
+ var getAutocompleteTheme = function getAutocompleteTheme(theme) {
5
+ return _ThemeFactory.ThemeFactory.create(
6
+ {
7
+ menuOffsetY: theme.autocompleteMenuOffsetY },
8
+
9
+ theme);
10
+
11
+ };exports.getAutocompleteTheme = getAutocompleteTheme;
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["getAutocompleteTheme.ts"],"names":["getAutocompleteTheme","theme","ThemeFactory","create","menuOffsetY","autocompleteMenuOffsetY"],"mappings":"6EAAA;;;AAGO,IAAMA,oBAAoB,GAAG,SAAvBA,oBAAuB,CAACC,KAAD,EAAyB;AAC3D,SAAOC,2BAAaC,MAAb;AACL;AACEC,IAAAA,WAAW,EAAEH,KAAK,CAACI,uBADrB,EADK;;AAILJ,EAAAA,KAJK,CAAP;;AAMD,CAPM,C","sourcesContent":["import { ThemeFactory } from '../../lib/theming/ThemeFactory';\nimport { Theme } from '../../lib/theming/Theme';\n\nexport const getAutocompleteTheme = (theme: Theme): Theme => {\n return ThemeFactory.create(\n {\n menuOffsetY: theme.autocompleteMenuOffsetY,\n },\n theme,\n );\n};\n"]}
@@ -0,0 +1,3 @@
1
+ export declare const ArrowLeftIcon: import("../../lib/forwardRefAndName").ReactUIComponentWithRef<SVGSVGElement, Omit<import("../../internal/icons2022/BaseIcon").IconProps, "size"> & {
2
+ size?: number | "small" | "medium" | "large" | undefined;
3
+ }>;
@@ -0,0 +1,15 @@
1
+ "use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");exports.__esModule = true;exports.ArrowLeftIcon = void 0;
2
+ var _react = _interopRequireDefault(require("react"));
3
+
4
+ var _ArrowALeftIcon16Light = require("../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light");
5
+ var _ArrowALeftIcon20Light = require("../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light");
6
+ var _ArrowALeftIcon24Regular = require("../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular");
7
+ var _iconSizer = require("../../internal/icons2022/iconSizer"); /* eslint-disable react/display-name */
8
+
9
+ var ArrowLeftIcon = (0, _iconSizer.iconSizer)(
10
+ {
11
+ small: function small() {return /*#__PURE__*/_react.default.createElement(_ArrowALeftIcon16Light.ArrowALeftIcon16Light, null);},
12
+ medium: function medium() {return /*#__PURE__*/_react.default.createElement(_ArrowALeftIcon20Light.ArrowALeftIcon20Light, null);},
13
+ large: function large() {return /*#__PURE__*/_react.default.createElement(_ArrowALeftIcon24Regular.ArrowALeftIcon24Regular, null);} },
14
+
15
+ 'ArrowLeftIcon');exports.ArrowLeftIcon = ArrowLeftIcon;
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["ArrowLeftIcon.tsx"],"names":["ArrowLeftIcon","small","medium","large"],"mappings":";AACA;;AAEA;AACA;AACA;AACA,+D,CANA;;AAQO,IAAMA,aAAa,GAAG;AAC3B;AACEC,EAAAA,KAAK,EAAE,sCAAM,6BAAC,4CAAD,OAAN,EADT;AAEEC,EAAAA,MAAM,EAAE,uCAAM,6BAAC,4CAAD,OAAN,EAFV;AAGEC,EAAAA,KAAK,EAAE,sCAAM,6BAAC,gDAAD,OAAN,EAHT,EAD2B;;AAM3B,eAN2B,CAAtB,C","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\n\nimport { ArrowALeftIcon16Light } from '../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon16Light';\nimport { ArrowALeftIcon20Light } from '../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon20Light';\nimport { ArrowALeftIcon24Regular } from '../../internal/icons2022/ArrowALeftIcon/ArrowALeftIcon24Regular';\nimport { iconSizer } from '../../internal/icons2022/iconSizer';\n\nexport const ArrowLeftIcon = iconSizer(\n {\n small: () => <ArrowALeftIcon16Light />,\n medium: () => <ArrowALeftIcon20Light />,\n large: () => <ArrowALeftIcon24Regular />,\n },\n 'ArrowLeftIcon',\n);\n"]}
@@ -0,0 +1,3 @@
1
+ export declare const ArrowRightIcon: import("../../lib/forwardRefAndName").ReactUIComponentWithRef<SVGSVGElement, Omit<import("../../internal/icons2022/BaseIcon").IconProps, "size"> & {
2
+ size?: number | "small" | "medium" | "large" | undefined;
3
+ }>;
@@ -0,0 +1,15 @@
1
+ "use strict";var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");exports.__esModule = true;exports.ArrowRightIcon = void 0;
2
+ var _react = _interopRequireDefault(require("react"));
3
+
4
+ var _ArrowARightIcon16Light = require("../../internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light");
5
+ var _ArrowARightIcon20Light = require("../../internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light");
6
+ var _ArrowARightIcon24Regular = require("../../internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular");
7
+ var _iconSizer = require("../../internal/icons2022/iconSizer"); /* eslint-disable react/display-name */
8
+
9
+ var ArrowRightIcon = (0, _iconSizer.iconSizer)(
10
+ {
11
+ small: function small() {return /*#__PURE__*/_react.default.createElement(_ArrowARightIcon16Light.ArrowARightIcon16Light, null);},
12
+ medium: function medium() {return /*#__PURE__*/_react.default.createElement(_ArrowARightIcon20Light.ArrowARightIcon20Light, null);},
13
+ large: function large() {return /*#__PURE__*/_react.default.createElement(_ArrowARightIcon24Regular.ArrowARightIcon24Regular, null);} },
14
+
15
+ 'ArrowRightIcon');exports.ArrowRightIcon = ArrowRightIcon;
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["ArrowRightIcon.tsx"],"names":["ArrowRightIcon","small","medium","large"],"mappings":";AACA;;AAEA;AACA;AACA;AACA,+D,CANA;;AAQO,IAAMA,cAAc,GAAG;AAC5B;AACEC,EAAAA,KAAK,EAAE,sCAAM,6BAAC,8CAAD,OAAN,EADT;AAEEC,EAAAA,MAAM,EAAE,uCAAM,6BAAC,8CAAD,OAAN,EAFV;AAGEC,EAAAA,KAAK,EAAE,sCAAM,6BAAC,kDAAD,OAAN,EAHT,EAD4B;;AAM5B,gBAN4B,CAAvB,C","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\n\nimport { ArrowARightIcon16Light } from '../../internal/icons2022/ArrowARightIcon/ArrowARightIcon16Light';\nimport { ArrowARightIcon20Light } from '../../internal/icons2022/ArrowARightIcon/ArrowARightIcon20Light';\nimport { ArrowARightIcon24Regular } from '../../internal/icons2022/ArrowARightIcon/ArrowARightIcon24Regular';\nimport { iconSizer } from '../../internal/icons2022/iconSizer';\n\nexport const ArrowRightIcon = iconSizer(\n {\n small: () => <ArrowARightIcon16Light />,\n medium: () => <ArrowARightIcon20Light />,\n large: () => <ArrowARightIcon24Regular />,\n },\n 'ArrowRightIcon',\n);\n"]}
@@ -1,8 +1,9 @@
1
1
  import React, { AriaAttributes } from 'react';
2
+ import { ThemeIn } from '../../lib/theming/Theme';
2
3
  import { CommonProps } from '../../internal/CommonWrapper';
3
4
  export declare type ButtonSize = 'small' | 'medium' | 'large';
4
5
  export declare type ButtonType = 'button' | 'submit' | 'reset';
5
- export declare type ButtonUse = 'default' | 'primary' | 'success' | 'danger' | 'pay' | 'link';
6
+ export declare type ButtonUse = 'default' | 'primary' | 'success' | 'danger' | 'pay' | 'link' | 'text' | 'backless';
6
7
  export interface ButtonProps extends CommonProps {
7
8
  /** @ignore */
8
9
  _noPadding?: boolean;
@@ -102,7 +103,7 @@ export interface ButtonProps extends CommonProps {
102
103
  /**
103
104
  * Стиль кнопки.
104
105
  *
105
- * **Допустимые значения**: `"default"`, `"primary"`, `"success"`, `"danger"`, `"pay"`, `"link"`.
106
+ * **Допустимые значения**: `"default"`, `"primary"`, `"success"`, `"danger"`, `"pay"`, `"link"`, `"text"`, `"backless"`.
106
107
  */
107
108
  use?: ButtonUse;
108
109
  /** @ignore */
@@ -115,6 +116,11 @@ export interface ButtonProps extends CommonProps {
115
116
  * CSS-свойство `width`.
116
117
  */
117
118
  width?: number | string;
119
+ /**
120
+ * Обычный объект с переменными темы.
121
+ * Он будет объединён с темой из контекста.
122
+ */
123
+ theme?: ThemeIn;
118
124
  /**
119
125
  * Атрибут для указания id элемента(-ов), описывающих его
120
126
  */
@@ -152,9 +158,7 @@ export declare class Button extends React.Component<ButtonProps, ButtonState> {
152
158
  blur(): void;
153
159
  render(): JSX.Element;
154
160
  private renderMain;
155
- private getLoadingSpinner;
156
161
  private getSizeClassName;
157
- private getSizeIconClassName;
158
162
  private getSizeWrapClassName;
159
163
  private handleFocus;
160
164
  private handleBlur;
@@ -5,13 +5,26 @@ var _client = require("../../lib/client");
5
5
  var _keyListener = require("../../lib/events/keyListener");
6
6
 
7
7
  var _ThemeContext = require("../../lib/theming/ThemeContext");
8
- var _Spinner = require("../Spinner");
9
8
  var _CommonWrapper = require("../../internal/CommonWrapper");
10
9
  var _Emotion = require("../../lib/theming/Emotion");
11
10
  var _rootNode = require("../../lib/rootNode");
11
+ var _ThemeFactory = require("../../lib/theming/ThemeFactory");
12
12
  var _createPropsGetter = require("../../lib/createPropsGetter");
13
+ var _ThemeHelpers = require("../../lib/theming/ThemeHelpers");
14
+ var _Link = require("../Link");
15
+ var _Spinner = require("../Spinner");
16
+ var _LoadingIcon = require("../../internal/icons2022/LoadingIcon");
17
+
18
+ var _Button = require("./Button.styles");
19
+ var _ButtonIcon = require("./ButtonIcon");
20
+ var _ButtonArrow = require("./ButtonArrow");
21
+ var _getInnerLinkTheme = require("./getInnerLinkTheme");var _class, _class2, _temp;
22
+
23
+
24
+
25
+
26
+
13
27
 
14
- var _Button = require("./Button.styles");var _class, _class2, _temp;
15
28
 
16
29
 
17
30
 
@@ -429,6 +442,52 @@ Button = (0, _rootNode.rootNode)(_class = (_temp = _class2 = /*#__PURE__*/functi
429
442
 
430
443
 
431
444
 
445
+
446
+
447
+
448
+
449
+
450
+
451
+
452
+
453
+
454
+
455
+
456
+
457
+
458
+
459
+
460
+
461
+
462
+
463
+
464
+
465
+
466
+
467
+
468
+
469
+
470
+
471
+
472
+
473
+
474
+
475
+
476
+
477
+
478
+
479
+
480
+
481
+
482
+
483
+
484
+
485
+
486
+
487
+
488
+
489
+
490
+
432
491
 
433
492
 
434
493
 
@@ -476,8 +535,10 @@ Button = (0, _rootNode.rootNode)(_class = (_temp = _class2 = /*#__PURE__*/functi
476
535
  * @public
477
536
  */;_proto.focus = function focus() {var _this$node;(_this$node = this.node) == null ? void 0 : _this$node.focus();} /**
478
537
  * @public
479
- */;_proto.blur = function blur() {var _this$node2;(_this$node2 = this.node) == null ? void 0 : _this$node2.blur();};_proto.render = function render() {var _this2 = this;return /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Consumer, null, function (theme) {_this2.theme = theme;return _this2.renderMain();});};_proto.renderMain = function renderMain() {var _cx, _cx2, _cx7, _cx8;var _this$props = this.props,corners = _this$props.corners,active = _this$props.active,disabled = _this$props.disabled,borderless = _this$props.borderless,checked = _this$props.checked,error = _this$props.error,warning = _this$props.warning,loading = _this$props.loading,arrow = _this$props.arrow,narrow = _this$props.narrow,icon = _this$props.icon,_noPadding = _this$props._noPadding,_noRightPadding = _this$props._noRightPadding,visuallyFocused = _this$props.visuallyFocused,align = _this$props.align,disableFocus = _this$props.disableFocus,onMouseEnter = _this$props.onMouseEnter,onMouseLeave = _this$props.onMouseLeave,onMouseOver = _this$props.onMouseOver,onKeyDown = _this$props.onKeyDown,onClick = _this$props.onClick,width = _this$props.width,children = _this$props.children,ariaDescribedby = _this$props['aria-describedby'];var _this$getProps = this.getProps(),use = _this$getProps.use,type = _this$getProps.type;var sizeClass = this.getSizeClassName();var isFocused = this.state.focusedByTab || visuallyFocused;var isLink = use === 'link';var rootProps = { // By default the type attribute is 'submit'. IE8 will fire a click event
538
+ */;_proto.blur = function blur() {var _this$node2;(_this$node2 = this.node) == null ? void 0 : _this$node2.blur();};_proto.render = function render() {var _this2 = this;return /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Consumer, null, function (theme) {_this2.theme = _this2.props.theme ? _ThemeFactory.ThemeFactory.create(_this2.props.theme, theme) : theme;return _this2.renderMain();});};_proto.renderMain = function renderMain() {var _cx2, _cx5, _cx6;var _this$props = this.props,corners = _this$props.corners,active = _this$props.active,disabled = _this$props.disabled,borderless = _this$props.borderless,checked = _this$props.checked,error = _this$props.error,warning = _this$props.warning,loading = _this$props.loading,narrow = _this$props.narrow,icon = _this$props.icon,_noPadding = _this$props._noPadding,_noRightPadding = _this$props._noRightPadding,visuallyFocused = _this$props.visuallyFocused,align = _this$props.align,disableFocus = _this$props.disableFocus,onMouseEnter = _this$props.onMouseEnter,onMouseLeave = _this$props.onMouseLeave,onMouseOver = _this$props.onMouseOver,onKeyDown = _this$props.onKeyDown,onClick = _this$props.onClick,width = _this$props.width,children = _this$props.children,ariaDescribedby = _this$props['aria-describedby'];var _this$getProps = this.getProps(),use = _this$getProps.use,type = _this$getProps.type,size = _this$getProps.size;var sizeClass = this.getSizeClassName();var isFocused = this.state.focusedByTab || visuallyFocused;var isLink = use === 'link';var _isTheme2022 = (0, _ThemeHelpers.isTheme2022)(this.theme); // eslint-disable-next-line react-hooks/rules-of-hooks
539
+ var _useButtonArrow = (0, _ButtonArrow.useButtonArrow)((0, _extends2.default)({}, this.props, { isFocused: Boolean(isFocused) }), this.theme),wrapClassNameWithArrow = _useButtonArrow[0],rootClassNameWithArrow = _useButtonArrow[1],arrowNode = _useButtonArrow[2];var rootClassName = '';if (_isTheme2022) {var trueDisabled = disabled || loading;rootClassName = _Emotion.cx.apply(void 0, [_Button.styles.root(this.theme), _Button.styles[use](this.theme), sizeClass, narrow && _Button.styles.narrow(), _noPadding && _Button.styles.noPadding(), _noRightPadding && _Button.styles.noRightPadding(), rootClassNameWithArrow].concat(trueDisabled ? [_Button.styles.disabled(this.theme), checked && _Button.styles.checkedDisabled(this.theme), checked && _Button.styles.checkedDisabled2022(this.theme), borderless && _Button.styles.borderless2022()] : [active && !checked && _Button.activeStyles[use](this.theme), isFocused && _Button.styles.focus(this.theme), checked && _Button.styles.checked2022(this.theme), checked && isFocused && _Button.styles.checkedFocused(this.theme), borderless && !checked && !isFocused && _Button.styles.borderless2022()]));} else {var _cx;rootClassName = (0, _Emotion.cx)((_cx = {}, _cx[_Button.styles.root(this.theme)] = true, _cx[_Button.styles.simulatedPress()] = true, _cx[_Button.styles[use](this.theme)] = true, _cx[_Button.activeStyles[use](this.theme)] = active, _cx[sizeClass] = true, _cx[_Button.styles.focus(this.theme)] = isFocused, _cx[_Button.styles.checked(this.theme)] = checked, _cx[_Button.styles.checkedFocused(this.theme)] = checked && isFocused, _cx[_Button.styles.disabled(this.theme)] = disabled || loading, _cx[_Button.styles.checkedDisabled(this.theme)] = checked && disabled, _cx[_Button.styles.borderless()] = borderless && !disabled && !loading && !checked && !isFocused && !active, _cx[_Button.styles.narrow()] = narrow, _cx[_Button.styles.noPadding()] = _noPadding, _cx[_Button.styles.noRightPadding()] = _noRightPadding, _cx));}var rootProps = { // By default the type attribute is 'submit'. IE8 will fire a click event
480
540
  // on this button if somewhere on the page user presses Enter while some
481
541
  // input is focused. So we set type to 'button' by default.
482
- type: type, className: (0, _Emotion.cx)((_cx = {}, _cx[_Button.styles.root(this.theme)] = true, _cx[_Button.styles[use](this.theme)] = true, _cx[_Button.activeStyles[use](this.theme)] = active, _cx[sizeClass] = true, _cx[_Button.styles.focus(this.theme)] = isFocused, _cx[_Button.styles.checked(this.theme)] = checked, _cx[_Button.styles.checkedFocused(this.theme)] = checked && isFocused, _cx[_Button.styles.disabled(this.theme)] = disabled || loading, _cx[_Button.styles.checkedDisabled(this.theme)] = checked && disabled, _cx[_Button.styles.borderless()] = borderless && !disabled && !loading && !checked && !isFocused && !active, _cx[_Button.styles.narrow()] = narrow, _cx[_Button.styles.noPadding()] = _noPadding, _cx[_Button.styles.noRightPadding()] = _noRightPadding, _cx)), style: (0, _extends2.default)({ textAlign: align }, corners), disabled: disabled || loading, onClick: onClick, onFocus: this.handleFocus, onBlur: this.handleBlur, onKeyDown: onKeyDown, onMouseEnter: onMouseEnter, onMouseLeave: onMouseLeave, onMouseOver: onMouseOver, tabIndex: disableFocus ? -1 : 0, title: this.props.title };var wrapProps = { className: (0, _Emotion.cx)((_cx2 = {}, _cx2[_Button.styles.wrap(this.theme)] = true, _cx2[_Button.styles.wrapArrow()] = arrow === true, _cx2[_Button.styles.wrapArrowLeft()] = arrow === 'left', _cx2[this.getSizeWrapClassName()] = true, _cx2)), style: { width: width } };var innerShadowNode = /*#__PURE__*/_react.default.createElement("div", { className: _Button.globalClasses.innerShadow });var outlineNode = null;if (!isFocused || isLink) {var _cx3;outlineNode = /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)(_Button.styles.outline(), (_cx3 = {}, _cx3[_Button.styles.outlineWarning(this.theme)] = warning, _cx3[_Button.styles.outlineError(this.theme)] = error, _cx3[_Button.styles.outlineLink()] = isLink, _cx3[_Button.styles.outlineLinkWarning(this.theme)] = isLink && warning, _cx3[_Button.styles.outlineLinkError(this.theme)] = isLink && error, _cx3)) });}var loadingNode = null;if (loading && !icon) {loadingNode = /*#__PURE__*/_react.default.createElement("div", { className: _Button.styles.loading() }, this.getLoadingSpinner());}var iconNode = null;if (icon) {var _cx4;iconNode = /*#__PURE__*/_react.default.createElement("span", { className: (0, _Emotion.cx)(_Button.styles.icon(), this.getSizeIconClassName(), (_cx4 = {}, _cx4[_Button.styles.iconNoRightMargin()] = !children, _cx4[_Button.styles.iconLink(this.theme)] = isLink, _cx4)) }, loading ? this.getLoadingSpinner() : icon);}var arrowNode = null;if (arrow) {var _cx5;arrowNode = /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)((_cx5 = {}, _cx5[_Button.styles.arrow()] = true, _cx5[_Button.styles.arrowWarning(this.theme)] = !checked && warning, _cx5[_Button.styles.arrowError(this.theme)] = !checked && error, _cx5[_Button.styles.arrowFocus(this.theme)] = !checked && isFocused, _cx5[_Button.styles.arrowLeft()] = arrow === 'left', _cx5)) }, /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)(_Button.globalClasses.arrowHelper, _Button.globalClasses.arrowHelperTop) }), /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)(_Button.globalClasses.arrowHelper, _Button.globalClasses.arrowHelperBottom) }));} // Force disable all props and features, that cannot be use with Link
483
- if (isLink) {var _cx6;rootProps.className = (0, _Emotion.cx)((_cx6 = {}, _cx6[_Button.styles.root(this.theme)] = true, _cx6[sizeClass] = true, _cx6[_Button.styles.link(this.theme)] = true, _cx6[_Button.styles.linkFocus(this.theme)] = isFocused, _cx6[_Button.styles.linkDisabled(this.theme)] = disabled || loading, _cx6));Object.assign(wrapProps, { className: (0, _Emotion.cx)(_Button.styles.wrap(this.theme), _Button.styles.wrapLink()), style: { width: wrapProps.style.width } });rootProps.style.textAlign = undefined;arrowNode = null;}return /*#__PURE__*/_react.default.createElement(_CommonWrapper.CommonWrapper, (0, _extends2.default)({ rootNodeRef: this.setRootNode }, this.props), /*#__PURE__*/_react.default.createElement("span", wrapProps, /*#__PURE__*/_react.default.createElement("button", (0, _extends2.default)({ "data-tid": ButtonDataTids.root, ref: this._ref }, rootProps, { "aria-describedby": ariaDescribedby }), innerShadowNode, outlineNode, loadingNode, arrowNode, /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)(_Button.styles.caption(), _Button.globalClasses.caption, (_cx7 = {}, _cx7[_Button.styles.captionTranslated()] = active || checked, _cx7[_Button.styles.captionLink()] = isLink, _cx7[_Button.styles.captionDisabled()] = !checked && disabled, _cx7)) }, iconNode, /*#__PURE__*/_react.default.createElement("span", { className: (0, _Emotion.cx)((_cx8 = {}, _cx8[_Button.styles.visibilityHidden()] = !!loadingNode, _cx8)) }, children)))));};_proto.getLoadingSpinner = function getLoadingSpinner() {return /*#__PURE__*/_react.default.createElement(_Spinner.Spinner, { caption: null, dimmed: true, type: "mini" });};_proto.getSizeClassName = function getSizeClassName() {var _cx9, _cx10, _cx11;switch (this.getProps().size) {case 'large':return (0, _Emotion.cx)(_Button.styles.sizeLarge(this.theme), (_cx9 = {}, _cx9[_Button.styles.sizeLargeIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx9));case 'medium':return (0, _Emotion.cx)(_Button.styles.sizeMedium(this.theme), (_cx10 = {}, _cx10[_Button.styles.sizeMediumIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx10));case 'small':default:return (0, _Emotion.cx)(_Button.styles.sizeSmall(this.theme), (_cx11 = {}, _cx11[_Button.styles.sizeSmallIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx11));}};_proto.getSizeIconClassName = function getSizeIconClassName() {switch (this.getProps().size) {case 'large':return _Button.styles.iconLarge(this.theme);case 'medium':return _Button.styles.iconMedium(this.theme);case 'small':default:return _Button.styles.iconSmall(this.theme);}};_proto.getSizeWrapClassName = function getSizeWrapClassName() {switch (this.getProps().size) {case 'large':return _Button.styles.wrapLarge(this.theme);case 'medium':return _Button.styles.wrapMedium(this.theme);case 'small':default:return _Button.styles.wrapSmall(this.theme);}};return Button;}(_react.default.Component), _class2.__KONTUR_REACT_UI__ = 'Button', _class2.__BUTTON__ = true, _class2.defaultProps = { use: 'default', size: 'small', type: 'button' }, _temp)) || _class;exports.Button = Button;var isButton = (0, _utils.isReactUIComponent)('Button');exports.isButton = isButton;
542
+ type: type, className: rootClassName, style: (0, _extends2.default)({ textAlign: align }, corners), disabled: disabled || loading, onClick: onClick, onFocus: this.handleFocus, onBlur: this.handleBlur, onKeyDown: onKeyDown, onMouseEnter: onMouseEnter, onMouseLeave: onMouseLeave, onMouseOver: onMouseOver, tabIndex: disableFocus ? -1 : 0, title: this.props.title };var wrapProps = { className: (0, _Emotion.cx)((_cx2 = {}, _cx2[_Button.styles.wrap(this.theme)] = true, _cx2[wrapClassNameWithArrow] = true, _cx2[this.getSizeWrapClassName()] = true, _cx2)), style: { width: width } };var innerShadowNode = _isTheme2022 ? null : /*#__PURE__*/_react.default.createElement("div", { className: _Button.globalClasses.innerShadow });var outlineNode = null;var isDisabled2022 = _isTheme2022 && (disabled || loading);if ((!isFocused || isLink) && !isDisabled2022) {var _cx3;outlineNode = /*#__PURE__*/_react.default.createElement("div", { style: { zIndex: _isTheme2022 && isLink ? -1 : undefined }, className: (0, _Emotion.cx)(_Button.styles.outline(), (_cx3 = {}, _cx3[_Button.styles.outlineWarning(this.theme)] = warning, _cx3[_Button.styles.outlineError(this.theme)] = error, _cx3[_Button.styles.outlineLink()] = isLink, _cx3[_Button.styles.outlineLinkWarning(this.theme)] = isLink && warning, _cx3[_Button.styles.outlineLinkError(this.theme)] = isLink && error, _cx3)) });}var iconNode = icon && /*#__PURE__*/_react.default.createElement(_ButtonIcon.ButtonIcon, { icon: icon, size: size, hasChildren: Boolean(children), disabled: disabled || false, loading: loading || false, use: use });var loadingNode = null;if (loading && !icon) {var loadingIcon = _isTheme2022 ? /*#__PURE__*/_react.default.createElement(_LoadingIcon.LoadingIcon, { size: size }) : /*#__PURE__*/_react.default.createElement(_Spinner.Spinner, { caption: null, dimmed: true, type: "mini" });loadingNode = /*#__PURE__*/_react.default.createElement("div", { className: _Button.styles.loading() }, loadingIcon);} // Force disable all props and features, that cannot be use with Link
543
+ if (isLink) {var _cx4;rootProps.className = (0, _Emotion.cx)((_cx4 = {}, _cx4[_Button.styles.root(this.theme)] = true, _cx4[sizeClass] = true, _cx4[_Button.styles.link(this.theme)] = true, _cx4[_Button.styles.linkLineHeight()] = !_client.isSafari || _client.isSafari && !_isTheme2022, _cx4[_Button.styles.linkLineHeightSafariFallback()] = _client.isSafari && _isTheme2022, _cx4[_Button.styles.linkFocus(this.theme)] = isFocused, _cx4[_Button.styles.linkDisabled(this.theme)] = disabled || loading, _cx4));Object.assign(wrapProps, { className: (0, _Emotion.cx)(_Button.styles.wrap(this.theme), _Button.styles.wrapLink()), style: { width: wrapProps.style.width } });rootProps.style.textAlign = undefined;}var captionNode = /*#__PURE__*/_react.default.createElement("div", { className: (0, _Emotion.cx)(_Button.styles.caption(), _Button.globalClasses.caption, (_cx5 = {}, _cx5[_Button.styles.captionTranslated()] = (active || checked) && !loading && !_isTheme2022, _cx5[_Button.styles.captionLink()] = isLink, _cx5[_Button.styles.captionDisabled()] = !checked && disabled, _cx5)) }, loadingNode, iconNode, /*#__PURE__*/_react.default.createElement("span", { className: (0, _Emotion.cx)(_Button.globalClasses.text, (_cx6 = {}, _cx6[_Button.styles.visibilityHidden()] = !!loadingNode, _cx6)) }, children));if (_isTheme2022 && isLink && !loading) {var _icon = icon;if (icon) {var sizes = { small: parseInt(this.theme.btnIconSizeSmall), medium: parseInt(this.theme.btnIconSizeMedium), large: parseInt(this.theme.btnIconSizeLarge) }; // Expect icon to have a `size` prop
544
+ _icon = /*#__PURE__*/_react.default.cloneElement(icon, { size: sizes[this.props.size || 'small'] });}captionNode = /*#__PURE__*/_react.default.createElement(_ThemeContext.ThemeContext.Provider, { value: (0, _getInnerLinkTheme.getInnerLinkTheme)(this.theme) }, /*#__PURE__*/_react.default.createElement(_Link.Link, { focused: isFocused, disabled: disabled, icon: _icon, as: "span", tabIndex: -1 }, children));}return /*#__PURE__*/_react.default.createElement(_CommonWrapper.CommonWrapper, (0, _extends2.default)({ rootNodeRef: this.setRootNode }, this.props), /*#__PURE__*/_react.default.createElement("span", wrapProps, /*#__PURE__*/_react.default.createElement("button", (0, _extends2.default)({ "data-tid": ButtonDataTids.root, ref: this._ref }, rootProps, { "aria-describedby": ariaDescribedby }), innerShadowNode, outlineNode, arrowNode, captionNode)));};_proto.getSizeClassName = function getSizeClassName() {var _cx7, _cx8, _cx9;var _isTheme2022 = (0, _ThemeHelpers.isTheme2022)(this.theme);switch (this.getProps().size) {case 'large':return (0, _Emotion.cx)(_Button.styles.sizeLarge(this.theme), (_cx7 = {}, _cx7[_Button.styles.sizeLargeIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx7[_Button.styles.sizeLargeWithIcon(this.theme)] = !!this.props.icon, _cx7[_Button.styles.sizeLargeWithIconWithoutText(this.theme)] = _isTheme2022 && !!this.props.icon && !this.props.children, _cx7));case 'medium':return (0, _Emotion.cx)(_Button.styles.sizeMedium(this.theme), (_cx8 = {}, _cx8[_Button.styles.sizeMediumIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx8[_Button.styles.sizeMediumWithIcon(this.theme)] = !!this.props.icon, _cx8[_Button.styles.sizeMediumWithIconWithoutText(this.theme)] = _isTheme2022 && !!this.props.icon && !this.props.children, _cx8));case 'small':default:return (0, _Emotion.cx)(_Button.styles.sizeSmall(this.theme), (_cx9 = {}, _cx9[_Button.styles.sizeSmallIE11(this.theme)] = _client.isIE11 || _client.isEdge, _cx9[_Button.styles.sizeSmallWithIcon(this.theme)] = !!this.props.icon, _cx9[_Button.styles.sizeSmallWithIconWithoutText(this.theme)] = _isTheme2022 && !!this.props.icon && !this.props.children, _cx9));}};_proto.getSizeWrapClassName = function getSizeWrapClassName() {switch (this.getProps().size) {case 'large':return _Button.styles.wrapLarge(this.theme);case 'medium':return _Button.styles.wrapMedium(this.theme);case 'small':default:return _Button.styles.wrapSmall(this.theme);}};return Button;}(_react.default.Component), _class2.__KONTUR_REACT_UI__ = 'Button', _class2.__BUTTON__ = true, _class2.defaultProps = { use: 'default', size: 'small', type: 'button' }, _temp)) || _class;exports.Button = Button;var isButton = (0, _utils.isReactUIComponent)('Button');exports.isButton = isButton;
@@ -1 +1 @@
1
- {"version":3,"sources":["Button.tsx"],"names":["ButtonDataTids","root","Button","rootNode","getProps","defaultProps","state","focusedByTab","node","handleFocus","e","props","disabled","disableFocus","requestAnimationFrame","keyListener","isTabPressed","setState","onFocus","handleBlur","onBlur","_ref","componentDidMount","autoFocus","focus","getDerivedStateFromProps","loading","blur","render","theme","renderMain","corners","active","borderless","checked","error","warning","arrow","narrow","icon","_noPadding","_noRightPadding","visuallyFocused","align","onMouseEnter","onMouseLeave","onMouseOver","onKeyDown","onClick","width","children","ariaDescribedby","use","type","sizeClass","getSizeClassName","isFocused","isLink","rootProps","className","styles","activeStyles","checkedFocused","checkedDisabled","noPadding","noRightPadding","style","textAlign","tabIndex","title","wrapProps","wrap","wrapArrow","wrapArrowLeft","getSizeWrapClassName","innerShadowNode","globalClasses","innerShadow","outlineNode","outline","outlineWarning","outlineError","outlineLink","outlineLinkWarning","outlineLinkError","loadingNode","getLoadingSpinner","iconNode","getSizeIconClassName","iconNoRightMargin","iconLink","arrowNode","arrowWarning","arrowError","arrowFocus","arrowLeft","arrowHelper","arrowHelperTop","arrowHelperBottom","link","linkFocus","linkDisabled","Object","assign","wrapLink","undefined","setRootNode","caption","captionTranslated","captionLink","captionDisabled","visibilityHidden","size","sizeLarge","sizeLargeIE11","isIE11","isEdge","sizeMedium","sizeMediumIE11","sizeSmall","sizeSmallIE11","iconLarge","iconMedium","iconSmall","wrapLarge","wrapMedium","wrapSmall","React","Component","__KONTUR_REACT_UI__","__BUTTON__","isButton"],"mappings":"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","sourcesContent":["import React, { AriaAttributes } from 'react';\n\nimport { isReactUIComponent } from '../../lib/utils';\nimport { isIE11, isEdge } from '../../lib/client';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { Theme } from '../../lib/theming/Theme';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { Spinner } from '../Spinner';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\n\nimport { styles, activeStyles, globalClasses } from './Button.styles';\n\nexport type ButtonSize = 'small' | 'medium' | 'large';\nexport type ButtonType = 'button' | 'submit' | 'reset';\nexport type ButtonUse = 'default' | 'primary' | 'success' | 'danger' | 'pay' | 'link';\n\nexport interface ButtonProps extends CommonProps {\n /** @ignore */\n _noPadding?: boolean;\n\n /** @ignore */\n _noRightPadding?: boolean;\n\n /**\n * Применяет к кнопке стили псевдокласса `:active`.\n */\n active?: boolean;\n\n /**\n * CSS-свойство `text-align`.\n */\n align?: React.CSSProperties['textAlign'];\n\n /**\n * Превращает обычную кнопку в кнопку со стрелкой.\n */\n arrow?: boolean | 'left';\n\n /**\n * Даёт кнопке фокус после окончания загрузки страницы.\n */\n autoFocus?: boolean;\n\n /**\n * Убирает обводку у кнопки.\n */\n borderless?: boolean;\n\n /**\n * @ignore\n */\n checked?: boolean;\n\n children?: React.ReactNode;\n\n /** @ignore */\n corners?: React.CSSProperties;\n\n /**\n * Отключенное состояние кнопки.\n */\n disabled?: boolean;\n\n /** @ignore */\n disableFocus?: boolean;\n\n /**\n * Состояние валидации при ошибке.\n */\n error?: boolean;\n\n /**\n * Иконка слева от текста кнопки.\n */\n icon?: React.ReactElement<any>;\n\n /**\n * Переводит кнопку в состояние загрузки.\n */\n loading?: boolean;\n\n /**\n * Сужает кнопку.\n */\n narrow?: boolean;\n\n /**\n * HTML-событие `onblur`.\n */\n onBlur?: React.FocusEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onclick`.\n */\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onfocus`.\n */\n onFocus?: React.FocusEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `keydown`.\n */\n onKeyDown?: React.KeyboardEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onmouseenter`.\n */\n onMouseEnter?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `mouseleave`.\n */\n onMouseLeave?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onmouseover`.\n */\n onMouseOver?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * Задаёт размер кнопки.\n *\n * **Допустимые значения**: `\"small\"`, `\"medium\"`, `\"large\"`.\n */\n size?: ButtonSize;\n\n /**\n * HTML-атрибут `type`.\n */\n type?: ButtonType;\n\n /**\n * HTML-атрибут `title`.\n */\n title?: string;\n\n /**\n * Стиль кнопки.\n *\n * **Допустимые значения**: `\"default\"`, `\"primary\"`, `\"success\"`, `\"danger\"`, `\"pay\"`, `\"link\"`.\n */\n use?: ButtonUse;\n\n /** @ignore */\n visuallyFocused?: boolean;\n\n /**\n * Состояние валидации при предупреждении.\n */\n warning?: boolean;\n\n /**\n * CSS-свойство `width`.\n */\n width?: number | string;\n\n /**\n * Атрибут для указания id элемента(-ов), описывающих его\n */\n 'aria-describedby'?: AriaAttributes['aria-describedby'];\n}\n\nexport interface ButtonState {\n focusedByTab: boolean;\n}\n\nexport const ButtonDataTids = {\n root: 'Button__root',\n} as const;\n\ntype DefaultProps = Required<Pick<ButtonProps, 'use' | 'size' | 'type'>>;\n\n@rootNode\nexport class Button extends React.Component<ButtonProps, ButtonState> {\n public static __KONTUR_REACT_UI__ = 'Button';\n public static __BUTTON__ = true;\n\n public static defaultProps: DefaultProps = {\n use: 'default',\n size: 'small',\n type: 'button',\n };\n\n private getProps = createPropsGetter(Button.defaultProps);\n\n public state = {\n focusedByTab: false,\n };\n\n private theme!: Theme;\n private node: HTMLButtonElement | null = null;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n if (this.props.autoFocus) {\n keyListener.isTabPressed = true;\n this.focus();\n }\n }\n\n public static getDerivedStateFromProps(props: ButtonProps) {\n if (props.loading || props.disabled) {\n return { focusedByTab: false };\n }\n return null;\n }\n\n /**\n * @public\n */\n public focus() {\n this.node?.focus();\n }\n\n /**\n * @public\n */\n public blur() {\n this.node?.blur();\n }\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const {\n corners,\n active,\n disabled,\n borderless,\n checked,\n error,\n warning,\n loading,\n arrow,\n narrow,\n icon,\n _noPadding,\n _noRightPadding,\n visuallyFocused,\n align,\n disableFocus,\n onMouseEnter,\n onMouseLeave,\n onMouseOver,\n onKeyDown,\n onClick,\n width,\n children,\n 'aria-describedby': ariaDescribedby,\n } = this.props;\n const { use, type } = this.getProps();\n const sizeClass = this.getSizeClassName();\n\n const isFocused = this.state.focusedByTab || visuallyFocused;\n const isLink = use === 'link';\n const rootProps = {\n // By default the type attribute is 'submit'. IE8 will fire a click event\n // on this button if somewhere on the page user presses Enter while some\n // input is focused. So we set type to 'button' by default.\n type,\n className: cx({\n [styles.root(this.theme)]: true,\n [styles[use](this.theme)]: true,\n [activeStyles[use](this.theme)]: active,\n [sizeClass]: true,\n [styles.focus(this.theme)]: isFocused,\n [styles.checked(this.theme)]: checked,\n [styles.checkedFocused(this.theme)]: checked && isFocused,\n [styles.disabled(this.theme)]: disabled || loading,\n [styles.checkedDisabled(this.theme)]: checked && disabled,\n [styles.borderless()]: borderless && !disabled && !loading && !checked && !isFocused && !active,\n [styles.narrow()]: narrow,\n [styles.noPadding()]: _noPadding,\n [styles.noRightPadding()]: _noRightPadding,\n }),\n style: {\n textAlign: align,\n ...corners,\n },\n disabled: disabled || loading,\n onClick,\n onFocus: this.handleFocus,\n onBlur: this.handleBlur,\n onKeyDown,\n onMouseEnter,\n onMouseLeave,\n onMouseOver,\n tabIndex: disableFocus ? -1 : 0,\n title: this.props.title,\n };\n\n const wrapProps = {\n className: cx({\n [styles.wrap(this.theme)]: true,\n [styles.wrapArrow()]: arrow === true,\n [styles.wrapArrowLeft()]: arrow === 'left',\n [this.getSizeWrapClassName()]: true,\n }),\n style: {\n width,\n },\n };\n\n const innerShadowNode = <div className={globalClasses.innerShadow} />;\n\n let outlineNode = null;\n if (!isFocused || isLink) {\n outlineNode = (\n <div\n className={cx(styles.outline(), {\n [styles.outlineWarning(this.theme)]: warning,\n [styles.outlineError(this.theme)]: error,\n [styles.outlineLink()]: isLink,\n [styles.outlineLinkWarning(this.theme)]: isLink && warning,\n [styles.outlineLinkError(this.theme)]: isLink && error,\n })}\n />\n );\n }\n\n let loadingNode = null;\n if (loading && !icon) {\n loadingNode = <div className={styles.loading()}>{this.getLoadingSpinner()}</div>;\n }\n\n let iconNode = null;\n if (icon) {\n iconNode = (\n <span\n className={cx(styles.icon(), this.getSizeIconClassName(), {\n [styles.iconNoRightMargin()]: !children,\n [styles.iconLink(this.theme)]: isLink,\n })}\n >\n {loading ? this.getLoadingSpinner() : icon}\n </span>\n );\n }\n\n let arrowNode = null;\n if (arrow) {\n arrowNode = (\n <div\n className={cx({\n [styles.arrow()]: true,\n [styles.arrowWarning(this.theme)]: !checked && warning,\n [styles.arrowError(this.theme)]: !checked && error,\n [styles.arrowFocus(this.theme)]: !checked && isFocused,\n [styles.arrowLeft()]: arrow === 'left',\n })}\n >\n <div className={cx(globalClasses.arrowHelper, globalClasses.arrowHelperTop)} />\n <div className={cx(globalClasses.arrowHelper, globalClasses.arrowHelperBottom)} />\n </div>\n );\n }\n\n // Force disable all props and features, that cannot be use with Link\n if (isLink) {\n rootProps.className = cx({\n [styles.root(this.theme)]: true,\n [sizeClass]: true,\n [styles.link(this.theme)]: true,\n [styles.linkFocus(this.theme)]: isFocused,\n [styles.linkDisabled(this.theme)]: disabled || loading,\n });\n Object.assign(wrapProps, {\n className: cx(styles.wrap(this.theme), styles.wrapLink()),\n style: { width: wrapProps.style.width },\n });\n rootProps.style.textAlign = undefined;\n arrowNode = null;\n }\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <span {...wrapProps}>\n <button data-tid={ButtonDataTids.root} ref={this._ref} {...rootProps} aria-describedby={ariaDescribedby}>\n {innerShadowNode}\n {outlineNode}\n {loadingNode}\n {arrowNode}\n <div\n className={cx(styles.caption(), globalClasses.caption, {\n [styles.captionTranslated()]: active || checked,\n [styles.captionLink()]: isLink,\n [styles.captionDisabled()]: !checked && disabled,\n })}\n >\n {iconNode}\n <span className={cx({ [styles.visibilityHidden()]: !!loadingNode })}>{children}</span>\n </div>\n </button>\n </span>\n </CommonWrapper>\n );\n }\n\n private getLoadingSpinner() {\n return <Spinner caption={null} dimmed type=\"mini\" />;\n }\n\n private getSizeClassName() {\n switch (this.getProps().size) {\n case 'large':\n return cx(styles.sizeLarge(this.theme), { [styles.sizeLargeIE11(this.theme)]: isIE11 || isEdge });\n case 'medium':\n return cx(styles.sizeMedium(this.theme), { [styles.sizeMediumIE11(this.theme)]: isIE11 || isEdge });\n case 'small':\n default:\n return cx(styles.sizeSmall(this.theme), { [styles.sizeSmallIE11(this.theme)]: isIE11 || isEdge });\n }\n }\n\n private getSizeIconClassName() {\n switch (this.getProps().size) {\n case 'large':\n return styles.iconLarge(this.theme);\n case 'medium':\n return styles.iconMedium(this.theme);\n case 'small':\n default:\n return styles.iconSmall(this.theme);\n }\n }\n\n private getSizeWrapClassName() {\n switch (this.getProps().size) {\n case 'large':\n return styles.wrapLarge(this.theme);\n case 'medium':\n return styles.wrapMedium(this.theme);\n case 'small':\n default:\n return styles.wrapSmall(this.theme);\n }\n }\n\n private handleFocus = (e: React.FocusEvent<HTMLButtonElement>) => {\n if (!this.props.disabled && !this.props.disableFocus) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n this.props.onFocus?.(e);\n }\n };\n\n private handleBlur = (e: React.FocusEvent<HTMLButtonElement>) => {\n this.setState({ focusedByTab: false });\n if (!this.props.disabled && !this.props.disableFocus) {\n this.props.onBlur?.(e);\n }\n };\n\n private _ref = (node: HTMLButtonElement | null) => {\n this.node = node;\n };\n}\n\nexport const isButton = isReactUIComponent<ButtonProps>('Button');\n"]}
1
+ {"version":3,"sources":["Button.tsx"],"names":["ButtonDataTids","root","Button","rootNode","getProps","defaultProps","state","focusedByTab","node","handleFocus","e","props","disabled","disableFocus","requestAnimationFrame","keyListener","isTabPressed","setState","onFocus","handleBlur","onBlur","_ref","componentDidMount","autoFocus","focus","getDerivedStateFromProps","loading","blur","render","theme","ThemeFactory","create","renderMain","corners","active","borderless","checked","error","warning","narrow","icon","_noPadding","_noRightPadding","visuallyFocused","align","onMouseEnter","onMouseLeave","onMouseOver","onKeyDown","onClick","width","children","ariaDescribedby","use","type","size","sizeClass","getSizeClassName","isFocused","isLink","_isTheme2022","Boolean","wrapClassNameWithArrow","rootClassNameWithArrow","arrowNode","rootClassName","trueDisabled","cx","styles","noPadding","noRightPadding","checkedDisabled","checkedDisabled2022","borderless2022","activeStyles","checked2022","checkedFocused","simulatedPress","rootProps","className","style","textAlign","tabIndex","title","wrapProps","wrap","getSizeWrapClassName","innerShadowNode","globalClasses","innerShadow","outlineNode","isDisabled2022","zIndex","undefined","outline","outlineWarning","outlineError","outlineLink","outlineLinkWarning","outlineLinkError","iconNode","loadingNode","loadingIcon","link","linkLineHeight","isSafari","linkLineHeightSafariFallback","linkFocus","linkDisabled","Object","assign","wrapLink","captionNode","caption","captionTranslated","captionLink","captionDisabled","text","visibilityHidden","_icon","sizes","small","parseInt","btnIconSizeSmall","medium","btnIconSizeMedium","large","btnIconSizeLarge","React","cloneElement","setRootNode","sizeLarge","sizeLargeIE11","isIE11","isEdge","sizeLargeWithIcon","sizeLargeWithIconWithoutText","sizeMedium","sizeMediumIE11","sizeMediumWithIcon","sizeMediumWithIconWithoutText","sizeSmall","sizeSmallIE11","sizeSmallWithIcon","sizeSmallWithIconWithoutText","wrapLarge","wrapMedium","wrapSmall","Component","__KONTUR_REACT_UI__","__BUTTON__","isButton"],"mappings":"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","sourcesContent":["import React, { AriaAttributes } from 'react';\n\nimport { isReactUIComponent } from '../../lib/utils';\nimport { isIE11, isEdge, isSafari } from '../../lib/client';\nimport { keyListener } from '../../lib/events/keyListener';\nimport { Theme, ThemeIn } from '../../lib/theming/Theme';\nimport { ThemeContext } from '../../lib/theming/ThemeContext';\nimport { CommonWrapper, CommonProps } from '../../internal/CommonWrapper';\nimport { cx } from '../../lib/theming/Emotion';\nimport { rootNode, TSetRootNode } from '../../lib/rootNode';\nimport { ThemeFactory } from '../../lib/theming/ThemeFactory';\nimport { createPropsGetter } from '../../lib/createPropsGetter';\nimport { isTheme2022 } from '../../lib/theming/ThemeHelpers';\nimport { Link } from '../Link';\nimport { Spinner } from '../Spinner';\nimport { LoadingIcon } from '../../internal/icons2022/LoadingIcon';\n\nimport { styles, activeStyles, globalClasses } from './Button.styles';\nimport { ButtonIcon } from './ButtonIcon';\nimport { useButtonArrow } from './ButtonArrow';\nimport { getInnerLinkTheme } from './getInnerLinkTheme';\n\nexport type ButtonSize = 'small' | 'medium' | 'large';\nexport type ButtonType = 'button' | 'submit' | 'reset';\nexport type ButtonUse = 'default' | 'primary' | 'success' | 'danger' | 'pay' | 'link' | 'text' | 'backless';\n\nexport interface ButtonProps extends CommonProps {\n /** @ignore */\n _noPadding?: boolean;\n\n /** @ignore */\n _noRightPadding?: boolean;\n\n /**\n * Применяет к кнопке стили псевдокласса `:active`.\n */\n active?: boolean;\n\n /**\n * CSS-свойство `text-align`.\n */\n align?: React.CSSProperties['textAlign'];\n\n /**\n * Превращает обычную кнопку в кнопку со стрелкой.\n */\n arrow?: boolean | 'left';\n\n /**\n * Даёт кнопке фокус после окончания загрузки страницы.\n */\n autoFocus?: boolean;\n\n /**\n * Убирает обводку у кнопки.\n */\n borderless?: boolean;\n\n /**\n * @ignore\n */\n checked?: boolean;\n\n children?: React.ReactNode;\n\n /** @ignore */\n corners?: React.CSSProperties;\n\n /**\n * Отключенное состояние кнопки.\n */\n disabled?: boolean;\n\n /** @ignore */\n disableFocus?: boolean;\n\n /**\n * Состояние валидации при ошибке.\n */\n error?: boolean;\n\n /**\n * Иконка слева от текста кнопки.\n */\n icon?: React.ReactElement<any>;\n\n /**\n * Переводит кнопку в состояние загрузки.\n */\n loading?: boolean;\n\n /**\n * Сужает кнопку.\n */\n narrow?: boolean;\n\n /**\n * HTML-событие `onblur`.\n */\n onBlur?: React.FocusEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onclick`.\n */\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onfocus`.\n */\n onFocus?: React.FocusEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `keydown`.\n */\n onKeyDown?: React.KeyboardEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onmouseenter`.\n */\n onMouseEnter?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `mouseleave`.\n */\n onMouseLeave?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * HTML-событие `onmouseover`.\n */\n onMouseOver?: React.MouseEventHandler<HTMLButtonElement>;\n\n /**\n * Задаёт размер кнопки.\n *\n * **Допустимые значения**: `\"small\"`, `\"medium\"`, `\"large\"`.\n */\n size?: ButtonSize;\n\n /**\n * HTML-атрибут `type`.\n */\n type?: ButtonType;\n\n /**\n * HTML-атрибут `title`.\n */\n title?: string;\n\n /**\n * Стиль кнопки.\n *\n * **Допустимые значения**: `\"default\"`, `\"primary\"`, `\"success\"`, `\"danger\"`, `\"pay\"`, `\"link\"`, `\"text\"`, `\"backless\"`.\n */\n use?: ButtonUse;\n\n /** @ignore */\n visuallyFocused?: boolean;\n\n /**\n * Состояние валидации при предупреждении.\n */\n warning?: boolean;\n\n /**\n * CSS-свойство `width`.\n */\n width?: number | string;\n\n /**\n * Обычный объект с переменными темы.\n * Он будет объединён с темой из контекста.\n */\n theme?: ThemeIn;\n\n /**\n * Атрибут для указания id элемента(-ов), описывающих его\n */\n 'aria-describedby'?: AriaAttributes['aria-describedby'];\n}\n\nexport interface ButtonState {\n focusedByTab: boolean;\n}\n\nexport const ButtonDataTids = {\n root: 'Button__root',\n} as const;\n\ntype DefaultProps = Required<Pick<ButtonProps, 'use' | 'size' | 'type'>>;\n\n@rootNode\nexport class Button extends React.Component<ButtonProps, ButtonState> {\n public static __KONTUR_REACT_UI__ = 'Button';\n public static __BUTTON__ = true;\n\n public static defaultProps: DefaultProps = {\n use: 'default',\n size: 'small',\n type: 'button',\n };\n\n private getProps = createPropsGetter(Button.defaultProps);\n\n public state = {\n focusedByTab: false,\n };\n\n private theme!: Theme;\n private node: HTMLButtonElement | null = null;\n private setRootNode!: TSetRootNode;\n\n public componentDidMount() {\n if (this.props.autoFocus) {\n keyListener.isTabPressed = true;\n this.focus();\n }\n }\n\n public static getDerivedStateFromProps(props: ButtonProps) {\n if (props.loading || props.disabled) {\n return { focusedByTab: false };\n }\n return null;\n }\n\n /**\n * @public\n */\n public focus() {\n this.node?.focus();\n }\n\n /**\n * @public\n */\n public blur() {\n this.node?.blur();\n }\n\n public render(): JSX.Element {\n return (\n <ThemeContext.Consumer>\n {(theme) => {\n this.theme = this.props.theme ? ThemeFactory.create(this.props.theme as Theme, theme) : theme;\n return this.renderMain();\n }}\n </ThemeContext.Consumer>\n );\n }\n\n private renderMain() {\n const {\n corners,\n active,\n disabled,\n borderless,\n checked,\n error,\n warning,\n loading,\n narrow,\n icon,\n _noPadding,\n _noRightPadding,\n visuallyFocused,\n align,\n disableFocus,\n onMouseEnter,\n onMouseLeave,\n onMouseOver,\n onKeyDown,\n onClick,\n width,\n children,\n 'aria-describedby': ariaDescribedby,\n } = this.props;\n const { use, type, size } = this.getProps();\n const sizeClass = this.getSizeClassName();\n\n const isFocused = this.state.focusedByTab || visuallyFocused;\n const isLink = use === 'link';\n const _isTheme2022 = isTheme2022(this.theme);\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const [wrapClassNameWithArrow, rootClassNameWithArrow, arrowNode] = useButtonArrow(\n { ...this.props, isFocused: Boolean(isFocused) },\n this.theme,\n );\n\n let rootClassName = '';\n if (_isTheme2022) {\n const trueDisabled = disabled || loading;\n rootClassName = cx(\n styles.root(this.theme),\n styles[use](this.theme),\n sizeClass,\n narrow && styles.narrow(),\n _noPadding && styles.noPadding(),\n _noRightPadding && styles.noRightPadding(),\n rootClassNameWithArrow,\n ...(trueDisabled\n ? [\n styles.disabled(this.theme),\n checked && styles.checkedDisabled(this.theme),\n checked && styles.checkedDisabled2022(this.theme),\n borderless && styles.borderless2022(),\n ]\n : [\n active && !checked && activeStyles[use](this.theme),\n isFocused && styles.focus(this.theme),\n checked && styles.checked2022(this.theme),\n checked && isFocused && styles.checkedFocused(this.theme),\n borderless && !checked && !isFocused && styles.borderless2022(),\n ]),\n );\n } else {\n rootClassName = cx({\n [styles.root(this.theme)]: true,\n [styles.simulatedPress()]: true,\n [styles[use](this.theme)]: true,\n [activeStyles[use](this.theme)]: active,\n [sizeClass]: true,\n [styles.focus(this.theme)]: isFocused,\n [styles.checked(this.theme)]: checked,\n [styles.checkedFocused(this.theme)]: checked && isFocused,\n [styles.disabled(this.theme)]: disabled || loading,\n [styles.checkedDisabled(this.theme)]: checked && disabled,\n [styles.borderless()]: borderless && !disabled && !loading && !checked && !isFocused && !active,\n [styles.narrow()]: narrow,\n [styles.noPadding()]: _noPadding,\n [styles.noRightPadding()]: _noRightPadding,\n });\n }\n\n const rootProps = {\n // By default the type attribute is 'submit'. IE8 will fire a click event\n // on this button if somewhere on the page user presses Enter while some\n // input is focused. So we set type to 'button' by default.\n type,\n className: rootClassName,\n style: {\n textAlign: align,\n ...corners,\n },\n disabled: disabled || loading,\n onClick,\n onFocus: this.handleFocus,\n onBlur: this.handleBlur,\n onKeyDown,\n onMouseEnter,\n onMouseLeave,\n onMouseOver,\n tabIndex: disableFocus ? -1 : 0,\n title: this.props.title,\n };\n\n const wrapProps = {\n className: cx({\n [styles.wrap(this.theme)]: true,\n [wrapClassNameWithArrow]: true,\n [this.getSizeWrapClassName()]: true,\n }),\n style: {\n width,\n },\n };\n\n const innerShadowNode = _isTheme2022 ? null : <div className={globalClasses.innerShadow} />;\n\n let outlineNode = null;\n const isDisabled2022 = _isTheme2022 && (disabled || loading);\n if ((!isFocused || isLink) && !isDisabled2022) {\n outlineNode = (\n <div\n style={{ zIndex: _isTheme2022 && isLink ? -1 : undefined }}\n className={cx(styles.outline(), {\n [styles.outlineWarning(this.theme)]: warning,\n [styles.outlineError(this.theme)]: error,\n [styles.outlineLink()]: isLink,\n [styles.outlineLinkWarning(this.theme)]: isLink && warning,\n [styles.outlineLinkError(this.theme)]: isLink && error,\n })}\n />\n );\n }\n\n const iconNode = icon && (\n <ButtonIcon\n icon={icon}\n size={size}\n hasChildren={Boolean(children)}\n disabled={disabled || false}\n loading={loading || false}\n use={use}\n />\n );\n let loadingNode = null;\n if (loading && !icon) {\n const loadingIcon = _isTheme2022 ? <LoadingIcon size={size} /> : <Spinner caption={null} dimmed type=\"mini\" />;\n loadingNode = <div className={styles.loading()}>{loadingIcon}</div>;\n }\n\n // Force disable all props and features, that cannot be use with Link\n if (isLink) {\n rootProps.className = cx({\n [styles.root(this.theme)]: true,\n [sizeClass]: true,\n [styles.link(this.theme)]: true,\n [styles.linkLineHeight()]: !isSafari || (isSafari && !_isTheme2022),\n [styles.linkLineHeightSafariFallback()]: isSafari && _isTheme2022,\n [styles.linkFocus(this.theme)]: isFocused,\n [styles.linkDisabled(this.theme)]: disabled || loading,\n });\n Object.assign(wrapProps, {\n className: cx(styles.wrap(this.theme), styles.wrapLink()),\n style: { width: wrapProps.style.width },\n });\n rootProps.style.textAlign = undefined;\n }\n\n let captionNode = (\n <div\n className={cx(styles.caption(), globalClasses.caption, {\n [styles.captionTranslated()]: (active || checked) && !loading && !_isTheme2022,\n [styles.captionLink()]: isLink,\n [styles.captionDisabled()]: !checked && disabled,\n })}\n >\n {loadingNode}\n {iconNode}\n <span\n className={cx(globalClasses.text, {\n [styles.visibilityHidden()]: !!loadingNode,\n })}\n >\n {children}\n </span>\n </div>\n );\n if (_isTheme2022 && isLink && !loading) {\n let _icon = icon;\n if (icon) {\n const sizes: Record<ButtonSize, number> = {\n small: parseInt(this.theme.btnIconSizeSmall),\n medium: parseInt(this.theme.btnIconSizeMedium),\n large: parseInt(this.theme.btnIconSizeLarge),\n };\n // Expect icon to have a `size` prop\n _icon = React.cloneElement(icon, { size: sizes[this.props.size || 'small'] });\n }\n\n captionNode = (\n <ThemeContext.Provider value={getInnerLinkTheme(this.theme)}>\n <Link focused={isFocused} disabled={disabled} icon={_icon} as=\"span\" tabIndex={-1}>\n {children}\n </Link>\n </ThemeContext.Provider>\n );\n }\n\n return (\n <CommonWrapper rootNodeRef={this.setRootNode} {...this.props}>\n <span {...wrapProps}>\n <button data-tid={ButtonDataTids.root} ref={this._ref} {...rootProps} aria-describedby={ariaDescribedby}>\n {innerShadowNode}\n {outlineNode}\n {arrowNode}\n {captionNode}\n </button>\n </span>\n </CommonWrapper>\n );\n }\n\n private getSizeClassName() {\n const _isTheme2022 = isTheme2022(this.theme);\n switch (this.getProps().size) {\n case 'large':\n return cx(styles.sizeLarge(this.theme), {\n [styles.sizeLargeIE11(this.theme)]: isIE11 || isEdge,\n [styles.sizeLargeWithIcon(this.theme)]: !!this.props.icon,\n [styles.sizeLargeWithIconWithoutText(this.theme)]: _isTheme2022 && !!this.props.icon && !this.props.children,\n });\n case 'medium':\n return cx(styles.sizeMedium(this.theme), {\n [styles.sizeMediumIE11(this.theme)]: isIE11 || isEdge,\n [styles.sizeMediumWithIcon(this.theme)]: !!this.props.icon,\n [styles.sizeMediumWithIconWithoutText(this.theme)]: _isTheme2022 && !!this.props.icon && !this.props.children,\n });\n case 'small':\n default:\n return cx(styles.sizeSmall(this.theme), {\n [styles.sizeSmallIE11(this.theme)]: isIE11 || isEdge,\n [styles.sizeSmallWithIcon(this.theme)]: !!this.props.icon,\n [styles.sizeSmallWithIconWithoutText(this.theme)]: _isTheme2022 && !!this.props.icon && !this.props.children,\n });\n }\n }\n\n private getSizeWrapClassName() {\n switch (this.getProps().size) {\n case 'large':\n return styles.wrapLarge(this.theme);\n case 'medium':\n return styles.wrapMedium(this.theme);\n case 'small':\n default:\n return styles.wrapSmall(this.theme);\n }\n }\n\n private handleFocus = (e: React.FocusEvent<HTMLButtonElement>) => {\n if (!this.props.disabled && !this.props.disableFocus) {\n // focus event fires before keyDown eventlistener\n // so we should check tabPressed in async way\n requestAnimationFrame(() => {\n if (keyListener.isTabPressed) {\n this.setState({ focusedByTab: true });\n }\n });\n this.props.onFocus?.(e);\n }\n };\n\n private handleBlur = (e: React.FocusEvent<HTMLButtonElement>) => {\n this.setState({ focusedByTab: false });\n if (!this.props.disabled && !this.props.disableFocus) {\n this.props.onBlur?.(e);\n }\n };\n\n private _ref = (node: HTMLButtonElement | null) => {\n this.node = node;\n };\n}\n\nexport const isButton = isReactUIComponent<ButtonProps>('Button');\n"]}