donghy 0.0.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 (535) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +422 -0
  3. package/dist/cjs/components/Button/Button.js +66 -0
  4. package/dist/cjs/components/Button/Button.module.css +137 -0
  5. package/dist/cjs/components/Button/index.js +14 -0
  6. package/dist/cjs/components/common/Affix/Affix.js +152 -0
  7. package/dist/cjs/components/common/Affix/Affix.module.css +11 -0
  8. package/dist/cjs/components/common/Affix/index.js +21 -0
  9. package/dist/cjs/components/common/Anchor/Anchor.js +224 -0
  10. package/dist/cjs/components/common/Anchor/Anchor.module.css +104 -0
  11. package/dist/cjs/components/common/Anchor/index.js +12 -0
  12. package/dist/cjs/components/common/App/App.js +214 -0
  13. package/dist/cjs/components/common/App/App.module.css +2 -0
  14. package/dist/cjs/components/common/App/index.js +12 -0
  15. package/dist/cjs/components/common/BackTop/BackTop.js +105 -0
  16. package/dist/cjs/components/common/BackTop/BackTop.module.css +43 -0
  17. package/dist/cjs/components/common/BackTop/index.js +12 -0
  18. package/dist/cjs/components/common/Button/Button.js +413 -0
  19. package/dist/cjs/components/common/Button/Button.module.css +122 -0
  20. package/dist/cjs/components/common/Button/index.js +12 -0
  21. package/dist/cjs/components/common/ConfigProvider/ConfigProvider.js +102 -0
  22. package/dist/cjs/components/common/ConfigProvider/ConfigProvider.module.css +2 -0
  23. package/dist/cjs/components/common/ConfigProvider/index.js +24 -0
  24. package/dist/cjs/components/common/FloatButton/FloatButton.js +552 -0
  25. package/dist/cjs/components/common/FloatButton/FloatButton.module.css +221 -0
  26. package/dist/cjs/components/common/FloatButton/index.js +24 -0
  27. package/dist/cjs/components/common/Icon/Icon.js +662 -0
  28. package/dist/cjs/components/common/Icon/Icon.module.css +26 -0
  29. package/dist/cjs/components/common/Icon/index.js +16 -0
  30. package/dist/cjs/components/common/Icon/style.css +26 -0
  31. package/dist/cjs/components/common/Typography/Typography.js +605 -0
  32. package/dist/cjs/components/common/Typography/Typography.module.css +303 -0
  33. package/dist/cjs/components/common/Typography/index.js +36 -0
  34. package/dist/cjs/components/common/Watermark/Watermark.js +248 -0
  35. package/dist/cjs/components/common/Watermark/Watermark.module.css +11 -0
  36. package/dist/cjs/components/common/Watermark/index.js +12 -0
  37. package/dist/cjs/components/common/index.js +115 -0
  38. package/dist/cjs/components/display/avatar/Avatar.js +127 -0
  39. package/dist/cjs/components/display/avatar/Avatar.module.css +95 -0
  40. package/dist/cjs/components/display/avatar/AvatarGroup.js +66 -0
  41. package/dist/cjs/components/display/avatar/index.js +19 -0
  42. package/dist/cjs/components/display/badge/Badge.js +152 -0
  43. package/dist/cjs/components/display/badge/Badge.module.css +161 -0
  44. package/dist/cjs/components/display/badge/BadgeRibbon.js +63 -0
  45. package/dist/cjs/components/display/badge/index.js +19 -0
  46. package/dist/cjs/components/display/calendar/Calendar.js +400 -0
  47. package/dist/cjs/components/display/calendar/Calendar.module.css +284 -0
  48. package/dist/cjs/components/display/calendar/index.js +12 -0
  49. package/dist/cjs/components/display/card/Card.js +201 -0
  50. package/dist/cjs/components/display/card/Card.module.css +222 -0
  51. package/dist/cjs/components/display/card/CardGrid.js +31 -0
  52. package/dist/cjs/components/display/card/CardMeta.js +63 -0
  53. package/dist/cjs/components/display/card/index.js +26 -0
  54. package/dist/cjs/components/display/carousel/Carousel.js +316 -0
  55. package/dist/cjs/components/display/carousel/Carousel.module.css +144 -0
  56. package/dist/cjs/components/display/carousel/index.js +12 -0
  57. package/dist/cjs/components/display/collapse/Collapse.js +183 -0
  58. package/dist/cjs/components/display/collapse/Collapse.module.css +149 -0
  59. package/dist/cjs/components/display/collapse/index.js +12 -0
  60. package/dist/cjs/components/display/descriptions/Descriptions.js +218 -0
  61. package/dist/cjs/components/display/descriptions/Descriptions.module.css +106 -0
  62. package/dist/cjs/components/display/descriptions/index.js +12 -0
  63. package/dist/cjs/components/display/empty/Empty.js +158 -0
  64. package/dist/cjs/components/display/empty/Empty.module.css +32 -0
  65. package/dist/cjs/components/display/empty/index.js +12 -0
  66. package/dist/cjs/components/display/image/Image.js +481 -0
  67. package/dist/cjs/components/display/image/Image.module.css +223 -0
  68. package/dist/cjs/components/display/image/ImagePreviewGroup.js +142 -0
  69. package/dist/cjs/components/display/image/index.js +19 -0
  70. package/dist/cjs/components/display/index.js +187 -0
  71. package/dist/cjs/components/display/list/List.js +215 -0
  72. package/dist/cjs/components/display/list/List.module.css +212 -0
  73. package/dist/cjs/components/display/list/index.js +12 -0
  74. package/dist/cjs/components/display/popover/Popover.js +142 -0
  75. package/dist/cjs/components/display/popover/Popover.module.css +138 -0
  76. package/dist/cjs/components/display/popover/index.js +12 -0
  77. package/dist/cjs/components/display/qrcode/QRCode.js +233 -0
  78. package/dist/cjs/components/display/qrcode/QRCode.module.css +91 -0
  79. package/dist/cjs/components/display/qrcode/index.js +12 -0
  80. package/dist/cjs/components/display/segmented/Segmented.js +177 -0
  81. package/dist/cjs/components/display/segmented/Segmented.module.css +82 -0
  82. package/dist/cjs/components/display/segmented/index.js +12 -0
  83. package/dist/cjs/components/display/statistic/Statistic.js +114 -0
  84. package/dist/cjs/components/display/statistic/Statistic.module.css +58 -0
  85. package/dist/cjs/components/display/statistic/StatisticTimer.js +174 -0
  86. package/dist/cjs/components/display/statistic/index.js +19 -0
  87. package/dist/cjs/components/display/table/Table.js +718 -0
  88. package/dist/cjs/components/display/table/Table.module.css +322 -0
  89. package/dist/cjs/components/display/table/index.js +12 -0
  90. package/dist/cjs/components/display/tag/CheckableTag.js +51 -0
  91. package/dist/cjs/components/display/tag/Tag.js +195 -0
  92. package/dist/cjs/components/display/tag/Tag.module.css +84 -0
  93. package/dist/cjs/components/display/tag/index.js +19 -0
  94. package/dist/cjs/components/display/timeline/Timeline.js +150 -0
  95. package/dist/cjs/components/display/timeline/Timeline.module.css +133 -0
  96. package/dist/cjs/components/display/timeline/index.js +12 -0
  97. package/dist/cjs/components/display/tooltip/Tooltip.js +121 -0
  98. package/dist/cjs/components/display/tooltip/Tooltip.module.css +118 -0
  99. package/dist/cjs/components/display/tooltip/index.js +12 -0
  100. package/dist/cjs/components/display/tour/Tour.js +450 -0
  101. package/dist/cjs/components/display/tour/Tour.module.css +318 -0
  102. package/dist/cjs/components/display/tour/index.js +12 -0
  103. package/dist/cjs/components/display/tree/Tree.js +837 -0
  104. package/dist/cjs/components/display/tree/Tree.module.css +235 -0
  105. package/dist/cjs/components/display/tree/index.js +12 -0
  106. package/dist/cjs/components/entry/auto-complete/AutoComplete.js +229 -0
  107. package/dist/cjs/components/entry/auto-complete/AutoComplete.module.css +113 -0
  108. package/dist/cjs/components/entry/auto-complete/index.js +12 -0
  109. package/dist/cjs/components/entry/cascader/Cascader.js +237 -0
  110. package/dist/cjs/components/entry/cascader/Cascader.module.css +124 -0
  111. package/dist/cjs/components/entry/cascader/index.js +12 -0
  112. package/dist/cjs/components/entry/choice/Checkbox.js +161 -0
  113. package/dist/cjs/components/entry/choice/Checkbox.module.css +88 -0
  114. package/dist/cjs/components/entry/choice/Radio.js +143 -0
  115. package/dist/cjs/components/entry/choice/Radio.module.css +85 -0
  116. package/dist/cjs/components/entry/choice/Switch.js +104 -0
  117. package/dist/cjs/components/entry/choice/Switch.module.css +86 -0
  118. package/dist/cjs/components/entry/choice/index.js +26 -0
  119. package/dist/cjs/components/entry/common.js +5 -0
  120. package/dist/cjs/components/entry/date-picker/DatePicker.js +212 -0
  121. package/dist/cjs/components/entry/date-picker/DatePicker.module.css +153 -0
  122. package/dist/cjs/components/entry/date-picker/index.js +12 -0
  123. package/dist/cjs/components/entry/form/Form.js +505 -0
  124. package/dist/cjs/components/entry/form/Form.module.css +124 -0
  125. package/dist/cjs/components/entry/form/Form.tokens.css +22 -0
  126. package/dist/cjs/components/entry/form/index.js +12 -0
  127. package/dist/cjs/components/entry/index.js +136 -0
  128. package/dist/cjs/components/entry/input/Input.js +257 -0
  129. package/dist/cjs/components/entry/input/Input.module.css +172 -0
  130. package/dist/cjs/components/entry/input/index.js +12 -0
  131. package/dist/cjs/components/entry/input-number/InputNumber.js +170 -0
  132. package/dist/cjs/components/entry/input-number/InputNumber.module.css +89 -0
  133. package/dist/cjs/components/entry/input-number/index.js +12 -0
  134. package/dist/cjs/components/entry/mention/Mention.js +170 -0
  135. package/dist/cjs/components/entry/mention/Mention.module.css +77 -0
  136. package/dist/cjs/components/entry/mention/index.js +12 -0
  137. package/dist/cjs/components/entry/range-picker/RangePicker.js +326 -0
  138. package/dist/cjs/components/entry/range-picker/RangePicker.module.css +193 -0
  139. package/dist/cjs/components/entry/range-picker/index.js +12 -0
  140. package/dist/cjs/components/entry/rate/Rate.js +123 -0
  141. package/dist/cjs/components/entry/rate/Rate.module.css +76 -0
  142. package/dist/cjs/components/entry/rate/index.js +12 -0
  143. package/dist/cjs/components/entry/select/Select.js +303 -0
  144. package/dist/cjs/components/entry/select/Select.module.css +202 -0
  145. package/dist/cjs/components/entry/select/index.js +12 -0
  146. package/dist/cjs/components/entry/slider/Slider.js +190 -0
  147. package/dist/cjs/components/entry/slider/Slider.module.css +196 -0
  148. package/dist/cjs/components/entry/slider/index.js +12 -0
  149. package/dist/cjs/components/entry/textarea/TextArea.js +99 -0
  150. package/dist/cjs/components/entry/textarea/TextArea.module.css +54 -0
  151. package/dist/cjs/components/entry/textarea/index.js +12 -0
  152. package/dist/cjs/components/entry/time-picker/TimePicker.js +213 -0
  153. package/dist/cjs/components/entry/time-picker/TimePicker.module.css +137 -0
  154. package/dist/cjs/components/entry/time-picker/index.js +12 -0
  155. package/dist/cjs/components/entry/tokens/index.js +151 -0
  156. package/dist/cjs/components/entry/transfer/Transfer.js +243 -0
  157. package/dist/cjs/components/entry/transfer/Transfer.module.css +170 -0
  158. package/dist/cjs/components/entry/transfer/index.js +12 -0
  159. package/dist/cjs/components/entry/tree-select/TreeSelect.js +225 -0
  160. package/dist/cjs/components/entry/tree-select/TreeSelect.module.css +138 -0
  161. package/dist/cjs/components/entry/tree-select/index.js +12 -0
  162. package/dist/cjs/components/entry/types.d.ts +10 -0
  163. package/dist/cjs/components/entry/upload/Upload.js +381 -0
  164. package/dist/cjs/components/entry/upload/Upload.module.css +150 -0
  165. package/dist/cjs/components/entry/upload/index.js +12 -0
  166. package/dist/cjs/components/feedback/alert/Alert.js +153 -0
  167. package/dist/cjs/components/feedback/alert/Alert.module.css +131 -0
  168. package/dist/cjs/components/feedback/alert/index.js +12 -0
  169. package/dist/cjs/components/feedback/drawer/Drawer.js +196 -0
  170. package/dist/cjs/components/feedback/drawer/Drawer.module.css +135 -0
  171. package/dist/cjs/components/feedback/drawer/index.js +12 -0
  172. package/dist/cjs/components/feedback/index.js +75 -0
  173. package/dist/cjs/components/feedback/message/Message.js +316 -0
  174. package/dist/cjs/components/feedback/message/Message.module.css +130 -0
  175. package/dist/cjs/components/feedback/message/index.js +12 -0
  176. package/dist/cjs/components/feedback/modal/Modal.js +193 -0
  177. package/dist/cjs/components/feedback/modal/Modal.module.css +123 -0
  178. package/dist/cjs/components/feedback/modal/index.js +12 -0
  179. package/dist/cjs/components/feedback/notification/Notification.js +339 -0
  180. package/dist/cjs/components/feedback/notification/Notification.module.css +262 -0
  181. package/dist/cjs/components/feedback/notification/index.js +12 -0
  182. package/dist/cjs/components/feedback/popconfirm/Popconfirm.js +169 -0
  183. package/dist/cjs/components/feedback/popconfirm/Popconfirm.module.css +180 -0
  184. package/dist/cjs/components/feedback/popconfirm/index.js +12 -0
  185. package/dist/cjs/components/feedback/progress/Progress.js +258 -0
  186. package/dist/cjs/components/feedback/progress/Progress.module.css +166 -0
  187. package/dist/cjs/components/feedback/progress/index.js +12 -0
  188. package/dist/cjs/components/feedback/result/Result.js +232 -0
  189. package/dist/cjs/components/feedback/result/Result.module.css +63 -0
  190. package/dist/cjs/components/feedback/result/index.js +12 -0
  191. package/dist/cjs/components/feedback/skeleton/Skeleton.js +174 -0
  192. package/dist/cjs/components/feedback/skeleton/Skeleton.module.css +96 -0
  193. package/dist/cjs/components/feedback/skeleton/index.js +12 -0
  194. package/dist/cjs/components/feedback/spin/Spin.js +178 -0
  195. package/dist/cjs/components/feedback/spin/Spin.module.css +86 -0
  196. package/dist/cjs/components/feedback/spin/index.js +12 -0
  197. package/dist/cjs/components/feedback/tokens/index.js +97 -0
  198. package/dist/cjs/components/index.js +1269 -0
  199. package/dist/cjs/components/layout/divider/Divider.js +45 -0
  200. package/dist/cjs/components/layout/divider/Divider.module.css +77 -0
  201. package/dist/cjs/components/layout/divider/index.js +12 -0
  202. package/dist/cjs/components/layout/flex/Flex.js +110 -0
  203. package/dist/cjs/components/layout/flex/Flex.module.css +26 -0
  204. package/dist/cjs/components/layout/flex/index.js +24 -0
  205. package/dist/cjs/components/layout/grid/Grid.js +171 -0
  206. package/dist/cjs/components/layout/grid/Grid.module.css +22 -0
  207. package/dist/cjs/components/layout/grid/index.js +18 -0
  208. package/dist/cjs/components/layout/index.js +79 -0
  209. package/dist/cjs/components/layout/layout/Layout.js +201 -0
  210. package/dist/cjs/components/layout/layout/Layout.module.css +92 -0
  211. package/dist/cjs/components/layout/layout/index.js +12 -0
  212. package/dist/cjs/components/layout/masonry/Masonry.js +53 -0
  213. package/dist/cjs/components/layout/masonry/Masonry.module.css +8 -0
  214. package/dist/cjs/components/layout/masonry/index.js +12 -0
  215. package/dist/cjs/components/layout/space/Space.js +76 -0
  216. package/dist/cjs/components/layout/space/Space.module.css +39 -0
  217. package/dist/cjs/components/layout/space/index.js +12 -0
  218. package/dist/cjs/components/layout/splitter/Splitter.js +192 -0
  219. package/dist/cjs/components/layout/splitter/Splitter.module.css +39 -0
  220. package/dist/cjs/components/layout/splitter/index.js +12 -0
  221. package/dist/cjs/components/layout/stack/Stack.js +45 -0
  222. package/dist/cjs/components/layout/stack/Stack.module.css +52 -0
  223. package/dist/cjs/components/layout/stack/index.js +12 -0
  224. package/dist/cjs/components/nav/breadcrumb/Breadcrumb.js +74 -0
  225. package/dist/cjs/components/nav/breadcrumb/Breadcrumb.module.css +60 -0
  226. package/dist/cjs/components/nav/breadcrumb/index.js +12 -0
  227. package/dist/cjs/components/nav/dropdown/Dropdown.js +134 -0
  228. package/dist/cjs/components/nav/dropdown/Dropdown.module.css +148 -0
  229. package/dist/cjs/components/nav/dropdown/index.js +12 -0
  230. package/dist/cjs/components/nav/index.js +47 -0
  231. package/dist/cjs/components/nav/menu/Menu.js +308 -0
  232. package/dist/cjs/components/nav/menu/Menu.module.css +250 -0
  233. package/dist/cjs/components/nav/menu/index.js +18 -0
  234. package/dist/cjs/components/nav/pagination/Pagination.js +277 -0
  235. package/dist/cjs/components/nav/pagination/Pagination.module.css +126 -0
  236. package/dist/cjs/components/nav/pagination/index.js +12 -0
  237. package/dist/cjs/components/nav/steps/Steps.js +135 -0
  238. package/dist/cjs/components/nav/steps/Steps.module.css +170 -0
  239. package/dist/cjs/components/nav/steps/index.js +12 -0
  240. package/dist/cjs/components/nav/tabs/Tabs.js +190 -0
  241. package/dist/cjs/components/nav/tabs/Tabs.module.css +251 -0
  242. package/dist/cjs/components/nav/tabs/index.js +12 -0
  243. package/dist/cjs/components/shared/constants/breakpoint.js +15 -0
  244. package/dist/cjs/components/shared/constants/index.js +18 -0
  245. package/dist/cjs/components/shared/hooks/index.js +53 -0
  246. package/dist/cjs/components/shared/hooks/useClickOutside.js +26 -0
  247. package/dist/cjs/components/shared/hooks/useControllableState.js +31 -0
  248. package/dist/cjs/components/shared/hooks/useEscapeKey.js +22 -0
  249. package/dist/cjs/components/shared/hooks/useMatchMedia.js +69 -0
  250. package/dist/cjs/components/shared/hooks/usePikaContext.js +40 -0
  251. package/dist/cjs/components/shared/hooks/useScrollListener.js +39 -0
  252. package/dist/cjs/components/shared/hooks/useZenContext.js +40 -0
  253. package/dist/cjs/components/shared/index.js +117 -0
  254. package/dist/cjs/components/shared/overlay/index.js +37 -0
  255. package/dist/cjs/components/shared/overlay/placement.js +105 -0
  256. package/dist/cjs/components/shared/overlay/useOverlay.js +183 -0
  257. package/dist/cjs/components/shared/types/common.js +5 -0
  258. package/dist/cjs/components/shared/types/css.js +5 -0
  259. package/dist/cjs/components/shared/types/index.js +5 -0
  260. package/dist/cjs/components/shared/utils/classNames.js +12 -0
  261. package/dist/cjs/components/shared/utils/index.js +38 -0
  262. package/dist/cjs/components/shared/utils/portal.js +20 -0
  263. package/dist/cjs/components/shared/utils/semantic.js +18 -0
  264. package/dist/cjs/global.css +247 -0
  265. package/dist/cjs/index.js +27 -0
  266. package/dist/cjs/theme/dark.css +56 -0
  267. package/dist/cjs/theme/dumi.css +695 -0
  268. package/dist/cjs/theme/tokens.js +133 -0
  269. package/dist/esm/components/Button/Button.js +60 -0
  270. package/dist/esm/components/Button/Button.module.css +137 -0
  271. package/dist/esm/components/Button/index.js +3 -0
  272. package/dist/esm/components/common/Affix/Affix.js +146 -0
  273. package/dist/esm/components/common/Affix/Affix.module.css +11 -0
  274. package/dist/esm/components/common/Affix/index.js +1 -0
  275. package/dist/esm/components/common/Anchor/Anchor.js +220 -0
  276. package/dist/esm/components/common/Anchor/Anchor.module.css +104 -0
  277. package/dist/esm/components/common/Anchor/index.js +1 -0
  278. package/dist/esm/components/common/App/App.js +206 -0
  279. package/dist/esm/components/common/App/App.module.css +2 -0
  280. package/dist/esm/components/common/App/index.js +1 -0
  281. package/dist/esm/components/common/BackTop/BackTop.js +99 -0
  282. package/dist/esm/components/common/BackTop/BackTop.module.css +43 -0
  283. package/dist/esm/components/common/BackTop/index.js +1 -0
  284. package/dist/esm/components/common/Button/Button.js +408 -0
  285. package/dist/esm/components/common/Button/Button.module.css +122 -0
  286. package/dist/esm/components/common/Button/index.js +1 -0
  287. package/dist/esm/components/common/ConfigProvider/ConfigProvider.js +99 -0
  288. package/dist/esm/components/common/ConfigProvider/ConfigProvider.module.css +2 -0
  289. package/dist/esm/components/common/ConfigProvider/index.js +2 -0
  290. package/dist/esm/components/common/FloatButton/FloatButton.js +572 -0
  291. package/dist/esm/components/common/FloatButton/FloatButton.module.css +221 -0
  292. package/dist/esm/components/common/FloatButton/index.js +1 -0
  293. package/dist/esm/components/common/Icon/Icon.js +651 -0
  294. package/dist/esm/components/common/Icon/Icon.module.css +26 -0
  295. package/dist/esm/components/common/Icon/index.js +2 -0
  296. package/dist/esm/components/common/Icon/style.css +26 -0
  297. package/dist/esm/components/common/Typography/Typography.js +599 -0
  298. package/dist/esm/components/common/Typography/Typography.module.css +303 -0
  299. package/dist/esm/components/common/Typography/index.js +1 -0
  300. package/dist/esm/components/common/Watermark/Watermark.js +243 -0
  301. package/dist/esm/components/common/Watermark/Watermark.module.css +11 -0
  302. package/dist/esm/components/common/Watermark/index.js +1 -0
  303. package/dist/esm/components/common/index.js +10 -0
  304. package/dist/esm/components/display/avatar/Avatar.js +128 -0
  305. package/dist/esm/components/display/avatar/Avatar.module.css +95 -0
  306. package/dist/esm/components/display/avatar/AvatarGroup.js +58 -0
  307. package/dist/esm/components/display/avatar/index.js +2 -0
  308. package/dist/esm/components/display/badge/Badge.js +153 -0
  309. package/dist/esm/components/display/badge/Badge.module.css +161 -0
  310. package/dist/esm/components/display/badge/BadgeRibbon.js +56 -0
  311. package/dist/esm/components/display/badge/index.js +2 -0
  312. package/dist/esm/components/display/calendar/Calendar.js +399 -0
  313. package/dist/esm/components/display/calendar/Calendar.module.css +284 -0
  314. package/dist/esm/components/display/calendar/index.js +1 -0
  315. package/dist/esm/components/display/card/Card.js +202 -0
  316. package/dist/esm/components/display/card/Card.module.css +222 -0
  317. package/dist/esm/components/display/card/CardGrid.js +22 -0
  318. package/dist/esm/components/display/card/CardMeta.js +56 -0
  319. package/dist/esm/components/display/card/index.js +3 -0
  320. package/dist/esm/components/display/carousel/Carousel.js +324 -0
  321. package/dist/esm/components/display/carousel/Carousel.module.css +144 -0
  322. package/dist/esm/components/display/carousel/index.js +1 -0
  323. package/dist/esm/components/display/collapse/Collapse.js +186 -0
  324. package/dist/esm/components/display/collapse/Collapse.module.css +149 -0
  325. package/dist/esm/components/display/collapse/index.js +1 -0
  326. package/dist/esm/components/display/descriptions/Descriptions.js +221 -0
  327. package/dist/esm/components/display/descriptions/Descriptions.module.css +106 -0
  328. package/dist/esm/components/display/descriptions/index.js +1 -0
  329. package/dist/esm/components/display/empty/Empty.js +157 -0
  330. package/dist/esm/components/display/empty/Empty.module.css +32 -0
  331. package/dist/esm/components/display/empty/index.js +1 -0
  332. package/dist/esm/components/display/image/Image.js +479 -0
  333. package/dist/esm/components/display/image/Image.module.css +223 -0
  334. package/dist/esm/components/display/image/ImagePreviewGroup.js +135 -0
  335. package/dist/esm/components/display/image/index.js +2 -0
  336. package/dist/esm/components/display/index.js +27 -0
  337. package/dist/esm/components/display/list/List.js +208 -0
  338. package/dist/esm/components/display/list/List.module.css +212 -0
  339. package/dist/esm/components/display/list/index.js +1 -0
  340. package/dist/esm/components/display/popover/Popover.js +144 -0
  341. package/dist/esm/components/display/popover/Popover.module.css +138 -0
  342. package/dist/esm/components/display/popover/index.js +1 -0
  343. package/dist/esm/components/display/qrcode/QRCode.js +226 -0
  344. package/dist/esm/components/display/qrcode/QRCode.module.css +91 -0
  345. package/dist/esm/components/display/qrcode/index.js +1 -0
  346. package/dist/esm/components/display/segmented/Segmented.js +170 -0
  347. package/dist/esm/components/display/segmented/Segmented.module.css +82 -0
  348. package/dist/esm/components/display/segmented/index.js +1 -0
  349. package/dist/esm/components/display/statistic/Statistic.js +107 -0
  350. package/dist/esm/components/display/statistic/Statistic.module.css +58 -0
  351. package/dist/esm/components/display/statistic/StatisticTimer.js +167 -0
  352. package/dist/esm/components/display/statistic/index.js +2 -0
  353. package/dist/esm/components/display/table/Table.js +712 -0
  354. package/dist/esm/components/display/table/Table.module.css +322 -0
  355. package/dist/esm/components/display/table/index.js +1 -0
  356. package/dist/esm/components/display/tag/CheckableTag.js +42 -0
  357. package/dist/esm/components/display/tag/Tag.js +188 -0
  358. package/dist/esm/components/display/tag/Tag.module.css +84 -0
  359. package/dist/esm/components/display/tag/index.js +2 -0
  360. package/dist/esm/components/display/timeline/Timeline.js +147 -0
  361. package/dist/esm/components/display/timeline/Timeline.module.css +133 -0
  362. package/dist/esm/components/display/timeline/index.js +1 -0
  363. package/dist/esm/components/display/tooltip/Tooltip.js +117 -0
  364. package/dist/esm/components/display/tooltip/Tooltip.module.css +118 -0
  365. package/dist/esm/components/display/tooltip/index.js +1 -0
  366. package/dist/esm/components/display/tour/Tour.js +449 -0
  367. package/dist/esm/components/display/tour/Tour.module.css +318 -0
  368. package/dist/esm/components/display/tour/index.js +1 -0
  369. package/dist/esm/components/display/tree/Tree.js +837 -0
  370. package/dist/esm/components/display/tree/Tree.module.css +235 -0
  371. package/dist/esm/components/display/tree/index.js +1 -0
  372. package/dist/esm/components/entry/auto-complete/AutoComplete.js +229 -0
  373. package/dist/esm/components/entry/auto-complete/AutoComplete.module.css +113 -0
  374. package/dist/esm/components/entry/auto-complete/index.js +1 -0
  375. package/dist/esm/components/entry/cascader/Cascader.js +229 -0
  376. package/dist/esm/components/entry/cascader/Cascader.module.css +124 -0
  377. package/dist/esm/components/entry/cascader/index.js +1 -0
  378. package/dist/esm/components/entry/choice/Checkbox.js +160 -0
  379. package/dist/esm/components/entry/choice/Checkbox.module.css +88 -0
  380. package/dist/esm/components/entry/choice/Radio.js +140 -0
  381. package/dist/esm/components/entry/choice/Radio.module.css +85 -0
  382. package/dist/esm/components/entry/choice/Switch.js +104 -0
  383. package/dist/esm/components/entry/choice/Switch.module.css +86 -0
  384. package/dist/esm/components/entry/choice/index.js +3 -0
  385. package/dist/esm/components/entry/common.js +1 -0
  386. package/dist/esm/components/entry/date-picker/DatePicker.js +213 -0
  387. package/dist/esm/components/entry/date-picker/DatePicker.module.css +153 -0
  388. package/dist/esm/components/entry/date-picker/index.js +1 -0
  389. package/dist/esm/components/entry/form/Form.js +518 -0
  390. package/dist/esm/components/entry/form/Form.module.css +124 -0
  391. package/dist/esm/components/entry/form/Form.tokens.css +22 -0
  392. package/dist/esm/components/entry/form/index.js +1 -0
  393. package/dist/esm/components/entry/index.js +19 -0
  394. package/dist/esm/components/entry/input/Input.js +252 -0
  395. package/dist/esm/components/entry/input/Input.module.css +172 -0
  396. package/dist/esm/components/entry/input/index.js +1 -0
  397. package/dist/esm/components/entry/input-number/InputNumber.js +168 -0
  398. package/dist/esm/components/entry/input-number/InputNumber.module.css +89 -0
  399. package/dist/esm/components/entry/input-number/index.js +1 -0
  400. package/dist/esm/components/entry/mention/Mention.js +169 -0
  401. package/dist/esm/components/entry/mention/Mention.module.css +77 -0
  402. package/dist/esm/components/entry/mention/index.js +1 -0
  403. package/dist/esm/components/entry/range-picker/RangePicker.js +320 -0
  404. package/dist/esm/components/entry/range-picker/RangePicker.module.css +193 -0
  405. package/dist/esm/components/entry/range-picker/index.js +1 -0
  406. package/dist/esm/components/entry/rate/Rate.js +120 -0
  407. package/dist/esm/components/entry/rate/Rate.module.css +76 -0
  408. package/dist/esm/components/entry/rate/index.js +1 -0
  409. package/dist/esm/components/entry/select/Select.js +303 -0
  410. package/dist/esm/components/entry/select/Select.module.css +202 -0
  411. package/dist/esm/components/entry/select/index.js +1 -0
  412. package/dist/esm/components/entry/slider/Slider.js +183 -0
  413. package/dist/esm/components/entry/slider/Slider.module.css +196 -0
  414. package/dist/esm/components/entry/slider/index.js +1 -0
  415. package/dist/esm/components/entry/textarea/TextArea.js +95 -0
  416. package/dist/esm/components/entry/textarea/TextArea.module.css +54 -0
  417. package/dist/esm/components/entry/textarea/index.js +1 -0
  418. package/dist/esm/components/entry/time-picker/TimePicker.js +211 -0
  419. package/dist/esm/components/entry/time-picker/TimePicker.module.css +137 -0
  420. package/dist/esm/components/entry/time-picker/index.js +1 -0
  421. package/dist/esm/components/entry/tokens/index.js +145 -0
  422. package/dist/esm/components/entry/transfer/Transfer.js +242 -0
  423. package/dist/esm/components/entry/transfer/Transfer.module.css +170 -0
  424. package/dist/esm/components/entry/transfer/index.js +1 -0
  425. package/dist/esm/components/entry/tree-select/TreeSelect.js +221 -0
  426. package/dist/esm/components/entry/tree-select/TreeSelect.module.css +138 -0
  427. package/dist/esm/components/entry/tree-select/index.js +1 -0
  428. package/dist/esm/components/entry/types.d.ts +10 -0
  429. package/dist/esm/components/entry/upload/Upload.js +382 -0
  430. package/dist/esm/components/entry/upload/Upload.module.css +150 -0
  431. package/dist/esm/components/entry/upload/index.js +1 -0
  432. package/dist/esm/components/feedback/alert/Alert.js +152 -0
  433. package/dist/esm/components/feedback/alert/Alert.module.css +131 -0
  434. package/dist/esm/components/feedback/alert/index.js +1 -0
  435. package/dist/esm/components/feedback/drawer/Drawer.js +190 -0
  436. package/dist/esm/components/feedback/drawer/Drawer.module.css +135 -0
  437. package/dist/esm/components/feedback/drawer/index.js +1 -0
  438. package/dist/esm/components/feedback/index.js +10 -0
  439. package/dist/esm/components/feedback/message/Message.js +317 -0
  440. package/dist/esm/components/feedback/message/Message.module.css +130 -0
  441. package/dist/esm/components/feedback/message/index.js +1 -0
  442. package/dist/esm/components/feedback/modal/Modal.js +191 -0
  443. package/dist/esm/components/feedback/modal/Modal.module.css +123 -0
  444. package/dist/esm/components/feedback/modal/index.js +1 -0
  445. package/dist/esm/components/feedback/notification/Notification.js +342 -0
  446. package/dist/esm/components/feedback/notification/Notification.module.css +262 -0
  447. package/dist/esm/components/feedback/notification/index.js +1 -0
  448. package/dist/esm/components/feedback/popconfirm/Popconfirm.js +165 -0
  449. package/dist/esm/components/feedback/popconfirm/Popconfirm.module.css +180 -0
  450. package/dist/esm/components/feedback/popconfirm/index.js +1 -0
  451. package/dist/esm/components/feedback/progress/Progress.js +262 -0
  452. package/dist/esm/components/feedback/progress/Progress.module.css +166 -0
  453. package/dist/esm/components/feedback/progress/index.js +1 -0
  454. package/dist/esm/components/feedback/result/Result.js +224 -0
  455. package/dist/esm/components/feedback/result/Result.module.css +63 -0
  456. package/dist/esm/components/feedback/result/index.js +1 -0
  457. package/dist/esm/components/feedback/skeleton/Skeleton.js +174 -0
  458. package/dist/esm/components/feedback/skeleton/Skeleton.module.css +96 -0
  459. package/dist/esm/components/feedback/skeleton/index.js +1 -0
  460. package/dist/esm/components/feedback/spin/Spin.js +175 -0
  461. package/dist/esm/components/feedback/spin/Spin.module.css +86 -0
  462. package/dist/esm/components/feedback/spin/index.js +1 -0
  463. package/dist/esm/components/feedback/tokens/index.js +91 -0
  464. package/dist/esm/components/index.js +24 -0
  465. package/dist/esm/components/layout/divider/Divider.js +36 -0
  466. package/dist/esm/components/layout/divider/Divider.module.css +77 -0
  467. package/dist/esm/components/layout/divider/index.js +1 -0
  468. package/dist/esm/components/layout/flex/Flex.js +108 -0
  469. package/dist/esm/components/layout/flex/Flex.module.css +26 -0
  470. package/dist/esm/components/layout/flex/index.js +1 -0
  471. package/dist/esm/components/layout/grid/Grid.js +167 -0
  472. package/dist/esm/components/layout/grid/Grid.module.css +22 -0
  473. package/dist/esm/components/layout/grid/index.js +1 -0
  474. package/dist/esm/components/layout/index.js +16 -0
  475. package/dist/esm/components/layout/layout/Layout.js +208 -0
  476. package/dist/esm/components/layout/layout/Layout.module.css +92 -0
  477. package/dist/esm/components/layout/layout/index.js +1 -0
  478. package/dist/esm/components/layout/masonry/Masonry.js +47 -0
  479. package/dist/esm/components/layout/masonry/Masonry.module.css +8 -0
  480. package/dist/esm/components/layout/masonry/index.js +1 -0
  481. package/dist/esm/components/layout/space/Space.js +70 -0
  482. package/dist/esm/components/layout/space/Space.module.css +39 -0
  483. package/dist/esm/components/layout/space/index.js +1 -0
  484. package/dist/esm/components/layout/splitter/Splitter.js +189 -0
  485. package/dist/esm/components/layout/splitter/Splitter.module.css +39 -0
  486. package/dist/esm/components/layout/splitter/index.js +1 -0
  487. package/dist/esm/components/layout/stack/Stack.js +38 -0
  488. package/dist/esm/components/layout/stack/Stack.module.css +52 -0
  489. package/dist/esm/components/layout/stack/index.js +1 -0
  490. package/dist/esm/components/nav/breadcrumb/Breadcrumb.js +66 -0
  491. package/dist/esm/components/nav/breadcrumb/Breadcrumb.module.css +60 -0
  492. package/dist/esm/components/nav/breadcrumb/index.js +1 -0
  493. package/dist/esm/components/nav/dropdown/Dropdown.js +128 -0
  494. package/dist/esm/components/nav/dropdown/Dropdown.module.css +148 -0
  495. package/dist/esm/components/nav/dropdown/index.js +1 -0
  496. package/dist/esm/components/nav/index.js +6 -0
  497. package/dist/esm/components/nav/menu/Menu.js +304 -0
  498. package/dist/esm/components/nav/menu/Menu.module.css +250 -0
  499. package/dist/esm/components/nav/menu/index.js +1 -0
  500. package/dist/esm/components/nav/pagination/Pagination.js +274 -0
  501. package/dist/esm/components/nav/pagination/Pagination.module.css +126 -0
  502. package/dist/esm/components/nav/pagination/index.js +1 -0
  503. package/dist/esm/components/nav/steps/Steps.js +132 -0
  504. package/dist/esm/components/nav/steps/Steps.module.css +170 -0
  505. package/dist/esm/components/nav/steps/index.js +1 -0
  506. package/dist/esm/components/nav/tabs/Tabs.js +187 -0
  507. package/dist/esm/components/nav/tabs/Tabs.module.css +251 -0
  508. package/dist/esm/components/nav/tabs/index.js +1 -0
  509. package/dist/esm/components/shared/constants/breakpoint.js +9 -0
  510. package/dist/esm/components/shared/constants/index.js +1 -0
  511. package/dist/esm/components/shared/hooks/index.js +6 -0
  512. package/dist/esm/components/shared/hooks/useClickOutside.js +20 -0
  513. package/dist/esm/components/shared/hooks/useControllableState.js +25 -0
  514. package/dist/esm/components/shared/hooks/useEscapeKey.js +16 -0
  515. package/dist/esm/components/shared/hooks/useMatchMedia.js +62 -0
  516. package/dist/esm/components/shared/hooks/usePikaContext.js +34 -0
  517. package/dist/esm/components/shared/hooks/useScrollListener.js +33 -0
  518. package/dist/esm/components/shared/hooks/useZenContext.js +34 -0
  519. package/dist/esm/components/shared/index.js +10 -0
  520. package/dist/esm/components/shared/overlay/index.js +2 -0
  521. package/dist/esm/components/shared/overlay/placement.js +98 -0
  522. package/dist/esm/components/shared/overlay/useOverlay.js +177 -0
  523. package/dist/esm/components/shared/types/common.js +1 -0
  524. package/dist/esm/components/shared/types/css.js +1 -0
  525. package/dist/esm/components/shared/types/index.js +1 -0
  526. package/dist/esm/components/shared/utils/classNames.js +6 -0
  527. package/dist/esm/components/shared/utils/index.js +3 -0
  528. package/dist/esm/components/shared/utils/portal.js +13 -0
  529. package/dist/esm/components/shared/utils/semantic.js +11 -0
  530. package/dist/esm/global.css +247 -0
  531. package/dist/esm/index.js +2 -0
  532. package/dist/esm/theme/dark.css +56 -0
  533. package/dist/esm/theme/dumi.css +695 -0
  534. package/dist/esm/theme/tokens.js +127 -0
  535. package/package.json +109 -0
@@ -0,0 +1,304 @@
1
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
2
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
4
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
5
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
6
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
7
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
8
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
9
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
10
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
11
+ import React, { forwardRef, createContext, useContext, useState, useCallback, useMemo } from 'react';
12
+ import styles from "./Menu.module.css";
13
+
14
+ /* ─── Types ─── */
15
+
16
+ /* ─── Context ─── */
17
+ import { jsx as _jsx } from "react/jsx-runtime";
18
+ import { jsxs as _jsxs } from "react/jsx-runtime";
19
+ var MenuContext = /*#__PURE__*/createContext({
20
+ mode: 'vertical',
21
+ theme: 'light',
22
+ selectedKey: undefined,
23
+ openKeys: [],
24
+ inlineCollapsed: false,
25
+ selectable: true,
26
+ triggerSubMenuAction: 'hover',
27
+ inlineIndent: 24,
28
+ expandIcon: null,
29
+ onClick: undefined,
30
+ onSelect: function onSelect() {},
31
+ onToggleOpen: function onToggleOpen() {}
32
+ });
33
+
34
+ /* ─── Item Renderer ─── */
35
+
36
+ var ItemRenderer = function ItemRenderer(_ref) {
37
+ var item = _ref.item,
38
+ level = _ref.level;
39
+ var ctx = useContext(MenuContext);
40
+ if (item.type === 'divider') {
41
+ return /*#__PURE__*/_jsx("li", {
42
+ className: styles.divider,
43
+ "data-divider": true,
44
+ role: "separator"
45
+ });
46
+ }
47
+ if (item.children && item.children.length > 0) {
48
+ return /*#__PURE__*/_jsx(SubMenuRenderer, {
49
+ item: item,
50
+ level: level
51
+ });
52
+ }
53
+ var isSelected = ctx.selectable && ctx.selectedKey === item.key;
54
+ var isDisabled = item.disabled;
55
+ var handleClick = function handleClick() {
56
+ var _ctx$onClick;
57
+ if (isDisabled) return;
58
+ (_ctx$onClick = ctx.onClick) === null || _ctx$onClick === void 0 || _ctx$onClick.call(ctx, item.key);
59
+ if (ctx.selectable) {
60
+ ctx.onSelect(item.key);
61
+ }
62
+ };
63
+ var cssVars = {
64
+ '--_indent': "".concat(level * ctx.inlineIndent, "px")
65
+ };
66
+ return /*#__PURE__*/_jsxs("li", {
67
+ className: styles.item,
68
+ style: cssVars,
69
+ "data-selected": isSelected || undefined,
70
+ "data-disabled": isDisabled || undefined,
71
+ "data-danger": item.danger || undefined,
72
+ "data-level": level,
73
+ role: "menuitem",
74
+ "aria-selected": isSelected || undefined,
75
+ "aria-disabled": isDisabled || undefined,
76
+ tabIndex: isDisabled ? -1 : 0,
77
+ onClick: handleClick,
78
+ onKeyDown: function onKeyDown(e) {
79
+ if (e.key === 'Enter' || e.key === ' ') {
80
+ e.preventDefault();
81
+ handleClick();
82
+ }
83
+ },
84
+ children: [item.icon && /*#__PURE__*/_jsx("span", {
85
+ className: styles.icon,
86
+ children: item.icon
87
+ }), /*#__PURE__*/_jsx("span", {
88
+ className: styles.label,
89
+ children: item.label
90
+ })]
91
+ });
92
+ };
93
+
94
+ /* ─── SubMenu Renderer ─── */
95
+
96
+ var SubMenuRenderer = function SubMenuRenderer(_ref2) {
97
+ var _ctx$expandIcon;
98
+ var item = _ref2.item,
99
+ level = _ref2.level;
100
+ var ctx = useContext(MenuContext);
101
+ var _useState = useState(false),
102
+ _useState2 = _slicedToArray(_useState, 2),
103
+ hoverOpen = _useState2[0],
104
+ setHoverOpen = _useState2[1];
105
+ var isOpen = ctx.openKeys.includes(item.key) || hoverOpen;
106
+ var isDisabled = item.disabled;
107
+ var isInline = ctx.mode === 'inline';
108
+ var handleTitleClick = function handleTitleClick() {
109
+ if (isDisabled) return;
110
+ if (isInline || ctx.triggerSubMenuAction === 'click') {
111
+ ctx.onToggleOpen(item.key);
112
+ }
113
+ };
114
+ var handleMouseEnter = function handleMouseEnter() {
115
+ if (ctx.triggerSubMenuAction === 'hover' && !isInline) {
116
+ setHoverOpen(true);
117
+ }
118
+ };
119
+ var handleMouseLeave = function handleMouseLeave() {
120
+ if (ctx.triggerSubMenuAction === 'hover' && !isInline) {
121
+ setHoverOpen(false);
122
+ }
123
+ };
124
+ var cssVars = {
125
+ '--_indent': "".concat(level * ctx.inlineIndent, "px")
126
+ };
127
+ var defaultExpandIcon = isInline ? /*#__PURE__*/_jsx("span", {
128
+ className: styles.expandArrow,
129
+ children: isOpen ? '▲' : '▼'
130
+ }) : /*#__PURE__*/_jsx("span", {
131
+ className: styles.expandArrow,
132
+ children: "\u25B6"
133
+ });
134
+ var expandIconEl = (_ctx$expandIcon = ctx.expandIcon) !== null && _ctx$expandIcon !== void 0 ? _ctx$expandIcon : defaultExpandIcon;
135
+ return /*#__PURE__*/_jsxs("li", {
136
+ className: styles.submenu,
137
+ "data-open": isOpen || undefined,
138
+ "data-disabled": isDisabled || undefined,
139
+ "data-level": level,
140
+ role: "none",
141
+ onMouseEnter: handleMouseEnter,
142
+ onMouseLeave: handleMouseLeave,
143
+ children: [/*#__PURE__*/_jsxs("div", {
144
+ className: styles.submenuTitle,
145
+ style: cssVars,
146
+ "data-selected": ctx.selectedKey === item.key || undefined,
147
+ onClick: handleTitleClick,
148
+ "aria-expanded": isOpen || undefined,
149
+ tabIndex: isDisabled ? -1 : 0,
150
+ onKeyDown: function onKeyDown(e) {
151
+ if (e.key === 'Enter' || e.key === ' ') {
152
+ e.preventDefault();
153
+ handleTitleClick();
154
+ }
155
+ },
156
+ children: [item.icon && /*#__PURE__*/_jsx("span", {
157
+ className: styles.icon,
158
+ children: item.icon
159
+ }), /*#__PURE__*/_jsx("span", {
160
+ className: styles.label,
161
+ children: item.label
162
+ }), /*#__PURE__*/_jsx("span", {
163
+ className: styles.expandIcon,
164
+ children: expandIconEl
165
+ })]
166
+ }), isInline ? /*#__PURE__*/_jsx("ul", {
167
+ className: styles.submenuInline,
168
+ "data-open": isOpen || undefined,
169
+ role: "menu",
170
+ children: item.children.map(function (child) {
171
+ return /*#__PURE__*/_jsx(ItemRenderer, {
172
+ item: child,
173
+ level: level + 1
174
+ }, child.key);
175
+ })
176
+ }) : isOpen && /*#__PURE__*/_jsx("ul", {
177
+ className: styles.submenuPopup,
178
+ role: "menu",
179
+ children: item.children.map(function (child) {
180
+ return /*#__PURE__*/_jsx(ItemRenderer, {
181
+ item: child,
182
+ level: 0
183
+ }, child.key);
184
+ })
185
+ })]
186
+ });
187
+ };
188
+
189
+ /* ─── Main Component ─── */
190
+
191
+ var Menu = /*#__PURE__*/forwardRef(function (_ref3, ref) {
192
+ var _ref3$mode = _ref3.mode,
193
+ mode = _ref3$mode === void 0 ? 'vertical' : _ref3$mode,
194
+ _ref3$theme = _ref3.theme,
195
+ theme = _ref3$theme === void 0 ? 'light' : _ref3$theme,
196
+ controlledSelectedKey = _ref3.selectedKey,
197
+ defaultSelectedKey = _ref3.defaultSelectedKey,
198
+ controlledOpenKeys = _ref3.openKeys,
199
+ _ref3$defaultOpenKeys = _ref3.defaultOpenKeys,
200
+ defaultOpenKeys = _ref3$defaultOpenKeys === void 0 ? [] : _ref3$defaultOpenKeys,
201
+ _ref3$inlineCollapsed = _ref3.inlineCollapsed,
202
+ inlineCollapsed = _ref3$inlineCollapsed === void 0 ? false : _ref3$inlineCollapsed,
203
+ _ref3$selectable = _ref3.selectable,
204
+ selectable = _ref3$selectable === void 0 ? true : _ref3$selectable,
205
+ _ref3$triggerSubMenuA = _ref3.triggerSubMenuAction,
206
+ triggerSubMenuAction = _ref3$triggerSubMenuA === void 0 ? 'hover' : _ref3$triggerSubMenuA,
207
+ _ref3$data = _ref3.data,
208
+ data = _ref3$data === void 0 ? [] : _ref3$data,
209
+ onSelect = _ref3.onSelect,
210
+ onChange = _ref3.onChange,
211
+ onClick = _ref3.onClick,
212
+ expandIcon = _ref3.expandIcon,
213
+ _ref3$inlineIndent = _ref3.inlineIndent,
214
+ inlineIndent = _ref3$inlineIndent === void 0 ? 24 : _ref3$inlineIndent,
215
+ children = _ref3.children,
216
+ className = _ref3.className,
217
+ style = _ref3.style;
218
+ var _useState3 = useState(defaultSelectedKey),
219
+ _useState4 = _slicedToArray(_useState3, 2),
220
+ internalSelectedKey = _useState4[0],
221
+ setInternalSelectedKey = _useState4[1];
222
+ var _useState5 = useState(defaultOpenKeys),
223
+ _useState6 = _slicedToArray(_useState5, 2),
224
+ internalOpenKeys = _useState6[0],
225
+ setInternalOpenKeys = _useState6[1];
226
+ var isControlledSelected = controlledSelectedKey !== undefined;
227
+ var isControlledOpen = controlledOpenKeys !== undefined;
228
+ var selectedKey = isControlledSelected ? controlledSelectedKey : internalSelectedKey;
229
+ var openKeys = isControlledOpen ? controlledOpenKeys : internalOpenKeys;
230
+ var handleSelect = useCallback(function (key) {
231
+ if (!isControlledSelected) {
232
+ setInternalSelectedKey(key);
233
+ }
234
+ onSelect === null || onSelect === void 0 || onSelect(key);
235
+ }, [isControlledSelected, onSelect]);
236
+ var handleToggleOpen = useCallback(function (key) {
237
+ var newOpenKeys = openKeys.includes(key) ? openKeys.filter(function (k) {
238
+ return k !== key;
239
+ }) : [].concat(_toConsumableArray(openKeys), [key]);
240
+ if (!isControlledOpen) {
241
+ setInternalOpenKeys(newOpenKeys);
242
+ }
243
+ onChange === null || onChange === void 0 || onChange(newOpenKeys);
244
+ }, [openKeys, isControlledOpen, onChange]);
245
+ var contextValue = useMemo(function () {
246
+ return {
247
+ mode: mode,
248
+ theme: theme,
249
+ selectedKey: selectedKey,
250
+ openKeys: openKeys,
251
+ inlineCollapsed: inlineCollapsed,
252
+ selectable: selectable,
253
+ triggerSubMenuAction: triggerSubMenuAction,
254
+ inlineIndent: inlineIndent,
255
+ expandIcon: expandIcon !== null && expandIcon !== void 0 ? expandIcon : null,
256
+ onClick: onClick,
257
+ onSelect: handleSelect,
258
+ onToggleOpen: handleToggleOpen
259
+ };
260
+ }, [mode, theme, selectedKey, openKeys, inlineCollapsed, selectable, triggerSubMenuAction, inlineIndent, expandIcon, onClick, handleSelect, handleToggleOpen]);
261
+ return /*#__PURE__*/_jsx(MenuContext.Provider, {
262
+ value: contextValue,
263
+ children: /*#__PURE__*/_jsxs("nav", {
264
+ ref: ref,
265
+ className: [styles.root, className].filter(Boolean).join(' '),
266
+ style: style,
267
+ "data-menu": true,
268
+ "data-mode": mode,
269
+ "data-theme": theme,
270
+ "data-inline-collapsed": inlineCollapsed || undefined,
271
+ role: "menu",
272
+ children: [/*#__PURE__*/_jsx("ul", {
273
+ className: styles.list,
274
+ children: data.map(function (item) {
275
+ return /*#__PURE__*/_jsx(ItemRenderer, {
276
+ item: item,
277
+ level: 0
278
+ }, item.key);
279
+ })
280
+ }), children]
281
+ })
282
+ });
283
+ });
284
+ Menu.displayName = 'Menu';
285
+
286
+ /* ─── Compound Components ─── */
287
+
288
+ var MenuDivider = /*#__PURE__*/forwardRef(function (_ref4, ref) {
289
+ var className = _ref4.className,
290
+ style = _ref4.style;
291
+ return /*#__PURE__*/_jsx("li", {
292
+ ref: ref,
293
+ className: [styles.divider, className].filter(Boolean).join(' '),
294
+ style: style,
295
+ "data-divider": true,
296
+ role: "separator"
297
+ });
298
+ });
299
+ MenuDivider.displayName = 'Menu.Divider';
300
+ var MenuCompound = Object.assign(Menu, {
301
+ Divider: MenuDivider
302
+ });
303
+ export { MenuCompound as Menu, MenuDivider };
304
+ export default MenuCompound;
@@ -0,0 +1,250 @@
1
+ /* ─── Menu Root ─── */
2
+ .root {
3
+ font-family: var(--nv-font-family, -apple-system, BlinkMacSystemFont, sans-serif);
4
+ font-size: var(--nv-font-size-middle, 14px);
5
+ line-height: 1;
6
+ margin: 0;
7
+ padding: 0;
8
+ outline: none;
9
+ }
10
+
11
+ .root[data-theme="light"] {
12
+ color: rgba(0, 0, 0, 0.85);
13
+ background: #fff;
14
+ }
15
+
16
+ .root[data-theme="dark"] {
17
+ color: rgba(255, 255, 255, 0.85);
18
+ background: #001529;
19
+ }
20
+
21
+ .list {
22
+ list-style: none;
23
+ margin: 0;
24
+ padding: 0;
25
+ }
26
+
27
+ .root[data-mode="horizontal"] .list {
28
+ display: flex;
29
+ flex-direction: row;
30
+ align-items: center;
31
+ border-bottom: 1px solid var(--nv-border-color, #d9d9d9);
32
+ }
33
+
34
+ .root[data-theme="dark"][data-mode="horizontal"] .list {
35
+ border-bottom-color: rgba(255, 255, 255, 0.12);
36
+ }
37
+
38
+ /* ─── Menu Item ─── */
39
+ .item {
40
+ display: flex;
41
+ align-items: center;
42
+ padding: 0 var(--nv-spacing-middle, 16px);
43
+ height: var(--nv-nav-item-height-middle, 40px);
44
+ cursor: pointer;
45
+ transition: all 0.2s var(--nv-ease-default, cubic-bezier(0.4, 0, 0.2, 1));
46
+ white-space: nowrap;
47
+ padding-left: calc(var(--_indent, 0px) + var(--nv-spacing-middle, 16px));
48
+ position: relative;
49
+ list-style: none;
50
+ }
51
+
52
+ .item:hover {
53
+ background: rgba(0, 0, 0, 0.04);
54
+ }
55
+
56
+ .item[data-selected] {
57
+ color: var(--nv-color-primary, #6C5CE7);
58
+ background: rgba(108, 92, 231, 0.08);
59
+ }
60
+
61
+ .item[data-disabled] {
62
+ color: rgba(0, 0, 0, 0.25);
63
+ cursor: not-allowed;
64
+ }
65
+
66
+ .item[data-danger] {
67
+ color: var(--nv-color-error, #FF7675);
68
+ }
69
+
70
+ .item[data-danger][data-selected] {
71
+ background: rgba(255, 118, 117, 0.08);
72
+ }
73
+
74
+ .root[data-theme="dark"] .item:hover {
75
+ background: rgba(255, 255, 255, 0.08);
76
+ }
77
+
78
+ .root[data-theme="dark"] .item[data-selected] {
79
+ background: rgba(108, 92, 231, 0.2);
80
+ }
81
+
82
+ .root[data-theme="dark"] .item[data-disabled] {
83
+ color: rgba(255, 255, 255, 0.35);
84
+ }
85
+
86
+ .root[data-theme="dark"] .item[data-danger] {
87
+ color: #ff7875;
88
+ }
89
+
90
+ .root[data-mode="horizontal"] .item {
91
+ border-bottom: 2px solid transparent;
92
+ }
93
+
94
+ .root[data-mode="horizontal"] .item[data-selected] {
95
+ border-bottom-color: var(--nv-color-primary, #6C5CE7);
96
+ }
97
+
98
+ /* ─── Icon ─── */
99
+ .icon {
100
+ display: inline-flex;
101
+ align-items: center;
102
+ margin-right: var(--nv-spacing-small, 8px);
103
+ font-size: var(--nv-menu-item-icon-size, 16px);
104
+ flex-shrink: 0;
105
+ }
106
+
107
+ .label {
108
+ flex: 1;
109
+ overflow: hidden;
110
+ text-overflow: ellipsis;
111
+ }
112
+
113
+ /* ─── SubMenu ─── */
114
+ .submenu {
115
+ position: relative;
116
+ list-style: none;
117
+ }
118
+
119
+ .submenuTitle {
120
+ display: flex;
121
+ align-items: center;
122
+ padding: 0 var(--nv-spacing-middle, 16px);
123
+ height: var(--nv-nav-item-height-middle, 40px);
124
+ cursor: pointer;
125
+ transition: all 0.2s var(--nv-ease-default, cubic-bezier(0.4, 0, 0.2, 1));
126
+ white-space: nowrap;
127
+ padding-left: calc(var(--_indent, 0px) + var(--nv-spacing-middle, 16px));
128
+ }
129
+
130
+ .submenuTitle:hover {
131
+ background: rgba(0, 0, 0, 0.04);
132
+ }
133
+
134
+ .submenuTitle[data-selected] {
135
+ color: var(--nv-color-primary, #6C5CE7);
136
+ }
137
+
138
+ .root[data-theme="dark"] .submenuTitle:hover {
139
+ background: rgba(255, 255, 255, 0.08);
140
+ }
141
+
142
+ .root[data-theme="dark"] .submenuTitle[data-selected] {
143
+ background: rgba(108, 92, 231, 0.2);
144
+ }
145
+
146
+ .submenu[data-disabled] .submenuTitle {
147
+ color: rgba(0, 0, 0, 0.25);
148
+ cursor: not-allowed;
149
+ }
150
+
151
+ .root[data-theme="dark"] .submenu[data-disabled] .submenuTitle {
152
+ color: rgba(255, 255, 255, 0.35);
153
+ }
154
+
155
+ /* ─── Expand Icon ─── */
156
+ .expandIcon {
157
+ display: inline-flex;
158
+ align-items: center;
159
+ margin-left: auto;
160
+ padding-left: var(--nv-spacing-small, 8px);
161
+ transition: transform 0.2s var(--nv-ease-default, cubic-bezier(0.4, 0, 0.2, 1));
162
+ }
163
+
164
+ .submenu[data-open] > .submenuTitle .expandIcon {
165
+ transform: rotate(180deg);
166
+ }
167
+
168
+ .expandArrow {
169
+ display: inline-flex;
170
+ font-size: 10px;
171
+ }
172
+
173
+ /* ─── SubMenu Inline ─── */
174
+ .submenuInline {
175
+ list-style: none;
176
+ margin: 0;
177
+ padding: 0;
178
+ overflow: hidden;
179
+ transition: height 0.2s var(--nv-ease-default, cubic-bezier(0.4, 0, 0.2, 1));
180
+ }
181
+
182
+ .submenuInline:not([data-open]) {
183
+ display: none;
184
+ }
185
+
186
+ /* ─── SubMenu Popup ─── */
187
+ .submenuPopup {
188
+ position: absolute;
189
+ left: 100%;
190
+ top: 0;
191
+ min-width: 160px;
192
+ list-style: none;
193
+ margin: 0;
194
+ padding: var(--nv-spacing-small, 8px) 0;
195
+ background: #fff;
196
+ border-radius: var(--nv-radius-middle, 8px);
197
+ box-shadow: var(--nv-shadow-middle, 0 4px 8px rgba(0, 0, 0, 0.08));
198
+ z-index: 1050;
199
+ }
200
+
201
+ .root[data-theme="dark"] .submenuPopup {
202
+ background: #1f1f1f;
203
+ }
204
+
205
+ .root[data-mode="horizontal"] .submenuPopup {
206
+ left: 0;
207
+ top: 100%;
208
+ }
209
+
210
+ .submenuPopup .item,
211
+ .submenuPopup .submenuTitle {
212
+ padding-left: var(--nv-spacing-middle, 16px);
213
+ }
214
+
215
+ /* ─── Divider ─── */
216
+ .divider {
217
+ height: 1px;
218
+ margin: var(--nv-spacing-small, 8px) 0;
219
+ background: var(--nv-border-color, #d9d9d9);
220
+ list-style: none;
221
+ }
222
+
223
+ .root[data-theme="dark"] .divider {
224
+ background: rgba(255, 255, 255, 0.12);
225
+ }
226
+
227
+ /* ─── Inline Collapsed ─── */
228
+ .root[data-inline-collapsed] .label,
229
+ .root[data-inline-collapsed] .expandIcon {
230
+ display: none;
231
+ }
232
+
233
+ .root[data-inline-collapsed] .item,
234
+ .root[data-inline-collapsed] .submenuTitle {
235
+ padding: 0;
236
+ justify-content: center;
237
+ }
238
+
239
+ .root[data-inline-collapsed] .icon {
240
+ margin-right: 0;
241
+ }
242
+
243
+ .root[data-inline-collapsed] .submenuInline {
244
+ display: none;
245
+ }
246
+
247
+ .root[data-inline-collapsed] .submenuPopup {
248
+ left: 100%;
249
+ top: 0;
250
+ }
@@ -0,0 +1 @@
1
+ export { Menu, MenuDivider } from "./Menu";