@broxus/react-uikit 0.1.3 → 0.2.1

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 (601) hide show
  1. package/LICENSE +154 -167
  2. package/dist/cjs/components/Accordion/Accordion.d.ts +3 -2
  3. package/dist/cjs/components/Accordion/Accordion.js +8 -5
  4. package/dist/cjs/components/Accordion/Item.d.ts +3 -6
  5. package/dist/cjs/components/Accordion/Item.js +6 -6
  6. package/dist/cjs/components/Accordion/index.d.ts +6 -5
  7. package/dist/cjs/components/Accordion/index.js +2 -2
  8. package/dist/cjs/components/Alert/index.d.ts +3 -3
  9. package/dist/cjs/components/Alert/index.js +17 -10
  10. package/dist/cjs/components/Align/Align.d.ts +5 -7
  11. package/dist/cjs/components/Align/Align.js +9 -6
  12. package/dist/cjs/components/Align/Left.d.ts +3 -5
  13. package/dist/cjs/components/Align/Left.js +3 -6
  14. package/dist/cjs/components/Align/Right.d.ts +3 -5
  15. package/dist/cjs/components/Align/Right.js +3 -6
  16. package/dist/cjs/components/Align/index.d.ts +8 -7
  17. package/dist/cjs/components/Align/index.js +3 -3
  18. package/dist/cjs/components/Article/Article.d.ts +1 -1
  19. package/dist/cjs/components/Article/Article.js +9 -4
  20. package/dist/cjs/components/Article/Meta.d.ts +4 -9
  21. package/dist/cjs/components/Article/Meta.js +8 -6
  22. package/dist/cjs/components/Article/Title.d.ts +4 -9
  23. package/dist/cjs/components/Article/Title.js +8 -6
  24. package/dist/cjs/components/Article/index.d.ts +7 -9
  25. package/dist/cjs/components/Article/index.js +3 -3
  26. package/dist/cjs/components/Badge/index.d.ts +4 -6
  27. package/dist/cjs/components/Badge/index.js +7 -4
  28. package/dist/cjs/components/Breadcrumb/Breadcrumb.d.ts +1 -1
  29. package/dist/cjs/components/Breadcrumb/Breadcrumb.js +7 -4
  30. package/dist/cjs/components/Breadcrumb/Item.d.ts +1 -4
  31. package/dist/cjs/components/Breadcrumb/Item.js +3 -4
  32. package/dist/cjs/components/Breadcrumb/index.d.ts +5 -5
  33. package/dist/cjs/components/Breadcrumb/index.js +2 -2
  34. package/dist/cjs/components/Button/Button.d.ts +1 -1
  35. package/dist/cjs/components/Button/Button.js +16 -14
  36. package/dist/cjs/components/Button/Group.d.ts +1 -4
  37. package/dist/cjs/components/Button/Group.js +6 -6
  38. package/dist/cjs/components/Button/index.d.ts +5 -5
  39. package/dist/cjs/components/Button/index.js +2 -2
  40. package/dist/cjs/components/Card/Badge.d.ts +3 -7
  41. package/dist/cjs/components/Card/Badge.js +10 -7
  42. package/dist/cjs/components/Card/Body.d.ts +1 -4
  43. package/dist/cjs/components/Card/Body.js +8 -6
  44. package/dist/cjs/components/Card/Card.d.ts +4 -6
  45. package/dist/cjs/components/Card/Card.js +17 -11
  46. package/dist/cjs/components/Card/Footer.d.ts +4 -9
  47. package/dist/cjs/components/Card/Footer.js +8 -6
  48. package/dist/cjs/components/Card/Header.d.ts +4 -9
  49. package/dist/cjs/components/Card/Header.js +8 -6
  50. package/dist/cjs/components/Card/Media.d.ts +1 -4
  51. package/dist/cjs/components/Card/Media.js +8 -6
  52. package/dist/cjs/components/Card/Title.d.ts +4 -9
  53. package/dist/cjs/components/Card/Title.js +9 -7
  54. package/dist/cjs/components/Card/index.d.ts +10 -10
  55. package/dist/cjs/components/Card/index.js +7 -7
  56. package/dist/cjs/components/Close/index.d.ts +3 -7
  57. package/dist/cjs/components/Close/index.js +7 -4
  58. package/dist/cjs/components/Component/index.d.ts +9 -4
  59. package/dist/cjs/components/Component/index.js +26 -2
  60. package/dist/cjs/components/ComponentProvider/index.d.ts +11 -0
  61. package/dist/cjs/components/ComponentProvider/index.js +49 -0
  62. package/dist/cjs/components/ConfrigProvider/index.d.ts +9 -7
  63. package/dist/cjs/components/ConfrigProvider/index.js +37 -7
  64. package/dist/cjs/components/Container/index.d.ts +4 -5
  65. package/dist/cjs/components/Container/index.js +12 -7
  66. package/dist/cjs/components/Control/Checkbox/Checkbox.d.ts +7 -2
  67. package/dist/cjs/components/Control/Checkbox/Checkbox.js +68 -46
  68. package/dist/cjs/components/Control/Checkbox/CheckboxGroupContext.d.ts +26 -0
  69. package/dist/cjs/components/Control/Checkbox/{Context.js → CheckboxGroupContext.js} +6 -3
  70. package/dist/cjs/components/Control/Checkbox/Group.d.ts +14 -2
  71. package/dist/cjs/components/Control/Checkbox/Group.js +31 -28
  72. package/dist/cjs/components/Control/Checkbox/index.d.ts +8 -6
  73. package/dist/cjs/components/Control/Checkbox/index.js +3 -3
  74. package/dist/cjs/components/Control/Checkbox/index.scss +15 -8
  75. package/dist/cjs/components/Control/Checkbox/types.d.ts +3 -66
  76. package/dist/cjs/components/Control/Input/Input.d.ts +2 -2
  77. package/dist/cjs/components/Control/Input/Input.js +22 -13
  78. package/dist/cjs/components/Control/Input/Number/index.d.ts +2 -2
  79. package/dist/cjs/components/Control/Input/Number/index.js +24 -19
  80. package/dist/cjs/components/Control/Input/Password/index.d.ts +2 -2
  81. package/dist/cjs/components/Control/Input/Password/index.js +39 -27
  82. package/dist/cjs/components/Control/Input/index.d.ts +7 -7
  83. package/dist/cjs/components/Control/Input/index.js +5 -5
  84. package/dist/cjs/components/Control/Input/types.d.ts +5 -5
  85. package/dist/cjs/components/Control/Input/useInput.d.ts +5 -4
  86. package/dist/cjs/components/Control/Input/useInput.js +47 -50
  87. package/dist/cjs/components/Control/Radio/Group.d.ts +7 -2
  88. package/dist/cjs/components/Control/Radio/Group.js +24 -17
  89. package/dist/cjs/components/Control/Radio/Radio.d.ts +6 -2
  90. package/dist/cjs/components/Control/Radio/Radio.js +58 -40
  91. package/dist/cjs/components/Control/Radio/RadioGroupContext.d.ts +9 -0
  92. package/dist/cjs/components/Control/Radio/{Context.js → RadioGroupContext.js} +6 -3
  93. package/dist/cjs/components/Control/Radio/index.d.ts +6 -6
  94. package/dist/cjs/components/Control/Radio/index.js +2 -17
  95. package/dist/cjs/components/Control/Radio/index.scss +9 -5
  96. package/dist/cjs/components/Control/Select/index.d.ts +8 -12
  97. package/dist/cjs/components/Control/Select/index.js +72 -49
  98. package/dist/cjs/components/Control/TextArea/index.d.ts +3 -10
  99. package/dist/cjs/components/Control/TextArea/index.js +51 -47
  100. package/dist/cjs/components/Control/TextArea/index.scss +10 -1
  101. package/dist/cjs/components/Control/index.d.ts +6 -6
  102. package/dist/cjs/components/Control/index.js +6 -6
  103. package/dist/cjs/components/Control/index.scss +6 -0
  104. package/dist/cjs/components/Control/types.d.ts +8 -7
  105. package/dist/cjs/components/Cover/index.d.ts +2 -1
  106. package/dist/cjs/components/Cover/index.js +24 -17
  107. package/dist/cjs/components/DescriptionList/Description.d.ts +1 -6
  108. package/dist/cjs/components/DescriptionList/Description.js +2 -5
  109. package/dist/cjs/components/DescriptionList/DescriptionList.d.ts +2 -1
  110. package/dist/cjs/components/DescriptionList/DescriptionList.js +10 -5
  111. package/dist/cjs/components/DescriptionList/Term.d.ts +1 -6
  112. package/dist/cjs/components/DescriptionList/Term.js +2 -5
  113. package/dist/cjs/components/DescriptionList/index.d.ts +6 -6
  114. package/dist/cjs/components/DescriptionList/index.js +3 -3
  115. package/dist/cjs/components/Divider/index.d.ts +2 -1
  116. package/dist/cjs/components/Divider/index.js +11 -6
  117. package/dist/cjs/components/Dotnav/Dotnav.d.ts +2 -1
  118. package/dist/cjs/components/Dotnav/Dotnav.js +10 -5
  119. package/dist/cjs/components/Dotnav/Item.d.ts +1 -4
  120. package/dist/cjs/components/Dotnav/Item.js +7 -6
  121. package/dist/cjs/components/Dotnav/index.d.ts +5 -5
  122. package/dist/cjs/components/Dotnav/index.js +2 -2
  123. package/dist/cjs/components/Drawer/index.d.ts +7 -44
  124. package/dist/cjs/components/Drawer/index.js +40 -139
  125. package/dist/cjs/components/Drawer/index.scss +11 -14
  126. package/dist/cjs/components/Drop/index.d.ts +12 -4
  127. package/dist/cjs/components/Drop/index.js +38 -21
  128. package/dist/cjs/components/Drop/index.scss +0 -26
  129. package/dist/cjs/components/Dropdown/index.d.ts +3 -3
  130. package/dist/cjs/components/Dropdown/index.js +5 -2
  131. package/dist/cjs/components/Flex/index.d.ts +15 -16
  132. package/dist/cjs/components/Flex/index.js +15 -13
  133. package/dist/cjs/components/Form/Controls.d.ts +3 -4
  134. package/dist/cjs/components/Form/Controls.js +10 -6
  135. package/dist/cjs/components/Form/ControlsText.d.ts +3 -4
  136. package/dist/cjs/components/Form/ControlsText.js +10 -6
  137. package/dist/cjs/components/Form/Fieldset.d.ts +4 -4
  138. package/dist/cjs/components/Form/Fieldset.js +10 -6
  139. package/dist/cjs/components/Form/Form.d.ts +4 -5
  140. package/dist/cjs/components/Form/Form.js +11 -7
  141. package/dist/cjs/components/Form/Label.d.ts +3 -4
  142. package/dist/cjs/components/Form/Label.js +9 -6
  143. package/dist/cjs/components/Form/Legend.d.ts +3 -4
  144. package/dist/cjs/components/Form/Legend.js +8 -6
  145. package/dist/cjs/components/Form/index.d.ts +9 -9
  146. package/dist/cjs/components/Form/index.js +6 -6
  147. package/dist/cjs/components/Grid/index.d.ts +7 -8
  148. package/dist/cjs/components/Grid/index.js +13 -11
  149. package/dist/cjs/components/Heading/index.d.ts +5 -6
  150. package/dist/cjs/components/Heading/index.js +11 -6
  151. package/dist/cjs/components/Icon/Button.d.ts +3 -5
  152. package/dist/cjs/components/Icon/Button.js +3 -6
  153. package/dist/cjs/components/Icon/Icon.d.ts +4 -6
  154. package/dist/cjs/components/Icon/Icon.js +9 -9
  155. package/dist/cjs/components/Icon/Link.d.ts +3 -5
  156. package/dist/cjs/components/Icon/Link.js +3 -6
  157. package/dist/cjs/components/Icon/default-svg-props.d.ts +1 -1
  158. package/dist/cjs/components/Icon/default-svg-props.js +2 -2
  159. package/dist/cjs/components/Icon/index.d.ts +9 -9
  160. package/dist/cjs/components/Icon/index.js +5 -5
  161. package/dist/cjs/components/Iconnav/Iconnav.d.ts +1 -1
  162. package/dist/cjs/components/Iconnav/Iconnav.js +6 -6
  163. package/dist/cjs/components/Iconnav/Item.d.ts +1 -5
  164. package/dist/cjs/components/Iconnav/Item.js +4 -5
  165. package/dist/cjs/components/Iconnav/index.d.ts +5 -5
  166. package/dist/cjs/components/Iconnav/index.js +2 -2
  167. package/dist/cjs/components/Label/index.d.ts +1 -1
  168. package/dist/cjs/components/Label/index.js +7 -7
  169. package/dist/cjs/components/Label/index.scss +1 -1
  170. package/dist/cjs/components/Link/index.d.ts +3 -3
  171. package/dist/cjs/components/Link/index.js +9 -3
  172. package/dist/cjs/components/List/Item.d.ts +2 -5
  173. package/dist/cjs/components/List/Item.js +2 -5
  174. package/dist/cjs/components/List/List.d.ts +1 -1
  175. package/dist/cjs/components/List/List.js +8 -8
  176. package/dist/cjs/components/List/index.d.ts +5 -5
  177. package/dist/cjs/components/List/index.js +2 -2
  178. package/dist/cjs/components/Modal/Modal.d.ts +4 -3
  179. package/dist/cjs/components/Modal/Modal.js +19 -16
  180. package/dist/cjs/components/Modal/index.d.ts +1 -1
  181. package/dist/cjs/components/Modal/index.js +1 -1
  182. package/dist/cjs/components/Nav/Divider.d.ts +3 -8
  183. package/dist/cjs/components/Nav/Divider.js +6 -7
  184. package/dist/cjs/components/Nav/Group/InternalNavItemGroup.d.ts +11 -0
  185. package/dist/cjs/components/Nav/Group/InternalNavItemGroup.js +42 -0
  186. package/dist/cjs/components/Nav/Group/index.d.ts +3 -0
  187. package/dist/cjs/components/Nav/{Group.js → Group/index.js} +10 -19
  188. package/dist/cjs/components/Nav/Header.d.ts +1 -1
  189. package/dist/cjs/components/Nav/Header.js +2 -2
  190. package/dist/cjs/components/Nav/Item/InternalNavItem.d.ts +16 -2
  191. package/dist/cjs/components/Nav/Item/InternalNavItem.js +54 -35
  192. package/dist/cjs/components/Nav/Item/LegacyNavItem.js +1 -1
  193. package/dist/cjs/components/Nav/Item/index.d.ts +2 -28
  194. package/dist/cjs/components/Nav/Item/index.js +6 -7
  195. package/dist/cjs/components/Nav/Nav.d.ts +23 -5
  196. package/dist/cjs/components/Nav/Nav.js +165 -123
  197. package/dist/cjs/components/Nav/Sub/InlineSubNavList.js +3 -3
  198. package/dist/cjs/components/Nav/Sub/PopupTrigger.d.ts +6 -6
  199. package/dist/cjs/components/Nav/Sub/PopupTrigger.js +21 -14
  200. package/dist/cjs/components/Nav/Sub/SubNavList.d.ts +1 -1
  201. package/dist/cjs/components/Nav/Sub/SubNavList.js +5 -3
  202. package/dist/cjs/components/Nav/Sub/index.d.ts +3 -19
  203. package/dist/cjs/components/Nav/Sub/index.js +58 -41
  204. package/dist/cjs/components/Nav/context/IdContext.js +3 -0
  205. package/dist/cjs/components/Nav/context/NavContext.d.ts +5 -4
  206. package/dist/cjs/components/Nav/context/NavContext.js +9 -3
  207. package/dist/cjs/components/Nav/context/PathContext.js +5 -0
  208. package/dist/cjs/components/Nav/context/PrivateContext.d.ts +7 -0
  209. package/dist/cjs/components/{Component/Component.js → Nav/context/PrivateContext.js} +2 -3
  210. package/dist/cjs/components/Nav/hooks/useAccessibility.d.ts +2 -2
  211. package/dist/cjs/components/Nav/hooks/useAccessibility.js +4 -3
  212. package/dist/cjs/components/Nav/hooks/useActive.d.ts +2 -2
  213. package/dist/cjs/components/Nav/hooks/useActive.js +6 -5
  214. package/dist/cjs/components/Nav/hooks/useDirectionStyle.d.ts +2 -0
  215. package/dist/cjs/components/Nav/hooks/useDirectionStyle.js +37 -0
  216. package/dist/cjs/components/Nav/hooks/useKeyRecords.d.ts +3 -3
  217. package/dist/cjs/components/Nav/hooks/useKeyRecords.js +14 -14
  218. package/dist/cjs/components/Nav/hooks/useMemoCallback.d.ts +1 -1
  219. package/dist/cjs/components/Nav/hooks/useMemoCallback.js +3 -1
  220. package/dist/cjs/components/Nav/hooks/useUUID.d.ts +1 -1
  221. package/dist/cjs/components/Nav/hooks/useUUID.js +3 -2
  222. package/dist/cjs/components/Nav/index.d.ts +9 -9
  223. package/dist/cjs/components/Nav/index.js +6 -6
  224. package/dist/cjs/components/Nav/index.scss +10 -7
  225. package/dist/cjs/components/Nav/types.d.ts +58 -10
  226. package/dist/cjs/components/Nav/utils/alignUtil.d.ts +1 -1
  227. package/dist/cjs/components/Nav/utils/motionUtil.d.ts +5 -2
  228. package/dist/cjs/components/Nav/utils/nodeUtil.d.ts +3 -1
  229. package/dist/cjs/components/Nav/utils/nodeUtil.js +38 -1
  230. package/dist/cjs/components/Nav/utils/warnUtil.d.ts +1 -1
  231. package/dist/cjs/components/Navbar/Center.d.ts +5 -7
  232. package/dist/cjs/components/Navbar/Center.js +8 -6
  233. package/dist/cjs/components/Navbar/Container.d.ts +4 -8
  234. package/dist/cjs/components/Navbar/Container.js +9 -7
  235. package/dist/cjs/components/Navbar/Item.d.ts +5 -8
  236. package/dist/cjs/components/Navbar/Item.js +8 -6
  237. package/dist/cjs/components/Navbar/Left.d.ts +5 -7
  238. package/dist/cjs/components/Navbar/Left.js +8 -6
  239. package/dist/cjs/components/Navbar/Nav.d.ts +1 -1
  240. package/dist/cjs/components/Navbar/Nav.js +5 -2
  241. package/dist/cjs/components/Navbar/Right.d.ts +3 -3
  242. package/dist/cjs/components/Navbar/Toggle.d.ts +5 -4
  243. package/dist/cjs/components/Navbar/index.d.ts +11 -11
  244. package/dist/cjs/components/Navbar/index.js +8 -8
  245. package/dist/cjs/components/Progress/index.d.ts +6 -0
  246. package/dist/cjs/components/Progress/index.js +39 -0
  247. package/dist/cjs/components/Progress/index.scss +129 -0
  248. package/dist/cjs/components/Section/index.d.ts +4 -6
  249. package/dist/cjs/components/Section/index.js +10 -8
  250. package/dist/cjs/components/Spinner/index.d.ts +3 -3
  251. package/dist/cjs/components/Spinner/index.js +7 -5
  252. package/dist/cjs/components/Tabs/index.d.ts +7 -11
  253. package/dist/cjs/components/Tabs/index.js +17 -18
  254. package/dist/cjs/components/Tabs/index.scss +9 -1
  255. package/dist/cjs/components/Text/index.d.ts +7 -8
  256. package/dist/cjs/components/Text/index.js +22 -20
  257. package/dist/cjs/components/Tile/index.d.ts +5 -6
  258. package/dist/cjs/components/Tile/index.js +10 -8
  259. package/dist/cjs/components/Tile/index.scss +8 -8
  260. package/dist/cjs/components/Width/Width.d.ts +5 -6
  261. package/dist/cjs/components/Width/Width.js +12 -6
  262. package/dist/cjs/components/Width/index.d.ts +3 -3
  263. package/dist/cjs/components/Width/index.js +3 -3
  264. package/dist/cjs/components/Width/types.d.ts +6 -6
  265. package/dist/cjs/components/Width/utils.d.ts +1 -1
  266. package/dist/cjs/components/Width/utils.js +3 -1
  267. package/dist/cjs/hooks/index.d.ts +3 -0
  268. package/dist/cjs/{utils/hooks → hooks}/index.js +3 -1
  269. package/dist/cjs/hooks/useContext.d.ts +2 -0
  270. package/dist/cjs/hooks/useContext.js +35 -0
  271. package/dist/cjs/hooks/useMounted.d.ts +1 -0
  272. package/dist/cjs/hooks/useMounted.js +38 -0
  273. package/dist/cjs/index.d.ts +33 -30
  274. package/dist/cjs/index.js +33 -30
  275. package/dist/cjs/styles/_import.components.scss +1 -2
  276. package/dist/cjs/styles/_import.scss +1 -2
  277. package/dist/cjs/styles/animation.scss +35 -35
  278. package/dist/cjs/styles/column.scss +0 -1
  279. package/dist/cjs/styles/mixins.scss +30 -1
  280. package/dist/cjs/styles/motion.scss +367 -44
  281. package/dist/cjs/styles/progress.scss +1 -129
  282. package/dist/cjs/styles/variables.scss +9 -5
  283. package/dist/cjs/types.d.ts +15 -3
  284. package/dist/cjs/utils/get-breakpoints-config-classes.d.ts +1 -1
  285. package/dist/cjs/utils/get-breakpoints-config-classes.js +1 -1
  286. package/dist/cjs/utils/index.d.ts +3 -4
  287. package/dist/cjs/utils/index.js +3 -4
  288. package/dist/cjs/utils/motion.d.ts +3 -3
  289. package/dist/cjs/utils/motion.js +23 -21
  290. package/dist/esm/components/Accordion/Accordion.d.ts +3 -2
  291. package/dist/esm/components/Accordion/Accordion.js +8 -4
  292. package/dist/esm/components/Accordion/Item.d.ts +3 -6
  293. package/dist/esm/components/Accordion/Item.js +5 -4
  294. package/dist/esm/components/Accordion/index.d.ts +6 -5
  295. package/dist/esm/components/Accordion/index.js +2 -2
  296. package/dist/esm/components/Alert/index.d.ts +3 -3
  297. package/dist/esm/components/Alert/index.js +17 -10
  298. package/dist/esm/components/Align/Align.d.ts +5 -7
  299. package/dist/esm/components/Align/Align.js +9 -5
  300. package/dist/esm/components/Align/Left.d.ts +3 -5
  301. package/dist/esm/components/Align/Left.js +2 -4
  302. package/dist/esm/components/Align/Right.d.ts +3 -5
  303. package/dist/esm/components/Align/Right.js +2 -4
  304. package/dist/esm/components/Align/index.d.ts +8 -7
  305. package/dist/esm/components/Align/index.js +3 -3
  306. package/dist/esm/components/Article/Article.d.ts +1 -1
  307. package/dist/esm/components/Article/Article.js +9 -3
  308. package/dist/esm/components/Article/Meta.d.ts +4 -9
  309. package/dist/esm/components/Article/Meta.js +7 -4
  310. package/dist/esm/components/Article/Title.d.ts +4 -9
  311. package/dist/esm/components/Article/Title.js +7 -4
  312. package/dist/esm/components/Article/index.d.ts +7 -9
  313. package/dist/esm/components/Article/index.js +3 -3
  314. package/dist/esm/components/Badge/index.d.ts +4 -6
  315. package/dist/esm/components/Badge/index.js +7 -3
  316. package/dist/esm/components/Breadcrumb/Breadcrumb.d.ts +1 -1
  317. package/dist/esm/components/Breadcrumb/Breadcrumb.js +7 -3
  318. package/dist/esm/components/Breadcrumb/Item.d.ts +1 -4
  319. package/dist/esm/components/Breadcrumb/Item.js +2 -2
  320. package/dist/esm/components/Breadcrumb/index.d.ts +5 -5
  321. package/dist/esm/components/Breadcrumb/index.js +3 -3
  322. package/dist/esm/components/Button/Button.d.ts +1 -1
  323. package/dist/esm/components/Button/Button.js +16 -14
  324. package/dist/esm/components/Button/Group.d.ts +1 -4
  325. package/dist/esm/components/Button/Group.js +5 -4
  326. package/dist/esm/components/Button/index.d.ts +5 -5
  327. package/dist/esm/components/Button/index.js +2 -2
  328. package/dist/esm/components/Card/Badge.d.ts +3 -7
  329. package/dist/esm/components/Card/Badge.js +9 -5
  330. package/dist/esm/components/Card/Body.d.ts +1 -4
  331. package/dist/esm/components/Card/Body.js +7 -4
  332. package/dist/esm/components/Card/Card.d.ts +4 -6
  333. package/dist/esm/components/Card/Card.js +17 -10
  334. package/dist/esm/components/Card/Footer.d.ts +4 -9
  335. package/dist/esm/components/Card/Footer.js +7 -4
  336. package/dist/esm/components/Card/Header.d.ts +4 -9
  337. package/dist/esm/components/Card/Header.js +7 -4
  338. package/dist/esm/components/Card/Media.d.ts +1 -4
  339. package/dist/esm/components/Card/Media.js +7 -4
  340. package/dist/esm/components/Card/Title.d.ts +4 -9
  341. package/dist/esm/components/Card/Title.js +8 -5
  342. package/dist/esm/components/Card/index.d.ts +10 -10
  343. package/dist/esm/components/Card/index.js +7 -7
  344. package/dist/esm/components/Close/index.d.ts +3 -7
  345. package/dist/esm/components/Close/index.js +7 -3
  346. package/dist/esm/components/Component/index.d.ts +9 -4
  347. package/dist/esm/components/Component/index.js +3 -1
  348. package/dist/esm/components/ComponentProvider/index.d.ts +11 -0
  349. package/dist/esm/components/ComponentProvider/index.js +21 -0
  350. package/dist/esm/components/ConfrigProvider/index.d.ts +9 -7
  351. package/dist/esm/components/ConfrigProvider/index.js +37 -7
  352. package/dist/esm/components/Container/index.d.ts +4 -5
  353. package/dist/esm/components/Container/index.js +12 -6
  354. package/dist/esm/components/Control/Checkbox/Checkbox.d.ts +7 -2
  355. package/dist/esm/components/Control/Checkbox/Checkbox.js +67 -45
  356. package/dist/esm/components/Control/Checkbox/CheckboxGroupContext.d.ts +26 -0
  357. package/dist/esm/components/Control/Checkbox/CheckboxGroupContext.js +8 -0
  358. package/dist/esm/components/Control/Checkbox/Group.d.ts +14 -2
  359. package/dist/esm/components/Control/Checkbox/Group.js +31 -28
  360. package/dist/esm/components/Control/Checkbox/index.d.ts +8 -6
  361. package/dist/esm/components/Control/Checkbox/index.js +3 -3
  362. package/dist/esm/components/Control/Checkbox/index.scss +15 -8
  363. package/dist/esm/components/Control/Checkbox/types.d.ts +3 -66
  364. package/dist/esm/components/Control/Input/Input.d.ts +2 -2
  365. package/dist/esm/components/Control/Input/Input.js +22 -13
  366. package/dist/esm/components/Control/Input/Number/index.d.ts +2 -2
  367. package/dist/esm/components/Control/Input/Number/index.js +24 -19
  368. package/dist/esm/components/Control/Input/Password/index.d.ts +2 -2
  369. package/dist/esm/components/Control/Input/Password/index.js +39 -27
  370. package/dist/esm/components/Control/Input/index.d.ts +7 -7
  371. package/dist/esm/components/Control/Input/index.js +5 -5
  372. package/dist/esm/components/Control/Input/types.d.ts +5 -5
  373. package/dist/esm/components/Control/Input/useInput.d.ts +5 -4
  374. package/dist/esm/components/Control/Input/useInput.js +47 -50
  375. package/dist/esm/components/Control/Radio/Group.d.ts +7 -2
  376. package/dist/esm/components/Control/Radio/Group.js +24 -17
  377. package/dist/esm/components/Control/Radio/Radio.d.ts +6 -2
  378. package/dist/esm/components/Control/Radio/Radio.js +57 -39
  379. package/dist/esm/components/Control/Radio/RadioGroupContext.d.ts +9 -0
  380. package/dist/esm/components/Control/Radio/RadioGroupContext.js +8 -0
  381. package/dist/esm/components/Control/Radio/index.d.ts +6 -6
  382. package/dist/esm/components/Control/Radio/index.js +2 -3
  383. package/dist/esm/components/Control/Radio/index.scss +9 -5
  384. package/dist/esm/components/Control/Select/index.d.ts +8 -12
  385. package/dist/esm/components/Control/Select/index.js +73 -50
  386. package/dist/esm/components/Control/TextArea/index.d.ts +3 -10
  387. package/dist/esm/components/Control/TextArea/index.js +51 -47
  388. package/dist/esm/components/Control/TextArea/index.scss +10 -1
  389. package/dist/esm/components/Control/index.d.ts +6 -6
  390. package/dist/esm/components/Control/index.js +6 -6
  391. package/dist/esm/components/Control/index.scss +6 -0
  392. package/dist/esm/components/Control/types.d.ts +8 -7
  393. package/dist/esm/components/Cover/index.d.ts +2 -1
  394. package/dist/esm/components/Cover/index.js +24 -16
  395. package/dist/esm/components/DescriptionList/Description.d.ts +1 -6
  396. package/dist/esm/components/DescriptionList/Description.js +1 -3
  397. package/dist/esm/components/DescriptionList/DescriptionList.d.ts +2 -1
  398. package/dist/esm/components/DescriptionList/DescriptionList.js +10 -4
  399. package/dist/esm/components/DescriptionList/Term.d.ts +1 -6
  400. package/dist/esm/components/DescriptionList/Term.js +1 -3
  401. package/dist/esm/components/DescriptionList/index.d.ts +6 -6
  402. package/dist/esm/components/DescriptionList/index.js +3 -3
  403. package/dist/esm/components/Divider/index.d.ts +2 -1
  404. package/dist/esm/components/Divider/index.js +11 -5
  405. package/dist/esm/components/Dotnav/Dotnav.d.ts +2 -1
  406. package/dist/esm/components/Dotnav/Dotnav.js +10 -4
  407. package/dist/esm/components/Dotnav/Item.d.ts +1 -4
  408. package/dist/esm/components/Dotnav/Item.js +6 -4
  409. package/dist/esm/components/Dotnav/index.d.ts +5 -5
  410. package/dist/esm/components/Dotnav/index.js +2 -2
  411. package/dist/esm/components/Drawer/index.d.ts +7 -44
  412. package/dist/esm/components/Drawer/index.js +42 -141
  413. package/dist/esm/components/Drawer/index.scss +11 -14
  414. package/dist/esm/components/Drop/index.d.ts +12 -4
  415. package/dist/esm/components/Drop/index.js +38 -21
  416. package/dist/esm/components/Drop/index.scss +0 -26
  417. package/dist/esm/components/Dropdown/index.d.ts +3 -3
  418. package/dist/esm/components/Dropdown/index.js +5 -2
  419. package/dist/esm/components/Flex/index.d.ts +15 -16
  420. package/dist/esm/components/Flex/index.js +15 -12
  421. package/dist/esm/components/Form/Controls.d.ts +3 -4
  422. package/dist/esm/components/Form/Controls.js +9 -4
  423. package/dist/esm/components/Form/ControlsText.d.ts +3 -4
  424. package/dist/esm/components/Form/ControlsText.js +9 -4
  425. package/dist/esm/components/Form/Fieldset.d.ts +4 -4
  426. package/dist/esm/components/Form/Fieldset.js +9 -4
  427. package/dist/esm/components/Form/Form.d.ts +4 -5
  428. package/dist/esm/components/Form/Form.js +11 -6
  429. package/dist/esm/components/Form/Label.d.ts +3 -4
  430. package/dist/esm/components/Form/Label.js +8 -4
  431. package/dist/esm/components/Form/Legend.d.ts +3 -4
  432. package/dist/esm/components/Form/Legend.js +7 -4
  433. package/dist/esm/components/Form/index.d.ts +9 -9
  434. package/dist/esm/components/Form/index.js +6 -6
  435. package/dist/esm/components/Grid/index.d.ts +7 -8
  436. package/dist/esm/components/Grid/index.js +14 -11
  437. package/dist/esm/components/Heading/index.d.ts +5 -6
  438. package/dist/esm/components/Heading/index.js +11 -5
  439. package/dist/esm/components/Icon/Button.d.ts +3 -5
  440. package/dist/esm/components/Icon/Button.js +2 -4
  441. package/dist/esm/components/Icon/Icon.d.ts +4 -6
  442. package/dist/esm/components/Icon/Icon.js +9 -8
  443. package/dist/esm/components/Icon/Link.d.ts +3 -5
  444. package/dist/esm/components/Icon/Link.js +2 -4
  445. package/dist/esm/components/Icon/default-svg-props.d.ts +1 -1
  446. package/dist/esm/components/Icon/default-svg-props.js +1 -1
  447. package/dist/esm/components/Icon/index.d.ts +9 -9
  448. package/dist/esm/components/Icon/index.js +5 -5
  449. package/dist/esm/components/Iconnav/Iconnav.d.ts +1 -1
  450. package/dist/esm/components/Iconnav/Iconnav.js +6 -5
  451. package/dist/esm/components/Iconnav/Item.d.ts +1 -5
  452. package/dist/esm/components/Iconnav/Item.js +3 -3
  453. package/dist/esm/components/Iconnav/index.d.ts +5 -5
  454. package/dist/esm/components/Iconnav/index.js +2 -2
  455. package/dist/esm/components/Label/index.d.ts +1 -1
  456. package/dist/esm/components/Label/index.js +7 -6
  457. package/dist/esm/components/Label/index.scss +1 -1
  458. package/dist/esm/components/Link/index.d.ts +3 -3
  459. package/dist/esm/components/Link/index.js +9 -3
  460. package/dist/esm/components/List/Item.d.ts +2 -5
  461. package/dist/esm/components/List/Item.js +1 -3
  462. package/dist/esm/components/List/List.d.ts +1 -1
  463. package/dist/esm/components/List/List.js +8 -7
  464. package/dist/esm/components/List/index.d.ts +5 -5
  465. package/dist/esm/components/List/index.js +2 -2
  466. package/dist/esm/components/Modal/Modal.d.ts +4 -3
  467. package/dist/esm/components/Modal/Modal.js +19 -15
  468. package/dist/esm/components/Modal/index.d.ts +1 -1
  469. package/dist/esm/components/Modal/index.js +1 -1
  470. package/dist/esm/components/Nav/Divider.d.ts +3 -8
  471. package/dist/esm/components/Nav/Divider.js +5 -5
  472. package/dist/esm/components/Nav/Group/InternalNavItemGroup.d.ts +11 -0
  473. package/dist/esm/components/Nav/Group/InternalNavItemGroup.js +13 -0
  474. package/dist/esm/components/Nav/Group/index.d.ts +3 -0
  475. package/dist/esm/components/Nav/Group/index.js +18 -0
  476. package/dist/esm/components/Nav/Header.d.ts +1 -1
  477. package/dist/esm/components/Nav/Header.js +2 -2
  478. package/dist/esm/components/Nav/Item/InternalNavItem.d.ts +16 -2
  479. package/dist/esm/components/Nav/Item/InternalNavItem.js +54 -34
  480. package/dist/esm/components/Nav/Item/LegacyNavItem.js +1 -1
  481. package/dist/esm/components/Nav/Item/index.d.ts +2 -28
  482. package/dist/esm/components/Nav/Item/index.js +5 -5
  483. package/dist/esm/components/Nav/Nav.d.ts +23 -5
  484. package/dist/esm/components/Nav/Nav.js +161 -118
  485. package/dist/esm/components/Nav/Sub/InlineSubNavList.js +3 -3
  486. package/dist/esm/components/Nav/Sub/PopupTrigger.d.ts +6 -6
  487. package/dist/esm/components/Nav/Sub/PopupTrigger.js +21 -13
  488. package/dist/esm/components/Nav/Sub/SubNavList.d.ts +1 -1
  489. package/dist/esm/components/Nav/Sub/SubNavList.js +5 -3
  490. package/dist/esm/components/Nav/Sub/index.d.ts +3 -19
  491. package/dist/esm/components/Nav/Sub/index.js +55 -37
  492. package/dist/esm/components/Nav/context/IdContext.js +3 -0
  493. package/dist/esm/components/Nav/context/NavContext.d.ts +5 -4
  494. package/dist/esm/components/Nav/context/NavContext.js +9 -3
  495. package/dist/esm/components/Nav/context/PathContext.js +5 -0
  496. package/dist/esm/components/Nav/context/PrivateContext.d.ts +7 -0
  497. package/dist/esm/components/Nav/context/PrivateContext.js +2 -0
  498. package/dist/esm/components/Nav/hooks/useAccessibility.d.ts +2 -2
  499. package/dist/esm/components/Nav/hooks/useAccessibility.js +3 -3
  500. package/dist/esm/components/Nav/hooks/useActive.d.ts +2 -2
  501. package/dist/esm/components/Nav/hooks/useActive.js +5 -5
  502. package/dist/esm/components/Nav/hooks/useDirectionStyle.d.ts +2 -0
  503. package/dist/esm/components/Nav/hooks/useDirectionStyle.js +10 -0
  504. package/dist/esm/components/Nav/hooks/useKeyRecords.d.ts +3 -3
  505. package/dist/esm/components/Nav/hooks/useKeyRecords.js +13 -13
  506. package/dist/esm/components/Nav/hooks/useMemoCallback.d.ts +1 -1
  507. package/dist/esm/components/Nav/hooks/useMemoCallback.js +2 -1
  508. package/dist/esm/components/Nav/hooks/useUUID.d.ts +1 -1
  509. package/dist/esm/components/Nav/hooks/useUUID.js +2 -2
  510. package/dist/esm/components/Nav/index.d.ts +9 -9
  511. package/dist/esm/components/Nav/index.js +6 -6
  512. package/dist/esm/components/Nav/index.scss +10 -7
  513. package/dist/esm/components/Nav/types.d.ts +58 -10
  514. package/dist/esm/components/Nav/utils/alignUtil.d.ts +1 -1
  515. package/dist/esm/components/Nav/utils/motionUtil.d.ts +5 -2
  516. package/dist/esm/components/Nav/utils/nodeUtil.d.ts +3 -1
  517. package/dist/esm/components/Nav/utils/nodeUtil.js +36 -0
  518. package/dist/esm/components/Nav/utils/warnUtil.d.ts +1 -1
  519. package/dist/esm/components/Navbar/Center.d.ts +5 -7
  520. package/dist/esm/components/Navbar/Center.js +7 -4
  521. package/dist/esm/components/Navbar/Container.d.ts +4 -8
  522. package/dist/esm/components/Navbar/Container.js +8 -5
  523. package/dist/esm/components/Navbar/Item.d.ts +5 -8
  524. package/dist/esm/components/Navbar/Item.js +7 -4
  525. package/dist/esm/components/Navbar/Left.d.ts +5 -7
  526. package/dist/esm/components/Navbar/Left.js +7 -4
  527. package/dist/esm/components/Navbar/Nav.d.ts +1 -1
  528. package/dist/esm/components/Navbar/Nav.js +5 -2
  529. package/dist/esm/components/Navbar/Right.d.ts +3 -3
  530. package/dist/esm/components/Navbar/Toggle.d.ts +5 -4
  531. package/dist/esm/components/Navbar/index.d.ts +11 -11
  532. package/dist/esm/components/Navbar/index.js +8 -8
  533. package/dist/esm/components/Progress/index.d.ts +6 -0
  534. package/dist/esm/components/Progress/index.js +10 -0
  535. package/dist/esm/components/Progress/index.scss +129 -0
  536. package/dist/esm/components/Section/index.d.ts +4 -6
  537. package/dist/esm/components/Section/index.js +10 -7
  538. package/dist/esm/components/Spinner/index.d.ts +3 -3
  539. package/dist/esm/components/Spinner/index.js +8 -6
  540. package/dist/esm/components/Tabs/index.d.ts +7 -11
  541. package/dist/esm/components/Tabs/index.js +17 -17
  542. package/dist/esm/components/Tabs/index.scss +9 -1
  543. package/dist/esm/components/Text/index.d.ts +7 -8
  544. package/dist/esm/components/Text/index.js +22 -19
  545. package/dist/esm/components/Tile/index.d.ts +5 -6
  546. package/dist/esm/components/Tile/index.js +10 -7
  547. package/dist/esm/components/Tile/index.scss +8 -8
  548. package/dist/esm/components/Width/Width.d.ts +5 -6
  549. package/dist/esm/components/Width/Width.js +12 -5
  550. package/dist/esm/components/Width/index.d.ts +3 -3
  551. package/dist/esm/components/Width/index.js +3 -3
  552. package/dist/esm/components/Width/types.d.ts +6 -6
  553. package/dist/esm/components/Width/utils.d.ts +1 -1
  554. package/dist/esm/components/Width/utils.js +3 -1
  555. package/dist/esm/hooks/index.d.ts +3 -0
  556. package/dist/esm/hooks/index.js +3 -0
  557. package/dist/esm/hooks/useContext.d.ts +2 -0
  558. package/dist/esm/hooks/useContext.js +8 -0
  559. package/dist/esm/hooks/useMounted.d.ts +1 -0
  560. package/dist/esm/hooks/useMounted.js +11 -0
  561. package/dist/esm/index.d.ts +33 -30
  562. package/dist/esm/index.js +33 -30
  563. package/dist/esm/styles/_import.components.scss +1 -2
  564. package/dist/esm/styles/_import.scss +1 -2
  565. package/dist/esm/styles/animation.scss +35 -35
  566. package/dist/esm/styles/column.scss +0 -1
  567. package/dist/esm/styles/mixins.scss +30 -1
  568. package/dist/esm/styles/motion.scss +367 -44
  569. package/dist/esm/styles/progress.scss +1 -129
  570. package/dist/esm/styles/variables.scss +9 -5
  571. package/dist/esm/types.d.ts +15 -3
  572. package/dist/esm/utils/get-breakpoints-config-classes.d.ts +1 -1
  573. package/dist/esm/utils/get-breakpoints-config-classes.js +1 -1
  574. package/dist/esm/utils/index.d.ts +3 -4
  575. package/dist/esm/utils/index.js +3 -4
  576. package/dist/esm/utils/motion.d.ts +3 -3
  577. package/dist/esm/utils/motion.js +20 -19
  578. package/package.json +39 -36
  579. package/dist/cjs/components/Component/Component.d.ts +0 -8
  580. package/dist/cjs/components/Control/Checkbox/Context.d.ts +0 -4
  581. package/dist/cjs/components/Control/Radio/Context.d.ts +0 -4
  582. package/dist/cjs/components/Control/Radio/types.d.ts +0 -25
  583. package/dist/cjs/components/Control/Radio/types.js +0 -2
  584. package/dist/cjs/components/Nav/Group.d.ts +0 -14
  585. package/dist/cjs/utils/hooks/index.d.ts +0 -1
  586. package/dist/esm/components/Component/Component.d.ts +0 -8
  587. package/dist/esm/components/Component/Component.js +0 -3
  588. package/dist/esm/components/Control/Checkbox/Context.d.ts +0 -4
  589. package/dist/esm/components/Control/Checkbox/Context.js +0 -5
  590. package/dist/esm/components/Control/Radio/Context.d.ts +0 -4
  591. package/dist/esm/components/Control/Radio/Context.js +0 -5
  592. package/dist/esm/components/Control/Radio/types.d.ts +0 -25
  593. package/dist/esm/components/Control/Radio/types.js +0 -1
  594. package/dist/esm/components/Nav/Group.d.ts +0 -14
  595. package/dist/esm/components/Nav/Group.js +0 -26
  596. package/dist/esm/utils/hooks/index.d.ts +0 -1
  597. package/dist/esm/utils/hooks/index.js +0 -1
  598. /package/dist/cjs/{utils/hooks → hooks}/useForceUpdate.d.ts +0 -0
  599. /package/dist/cjs/{utils/hooks → hooks}/useForceUpdate.js +0 -0
  600. /package/dist/esm/{utils/hooks → hooks}/useForceUpdate.d.ts +0 -0
  601. /package/dist/esm/{utils/hooks → hooks}/useForceUpdate.js +0 -0
@@ -1,18 +1,10 @@
1
1
  import * as React from 'react';
2
- import type { GetContainer } from 'rc-util/lib/PortalWrapper';
3
- import type { Direction } from '../../types';
2
+ import { type DrawerProps as RcDrawerProps } from 'rc-drawer';
3
+ import { type Direction } from '../../types';
4
4
  import './index.scss';
5
- declare type DrawerRef = {
6
- push(): void;
7
- pull(): void;
8
- };
9
- declare type EventType = React.KeyboardEvent | React.MouseEvent;
10
- declare type LevelMove = number | [number, number];
11
- declare const PlacementTypes: ["top", "right", "bottom", "left"];
12
- declare type PlacementType = typeof PlacementTypes[number];
13
- declare const SizeTypes: ["default", "large"];
14
- declare type SizeType = typeof SizeTypes[number];
15
- declare type TriggerArguments = {
5
+ declare const SizeTypes: readonly ["default", "large"];
6
+ type SizeType = (typeof SizeTypes)[number];
7
+ type TriggerArguments = {
16
8
  collapse: () => void;
17
9
  expand: () => void;
18
10
  isOpen: boolean;
@@ -20,43 +12,14 @@ declare type TriggerArguments = {
20
12
  export interface PushState {
21
13
  distance: string | number;
22
14
  }
23
- export interface DrawerProps {
24
- afterVisibleChange?: (visible: boolean) => void;
15
+ export interface DrawerProps extends RcDrawerProps {
25
16
  animation?: 'push' | 'reveal';
26
- autoFocus?: boolean;
27
- children?: React.ReactNode;
28
- className?: string;
29
17
  closable?: boolean;
30
18
  closeIcon?: React.ReactNode;
31
19
  defaultOpen?: boolean;
32
- destroyOnClose?: boolean;
33
20
  direction?: Direction;
34
- duration?: string;
35
- ease?: string;
36
- forceRender?: boolean;
37
- getContainer?: GetContainer;
38
- handler?: React.ReactElement | null | false;
39
- height?: number | string;
40
- keyboard?: boolean;
41
- level?: string | string[] | null;
42
- levelMove?: LevelMove | ((event: {
43
- target: HTMLElement;
44
- open: boolean;
45
- }) => LevelMove);
46
- maskClosable?: boolean;
47
- maskStyle?: React.CSSProperties;
48
- open?: boolean;
49
- placement?: PlacementType;
50
- prefixCls?: string;
51
- push?: boolean | PushState;
52
- showMask?: boolean;
53
21
  size?: SizeType;
54
- style?: React.CSSProperties;
55
22
  trigger?: (args: TriggerArguments) => JSX.Element;
56
- width?: number | string;
57
- wrapperClassName?: string;
58
- zIndex?: number;
59
- onClose?: (event: EventType) => void;
60
23
  }
61
- export declare const Drawer: React.ForwardRefExoticComponent<DrawerProps & React.RefAttributes<DrawerRef>>;
24
+ export declare const Drawer: React.MemoExoticComponent<(props: DrawerProps) => JSX.Element>;
62
25
  export {};
@@ -31,159 +31,60 @@ const React = __importStar(require("react"));
31
31
  const js_utils_1 = require("@broxus/js-utils");
32
32
  const classnames_1 = __importDefault(require("classnames"));
33
33
  const rc_drawer_1 = __importDefault(require("rc-drawer"));
34
+ const ConfrigProvider_1 = require("../ConfrigProvider");
34
35
  const utils_1 = require("../../utils");
35
36
  require("./index.scss");
36
- const DrawerContext = React.createContext(null);
37
- const PlacementTypes = (0, js_utils_1.tuple)('top', 'right', 'bottom', 'left');
38
- const SizeTypes = (0, js_utils_1.tuple)('default', 'large');
37
+ const SizeTypes = ['default', 'large'];
39
38
  const defaultPushState = { distance: 180 };
40
- exports.Drawer = React.forwardRef((props, ref) => {
41
- const { animation, children, className, defaultOpen, destroyOnClose, direction, duration = 'var(--drawer-transition-duration)', ease = 'var(--ease-in-out-circ)', keyboard = true, level = null, maskClosable = true, open, placement = 'right', prefixCls = 'uk-drawer', push = defaultPushState, showMask = true, size = 'default', style, trigger, wrapperClassName, zIndex, ...restProps } = props;
42
- const forceUpdate = (0, utils_1.useForceUpdate)();
43
- const parentDrawer = React.useContext(DrawerContext);
44
- const destroyClose = React.useRef(false);
45
- const [internalPush, setPush] = React.useState(false);
39
+ exports.Drawer = React.memo((props) => {
40
+ const config = (0, ConfrigProvider_1.useConfig)();
41
+ const { animation, children, className, defaultOpen, destroyOnClose, direction, getContainer = config.getPopupContainer, keyboard = true, mask = true, maskClosable = true, open, placement = 'right', prefixCls = config.prefixCls, push = defaultPushState, size = 'default', rootClassName, trigger, ...restProps } = props;
46
42
  const [internalOpen, setOpen] = React.useState(defaultOpen);
47
- // eslint-disable-next-line no-param-reassign
48
43
  const mergedOpen = open === undefined ? internalOpen : open;
49
- React.useEffect(() => {
50
- // fix: delete drawer in child and re-render, no push started.
51
- // <Drawer>{show && <Drawer />}</Drawer>
52
- if (mergedOpen && parentDrawer) {
53
- parentDrawer.push();
54
- }
55
- return () => {
56
- if (parentDrawer) {
57
- parentDrawer.pull();
58
- // parentDrawer = null
59
- }
60
- };
61
- }, []);
62
- React.useEffect(() => {
63
- if (parentDrawer) {
64
- if (mergedOpen) {
65
- parentDrawer.push();
66
- forceUpdate();
67
- }
68
- else {
69
- parentDrawer.pull();
70
- forceUpdate();
71
- }
72
- }
73
- }, [mergedOpen]);
74
- const drawerClassName = React.useMemo(() => (0, classnames_1.default)({
75
- [`${prefixCls}-${size}`]: size !== undefined,
76
- [`${prefixCls}-${animation}`]: animation !== undefined,
77
- [`${prefixCls}-rtl`]: direction === 'rtl',
78
- 'no-mask': !showMask,
79
- }, className), [prefixCls, size, animation, showMask, direction, className]);
80
- const drawerWrapperClassName = React.useMemo(() => (0, classnames_1.default)(`${prefixCls}-container`, {
81
- [`${prefixCls}-${animation}-container`]: animation !== undefined,
82
- }, wrapperClassName), [prefixCls, animation, wrapperClassName]);
83
- const operations = React.useMemo(() => ({
84
- pull() {
85
- if (push) {
86
- setPush(false);
87
- forceUpdate();
88
- }
89
- },
90
- push() {
91
- if (push) {
92
- setPush(true);
93
- forceUpdate();
94
- }
95
- },
96
- }), [push]);
97
- React.useImperativeHandle(ref, () => operations, [operations]);
98
- const isDestroyOnClose = destroyOnClose && !mergedOpen;
99
- const afterVisibleChange = (visible) => {
100
- restProps.afterVisibleChange?.(visible);
44
+ const rootCls = React.useMemo(() => config.getRootPrefixCls(prefixCls || config.prefixCls, 'drawer'), [config, prefixCls]);
45
+ const drawerRootClassName = React.useMemo(() => (0, classnames_1.default)({
46
+ [`${rootCls}-${size}`]: size !== undefined,
47
+ [`${rootCls}-${animation}`]: animation !== undefined,
48
+ [`${rootCls}-rtl`]: direction === 'rtl',
49
+ 'no-mask': !mask,
50
+ }, rootClassName), [rootCls, size, animation, mask, direction, rootClassName]);
51
+ const drawerWrapperClassName = React.useMemo(() => (0, classnames_1.default)(`${rootCls}-container`, {
52
+ [`${rootCls}-${animation}-container`]: animation !== undefined,
53
+ }), [rootCls, animation]);
54
+ const afterOpenChange = React.useCallback((visible) => {
55
+ restProps.afterOpenChange?.(visible);
101
56
  if (visible) {
57
+ (0, js_utils_1.addClass)(document.body, drawerWrapperClassName);
102
58
  (0, utils_1.addModalMode)();
103
59
  }
104
60
  else {
105
61
  (0, utils_1.removeModalMode)();
62
+ (0, js_utils_1.removeClass)(document.body, drawerWrapperClassName);
106
63
  }
107
- };
108
- const getRcDrawerStyle = () => {
109
- // get drawer push width or height
110
- const getPushTransform = (_placement) => {
111
- let distance;
112
- // noinspection SuspiciousTypeOfGuard
113
- if (typeof push === 'boolean') {
114
- distance = push ? defaultPushState.distance : 0;
115
- }
116
- else {
117
- distance = push?.distance;
118
- }
119
- distance = parseFloat(String(distance || 0));
120
- if (_placement === 'left' || _placement === 'right') {
121
- return `translateX(${_placement === 'left' ? distance : -distance}px)`;
122
- }
123
- if (_placement === 'top' || _placement === 'bottom') {
124
- return `translateY(${_placement === 'top' ? distance : -distance}px)`;
125
- }
126
- return '';
127
- };
128
- return {
129
- transform: internalPush ? getPushTransform(placement) : undefined,
130
- zIndex,
131
- ...style,
132
- };
133
- };
134
- const collapse = () => {
64
+ }, [drawerWrapperClassName, restProps]);
65
+ const collapse = React.useCallback(() => {
135
66
  setOpen(false);
136
- };
137
- const expand = () => {
67
+ }, []);
68
+ const expand = React.useCallback(() => {
138
69
  setOpen(true);
139
- };
140
- const onClose = (event) => {
70
+ }, []);
71
+ const onClose = React.useCallback((event) => {
141
72
  setOpen(false);
142
73
  restProps.onClose?.(event);
143
- };
144
- const onDestroyTransitionEnd = () => {
145
- if (!isDestroyOnClose) {
146
- return;
147
- }
148
- if (!mergedOpen) {
149
- destroyClose.current = true;
150
- forceUpdate();
151
- }
152
- };
153
- const renderBody = () => {
154
- if (destroyClose.current && !mergedOpen) {
155
- return null;
156
- }
157
- destroyClose.current = false;
158
- const containerStyle = {};
159
- if (isDestroyOnClose) {
160
- // Increase the opacity transition, delete children after closing.
161
- containerStyle.opacity = 0;
162
- containerStyle.transition = 'opacity var(--transition-duration)';
163
- }
164
- return (React.createElement("div", { className: `${prefixCls}-body-wrapper`, style: containerStyle, onTransitionEnd: onDestroyTransitionEnd },
165
- React.createElement("div", { className: `${prefixCls}-body` }, children)));
166
- };
167
- return (React.createElement(DrawerContext.Provider, { value: operations },
74
+ }, [restProps]);
75
+ return (React.createElement(React.Fragment, null,
168
76
  trigger?.({ collapse, expand, isOpen: !!mergedOpen }),
169
- React.createElement(rc_drawer_1.default, { ...{
170
- afterVisibleChange,
171
- children,
172
- className: drawerClassName,
173
- defaultOpen,
174
- duration,
175
- ease,
176
- handler: false,
177
- keyboard,
178
- level: (animation !== undefined && level == null) ? 'all' : level,
179
- maskClosable,
180
- open: mergedOpen,
181
- placement,
182
- prefixCls,
183
- showMask,
184
- style: getRcDrawerStyle(),
185
- wrapperClassName: drawerWrapperClassName,
186
- ...restProps,
187
- onClose,
188
- } }, renderBody())));
77
+ React.createElement(rc_drawer_1.default, { afterOpenChange: afterOpenChange, className: className, destroyOnClose: destroyOnClose, keyboard: keyboard, getContainer: getContainer, mask: mask, maskClosable: maskClosable, maskMotion: {
78
+ motionDeadline: 200,
79
+ motionName: (0, utils_1.getMotionName)(prefixCls || config.prefixCls, 'fade'),
80
+ }, motion: motionPlacement => ({
81
+ motionAppear: true,
82
+ motionDeadline: 200,
83
+ motionEnter: true,
84
+ motionLeave: true,
85
+ motionName: (0, utils_1.getMotionName)(config.prefixCls, `slide-${motionPlacement}`),
86
+ }), open: mergedOpen, placement: placement, prefixCls: rootCls, push: push, rootClassName: drawerRootClassName, onClose: onClose, ...restProps }, children)));
189
87
  });
88
+ if (process.env.NODE_ENV !== 'production') {
89
+ exports.Drawer.displayName = 'Drawer';
90
+ }
@@ -32,10 +32,8 @@
32
32
 
33
33
  .uk-drawer {
34
34
  height: 100%;
35
+ pointer-events: none;
35
36
  position: fixed;
36
- transition: height 0s ease var(--drawer-transition-duration),
37
- transform var(--drawer-transition-duration) var(--ease-in-out-circ),
38
- width 0s ease var(--drawer-transition-duration);
39
37
  width: 0;
40
38
  z-index: var(--drawer-z-index);
41
39
  @if mixin-exists(hook-drawer) {
@@ -52,11 +50,6 @@
52
50
  transform: none !important;
53
51
  }
54
52
 
55
- .uk-drawer > * {
56
- transition: box-shadow var(--drawer-transition-duration) var(--ease-in-out-circ),
57
- transform var(--drawer-transition-duration) var(--ease-in-out-circ);
58
- }
59
-
60
53
  /* Reveal animation */
61
54
  .uk-drawer-reveal:not(.uk-drawer-open) .uk-drawer-content-wrapper {
62
55
  transform: none !important;
@@ -97,12 +90,18 @@
97
90
  .uk-drawer-content-wrapper {
98
91
  height: 100%;
99
92
  position: absolute;
93
+ transition: transform;
94
+ transition-duration: var(--drawer-transition-duration);
100
95
  width: 100%;
101
96
  @if mixin-exists(hook-drawer-content-wrapper) {
102
97
  @include hook-drawer-content-wrapper;
103
98
  }
104
99
  }
105
100
 
101
+ .uk-drawer-content-wrapper-hidden {
102
+ display: none;
103
+ }
104
+
106
105
  .uk-drawer-content {
107
106
  background-clip: padding-box;
108
107
  background-color: var(--drawer-content-background);
@@ -110,6 +109,7 @@
110
109
  height: 100%;
111
110
  outline: 0 none;
112
111
  overflow: visible;
112
+ pointer-events: auto;
113
113
  position: relative;
114
114
  width: 100%;
115
115
  z-index: 1;
@@ -144,7 +144,7 @@
144
144
  }
145
145
 
146
146
 
147
- // Side
147
+ // Sides
148
148
  // ========================================================================
149
149
 
150
150
  /*
@@ -246,16 +246,14 @@
246
246
  // ========================================================================
247
247
 
248
248
  .uk-drawer-mask {
249
- animation: uk-motion-fade var(--drawer-transition-duration) var(--ease-in-out-circ);
250
249
  background-color: var(--drawer-mask-background);
251
- height: 0;
250
+ bottom: 0;
252
251
  left: 0;
253
252
  opacity: 0;
254
253
  pointer-events: none;
255
254
  position: absolute;
255
+ right: 0;
256
256
  top: 0;
257
- transition: height 0s ease var(--drawer-transition-duration), opacity var(--drawer-transition-duration) linear;
258
- width: 100%;
259
257
  @if mixin-exists(hook-drawer-mask) {
260
258
  @include hook-drawer-mask;
261
259
  }
@@ -265,7 +263,6 @@
265
263
  height: 100%;
266
264
  opacity: 1;
267
265
  pointer-events: auto;
268
- transition: opacity var(--drawer-transition-duration) linear;
269
266
  @if mixin-exists(hook-drawer-mask-open) {
270
267
  @include hook-drawer-mask-open;
271
268
  }
@@ -1,11 +1,10 @@
1
1
  import * as React from 'react';
2
- import type { TriggerProps } from 'rc-trigger';
3
- import type { ActionType, AlignType, AnimationType, BuildInPlacements } from 'rc-trigger/lib/interface';
2
+ import { type BuildInPlacements, type TriggerProps } from 'rc-trigger';
3
+ import { type ActionType, type AlignType } from 'rc-trigger/lib/interface';
4
4
  import './index.scss';
5
5
  export interface DropProps extends Pick<TriggerProps, 'children' | 'getPopupContainer' | 'mouseEnterDelay' | 'mouseLeaveDelay'> {
6
6
  align?: AlignType;
7
7
  alignPoint?: boolean;
8
- animation?: AnimationType;
9
8
  arrow?: boolean;
10
9
  hideAction?: ActionType[];
11
10
  minOverlayWidthMatchTrigger?: boolean;
@@ -16,6 +15,7 @@ export interface DropProps extends Pick<TriggerProps, 'children' | 'getPopupCont
16
15
  placement?: string;
17
16
  placements?: BuildInPlacements;
18
17
  prefixCls?: string;
18
+ rootCls?: string;
19
19
  showAction?: ActionType[];
20
20
  transitionName?: string;
21
21
  trigger?: ActionType | ActionType[];
@@ -23,4 +23,12 @@ export interface DropProps extends Pick<TriggerProps, 'children' | 'getPopupCont
23
23
  onOverlayClick?: (e: Event) => void;
24
24
  onVisibleChange?: (visible: boolean) => void;
25
25
  }
26
- export declare const Drop: React.ForwardRefExoticComponent<DropProps & React.RefAttributes<unknown>>;
26
+ export type TriggerRef = {
27
+ forceAlign: VoidFunction;
28
+ };
29
+ export type DropRef = {
30
+ close: VoidFunction;
31
+ open: VoidFunction;
32
+ triggerRef: TriggerRef;
33
+ };
34
+ export declare const Drop: React.ForwardRefExoticComponent<DropProps & React.RefAttributes<DropRef>>;
@@ -30,57 +30,74 @@ exports.Drop = void 0;
30
30
  const React = __importStar(require("react"));
31
31
  const classnames_1 = __importDefault(require("classnames"));
32
32
  const rc_trigger_1 = __importDefault(require("rc-trigger"));
33
- const placements_1 = __importDefault(require("./placements"));
33
+ const ConfrigProvider_1 = require("../ConfrigProvider");
34
+ const placements_1 = __importDefault(require("../Drop/placements"));
35
+ const utils_1 = require("../../utils");
34
36
  require("./index.scss");
35
37
  exports.Drop = React.forwardRef((props, ref) => {
36
- const { align, alignPoint, animation, arrow = false, children, getPopupContainer, hideAction, minOverlayWidthMatchTrigger, overlay, overlayClassName, overlayStyle, prefixCls = 'uk-drop', placement = 'bottom-left', placements = placements_1.default, showAction, transitionName = 'uk-motion-slide-up', trigger = ['hover'], visible, onOverlayClick, onVisibleChange, ...restProps } = props;
38
+ const config = (0, ConfrigProvider_1.useConfig)();
39
+ const { align, alignPoint, arrow = false, children, getPopupContainer, hideAction, minOverlayWidthMatchTrigger, overlay, overlayClassName, overlayStyle, prefixCls = config.prefixCls, placement = 'bottom-left', placements = placements_1.default, rootCls: externalRootCls, showAction, trigger = ['hover'], visible, onOverlayClick, onVisibleChange, ...restProps } = props;
37
40
  const triggerRef = React.useRef(null);
38
41
  const [triggerVisible, setTriggerVisible] = React.useState();
39
42
  const mergedVisible = 'visible' in restProps ? visible : triggerVisible;
40
- const onPopupVisibleChange = (value) => {
43
+ const rootCls = React.useMemo(() => externalRootCls ?? config.getRootPrefixCls(prefixCls || config.prefixCls, 'drop'), [config, prefixCls, externalRootCls]);
44
+ const onPopupVisibleChange = React.useCallback((value) => {
41
45
  setTriggerVisible(value);
42
46
  onVisibleChange?.(value);
43
- };
44
- const getOverlayElement = () => {
47
+ }, [onVisibleChange]);
48
+ const getOverlayElement = React.useCallback(() => {
45
49
  if (typeof overlay === 'function') {
46
50
  return overlay();
47
51
  }
48
52
  return overlay;
49
- };
50
- const getDropElement = () => (React.createElement(React.Fragment, null,
53
+ }, [overlay]);
54
+ const getDropElement = React.useCallback(() => (React.createElement(React.Fragment, null,
51
55
  arrow && React.createElement("div", { className: `${prefixCls}-arrow` }),
52
56
  React.cloneElement(getOverlayElement(), {
53
57
  onClick: onOverlayClick,
54
- })));
55
- const getDropElementOrLambda = () => {
58
+ }))), [arrow, getOverlayElement, onOverlayClick, prefixCls]);
59
+ const getDropElementOrLambda = React.useCallback(() => {
56
60
  if (typeof overlay === 'function') {
57
- return getDropElement;
61
+ return getDropElement();
58
62
  }
59
- return getDropElement();
60
- };
61
- const getMinOverlayWidthMatchTrigger = () => {
63
+ return getDropElement;
64
+ }, [getDropElement, overlay]);
65
+ const getMinOverlayWidthMatchTrigger = React.useCallback(() => {
62
66
  if (minOverlayWidthMatchTrigger !== undefined) {
63
67
  return minOverlayWidthMatchTrigger;
64
68
  }
65
69
  return !alignPoint;
66
- };
67
- const renderChildren = () => {
70
+ }, [alignPoint, minOverlayWidthMatchTrigger]);
71
+ const renderChildren = React.useCallback(() => {
68
72
  const childrenProps = children.props ? children.props : {};
69
- const childClassName = (0, classnames_1.default)(childrenProps.className, 'uk-open');
73
+ const childClassName = (0, classnames_1.default)(childrenProps.className, `${prefixCls || config.prefixCls}-open`);
70
74
  return triggerVisible && children
71
75
  ? React.cloneElement(children, {
72
76
  className: childClassName,
73
77
  })
74
78
  : children;
75
- };
76
- React.useImperativeHandle(ref, () => triggerRef.current);
79
+ }, [children, config.prefixCls, prefixCls, triggerVisible]);
80
+ React.useImperativeHandle(ref, () => ({
81
+ close() {
82
+ setTriggerVisible(false);
83
+ },
84
+ open() {
85
+ setTriggerVisible(true);
86
+ },
87
+ // @ts-ignore
88
+ triggerRef: triggerRef.current,
89
+ }));
77
90
  let triggerHideAction = hideAction;
78
91
  if (!triggerHideAction && trigger.indexOf('contextMenu') > -1) {
79
92
  triggerHideAction = ['click'];
80
93
  }
81
- return (React.createElement(rc_trigger_1.default, { ref: triggerRef, ...restProps, action: trigger, builtinPlacements: placements, getPopupContainer: getPopupContainer, hideAction: triggerHideAction || [], popup: getDropElementOrLambda(), popupAlign: align, popupAnimation: animation, popupClassName: (0, classnames_1.default)(overlayClassName, {
82
- [`${prefixCls}-show-arrow`]: arrow,
83
- }), popupPlacement: placement, popupStyle: overlayStyle, popupTransitionName: transitionName, popupVisible: mergedVisible, prefixCls: prefixCls, showAction: showAction, stretch: getMinOverlayWidthMatchTrigger() ? 'minWidth' : '', onPopupVisibleChange: onPopupVisibleChange }, renderChildren()));
94
+ return (React.createElement(rc_trigger_1.default, { ref: triggerRef, action: trigger, builtinPlacements: placements, getPopupContainer: getPopupContainer, hideAction: triggerHideAction || [], mouseLeaveDelay: 0.2, popup: getDropElementOrLambda(), popupAlign: align, popupClassName: (0, classnames_1.default)(overlayClassName, {
95
+ [`${rootCls}-show-arrow`]: arrow,
96
+ }), popupMotion: {
97
+ forceRender: true,
98
+ motionDeadline: 300,
99
+ motionName: (0, utils_1.getMotionName)(prefixCls || config.prefixCls, 'slide-bottom-small'),
100
+ }, popupPlacement: placement, popupStyle: overlayStyle, popupVisible: mergedVisible, prefixCls: rootCls, showAction: showAction, stretch: getMinOverlayWidthMatchTrigger() ? 'minWidth' : '', ...restProps, onPopupVisibleChange: onPopupVisibleChange }, renderChildren()));
84
101
  });
85
102
  if (process.env.NODE_ENV !== 'production') {
86
103
  exports.Drop.displayName = 'Drop';
@@ -44,32 +44,6 @@
44
44
  .uk-drop-hidden { display: none; }
45
45
 
46
46
 
47
- /* Position Animation
48
- ========================================================================== */
49
-
50
- [class*='uk-drop-placement-bottom'] {
51
- &.uk-slide-up-enter.uk-slide-up-enter-active,
52
- &.uk-slide-up-appear.uk-slide-up-appear-active {
53
- animation-name: uk-slide-up-in;
54
- }
55
-
56
- &.uk-slide-up-leave.uk-slide-up-leave-active {
57
- animation-name: uk-slide-up-out;
58
- }
59
- }
60
-
61
- [class*='uk-drop-placement-top'] {
62
- &.uk-slide-up-enter.uk-slide-up-enter-active,
63
- &.uk-slide-up-appear.uk-slide-up-appear-active {
64
- animation-name: uk-slide-down-in;
65
- }
66
-
67
- &.uk-slide-up-leave.uk-slide-up-leave-active {
68
- animation-name: uk-slide-down-out;
69
- }
70
- }
71
-
72
-
73
47
  /* Grid modifiers
74
48
  ========================================================================== */
75
49
 
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- import type { DropProps } from '../Drop';
2
+ import { type DropProps, type DropRef } from '../Drop';
3
3
  import './index.scss';
4
- export declare type DropdownProps = DropProps;
5
- export declare const Dropdown: React.ForwardRefExoticComponent<DropProps & React.RefAttributes<unknown>>;
4
+ export type DropdownProps = DropProps;
5
+ export declare const Dropdown: React.ForwardRefExoticComponent<DropProps & React.RefAttributes<DropRef>>;
@@ -25,11 +25,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.Dropdown = void 0;
27
27
  const React = __importStar(require("react"));
28
+ const ConfrigProvider_1 = require("../ConfrigProvider");
28
29
  const Drop_1 = require("../Drop");
29
30
  require("./index.scss");
30
31
  exports.Dropdown = React.forwardRef((props, ref) => {
31
- const { children, ...restProps } = props;
32
- return (React.createElement(Drop_1.Drop, { ref: ref, ...restProps, prefixCls: "uk-dropdown" }, children));
32
+ const config = (0, ConfrigProvider_1.useConfig)();
33
+ const { children, prefixCls = config.prefixCls, ...restProps } = props;
34
+ const rootCls = React.useMemo(() => config.getRootPrefixCls(prefixCls || config.prefixCls, 'dropdown'), [config, prefixCls]);
35
+ return (React.createElement(Drop_1.Drop, { ref: ref, ...restProps, rootCls: rootCls }, children));
33
36
  });
34
37
  if (process.env.NODE_ENV !== 'production') {
35
38
  exports.Dropdown.displayName = 'Dropdown';
@@ -1,14 +1,14 @@
1
1
  import * as React from 'react';
2
- import type { BreakpointsConfig } from '../../types';
3
- import type { PolymorphicComponentProps } from '../Component';
2
+ import { type PolymorphicProps } from '../Component';
3
+ import { type BreakpointsConfig } from '../../types';
4
4
  import './index.scss';
5
- export declare type FlexAlignContent = 'stretch' | 'between' | 'around' | 'top' | 'middle' | 'bottom';
6
- export declare type FlexAlignItems = 'stretch' | 'top' | 'middle' | 'bottom';
7
- export declare type FlexDirection = 'row' | 'row-reverse' | 'column' | 'column-reverse';
8
- export declare type FlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';
9
- export declare type FlexJustifyContent = 'left' | 'center' | 'right' | 'between' | 'around';
10
- export declare type FlexItemDimensions = 'none' | 'auto' | 'fill' | '1';
11
- export declare type FlexBreakpoint = {
5
+ export type FlexAlignContent = 'stretch' | 'between' | 'around' | 'top' | 'middle' | 'bottom';
6
+ export type FlexAlignItems = 'stretch' | 'top' | 'middle' | 'bottom';
7
+ export type FlexDirection = 'row' | 'row-reverse' | 'column' | 'column-reverse';
8
+ export type FlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';
9
+ export type FlexJustifyContent = 'left' | 'center' | 'right' | 'between' | 'around';
10
+ export type FlexItemDimensions = 'none' | 'auto' | 'fill' | '1';
11
+ export type FlexBreakpoint = {
12
12
  alignContent?: FlexAlignContent;
13
13
  alignItems?: FlexAlignItems;
14
14
  flexDirection?: FlexDirection;
@@ -16,11 +16,10 @@ export declare type FlexBreakpoint = {
16
16
  itemDimensions?: FlexItemDimensions;
17
17
  justifyContent?: FlexJustifyContent;
18
18
  };
19
- export declare type FlexBreakpointsConfig = BreakpointsConfig<FlexBreakpoint>;
20
- export declare type FlexOwnProps = FlexBreakpoint & FlexBreakpointsConfig & {
19
+ export type FlexBreakpointsConfig = BreakpointsConfig<FlexBreakpoint>;
20
+ export type FlexOwnProps = {
21
21
  inline?: boolean;
22
- };
23
- export declare type FlexProps<E extends React.ElementType = React.ElementType> = PolymorphicComponentProps<E, FlexOwnProps>;
24
- declare const defaultElement = "div";
25
- export declare function Flex<E extends React.ElementType = typeof defaultElement>(props: FlexProps<E>): JSX.Element;
26
- export {};
22
+ prefixCls?: string;
23
+ } & FlexBreakpoint & FlexBreakpointsConfig;
24
+ export type FlexProps<E extends React.ElementType = React.ElementType> = React.PropsWithChildren<FlexOwnProps & PolymorphicProps<E>> & PolymorphicProps<E, FlexOwnProps>;
25
+ export declare const Flex: React.MemoExoticComponent<(<E extends React.ElementType<any> = "div">(props: FlexProps<E>) => JSX.Element)>;
@@ -30,19 +30,21 @@ exports.Flex = void 0;
30
30
  const React = __importStar(require("react"));
31
31
  const classnames_1 = __importDefault(require("classnames"));
32
32
  const Component_1 = require("../Component");
33
+ const ConfrigProvider_1 = require("../ConfrigProvider");
33
34
  require("./index.scss");
34
35
  const defaultElement = 'div';
35
- function Flex(props) {
36
- const { alignContent, alignItems, className, flexDirection, flexWrap, inline, itemDimensions, justifyContent, ...restProps } = props;
36
+ exports.Flex = React.memo((props) => {
37
+ const config = (0, ConfrigProvider_1.useConfig)();
38
+ const { alignContent, alignItems, className, flexDirection, flexWrap, inline, itemDimensions, justifyContent, prefixCls = config.prefixCls, ...restProps } = props;
39
+ const rootCls = React.useMemo(() => config.getRootPrefixCls(prefixCls || config.prefixCls, 'flex'), [config, prefixCls]);
37
40
  return (React.createElement(Component_1.Component, { className: (0, classnames_1.default)({
38
- 'uk-flex': !inline,
39
- 'uk-flex-inline': inline,
40
- [`uk-flex-${alignItems}`]: alignItems !== undefined,
41
- [`uk-flex-${flexDirection}`]: flexDirection !== undefined,
42
- [`uk-flex-${flexWrap}`]: flexWrap !== undefined,
43
- [`uk-flex-wrap-${alignContent}`]: flexWrap !== undefined && alignContent !== undefined,
44
- [`uk-flex-${justifyContent}`]: justifyContent !== undefined,
45
- [`uk-flex-${itemDimensions}`]: itemDimensions !== undefined,
46
- }, className), component: defaultElement, ...restProps }));
47
- }
48
- exports.Flex = Flex;
41
+ [rootCls]: !inline,
42
+ [`${rootCls}-inline`]: inline,
43
+ [`${rootCls}-${alignItems}`]: alignItems !== undefined,
44
+ [`${rootCls}-${flexDirection}`]: flexDirection !== undefined,
45
+ [`${rootCls}-${flexWrap}`]: flexWrap !== undefined,
46
+ [`${rootCls}-wrap-${alignContent}`]: flexWrap !== undefined && alignContent !== undefined,
47
+ [`${rootCls}-${justifyContent}`]: justifyContent !== undefined,
48
+ [`${rootCls}-${itemDimensions}`]: itemDimensions !== undefined,
49
+ }, className), ...restProps }));
50
+ });
@@ -1,6 +1,5 @@
1
1
  import * as React from 'react';
2
- export declare type ControlsProps = React.HTMLAttributes<HTMLDivElement>;
3
- export declare function Controls(props: ControlsProps): JSX.Element;
4
- export declare namespace Controls {
5
- var displayName: string;
2
+ export interface ControlsProps extends React.HTMLAttributes<HTMLDivElement> {
3
+ prefixCls?: string;
6
4
  }
5
+ export declare const Controls: React.MemoExoticComponent<(props: ControlsProps) => JSX.Element>;