@lobehub/ui 4.3.2 → 4.3.3

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 (633) hide show
  1. package/es/Accordion/Accordion.mjs +2 -2
  2. package/es/Accordion/Accordion.mjs.map +1 -1
  3. package/es/Accordion/AccordionItem.mjs +11 -2
  4. package/es/Accordion/AccordionItem.mjs.map +1 -1
  5. package/es/Accordion/style.mjs +12 -9
  6. package/es/Accordion/style.mjs.map +1 -1
  7. package/es/ActionIcon/ActionIcon.d.mts +2 -2
  8. package/es/ActionIcon/ActionIcon.mjs +2 -57
  9. package/es/ActionIcon/ActionIcon.mjs.map +1 -1
  10. package/es/ActionIcon/style.mjs +76 -20
  11. package/es/ActionIcon/style.mjs.map +1 -1
  12. package/es/ActionIconGroup/ActionIconGroup.mjs +2 -30
  13. package/es/ActionIconGroup/ActionIconGroup.mjs.map +1 -1
  14. package/es/ActionIconGroup/style.mjs +39 -10
  15. package/es/ActionIconGroup/style.mjs.map +1 -1
  16. package/es/Alert/Alert.d.mts +2 -2
  17. package/es/Alert/Alert.mjs +17 -60
  18. package/es/Alert/Alert.mjs.map +1 -1
  19. package/es/Alert/style.mjs +318 -82
  20. package/es/Alert/style.mjs.map +1 -1
  21. package/es/AutoComplete/Select.d.mts +2 -2
  22. package/es/AutoComplete/Select.mjs +7 -21
  23. package/es/AutoComplete/Select.mjs.map +1 -1
  24. package/es/AutoComplete/style.mjs +32 -15
  25. package/es/AutoComplete/style.mjs.map +1 -1
  26. package/es/Avatar/Avatar.mjs +12 -24
  27. package/es/Avatar/Avatar.mjs.map +1 -1
  28. package/es/Avatar/AvatarGroup/index.d.mts +2 -2
  29. package/es/Avatar/AvatarGroup/index.mjs +3 -3
  30. package/es/Avatar/AvatarGroup/index.mjs.map +1 -1
  31. package/es/Avatar/AvatarGroup/style.mjs +9 -8
  32. package/es/Avatar/AvatarGroup/style.mjs.map +1 -1
  33. package/es/Avatar/style.mjs +30 -10
  34. package/es/Avatar/style.mjs.map +1 -1
  35. package/es/Block/Block.mjs +3 -48
  36. package/es/Block/Block.mjs.map +1 -1
  37. package/es/Block/style.mjs +58 -12
  38. package/es/Block/style.mjs.map +1 -1
  39. package/es/Burger/Burger.d.mts +2 -2
  40. package/es/Burger/Burger.mjs +21 -8
  41. package/es/Burger/Burger.mjs.map +1 -1
  42. package/es/Burger/style.mjs +115 -96
  43. package/es/Burger/style.mjs.map +1 -1
  44. package/es/Button/Button.mjs +6 -21
  45. package/es/Button/Button.mjs.map +1 -1
  46. package/es/Button/style.mjs +25 -7
  47. package/es/Button/style.mjs.map +1 -1
  48. package/es/Checkbox/Checkbox.mjs +2 -2
  49. package/es/Checkbox/Checkbox.mjs.map +1 -1
  50. package/es/Checkbox/style.mjs +12 -13
  51. package/es/Checkbox/style.mjs.map +1 -1
  52. package/es/CodeEditor/CodeEditor.d.mts +2 -2
  53. package/es/CodeEditor/CodeEditor.mjs +5 -13
  54. package/es/CodeEditor/CodeEditor.mjs.map +1 -1
  55. package/es/CodeEditor/style.mjs +21 -12
  56. package/es/CodeEditor/style.mjs.map +1 -1
  57. package/es/Collapse/Collapse.d.mts +2 -2
  58. package/es/Collapse/Collapse.mjs +4 -29
  59. package/es/Collapse/Collapse.mjs.map +1 -1
  60. package/es/Collapse/style.mjs +78 -18
  61. package/es/Collapse/style.mjs.map +1 -1
  62. package/es/ColorSwatches/ColorSwatches.mjs +20 -14
  63. package/es/ColorSwatches/ColorSwatches.mjs.map +1 -1
  64. package/es/ColorSwatches/style.mjs +35 -34
  65. package/es/ColorSwatches/style.mjs.map +1 -1
  66. package/es/ConfigProvider/index.d.mts +2 -2
  67. package/es/CopyButton/CopyButton.d.mts +2 -2
  68. package/es/DatePicker/DatePicker.d.mts +2 -2
  69. package/es/DatePicker/DatePicker.mjs +7 -21
  70. package/es/DatePicker/DatePicker.mjs.map +1 -1
  71. package/es/DatePicker/style.mjs +24 -7
  72. package/es/DatePicker/style.mjs.map +1 -1
  73. package/es/DraggablePanel/DraggablePanel.mjs +19 -62
  74. package/es/DraggablePanel/DraggablePanel.mjs.map +1 -1
  75. package/es/DraggablePanel/components/DraggablePanelBody.d.mts +2 -2
  76. package/es/DraggablePanel/components/DraggablePanelBody.mjs +2 -2
  77. package/es/DraggablePanel/components/DraggablePanelBody.mjs.map +1 -1
  78. package/es/DraggablePanel/components/DraggablePanelContainer.d.mts +2 -2
  79. package/es/DraggablePanel/components/DraggablePanelContainer.mjs +2 -2
  80. package/es/DraggablePanel/components/DraggablePanelContainer.mjs.map +1 -1
  81. package/es/DraggablePanel/components/DraggablePanelFooter.d.mts +2 -2
  82. package/es/DraggablePanel/components/DraggablePanelFooter.mjs +2 -2
  83. package/es/DraggablePanel/components/DraggablePanelFooter.mjs.map +1 -1
  84. package/es/DraggablePanel/components/DraggablePanelHeader.d.mts +2 -2
  85. package/es/DraggablePanel/components/DraggablePanelHeader.mjs +2 -2
  86. package/es/DraggablePanel/components/DraggablePanelHeader.mjs.map +1 -1
  87. package/es/DraggablePanel/components/style.mjs +6 -6
  88. package/es/DraggablePanel/components/style.mjs.map +1 -1
  89. package/es/DraggablePanel/style.mjs +336 -194
  90. package/es/DraggablePanel/style.mjs.map +1 -1
  91. package/es/DraggableSideNav/DraggableSideNav.d.mts +2 -2
  92. package/es/DraggableSideNav/DraggableSideNav.mjs +11 -8
  93. package/es/DraggableSideNav/DraggableSideNav.mjs.map +1 -1
  94. package/es/DraggableSideNav/style.mjs +192 -181
  95. package/es/DraggableSideNav/style.mjs.map +1 -1
  96. package/es/Drawer/Drawer.d.mts +2 -2
  97. package/es/Drawer/Drawer.mjs +11 -13
  98. package/es/Drawer/Drawer.mjs.map +1 -1
  99. package/es/Dropdown/Dropdown.d.mts +2 -2
  100. package/es/EditableText/EditableText.d.mts +2 -2
  101. package/es/EditableText/EditableText.mjs +1 -1
  102. package/es/EmojiPicker/AvatarUploader.mjs +3 -4
  103. package/es/EmojiPicker/AvatarUploader.mjs.map +1 -1
  104. package/es/EmojiPicker/EmojiPicker.d.mts +2 -2
  105. package/es/EmojiPicker/EmojiPicker.mjs +11 -4
  106. package/es/EmojiPicker/EmojiPicker.mjs.map +1 -1
  107. package/es/EmojiPicker/style.mjs +9 -9
  108. package/es/EmojiPicker/style.mjs.map +1 -1
  109. package/es/Empty/Empty.mjs +4 -4
  110. package/es/Empty/Empty.mjs.map +1 -1
  111. package/es/FileTypeIcon/FileTypeIcon.mjs +5 -6
  112. package/es/FileTypeIcon/FileTypeIcon.mjs.map +1 -1
  113. package/es/FileTypeIcon/components/FileIcon.mjs +5 -5
  114. package/es/FileTypeIcon/components/FileIcon.mjs.map +1 -1
  115. package/es/FileTypeIcon/components/FolderIcon.mjs +4 -4
  116. package/es/FileTypeIcon/components/FolderIcon.mjs.map +1 -1
  117. package/es/FileTypeIcon/style.mjs +3 -3
  118. package/es/FileTypeIcon/style.mjs.map +1 -1
  119. package/es/Flex/FlexBasic.d.mts +2 -2
  120. package/es/FluentEmoji/FluentEmoji.mjs +2 -2
  121. package/es/FluentEmoji/FluentEmoji.mjs.map +1 -1
  122. package/es/FluentEmoji/style.mjs +3 -3
  123. package/es/FluentEmoji/style.mjs.map +1 -1
  124. package/es/FontLoader/index.d.mts +2 -2
  125. package/es/Footer/Footer.d.mts +2 -2
  126. package/es/Footer/Footer.mjs +10 -8
  127. package/es/Footer/Footer.mjs.map +1 -1
  128. package/es/Footer/style.mjs +169 -133
  129. package/es/Footer/style.mjs.map +1 -1
  130. package/es/Form/Form.mjs +4 -14
  131. package/es/Form/Form.mjs.map +1 -1
  132. package/es/Form/components/FormDivider.mjs +3 -4
  133. package/es/Form/components/FormDivider.mjs.map +1 -1
  134. package/es/Form/components/FormFlatGroup.mjs +4 -14
  135. package/es/Form/components/FormFlatGroup.mjs.map +1 -1
  136. package/es/Form/components/FormGroup.d.mts +2 -2
  137. package/es/Form/components/FormGroup.mjs +5 -13
  138. package/es/Form/components/FormGroup.mjs.map +1 -1
  139. package/es/Form/components/FormItem.d.mts +2 -2
  140. package/es/Form/components/FormItem.mjs +12 -27
  141. package/es/Form/components/FormItem.mjs.map +1 -1
  142. package/es/Form/components/FormSubmitFooter.d.mts +2 -2
  143. package/es/Form/components/FormSubmitFooter.mjs +5 -4
  144. package/es/Form/components/FormSubmitFooter.mjs.map +1 -1
  145. package/es/Form/components/FormTitle.mjs +5 -5
  146. package/es/Form/components/FormTitle.mjs.map +1 -1
  147. package/es/Form/style.mjs +120 -72
  148. package/es/Form/style.mjs.map +1 -1
  149. package/es/FormModal/FormModal.d.mts +2 -2
  150. package/es/FormModal/FormModal.mjs +7 -8
  151. package/es/FormModal/FormModal.mjs.map +1 -1
  152. package/es/FormModal/style.mjs +7 -7
  153. package/es/FormModal/style.mjs.map +1 -1
  154. package/es/Grid/Grid.mjs +17 -4
  155. package/es/Grid/Grid.mjs.map +1 -1
  156. package/es/Grid/style.mjs +15 -16
  157. package/es/Grid/style.mjs.map +1 -1
  158. package/es/GroupAvatar/GroupAvatar.mjs +2 -14
  159. package/es/GroupAvatar/GroupAvatar.mjs.map +1 -1
  160. package/es/GroupAvatar/style.mjs +27 -16
  161. package/es/GroupAvatar/style.mjs.map +1 -1
  162. package/es/GuideCard/GuideCard.d.mts +2 -2
  163. package/es/GuideCard/GuideCard.mjs +5 -21
  164. package/es/GuideCard/GuideCard.mjs.map +1 -1
  165. package/es/GuideCard/style.mjs +57 -15
  166. package/es/GuideCard/style.mjs.map +1 -1
  167. package/es/Header/Header.d.mts +2 -2
  168. package/es/Header/Header.mjs +6 -7
  169. package/es/Header/Header.mjs.map +1 -1
  170. package/es/Header/style.mjs +8 -10
  171. package/es/Header/style.mjs.map +1 -1
  172. package/es/Highlighter/FullFeatured.mjs +2 -40
  173. package/es/Highlighter/FullFeatured.mjs.map +1 -1
  174. package/es/Highlighter/Highlighter.d.mts +2 -2
  175. package/es/Highlighter/Highlighter.mjs +2 -25
  176. package/es/Highlighter/Highlighter.mjs.map +1 -1
  177. package/es/Highlighter/SyntaxHighlighter/StaticRenderer.mjs +1 -1
  178. package/es/Highlighter/SyntaxHighlighter/StaticRenderer.mjs.map +1 -1
  179. package/es/Highlighter/SyntaxHighlighter/StreamRenderer.mjs +11 -31
  180. package/es/Highlighter/SyntaxHighlighter/StreamRenderer.mjs.map +1 -1
  181. package/es/Highlighter/SyntaxHighlighter/index.d.mts +2 -2
  182. package/es/Highlighter/SyntaxHighlighter/index.mjs +3 -31
  183. package/es/Highlighter/SyntaxHighlighter/index.mjs.map +1 -1
  184. package/es/Highlighter/SyntaxHighlighter/style.mjs +43 -16
  185. package/es/Highlighter/SyntaxHighlighter/style.mjs.map +1 -1
  186. package/es/Highlighter/style.mjs +64 -25
  187. package/es/Highlighter/style.mjs.map +1 -1
  188. package/es/Highlighter/theme/lobe-theme.mjs +370 -0
  189. package/es/Highlighter/theme/lobe-theme.mjs.map +1 -0
  190. package/es/Hotkey/Hotkey.d.mts +2 -2
  191. package/es/Hotkey/Hotkey.mjs +5 -20
  192. package/es/Hotkey/Hotkey.mjs.map +1 -1
  193. package/es/Hotkey/style.mjs +53 -17
  194. package/es/Hotkey/style.mjs.map +1 -1
  195. package/es/HotkeyInput/HotkeyInput.d.mts +2 -2
  196. package/es/HotkeyInput/HotkeyInput.mjs +5 -36
  197. package/es/HotkeyInput/HotkeyInput.mjs.map +1 -1
  198. package/es/HotkeyInput/style.mjs +46 -14
  199. package/es/HotkeyInput/style.mjs.map +1 -1
  200. package/es/Icon/Icon.d.mts +2 -2
  201. package/es/Icon/Icon.mjs +2 -10
  202. package/es/Icon/Icon.mjs.map +1 -1
  203. package/es/Icon/components/IconProvider.d.mts +3 -3
  204. package/es/Icon/style.mjs +15 -6
  205. package/es/Icon/style.mjs.map +1 -1
  206. package/es/Image/Image.mjs +8 -15
  207. package/es/Image/Image.mjs.map +1 -1
  208. package/es/Image/PreviewGroup.d.mts +2 -2
  209. package/es/Image/components/Toolbar.mjs +1 -2
  210. package/es/Image/components/Toolbar.mjs.map +1 -1
  211. package/es/Image/components/usePreview.mjs +2 -2
  212. package/es/Image/components/usePreview.mjs.map +1 -1
  213. package/es/Image/components/usePreviewGroup.mjs +4 -4
  214. package/es/Image/components/usePreviewGroup.mjs.map +1 -1
  215. package/es/Image/style.mjs +79 -54
  216. package/es/Image/style.mjs.map +1 -1
  217. package/es/ImageSelect/ImageSelect.mjs +2 -2
  218. package/es/ImageSelect/ImageSelect.mjs.map +1 -1
  219. package/es/ImageSelect/styles.mjs +11 -10
  220. package/es/ImageSelect/styles.mjs.map +1 -1
  221. package/es/Input/Input.d.mts +2 -2
  222. package/es/Input/Input.mjs +7 -21
  223. package/es/Input/Input.mjs.map +1 -1
  224. package/es/Input/InputNumber.d.mts +2 -2
  225. package/es/Input/InputNumber.mjs +7 -21
  226. package/es/Input/InputNumber.mjs.map +1 -1
  227. package/es/Input/InputOPT.d.mts +2 -2
  228. package/es/Input/InputOPT.mjs +7 -22
  229. package/es/Input/InputOPT.mjs.map +1 -1
  230. package/es/Input/InputPassword.d.mts +2 -2
  231. package/es/Input/InputPassword.mjs +6 -21
  232. package/es/Input/InputPassword.mjs.map +1 -1
  233. package/es/Input/TextArea.d.mts +2 -2
  234. package/es/Input/TextArea.mjs +6 -21
  235. package/es/Input/TextArea.mjs.map +1 -1
  236. package/es/Input/style.mjs +57 -25
  237. package/es/Input/style.mjs.map +1 -1
  238. package/es/Layout/Layout.mjs +36 -33
  239. package/es/Layout/Layout.mjs.map +1 -1
  240. package/es/Layout/components/LayoutFooter.d.mts +2 -2
  241. package/es/Layout/components/LayoutFooter.mjs +2 -2
  242. package/es/Layout/components/LayoutFooter.mjs.map +1 -1
  243. package/es/Layout/components/LayoutHeader.d.mts +2 -2
  244. package/es/Layout/components/LayoutHeader.mjs +2 -2
  245. package/es/Layout/components/LayoutHeader.mjs.map +1 -1
  246. package/es/Layout/components/LayoutMain.d.mts +2 -2
  247. package/es/Layout/components/LayoutMain.mjs +2 -2
  248. package/es/Layout/components/LayoutMain.mjs.map +1 -1
  249. package/es/Layout/components/LayoutSidebar.d.mts +2 -2
  250. package/es/Layout/components/LayoutSidebar.mjs +3 -3
  251. package/es/Layout/components/LayoutSidebar.mjs.map +1 -1
  252. package/es/Layout/components/LayoutSidebarInner.d.mts +2 -2
  253. package/es/Layout/components/LayoutSidebarInner.mjs +2 -2
  254. package/es/Layout/components/LayoutSidebarInner.mjs.map +1 -1
  255. package/es/Layout/components/LayoutToc.d.mts +2 -2
  256. package/es/Layout/components/LayoutToc.mjs +2 -2
  257. package/es/Layout/components/LayoutToc.mjs.map +1 -1
  258. package/es/Layout/style.mjs +6 -5
  259. package/es/Layout/style.mjs.map +1 -1
  260. package/es/List/ListItem/index.d.mts +2 -2
  261. package/es/List/ListItem/index.mjs +2 -2
  262. package/es/List/ListItem/index.mjs.map +1 -1
  263. package/es/List/ListItem/style.mjs +12 -11
  264. package/es/List/ListItem/style.mjs.map +1 -1
  265. package/es/Markdown/Markdown.d.mts +2 -2
  266. package/es/Markdown/Markdown.mjs +3 -25
  267. package/es/Markdown/Markdown.mjs.map +1 -1
  268. package/es/Markdown/SyntaxMarkdown/StreamdownRender.mjs +1 -2
  269. package/es/Markdown/SyntaxMarkdown/StreamdownRender.mjs.map +1 -1
  270. package/es/Markdown/SyntaxMarkdown/style.mjs +3 -3
  271. package/es/Markdown/SyntaxMarkdown/style.mjs.map +1 -1
  272. package/es/Markdown/Typography.d.mts +2 -2
  273. package/es/Markdown/Typography.mjs +2 -2
  274. package/es/Markdown/Typography.mjs.map +1 -1
  275. package/es/Markdown/components/CodeBlock.mjs +1 -0
  276. package/es/Markdown/components/CodeBlock.mjs.map +1 -1
  277. package/es/Markdown/components/SearchResultCards/SearchResultCard.mjs +1 -2
  278. package/es/Markdown/components/SearchResultCards/SearchResultCard.mjs.map +1 -1
  279. package/es/Markdown/components/SearchResultCards/index.d.mts +2 -2
  280. package/es/Markdown/components/SearchResultCards/style.mjs +3 -3
  281. package/es/Markdown/components/SearchResultCards/style.mjs.map +1 -1
  282. package/es/Markdown/markdown.style.mjs +23 -23
  283. package/es/Markdown/markdown.style.mjs.map +1 -1
  284. package/es/Markdown/style.mjs +48 -26
  285. package/es/Markdown/style.mjs.map +1 -1
  286. package/es/MaskShadow/MaskShadow.d.mts +2 -2
  287. package/es/MaskShadow/MaskShadow.mjs +8 -12
  288. package/es/MaskShadow/MaskShadow.mjs.map +1 -1
  289. package/es/MaskShadow/style.mjs +33 -8
  290. package/es/MaskShadow/style.mjs.map +1 -1
  291. package/es/Menu/Menu.d.mts +2 -2
  292. package/es/Menu/Menu.mjs +3 -25
  293. package/es/Menu/Menu.mjs.map +1 -1
  294. package/es/Menu/style.mjs +40 -15
  295. package/es/Menu/style.mjs.map +1 -1
  296. package/es/Mermaid/FullFeatured.mjs +2 -35
  297. package/es/Mermaid/FullFeatured.mjs.map +1 -1
  298. package/es/Mermaid/Mermaid.d.mts +2 -2
  299. package/es/Mermaid/Mermaid.mjs +5 -28
  300. package/es/Mermaid/Mermaid.mjs.map +1 -1
  301. package/es/Mermaid/SyntaxMermaid/StaticMermaid.mjs +82 -0
  302. package/es/Mermaid/SyntaxMermaid/StaticMermaid.mjs.map +1 -0
  303. package/es/Mermaid/SyntaxMermaid/StreamMermaid.mjs +94 -0
  304. package/es/Mermaid/SyntaxMermaid/StreamMermaid.mjs.map +1 -0
  305. package/es/Mermaid/SyntaxMermaid/index.d.mts +2 -2
  306. package/es/Mermaid/SyntaxMermaid/index.mjs +36 -58
  307. package/es/Mermaid/SyntaxMermaid/index.mjs.map +1 -1
  308. package/es/Mermaid/SyntaxMermaid/style.mjs +80 -0
  309. package/es/Mermaid/SyntaxMermaid/style.mjs.map +1 -0
  310. package/es/Mermaid/type.d.mts +3 -2
  311. package/es/Modal/Modal.d.mts +2 -2
  312. package/es/Modal/Modal.mjs +8 -9
  313. package/es/Modal/Modal.mjs.map +1 -1
  314. package/es/Modal/style.mjs +13 -11
  315. package/es/Modal/style.mjs.map +1 -1
  316. package/es/MotionProvider/index.d.mts +2 -2
  317. package/es/ScrollShadow/ScrollShadow.mjs +20 -43
  318. package/es/ScrollShadow/ScrollShadow.mjs.map +1 -1
  319. package/es/ScrollShadow/style.mjs +54 -12
  320. package/es/ScrollShadow/style.mjs.map +1 -1
  321. package/es/SearchBar/SearchBar.d.mts +2 -2
  322. package/es/SearchBar/SearchBar.mjs +2 -2
  323. package/es/SearchBar/SearchBar.mjs.map +1 -1
  324. package/es/SearchBar/style.mjs +7 -6
  325. package/es/SearchBar/style.mjs.map +1 -1
  326. package/es/Segmented/Segmented.d.mts +2 -2
  327. package/es/Segmented/Segmented.mjs +4 -26
  328. package/es/Segmented/Segmented.mjs.map +1 -1
  329. package/es/Segmented/style.mjs +33 -9
  330. package/es/Segmented/style.mjs.map +1 -1
  331. package/es/Select/Select.d.mts +2 -2
  332. package/es/Select/Select.mjs +7 -21
  333. package/es/Select/Select.mjs.map +1 -1
  334. package/es/Select/style.mjs +36 -19
  335. package/es/Select/style.mjs.map +1 -1
  336. package/es/SideNav/SideNav.d.mts +2 -2
  337. package/es/SideNav/SideNav.mjs +2 -2
  338. package/es/SideNav/SideNav.mjs.map +1 -1
  339. package/es/SideNav/style.mjs +5 -5
  340. package/es/SideNav/style.mjs.map +1 -1
  341. package/es/Skeleton/Skeleton.mjs +2 -2
  342. package/es/Skeleton/Skeleton.mjs.map +1 -1
  343. package/es/Skeleton/SkeletonAvatar.mjs +3 -3
  344. package/es/Skeleton/SkeletonAvatar.mjs.map +1 -1
  345. package/es/Skeleton/SkeletonBlock.mjs +2 -2
  346. package/es/Skeleton/SkeletonBlock.mjs.map +1 -1
  347. package/es/Skeleton/SkeletonButton.mjs +5 -6
  348. package/es/Skeleton/SkeletonButton.mjs.map +1 -1
  349. package/es/Skeleton/SkeletonTags.mjs +5 -5
  350. package/es/Skeleton/SkeletonTags.mjs.map +1 -1
  351. package/es/Skeleton/SkeletonTitle.mjs +2 -2
  352. package/es/Skeleton/SkeletonTitle.mjs.map +1 -1
  353. package/es/Skeleton/style.mjs +7 -8
  354. package/es/Skeleton/style.mjs.map +1 -1
  355. package/es/SliderWithInput/SliderWithInput.d.mts +2 -2
  356. package/es/Snippet/Snippet.mjs +2 -21
  357. package/es/Snippet/Snippet.mjs.map +1 -1
  358. package/es/Snippet/style.mjs +27 -9
  359. package/es/Snippet/style.mjs.map +1 -1
  360. package/es/SortableList/SortableList.mjs +1 -2
  361. package/es/SortableList/SortableList.mjs.map +1 -1
  362. package/es/SortableList/components/DragHandle.d.mts +2 -2
  363. package/es/SortableList/components/SortableItem.d.mts +2 -2
  364. package/es/SortableList/components/SortableItem.mjs +3 -22
  365. package/es/SortableList/components/SortableItem.mjs.map +1 -1
  366. package/es/SortableList/style.mjs +24 -7
  367. package/es/SortableList/style.mjs.map +1 -1
  368. package/es/Tabs/Tabs.mjs +3 -26
  369. package/es/Tabs/Tabs.mjs.map +1 -1
  370. package/es/Tabs/style.mjs +34 -10
  371. package/es/Tabs/style.mjs.map +1 -1
  372. package/es/Tag/Tag.mjs +3 -21
  373. package/es/Tag/Tag.mjs.map +1 -1
  374. package/es/Tag/styles.mjs +36 -10
  375. package/es/Tag/styles.mjs.map +1 -1
  376. package/es/Text/Text.mjs +2 -35
  377. package/es/Text/Text.mjs.map +1 -1
  378. package/es/Text/styles.mjs +49 -17
  379. package/es/Text/styles.mjs.map +1 -1
  380. package/es/ThemeProvider/ConfigProvider.mjs +11 -12
  381. package/es/ThemeProvider/ConfigProvider.mjs.map +1 -1
  382. package/es/ThemeProvider/ThemeProvider.d.mts +2 -2
  383. package/es/ThemeProvider/ThemeProvider.mjs +1 -1
  384. package/es/Toc/Toc.d.mts +2 -2
  385. package/es/Toc/Toc.mjs +8 -6
  386. package/es/Toc/Toc.mjs.map +1 -1
  387. package/es/Toc/TocMobile.mjs +1 -5
  388. package/es/Toc/TocMobile.mjs.map +1 -1
  389. package/es/Toc/style.mjs +52 -52
  390. package/es/Toc/style.mjs.map +1 -1
  391. package/es/Tooltip/TooltipFloating.mjs +2 -2
  392. package/es/Tooltip/TooltipFloating.mjs.map +1 -1
  393. package/es/Tooltip/TooltipPortal.mjs +3 -1
  394. package/es/Tooltip/TooltipPortal.mjs.map +1 -1
  395. package/es/Tooltip/style.mjs +7 -7
  396. package/es/Tooltip/style.mjs.map +1 -1
  397. package/es/Video/index.d.mts +2 -2
  398. package/es/Video/index.mjs +13 -13
  399. package/es/Video/index.mjs.map +1 -1
  400. package/es/Video/style.mjs +49 -42
  401. package/es/Video/style.mjs.map +1 -1
  402. package/es/awesome/AuroraBackground/AuroraBackground.d.mts +2 -2
  403. package/es/awesome/AuroraBackground/AuroraBackground.mjs +4 -3
  404. package/es/awesome/AuroraBackground/AuroraBackground.mjs.map +1 -1
  405. package/es/awesome/AuroraBackground/style.mjs +129 -90
  406. package/es/awesome/AuroraBackground/style.mjs.map +1 -1
  407. package/es/awesome/BottomGradientButton/BottomGradientButton.d.mts +2 -2
  408. package/es/awesome/BottomGradientButton/BottomGradientButton.mjs +2 -2
  409. package/es/awesome/BottomGradientButton/BottomGradientButton.mjs.map +1 -1
  410. package/es/awesome/BottomGradientButton/style.mjs +6 -5
  411. package/es/awesome/BottomGradientButton/style.mjs.map +1 -1
  412. package/es/awesome/Features/FeatureItem.mjs +10 -7
  413. package/es/awesome/Features/FeatureItem.mjs.map +1 -1
  414. package/es/awesome/Features/Features.d.mts +2 -2
  415. package/es/awesome/Features/style.mjs +141 -90
  416. package/es/awesome/Features/style.mjs.map +1 -1
  417. package/es/awesome/Giscus/Giscus.d.mts +2 -2
  418. package/es/awesome/GradientButton/GradientButton.d.mts +2 -2
  419. package/es/awesome/GradientButton/GradientButton.mjs +26 -5
  420. package/es/awesome/GradientButton/GradientButton.mjs.map +1 -1
  421. package/es/awesome/GradientButton/style.mjs +93 -63
  422. package/es/awesome/GradientButton/style.mjs.map +1 -1
  423. package/es/awesome/GridBackground/GridBackground.d.mts +2 -2
  424. package/es/awesome/GridBackground/GridBackground.mjs +30 -9
  425. package/es/awesome/GridBackground/GridBackground.mjs.map +1 -1
  426. package/es/awesome/GridBackground/GridShowcase.d.mts +2 -2
  427. package/es/awesome/GridBackground/style.mjs +70 -62
  428. package/es/awesome/GridBackground/style.mjs.map +1 -1
  429. package/es/awesome/Hero/Hero.d.mts +2 -2
  430. package/es/awesome/Hero/Hero.mjs +1 -2
  431. package/es/awesome/Hero/Hero.mjs.map +1 -1
  432. package/es/awesome/Hero/style.mjs +11 -10
  433. package/es/awesome/Hero/style.mjs.map +1 -1
  434. package/es/awesome/Spline/ParentSize.mjs +1 -1
  435. package/es/awesome/Spline/Spine.d.mts +2 -2
  436. package/es/awesome/Spotlight/Spotlight.d.mts +2 -2
  437. package/es/awesome/Spotlight/Spotlight.mjs +15 -7
  438. package/es/awesome/Spotlight/Spotlight.mjs.map +1 -1
  439. package/es/awesome/Spotlight/style.mjs +76 -23
  440. package/es/awesome/Spotlight/style.mjs.map +1 -1
  441. package/es/awesome/SpotlightCard/SpotlightCard.d.mts +2 -2
  442. package/es/awesome/SpotlightCard/SpotlightCard.mjs +11 -7
  443. package/es/awesome/SpotlightCard/SpotlightCard.mjs.map +1 -1
  444. package/es/awesome/SpotlightCard/SpotlightCardItem.mjs +10 -7
  445. package/es/awesome/SpotlightCard/SpotlightCardItem.mjs.map +1 -1
  446. package/es/awesome/SpotlightCard/style.mjs +121 -69
  447. package/es/awesome/SpotlightCard/style.mjs.map +1 -1
  448. package/es/awesome/TypewriterEffect/TypewriterEffect.d.mts +2 -2
  449. package/es/awesome/TypewriterEffect/TypewriterEffect.mjs +6 -5
  450. package/es/awesome/TypewriterEffect/TypewriterEffect.mjs.map +1 -1
  451. package/es/awesome/TypewriterEffect/style.mjs +8 -8
  452. package/es/awesome/TypewriterEffect/style.mjs.map +1 -1
  453. package/es/brand/BrandLoading/{style-Cz42xGgB.css → style-DX648z7a.css} +1 -1
  454. package/es/brand/BrandLoading/{style-Cz42xGgB.css.map → style-DX648z7a.css.map} +1 -1
  455. package/es/brand/LobeChat/index.d.mts +2 -2
  456. package/es/brand/LobeChat/index.mjs +5 -7
  457. package/es/brand/LobeChat/index.mjs.map +1 -1
  458. package/es/brand/LobeHub/index.d.mts +2 -2
  459. package/es/brand/LobeHub/index.mjs +5 -7
  460. package/es/brand/LobeHub/index.mjs.map +1 -1
  461. package/es/brand/LobeHub/style.mjs +3 -3
  462. package/es/brand/LobeHub/style.mjs.map +1 -1
  463. package/es/brand/LogoFlat/index.d.mts +3 -6
  464. package/es/brand/LogoFlat/index.mjs +2 -76
  465. package/es/brand/LogoFlat/index.mjs.map +1 -1
  466. package/es/brand/LogoMono/index.d.mts +2 -10
  467. package/es/brand/LogoMono/index.mjs +2 -84
  468. package/es/brand/LogoThree/LogoSpline.d.mts +2 -2
  469. package/es/brand/LogoThree/index.d.mts +2 -2
  470. package/es/brand/index.d.mts +3 -3
  471. package/es/brand/index.mjs +2 -2
  472. package/es/chat/BackBottom/BackBottom.d.mts +2 -2
  473. package/es/chat/BackBottom/BackBottom.mjs +3 -3
  474. package/es/chat/BackBottom/BackBottom.mjs.map +1 -1
  475. package/es/chat/BackBottom/style.mjs +27 -8
  476. package/es/chat/BackBottom/style.mjs.map +1 -1
  477. package/es/chat/ChatHeader/ChatHeader.mjs +2 -2
  478. package/es/chat/ChatHeader/ChatHeader.mjs.map +1 -1
  479. package/es/chat/ChatHeader/ChatHeaderTitle.mjs +8 -9
  480. package/es/chat/ChatHeader/ChatHeaderTitle.mjs.map +1 -1
  481. package/es/chat/ChatHeader/style.mjs +7 -7
  482. package/es/chat/ChatHeader/style.mjs.map +1 -1
  483. package/es/chat/ChatInputArea/ChatInputArea.mjs +1 -2
  484. package/es/chat/ChatInputArea/ChatInputArea.mjs.map +1 -1
  485. package/es/chat/ChatInputArea/components/ChatInputActionBar.mjs +4 -5
  486. package/es/chat/ChatInputArea/components/ChatInputActionBar.mjs.map +1 -1
  487. package/es/chat/ChatInputArea/components/ChatInputAreaInner.d.mts +2 -2
  488. package/es/chat/ChatInputArea/components/ChatSendButton.mjs +2 -3
  489. package/es/chat/ChatInputArea/components/ChatSendButton.mjs.map +1 -1
  490. package/es/chat/ChatInputArea/style.mjs +6 -5
  491. package/es/chat/ChatInputArea/style.mjs.map +1 -1
  492. package/es/chat/ChatItem/ChatItem.d.mts +2 -2
  493. package/es/chat/ChatItem/ChatItem.mjs +19 -16
  494. package/es/chat/ChatItem/ChatItem.mjs.map +1 -1
  495. package/es/chat/ChatItem/components/Actions.mjs +8 -8
  496. package/es/chat/ChatItem/components/Actions.mjs.map +1 -1
  497. package/es/chat/ChatItem/components/Avatar.mjs +7 -3
  498. package/es/chat/ChatItem/components/Avatar.mjs.map +1 -1
  499. package/es/chat/ChatItem/components/ErrorContent.mjs +2 -3
  500. package/es/chat/ChatItem/components/ErrorContent.mjs.map +1 -1
  501. package/es/chat/ChatItem/components/Loading.mjs +3 -4
  502. package/es/chat/ChatItem/components/Loading.mjs.map +1 -1
  503. package/es/chat/ChatItem/components/MessageContent.mjs +11 -10
  504. package/es/chat/ChatItem/components/MessageContent.mjs.map +1 -1
  505. package/es/chat/ChatItem/components/Title.mjs +3 -8
  506. package/es/chat/ChatItem/components/Title.mjs.map +1 -1
  507. package/es/chat/ChatItem/style.mjs +294 -142
  508. package/es/chat/ChatItem/style.mjs.map +1 -1
  509. package/es/chat/ChatList/ChatList.d.mts +2 -2
  510. package/es/chat/ChatList/ChatList.mjs +2 -2
  511. package/es/chat/ChatList/ChatList.mjs.map +1 -1
  512. package/es/chat/ChatList/style.mjs +3 -3
  513. package/es/chat/ChatList/style.mjs.map +1 -1
  514. package/es/chat/EditableMessage/EditableMessage.d.mts +2 -2
  515. package/es/chat/EditableMessage/EditableMessage.mjs +1 -1
  516. package/es/chat/EditableMessageList/EditableMessageList.d.mts +2 -2
  517. package/es/chat/LoadingDots/LoadingDots.mjs +17 -10
  518. package/es/chat/LoadingDots/LoadingDots.mjs.map +1 -1
  519. package/es/chat/LoadingDots/style.mjs +117 -116
  520. package/es/chat/LoadingDots/style.mjs.map +1 -1
  521. package/es/chat/LoadingDots/type.d.mts +6 -0
  522. package/es/chat/MessageInput/MessageInput.d.mts +2 -2
  523. package/es/chat/MessageInput/MessageInput.mjs +4 -5
  524. package/es/chat/MessageInput/MessageInput.mjs.map +1 -1
  525. package/es/chat/MessageInput/style.mjs +4 -4
  526. package/es/chat/MessageInput/style.mjs.map +1 -1
  527. package/es/chat/MessageModal/MessageModal.d.mts +2 -2
  528. package/es/chat/MessageModal/MessageModal.mjs +4 -5
  529. package/es/chat/MessageModal/MessageModal.mjs.map +1 -1
  530. package/es/chat/TokenTag/TokenTag.mjs +5 -6
  531. package/es/chat/TokenTag/TokenTag.mjs.map +1 -1
  532. package/es/color/ColorScales/ScaleRow.mjs +1 -2
  533. package/es/color/ColorScales/ScaleRow.mjs.map +1 -1
  534. package/es/color/ColorScales/index.d.mts +2 -2
  535. package/es/color/ColorScales/index.mjs +1 -2
  536. package/es/color/ColorScales/index.mjs.map +1 -1
  537. package/es/color/ColorScales/style.mjs +4 -4
  538. package/es/color/ColorScales/style.mjs.map +1 -1
  539. package/es/hooks/useHighlight.mjs +84 -227
  540. package/es/hooks/useHighlight.mjs.map +1 -1
  541. package/es/hooks/useMermaid.mjs +104 -57
  542. package/es/hooks/useMermaid.mjs.map +1 -1
  543. package/es/hooks/useStreamHighlight.mjs +221 -0
  544. package/es/hooks/useStreamHighlight.mjs.map +1 -0
  545. package/es/hooks/useStreamMermaid.mjs +87 -0
  546. package/es/hooks/useStreamMermaid.mjs.map +1 -0
  547. package/es/i18n/context.d.mts +2 -2
  548. package/es/icons/lucideExtra/BotPromptIcon.d.mts +2 -2
  549. package/es/icons/lucideExtra/CreateBotIcon.d.mts +2 -2
  550. package/es/icons/lucideExtra/DiscordIcon.d.mts +2 -2
  551. package/es/icons/lucideExtra/GlobeOffIcon.d.mts +3 -3
  552. package/es/icons/lucideExtra/GroupBotIcon.d.mts +3 -3
  553. package/es/icons/lucideExtra/GroupBotSquareIcon.d.mts +3 -3
  554. package/es/icons/lucideExtra/LeftClickIcon.d.mts +3 -3
  555. package/es/icons/lucideExtra/LeftDoubleClickIcon.d.mts +3 -3
  556. package/es/icons/lucideExtra/McpIcon.d.mts +3 -3
  557. package/es/icons/lucideExtra/ProviderIcon.d.mts +3 -3
  558. package/es/icons/lucideExtra/RightClickIcon.d.mts +3 -3
  559. package/es/icons/lucideExtra/RightDoubleClickIcon.d.mts +3 -3
  560. package/es/icons/lucideExtra/ShapesUploadIcon.d.mts +3 -3
  561. package/es/icons/lucideExtra/TreeDownRightIcon.d.mts +3 -3
  562. package/es/icons/lucideExtra/TreeUpDownRightIcon.d.mts +3 -3
  563. package/es/index.d.mts +2 -1
  564. package/es/index.mjs +9 -8
  565. package/es/mdx/Callout/index.mjs +8 -7
  566. package/es/mdx/Callout/index.mjs.map +1 -1
  567. package/es/mdx/Callout/style.mjs +3 -4
  568. package/es/mdx/Callout/style.mjs.map +1 -1
  569. package/es/mdx/Cards/Card.mjs +14 -16
  570. package/es/mdx/Cards/Card.mjs.map +1 -1
  571. package/es/mdx/Cards/index.mjs +2 -2
  572. package/es/mdx/Cards/index.mjs.map +1 -1
  573. package/es/mdx/Cards/style.mjs +3 -3
  574. package/es/mdx/Cards/style.mjs.map +1 -1
  575. package/es/mdx/FileTree/Folder.mjs +1 -16
  576. package/es/mdx/FileTree/Folder.mjs.map +1 -1
  577. package/es/mdx/FileTree/index.mjs +2 -2
  578. package/es/mdx/FileTree/index.mjs.map +1 -1
  579. package/es/mdx/FileTree/style.mjs +19 -7
  580. package/es/mdx/FileTree/style.mjs.map +1 -1
  581. package/es/mdx/Mdx/index.d.mts +2 -2
  582. package/es/mdx/Mdx/index.mjs +2 -2
  583. package/es/mdx/Mdx/index.mjs.map +1 -1
  584. package/es/mdx/Steps/index.mjs +2 -2
  585. package/es/mdx/Steps/index.mjs.map +1 -1
  586. package/es/mdx/Steps/style.mjs +8 -8
  587. package/es/mdx/Steps/style.mjs.map +1 -1
  588. package/es/mdx/Tabs/Tab.mjs +3 -12
  589. package/es/mdx/Tabs/Tab.mjs.map +1 -1
  590. package/es/mdx/Tabs/index.mjs +2 -2
  591. package/es/mdx/Tabs/index.mjs.map +1 -1
  592. package/es/mdx/Tabs/style.mjs +12 -14
  593. package/es/mdx/Tabs/style.mjs.map +1 -1
  594. package/es/mdx/mdxComponents/Citation/PopoverPanel.mjs +1 -22
  595. package/es/mdx/mdxComponents/Citation/PopoverPanel.mjs.map +1 -1
  596. package/es/mdx/mdxComponents/Citation/index.mjs +3 -17
  597. package/es/mdx/mdxComponents/Citation/index.mjs.map +1 -1
  598. package/es/mdx/mdxComponents/Citation/style.mjs +39 -0
  599. package/es/mdx/mdxComponents/Citation/style.mjs.map +1 -0
  600. package/es/mdx/mdxComponents/Pre.mjs +7 -9
  601. package/es/mdx/mdxComponents/Pre.mjs.map +1 -1
  602. package/es/mobile/ChatHeader/ChatHeader.mjs +2 -2
  603. package/es/mobile/ChatHeader/ChatHeader.mjs.map +1 -1
  604. package/es/mobile/ChatHeader/ChatHeaderTitle.d.mts +2 -2
  605. package/es/mobile/ChatHeader/ChatHeaderTitle.mjs +7 -8
  606. package/es/mobile/ChatHeader/ChatHeaderTitle.mjs.map +1 -1
  607. package/es/mobile/ChatHeader/style.mjs +6 -6
  608. package/es/mobile/ChatHeader/style.mjs.map +1 -1
  609. package/es/mobile/ChatInputArea/ChatInputArea.mjs +2 -2
  610. package/es/mobile/ChatInputArea/ChatInputArea.mjs.map +1 -1
  611. package/es/mobile/ChatInputArea/components/ChatSendButton.d.mts +2 -2
  612. package/es/mobile/ChatInputArea/style.mjs +5 -5
  613. package/es/mobile/ChatInputArea/style.mjs.map +1 -1
  614. package/es/mobile/SafeArea/SafeArea.mjs +2 -2
  615. package/es/mobile/SafeArea/SafeArea.mjs.map +1 -1
  616. package/es/mobile/SafeArea/style.mjs +3 -3
  617. package/es/mobile/SafeArea/style.mjs.map +1 -1
  618. package/es/mobile/TabBar/TabBar.mjs +2 -2
  619. package/es/mobile/TabBar/TabBar.mjs.map +1 -1
  620. package/es/mobile/TabBar/style.mjs +7 -7
  621. package/es/mobile/TabBar/style.mjs.map +1 -1
  622. package/es/storybook/StoryBook/index.d.mts +2 -2
  623. package/es/storybook/StoryBook/index.mjs +4 -5
  624. package/es/storybook/StoryBook/index.mjs.map +1 -1
  625. package/es/storybook/StoryBook/style.mjs +27 -24
  626. package/es/storybook/StoryBook/style.mjs.map +1 -1
  627. package/es/styles/index.d.mts +2 -1
  628. package/es/styles/index.mjs +2 -1
  629. package/es/styles/theme/customStylishStatic.d.mts +7 -0
  630. package/es/styles/theme/customStylishStatic.mjs +161 -0
  631. package/es/styles/theme/customStylishStatic.mjs.map +1 -0
  632. package/package.json +3 -2
  633. package/es/brand/LogoMono/index.mjs.map +0 -1
@@ -6,13 +6,13 @@ import Hotkey_default from "../Hotkey/Hotkey.mjs";
6
6
  import ActionIcon_default from "../ActionIcon/ActionIcon.mjs";
7
7
  import { useTranslation } from "../i18n/useTranslation.mjs";
8
8
  import hotkey_default from "../i18n/resources/en/hotkey.mjs";
9
- import { useStyles } from "./style.mjs";
9
+ import { styles, variants } from "./style.mjs";
10
10
  import { memo, useCallback, useEffect, useMemo, useRef, useState } from "react";
11
11
  import { jsx, jsxs } from "react/jsx-runtime";
12
+ import { cx, useThemeMode } from "antd-style";
12
13
  import useMergeState from "use-merge-value";
13
- import { cva } from "class-variance-authority";
14
- import { Undo2Icon } from "lucide-react";
15
14
  import { isEqual } from "es-toolkit/compat";
15
+ import { Undo2Icon } from "lucide-react";
16
16
  import { useHotkeys, useRecordHotkeys } from "react-hotkeys-hook";
17
17
 
18
18
  //#region src/HotkeyInput/HotkeyInput.tsx
@@ -21,7 +21,7 @@ const HotkeyInput = memo(({ value = "", defaultValue = "", resetValue = "", onCh
21
21
  const [hasConflict, setHasConflict] = useState(false);
22
22
  const [hasInvalidCombination, setHasInvalidCombination] = useState(false);
23
23
  const inputRef = useRef(null);
24
- const { cx, styles, theme } = useStyles();
24
+ const { isDarkMode } = useThemeMode();
25
25
  const { t } = useTranslation(hotkey_default);
26
26
  const isAppleDevice = useMemo(() => checkIsAppleDevice(isApple), [isApple]);
27
27
  const [hotkeyValue, setHotkeyValue] = useMergeState(defaultValue, {
@@ -29,37 +29,6 @@ const HotkeyInput = memo(({ value = "", defaultValue = "", resetValue = "", onCh
29
29
  onChange,
30
30
  value
31
31
  });
32
- const variants = useMemo(() => cva(styles.root, {
33
- defaultVariants: {
34
- disabled: false,
35
- error: false,
36
- shadow: false,
37
- variant: "outlined"
38
- },
39
- variants: {
40
- variant: {
41
- filled: styles.filled,
42
- outlined: styles.outlined,
43
- borderless: styles.borderless
44
- },
45
- shadow: {
46
- false: null,
47
- true: styles.shadow
48
- },
49
- focused: {
50
- false: null,
51
- true: styles.focused
52
- },
53
- error: {
54
- fales: null,
55
- true: styles.error
56
- },
57
- disabled: {
58
- false: null,
59
- true: styles.disabled
60
- }
61
- }
62
- }), [styles]);
63
32
  const [recordedKeys, { start, stop, isRecording, resetKeys }] = useRecordHotkeys();
64
33
  useHotkeys("*", () => {
65
34
  inputRef.current?.blur();
@@ -173,7 +142,7 @@ const HotkeyInput = memo(({ value = "", defaultValue = "", resetValue = "", onCh
173
142
  error: hasConflict || hasInvalidCombination,
174
143
  focused: isFocused,
175
144
  shadow,
176
- variant: variant || (theme.isDarkMode ? "filled" : "outlined")
145
+ variant: variant || (isDarkMode ? "filled" : "outlined")
177
146
  })),
178
147
  horizontal: true,
179
148
  justify: "space-between",
@@ -1 +1 @@
1
- {"version":3,"file":"HotkeyInput.mjs","names":["hotkeyMessages","useControlledState","modifiers: string[]","normalKeys: string[]","normalizedKey: any","Flexbox","Hotkey","ActionIcon"],"sources":["../../src/HotkeyInput/HotkeyInput.tsx"],"sourcesContent":["'use client';\n\nimport type { InputRef } from 'antd';\nimport { cva } from 'class-variance-authority';\nimport { isEqual } from 'es-toolkit/compat';\nimport { Undo2Icon } from 'lucide-react';\nimport {\n type FocusEvent,\n type MouseEvent,\n memo,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useHotkeys, useRecordHotkeys } from 'react-hotkeys-hook';\nimport useControlledState from 'use-merge-value';\n\nimport ActionIcon from '@/ActionIcon';\nimport { Flexbox } from '@/Flex';\nimport Hotkey from '@/Hotkey';\nimport { NORMATIVE_MODIFIER, checkIsAppleDevice, splitKeysByPlus } from '@/Hotkey/utils';\nimport hotkeyMessages from '@/i18n/resources/en/hotkey';\nimport { useTranslation } from '@/i18n/useTranslation';\n\nimport { useStyles } from './style';\nimport type { HotkeyInputProps } from './type';\n\nconst HotkeyInput = memo<HotkeyInputProps>(\n ({\n value = '',\n defaultValue = '',\n resetValue = '',\n onChange,\n onConflict,\n placeholder,\n disabled,\n shadow,\n allowReset = true,\n style,\n className,\n hotkeyConflicts = [],\n variant,\n texts,\n isApple,\n onBlur,\n onReset,\n onFocus,\n }) => {\n const [isFocused, setIsFocused] = useState(false);\n const [hasConflict, setHasConflict] = useState(false);\n const [hasInvalidCombination, setHasInvalidCombination] = useState(false);\n const inputRef = useRef<InputRef>(null);\n const { cx, styles, theme } = useStyles();\n const { t } = useTranslation(hotkeyMessages);\n const isAppleDevice = useMemo(() => checkIsAppleDevice(isApple), [isApple]);\n const [hotkeyValue, setHotkeyValue] = useControlledState(defaultValue, {\n defaultValue,\n onChange,\n value,\n });\n\n const variants = useMemo(\n () =>\n cva(styles.root, {\n defaultVariants: {\n disabled: false,\n error: false,\n shadow: false,\n variant: 'outlined',\n },\n /* eslint-disable sort-keys-fix/sort-keys-fix */\n variants: {\n variant: {\n filled: styles.filled,\n outlined: styles.outlined,\n borderless: styles.borderless,\n },\n shadow: {\n false: null,\n true: styles.shadow,\n },\n focused: {\n false: null,\n true: styles.focused,\n },\n error: {\n fales: null,\n true: styles.error,\n },\n disabled: {\n false: null,\n true: styles.disabled,\n },\n },\n /* eslint-enable sort-keys-fix/sort-keys-fix */\n }),\n [styles],\n );\n\n // 使用 useRecordHotkeys 处理快捷键录入\n const [recordedKeys, { start, stop, isRecording, resetKeys }] = useRecordHotkeys();\n\n useHotkeys(\n '*',\n () => {\n inputRef.current?.blur();\n },\n {\n enableOnContentEditable: true,\n enableOnFormTags: true,\n enabled: isRecording && !disabled,\n keydown: false,\n keyup: true,\n preventDefault: true,\n },\n );\n\n // 处理按键,保证格式正确:修饰键在前,最多一个非修饰键在后\n const formatKeys = useCallback((keysSet: Set<string>) => {\n const modifiers: string[] = [];\n const normalKeys: string[] = [];\n\n for (const key of keysSet) {\n // 处理不同表示的修饰键\n const normalizedKey: any = key.toLowerCase();\n if (NORMATIVE_MODIFIER.includes(normalizedKey)) {\n // 统一修饰键表示\n if (\n (!isAppleDevice && normalizedKey === 'ctrl') ||\n (isAppleDevice && normalizedKey === 'meta')\n ) {\n if (!modifiers.includes('mod')) modifiers.push('mod');\n } else if (!modifiers.includes(normalizedKey)) {\n modifiers.push(normalizedKey);\n }\n } else {\n normalKeys.push(key);\n }\n }\n\n // 至少需要一个修饰键\n if (modifiers.length === 0 && normalKeys.length > 0) {\n return { isValid: false, keys: [] };\n }\n\n // 只允许一个非修饰键,如果有多个,只保留最后一个\n const finalKey = normalKeys.length > 0 ? [normalKeys.at(-1)] : [];\n const shortcuts = [modifiers, finalKey];\n\n return {\n // 组合必须包含至少一个按键\n isValid: shortcuts.every((k) => k.length > 0),\n keys: shortcuts.flat(),\n };\n }, []);\n\n // 获取格式化后的按键字符串\n const { isValid, keys } = formatKeys(recordedKeys);\n const keysString = keys.join('+');\n\n // 检查快捷键冲突\n const checkHotkeyConflict = useCallback(\n (newHotkey: string): boolean => {\n return hotkeyConflicts\n .filter((conflictKey) => conflictKey !== resetValue)\n .some((conflictKey) => {\n const newKeys = splitKeysByPlus(newHotkey);\n const conflictKeys = splitKeysByPlus(conflictKey);\n return isEqual(newKeys, conflictKeys);\n });\n },\n [hotkeyConflicts],\n );\n\n // 当按键组合完成时处理结果\n useEffect(() => {\n if (recordedKeys.size > 0 && !isRecording) {\n if (!isValid) {\n setHasInvalidCombination(true);\n setHasConflict(false);\n return;\n }\n\n setHasInvalidCombination(false);\n const newKeysString = keysString;\n\n // 检查冲突\n const conflict = checkHotkeyConflict(newKeysString);\n if (conflict) {\n setHasConflict(true);\n onConflict?.(newKeysString);\n } else {\n setHasConflict(false);\n setHotkeyValue?.(newKeysString);\n }\n }\n }, [\n recordedKeys,\n isRecording,\n isValid,\n keysString,\n checkHotkeyConflict,\n setHotkeyValue,\n onConflict,\n ]);\n\n // 处理输入框焦点\n const handleFocus = (e: FocusEvent<HTMLInputElement>) => {\n if (disabled) return;\n setIsFocused(true);\n setHasConflict(false);\n setHasInvalidCombination(false);\n start(); // 开始记录\n onFocus?.(e);\n };\n\n const handleBlur = (e: FocusEvent<HTMLInputElement>) => {\n setIsFocused(false);\n stop(); // 停止记录\n onBlur?.(e);\n };\n\n // 重置功能\n const handleReset = (e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setHotkeyValue?.(resetValue);\n resetKeys();\n setHasConflict(false);\n setHasInvalidCombination(false);\n setIsFocused(false);\n stop(); // 停止记录\n onReset?.(hotkeyValue, resetValue);\n };\n\n const handleClick = (e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n if (disabled || isFocused) return;\n inputRef.current?.focus();\n };\n\n const placeholderText = placeholder ?? t('hotkey.placeholder');\n const resetTitle = texts?.reset ?? t('hotkey.reset');\n const conflictText = texts?.conflicts ?? t('hotkey.conflict');\n const invalidText = texts?.invalidCombination ?? t('hotkey.invalidCombination');\n\n return (\n <Flexbox\n className={className}\n gap={8}\n style={{\n position: 'relative',\n ...style,\n }}\n >\n <Flexbox\n align={'center'}\n className={cx(\n variants({\n disabled,\n error: hasConflict || hasInvalidCombination,\n focused: isFocused,\n shadow,\n variant: variant || (theme.isDarkMode ? 'filled' : 'outlined'),\n }),\n )}\n horizontal\n justify={'space-between'}\n onClick={handleClick}\n >\n <div style={{ pointerEvents: 'none' }}>\n {isRecording ? (\n <span className={styles.placeholder}>\n {keys.length > 0 ? <Hotkey keys={keysString} /> : placeholderText}\n </span>\n ) : hotkeyValue ? (\n <Hotkey keys={hotkeyValue} />\n ) : (\n <span className={styles.placeholder}>{placeholderText}</span>\n )}\n </div>\n\n {/* 隐藏的输入框,用于接收焦点 */}\n <input\n className={styles.hiddenInput}\n disabled={disabled}\n onBlur={handleBlur}\n onFocus={handleFocus}\n readOnly\n ref={inputRef as any}\n style={{ pointerEvents: 'none' }}\n />\n\n {!isFocused && allowReset && hotkeyValue && hotkeyValue !== resetValue && !disabled && (\n <ActionIcon\n icon={Undo2Icon}\n onClick={handleReset}\n size={'small'}\n title={resetTitle}\n variant={'filled'}\n />\n )}\n </Flexbox>\n {hasConflict && <div className={styles.errorText}>{conflictText}</div>}\n {hasInvalidCombination && <div className={styles.errorText}>{invalidText}</div>}\n </Flexbox>\n );\n },\n);\n\nHotkeyInput.displayName = 'HotkeyInput';\n\nexport default HotkeyInput;\n"],"mappings":"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"}
1
+ {"version":3,"file":"HotkeyInput.mjs","names":["hotkeyMessages","useControlledState","modifiers: string[]","normalKeys: string[]","normalizedKey: any","Flexbox","Hotkey","ActionIcon"],"sources":["../../src/HotkeyInput/HotkeyInput.tsx"],"sourcesContent":["'use client';\n\nimport type { InputRef } from 'antd';\nimport { cx, useThemeMode } from 'antd-style';\nimport { isEqual } from 'es-toolkit/compat';\nimport { Undo2Icon } from 'lucide-react';\nimport {\n type FocusEvent,\n type MouseEvent,\n memo,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useHotkeys, useRecordHotkeys } from 'react-hotkeys-hook';\nimport useControlledState from 'use-merge-value';\n\nimport ActionIcon from '@/ActionIcon';\nimport { Flexbox } from '@/Flex';\nimport Hotkey from '@/Hotkey';\nimport { NORMATIVE_MODIFIER, checkIsAppleDevice, splitKeysByPlus } from '@/Hotkey/utils';\nimport hotkeyMessages from '@/i18n/resources/en/hotkey';\nimport { useTranslation } from '@/i18n/useTranslation';\n\nimport { styles, variants } from './style';\nimport type { HotkeyInputProps } from './type';\n\nconst HotkeyInput = memo<HotkeyInputProps>(\n ({\n value = '',\n defaultValue = '',\n resetValue = '',\n onChange,\n onConflict,\n placeholder,\n disabled,\n shadow,\n allowReset = true,\n style,\n className,\n hotkeyConflicts = [],\n variant,\n texts,\n isApple,\n onBlur,\n onReset,\n onFocus,\n }) => {\n const [isFocused, setIsFocused] = useState(false);\n const [hasConflict, setHasConflict] = useState(false);\n const [hasInvalidCombination, setHasInvalidCombination] = useState(false);\n const inputRef = useRef<InputRef>(null);\n const { isDarkMode } = useThemeMode();\n const { t } = useTranslation(hotkeyMessages);\n const isAppleDevice = useMemo(() => checkIsAppleDevice(isApple), [isApple]);\n const [hotkeyValue, setHotkeyValue] = useControlledState(defaultValue, {\n defaultValue,\n onChange,\n value,\n });\n\n // 使用 useRecordHotkeys 处理快捷键录入\n const [recordedKeys, { start, stop, isRecording, resetKeys }] = useRecordHotkeys();\n\n useHotkeys(\n '*',\n () => {\n inputRef.current?.blur();\n },\n {\n enableOnContentEditable: true,\n enableOnFormTags: true,\n enabled: isRecording && !disabled,\n keydown: false,\n keyup: true,\n preventDefault: true,\n },\n );\n\n // 处理按键,保证格式正确:修饰键在前,最多一个非修饰键在后\n const formatKeys = useCallback((keysSet: Set<string>) => {\n const modifiers: string[] = [];\n const normalKeys: string[] = [];\n\n for (const key of keysSet) {\n // 处理不同表示的修饰键\n const normalizedKey: any = key.toLowerCase();\n if (NORMATIVE_MODIFIER.includes(normalizedKey)) {\n // 统一修饰键表示\n if (\n (!isAppleDevice && normalizedKey === 'ctrl') ||\n (isAppleDevice && normalizedKey === 'meta')\n ) {\n if (!modifiers.includes('mod')) modifiers.push('mod');\n } else if (!modifiers.includes(normalizedKey)) {\n modifiers.push(normalizedKey);\n }\n } else {\n normalKeys.push(key);\n }\n }\n\n // 至少需要一个修饰键\n if (modifiers.length === 0 && normalKeys.length > 0) {\n return { isValid: false, keys: [] };\n }\n\n // 只允许一个非修饰键,如果有多个,只保留最后一个\n const finalKey = normalKeys.length > 0 ? [normalKeys.at(-1)] : [];\n const shortcuts = [modifiers, finalKey];\n\n return {\n // 组合必须包含至少一个按键\n isValid: shortcuts.every((k) => k.length > 0),\n keys: shortcuts.flat(),\n };\n }, []);\n\n // 获取格式化后的按键字符串\n const { isValid, keys } = formatKeys(recordedKeys);\n const keysString = keys.join('+');\n\n // 检查快捷键冲突\n const checkHotkeyConflict = useCallback(\n (newHotkey: string): boolean => {\n return hotkeyConflicts\n .filter((conflictKey) => conflictKey !== resetValue)\n .some((conflictKey) => {\n const newKeys = splitKeysByPlus(newHotkey);\n const conflictKeys = splitKeysByPlus(conflictKey);\n return isEqual(newKeys, conflictKeys);\n });\n },\n [hotkeyConflicts],\n );\n\n // 当按键组合完成时处理结果\n useEffect(() => {\n if (recordedKeys.size > 0 && !isRecording) {\n if (!isValid) {\n setHasInvalidCombination(true);\n setHasConflict(false);\n return;\n }\n\n setHasInvalidCombination(false);\n const newKeysString = keysString;\n\n // 检查冲突\n const conflict = checkHotkeyConflict(newKeysString);\n if (conflict) {\n setHasConflict(true);\n onConflict?.(newKeysString);\n } else {\n setHasConflict(false);\n setHotkeyValue?.(newKeysString);\n }\n }\n }, [\n recordedKeys,\n isRecording,\n isValid,\n keysString,\n checkHotkeyConflict,\n setHotkeyValue,\n onConflict,\n ]);\n\n // 处理输入框焦点\n const handleFocus = (e: FocusEvent<HTMLInputElement>) => {\n if (disabled) return;\n setIsFocused(true);\n setHasConflict(false);\n setHasInvalidCombination(false);\n start(); // 开始记录\n onFocus?.(e);\n };\n\n const handleBlur = (e: FocusEvent<HTMLInputElement>) => {\n setIsFocused(false);\n stop(); // 停止记录\n onBlur?.(e);\n };\n\n // 重置功能\n const handleReset = (e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setHotkeyValue?.(resetValue);\n resetKeys();\n setHasConflict(false);\n setHasInvalidCombination(false);\n setIsFocused(false);\n stop(); // 停止记录\n onReset?.(hotkeyValue, resetValue);\n };\n\n const handleClick = (e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n if (disabled || isFocused) return;\n inputRef.current?.focus();\n };\n\n const placeholderText = placeholder ?? t('hotkey.placeholder');\n const resetTitle = texts?.reset ?? t('hotkey.reset');\n const conflictText = texts?.conflicts ?? t('hotkey.conflict');\n const invalidText = texts?.invalidCombination ?? t('hotkey.invalidCombination');\n\n return (\n <Flexbox\n className={className}\n gap={8}\n style={{\n position: 'relative',\n ...style,\n }}\n >\n <Flexbox\n align={'center'}\n className={cx(\n variants({\n disabled,\n error: hasConflict || hasInvalidCombination,\n focused: isFocused,\n shadow,\n variant: variant || (isDarkMode ? 'filled' : 'outlined'),\n }),\n )}\n horizontal\n justify={'space-between'}\n onClick={handleClick}\n >\n <div style={{ pointerEvents: 'none' }}>\n {isRecording ? (\n <span className={styles.placeholder}>\n {keys.length > 0 ? <Hotkey keys={keysString} /> : placeholderText}\n </span>\n ) : hotkeyValue ? (\n <Hotkey keys={hotkeyValue} />\n ) : (\n <span className={styles.placeholder}>{placeholderText}</span>\n )}\n </div>\n\n {/* 隐藏的输入框,用于接收焦点 */}\n <input\n className={styles.hiddenInput}\n disabled={disabled}\n onBlur={handleBlur}\n onFocus={handleFocus}\n readOnly\n ref={inputRef as any}\n style={{ pointerEvents: 'none' }}\n />\n\n {!isFocused && allowReset && hotkeyValue && hotkeyValue !== resetValue && !disabled && (\n <ActionIcon\n icon={Undo2Icon}\n onClick={handleReset}\n size={'small'}\n title={resetTitle}\n variant={'filled'}\n />\n )}\n </Flexbox>\n {hasConflict && <div className={styles.errorText}>{conflictText}</div>}\n {hasInvalidCombination && <div className={styles.errorText}>{invalidText}</div>}\n </Flexbox>\n );\n },\n);\n\nHotkeyInput.displayName = 'HotkeyInput';\n\nexport default HotkeyInput;\n"],"mappings":"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"}
@@ -1,20 +1,22 @@
1
- import { createStyles } from "antd-style";
1
+ import { staticStylish } from "../styles/theme/customStylishStatic.mjs";
2
+ import { createStaticStyles } from "antd-style";
3
+ import { cva } from "class-variance-authority";
2
4
 
3
5
  //#region src/HotkeyInput/style.ts
4
- const useStyles = createStyles(({ css: css$1, token, stylish }) => {
6
+ const styles = createStaticStyles(({ css: css$1, cssVar: cssVar$1 }) => {
5
7
  return {
6
- borderless: stylish.variantBorderless,
7
- disabled: stylish.disabled,
8
+ borderless: staticStylish.variantBorderless,
9
+ disabled: staticStylish.disabled,
8
10
  error: css$1`
9
- border: 1px solid ${token.colorError};
11
+ border: 1px solid ${cssVar$1.colorError};
10
12
  `,
11
13
  errorText: css$1`
12
14
  font-size: 12px;
13
- color: ${token.colorError};
15
+ color: ${cssVar$1.colorError};
14
16
  `,
15
- filled: stylish.variantFilled,
17
+ filled: staticStylish.variantFilled,
16
18
  focused: css$1`
17
- background: ${token.colorFillSecondary} !important;
19
+ background: ${cssVar$1.colorFillSecondary} !important;
18
20
  `,
19
21
  hiddenInput: css$1`
20
22
  cursor: text;
@@ -29,9 +31,9 @@ const useStyles = createStyles(({ css: css$1, token, stylish }) => {
29
31
 
30
32
  opacity: 0;
31
33
  `,
32
- outlined: stylish.variantOutlined,
34
+ outlined: staticStylish.variantOutlined,
33
35
  placeholder: css$1`
34
- color: ${token.colorTextDescription};
36
+ color: ${cssVar$1.colorTextDescription};
35
37
  `,
36
38
  root: css$1`
37
39
  cursor: pointer;
@@ -42,13 +44,43 @@ const useStyles = createStyles(({ css: css$1, token, stylish }) => {
42
44
  height: 36px;
43
45
  padding-block: 0;
44
46
  padding-inline: 12px;
45
-
46
- border-radius: ${token.borderRadius}px;
47
+ border-radius: ${cssVar$1.borderRadius};
47
48
  `,
48
- shadow: stylish.shadow
49
+ shadow: staticStylish.shadow
49
50
  };
50
51
  });
52
+ const variants = cva(styles.root, {
53
+ defaultVariants: {
54
+ disabled: false,
55
+ error: false,
56
+ shadow: false,
57
+ variant: "outlined"
58
+ },
59
+ variants: {
60
+ variant: {
61
+ filled: styles.filled,
62
+ outlined: styles.outlined,
63
+ borderless: styles.borderless
64
+ },
65
+ shadow: {
66
+ false: null,
67
+ true: styles.shadow
68
+ },
69
+ focused: {
70
+ false: null,
71
+ true: styles.focused
72
+ },
73
+ error: {
74
+ fales: null,
75
+ true: styles.error
76
+ },
77
+ disabled: {
78
+ false: null,
79
+ true: styles.disabled
80
+ }
81
+ }
82
+ });
51
83
 
52
84
  //#endregion
53
- export { useStyles };
85
+ export { styles, variants };
54
86
  //# sourceMappingURL=style.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"style.mjs","names":[],"sources":["../../src/HotkeyInput/style.ts"],"sourcesContent":["import { createStyles } from 'antd-style';\n\nexport const useStyles = createStyles(({ css, token, stylish }) => {\n return {\n borderless: stylish.variantBorderless,\n disabled: stylish.disabled,\n error: css`\n border: 1px solid ${token.colorError};\n `,\n errorText: css`\n font-size: 12px;\n color: ${token.colorError};\n `,\n filled: stylish.variantFilled,\n focused: css`\n background: ${token.colorFillSecondary} !important;\n `,\n hiddenInput: css`\n cursor: text;\n\n position: absolute;\n z-index: -1;\n inset-block-start: 0;\n inset-inline-start: 0;\n\n width: 100%;\n height: 100%;\n\n opacity: 0;\n `,\n outlined: stylish.variantOutlined,\n placeholder: css`\n color: ${token.colorTextDescription};\n `,\n root: css`\n cursor: pointer;\n\n position: relative;\n\n max-width: 100%;\n height: 36px;\n padding-block: 0;\n padding-inline: 12px;\n\n border-radius: ${token.borderRadius}px;\n `,\n shadow: stylish.shadow,\n };\n});\n"],"mappings":";;;AAEA,MAAa,YAAY,cAAc,EAAE,YAAK,OAAO,cAAc;AACjE,QAAO;EACL,YAAY,QAAQ;EACpB,UAAU,QAAQ;EAClB,OAAO,KAAG;0BACY,MAAM,WAAW;;EAEvC,WAAW,KAAG;;eAEH,MAAM,WAAW;;EAE5B,QAAQ,QAAQ;EAChB,SAAS,KAAG;oBACI,MAAM,mBAAmB;;EAEzC,aAAa,KAAG;;;;;;;;;;;;;EAahB,UAAU,QAAQ;EAClB,aAAa,KAAG;eACL,MAAM,qBAAqB;;EAEtC,MAAM,KAAG;;;;;;;;;;uBAUU,MAAM,aAAa;;EAEtC,QAAQ,QAAQ;EACjB;EACD"}
1
+ {"version":3,"file":"style.mjs","names":["lobeStaticStylish","cssVar"],"sources":["../../src/HotkeyInput/style.ts"],"sourcesContent":["import { createStaticStyles } from 'antd-style';\nimport { cva } from 'class-variance-authority';\n\nimport { lobeStaticStylish } from '@/styles';\n\nexport const styles = createStaticStyles(({ css, cssVar }) => {\n return {\n borderless: lobeStaticStylish.variantBorderless,\n disabled: lobeStaticStylish.disabled,\n error: css`\n border: 1px solid ${cssVar.colorError};\n `,\n errorText: css`\n font-size: 12px;\n color: ${cssVar.colorError};\n `,\n filled: lobeStaticStylish.variantFilled,\n focused: css`\n background: ${cssVar.colorFillSecondary} !important;\n `,\n hiddenInput: css`\n cursor: text;\n\n position: absolute;\n z-index: -1;\n inset-block-start: 0;\n inset-inline-start: 0;\n\n width: 100%;\n height: 100%;\n\n opacity: 0;\n `,\n outlined: lobeStaticStylish.variantOutlined,\n placeholder: css`\n color: ${cssVar.colorTextDescription};\n `,\n root: css`\n cursor: pointer;\n\n position: relative;\n\n max-width: 100%;\n height: 36px;\n padding-block: 0;\n padding-inline: 12px;\n border-radius: ${cssVar.borderRadius};\n `,\n shadow: lobeStaticStylish.shadow,\n };\n});\n\nexport const variants = cva(styles.root, {\n defaultVariants: {\n disabled: false,\n error: false,\n shadow: false,\n variant: 'outlined',\n },\n /* eslint-disable sort-keys-fix/sort-keys-fix */\n variants: {\n variant: {\n filled: styles.filled,\n outlined: styles.outlined,\n borderless: styles.borderless,\n },\n shadow: {\n false: null,\n true: styles.shadow,\n },\n focused: {\n false: null,\n true: styles.focused,\n },\n error: {\n fales: null,\n true: styles.error,\n },\n disabled: {\n false: null,\n true: styles.disabled,\n },\n },\n /* eslint-enable sort-keys-fix/sort-keys-fix */\n});\n"],"mappings":";;;;;AAKA,MAAa,SAAS,oBAAoB,EAAE,YAAK,uBAAa;AAC5D,QAAO;EACL,YAAYA,cAAkB;EAC9B,UAAUA,cAAkB;EAC5B,OAAO,KAAG;0BACYC,SAAO,WAAW;;EAExC,WAAW,KAAG;;eAEHA,SAAO,WAAW;;EAE7B,QAAQD,cAAkB;EAC1B,SAAS,KAAG;oBACIC,SAAO,mBAAmB;;EAE1C,aAAa,KAAG;;;;;;;;;;;;;EAahB,UAAUD,cAAkB;EAC5B,aAAa,KAAG;eACLC,SAAO,qBAAqB;;EAEvC,MAAM,KAAG;;;;;;;;;uBASUA,SAAO,aAAa;;EAEvC,QAAQD,cAAkB;EAC3B;EACD;AAEF,MAAa,WAAW,IAAI,OAAO,MAAM;CACvC,iBAAiB;EACf,UAAU;EACV,OAAO;EACP,QAAQ;EACR,SAAS;EACV;CAED,UAAU;EACR,SAAS;GACP,QAAQ,OAAO;GACf,UAAU,OAAO;GACjB,YAAY,OAAO;GACpB;EACD,QAAQ;GACN,OAAO;GACP,MAAM,OAAO;GACd;EACD,SAAS;GACP,OAAO;GACP,MAAM,OAAO;GACd;EACD,OAAO;GACL,OAAO;GACP,MAAM,OAAO;GACd;EACD,UAAU;GACR,OAAO;GACP,MAAM,OAAO;GACd;EACF;CAEF,CAAC"}
@@ -1,8 +1,8 @@
1
1
  import { IconProps } from "./type.mjs";
2
- import * as react43 from "react";
2
+ import * as react9 from "react";
3
3
 
4
4
  //#region src/Icon/Icon.d.ts
5
- declare const Icon: react43.NamedExoticComponent<IconProps>;
5
+ declare const Icon: react9.NamedExoticComponent<IconProps>;
6
6
  //#endregion
7
7
  export { Icon };
8
8
  //# sourceMappingURL=Icon.d.mts.map
package/es/Icon/Icon.mjs CHANGED
@@ -2,21 +2,13 @@
2
2
 
3
3
  import { useIconContext } from "./components/IconProvider.mjs";
4
4
  import { calcSize } from "./components/utils.mjs";
5
- import { useStyles } from "./style.mjs";
5
+ import { variants } from "./style.mjs";
6
6
  import { isValidElement, memo, useMemo } from "react";
7
7
  import { jsx } from "react/jsx-runtime";
8
- import { cva } from "class-variance-authority";
8
+ import { cx } from "antd-style";
9
9
 
10
10
  //#region src/Icon/Icon.tsx
11
11
  const Icon = memo(({ icon, size: iconSize, color, fill = "transparent", className, focusable, spin, fillRule, fillOpacity, ref, ...rest }) => {
12
- const { styles, cx } = useStyles();
13
- const variants = useMemo(() => cva("anticon", {
14
- defaultVariants: { spin: false },
15
- variants: { spin: {
16
- false: null,
17
- true: styles.spin
18
- } }
19
- }), [styles]);
20
12
  const { color: colorConfig, fill: fillConfig, fillOpacity: fillOpacityConfig, fillRule: fillRuleConfig, focusable: focusableConfig, className: classNameConfig, size: sizeConfig, ...restConfig } = useIconContext();
21
13
  const { size, strokeWidth } = useMemo(() => calcSize(iconSize || sizeConfig), [iconSize, sizeConfig]);
22
14
  const SvgIcon = icon;
@@ -1 +1 @@
1
- {"version":3,"file":"Icon.mjs","names":[],"sources":["../../src/Icon/Icon.tsx"],"sourcesContent":["'use client';\n\nimport { cva } from 'class-variance-authority';\nimport { LucideIcon } from 'lucide-react';\nimport { isValidElement, memo, useMemo } from 'react';\n\nimport { useIconContext } from './components/IconProvider';\nimport { calcSize } from './components/utils';\nimport { useStyles } from './style';\nimport type { IconProps } from './type';\n\nconst Icon = memo<IconProps>(\n ({\n icon,\n size: iconSize,\n color,\n fill = 'transparent',\n className,\n focusable,\n spin,\n fillRule,\n fillOpacity,\n ref,\n ...rest\n }) => {\n const { styles, cx } = useStyles();\n\n const variants = useMemo(\n () =>\n cva('anticon', {\n defaultVariants: {\n spin: false,\n },\n /* eslint-disable sort-keys-fix/sort-keys-fix */\n variants: {\n spin: {\n false: null,\n true: styles.spin,\n },\n },\n /* eslint-enable sort-keys-fix/sort-keys-fix */\n }),\n [styles],\n );\n\n const {\n color: colorConfig,\n fill: fillConfig,\n fillOpacity: fillOpacityConfig,\n fillRule: fillRuleConfig,\n focusable: focusableConfig,\n className: classNameConfig,\n size: sizeConfig,\n ...restConfig\n } = useIconContext();\n\n const { size, strokeWidth } = useMemo(\n () => calcSize(iconSize || sizeConfig),\n [iconSize, sizeConfig],\n );\n\n const SvgIcon = icon as LucideIcon;\n\n return (\n <span\n className={cx(variants({ spin }), classNameConfig, className)}\n role=\"img\"\n {...restConfig}\n {...rest}\n >\n {icon &&\n (isValidElement(icon) ? (\n icon\n ) : (\n <SvgIcon\n color={color || colorConfig}\n fill={fill || fillConfig}\n fillOpacity={fillOpacity || fillOpacityConfig}\n fillRule={fillRule || fillRuleConfig}\n focusable={focusable || focusableConfig}\n height={size}\n ref={ref}\n size={size}\n strokeWidth={strokeWidth}\n width={size}\n />\n ))}\n </span>\n );\n },\n);\n\nIcon.displayName = 'Icon';\n\nexport default Icon;\n"],"mappings":";;;;;;;;;;AAWA,MAAM,OAAO,MACV,EACC,MACA,MAAM,UACN,OACA,OAAO,eACP,WACA,WACA,MACA,UACA,aACA,KACA,GAAG,WACC;CACJ,MAAM,EAAE,QAAQ,OAAO,WAAW;CAElC,MAAM,WAAW,cAEb,IAAI,WAAW;EACb,iBAAiB,EACf,MAAM,OACP;EAED,UAAU,EACR,MAAM;GACJ,OAAO;GACP,MAAM,OAAO;GACd,EACF;EAEF,CAAC,EACJ,CAAC,OAAO,CACT;CAED,MAAM,EACJ,OAAO,aACP,MAAM,YACN,aAAa,mBACb,UAAU,gBACV,WAAW,iBACX,WAAW,iBACX,MAAM,YACN,GAAG,eACD,gBAAgB;CAEpB,MAAM,EAAE,MAAM,gBAAgB,cACtB,SAAS,YAAY,WAAW,EACtC,CAAC,UAAU,WAAW,CACvB;CAED,MAAM,UAAU;AAEhB,QACE,oBAAC;EACC,WAAW,GAAG,SAAS,EAAE,MAAM,CAAC,EAAE,iBAAiB,UAAU;EAC7D,MAAK;EACL,GAAI;EACJ,GAAI;YAEH,SACE,eAAe,KAAK,GACnB,OAEA,oBAAC;GACC,OAAO,SAAS;GAChB,MAAM,QAAQ;GACd,aAAa,eAAe;GAC5B,UAAU,YAAY;GACtB,WAAW,aAAa;GACxB,QAAQ;GACH;GACC;GACO;GACb,OAAO;IACP;GAED;EAGZ;AAED,KAAK,cAAc;AAEnB,mBAAe"}
1
+ {"version":3,"file":"Icon.mjs","names":[],"sources":["../../src/Icon/Icon.tsx"],"sourcesContent":["'use client';\n\nimport { cx } from 'antd-style';\nimport { LucideIcon } from 'lucide-react';\nimport { isValidElement, memo, useMemo } from 'react';\n\nimport { useIconContext } from './components/IconProvider';\nimport { calcSize } from './components/utils';\nimport { variants } from './style';\nimport type { IconProps } from './type';\n\nconst Icon = memo<IconProps>(\n ({\n icon,\n size: iconSize,\n color,\n fill = 'transparent',\n className,\n focusable,\n spin,\n fillRule,\n fillOpacity,\n ref,\n ...rest\n }) => {\n const {\n color: colorConfig,\n fill: fillConfig,\n fillOpacity: fillOpacityConfig,\n fillRule: fillRuleConfig,\n focusable: focusableConfig,\n className: classNameConfig,\n size: sizeConfig,\n ...restConfig\n } = useIconContext();\n\n const { size, strokeWidth } = useMemo(\n () => calcSize(iconSize || sizeConfig),\n [iconSize, sizeConfig],\n );\n\n const SvgIcon = icon as LucideIcon;\n\n return (\n <span\n className={cx(variants({ spin }), classNameConfig, className)}\n role=\"img\"\n {...restConfig}\n {...rest}\n >\n {icon &&\n (isValidElement(icon) ? (\n icon\n ) : (\n <SvgIcon\n color={color || colorConfig}\n fill={fill || fillConfig}\n fillOpacity={fillOpacity || fillOpacityConfig}\n fillRule={fillRule || fillRuleConfig}\n focusable={focusable || focusableConfig}\n height={size}\n ref={ref}\n size={size}\n strokeWidth={strokeWidth}\n width={size}\n />\n ))}\n </span>\n );\n },\n);\n\nIcon.displayName = 'Icon';\n\nexport default Icon;\n"],"mappings":";;;;;;;;;;AAWA,MAAM,OAAO,MACV,EACC,MACA,MAAM,UACN,OACA,OAAO,eACP,WACA,WACA,MACA,UACA,aACA,KACA,GAAG,WACC;CACJ,MAAM,EACJ,OAAO,aACP,MAAM,YACN,aAAa,mBACb,UAAU,gBACV,WAAW,iBACX,WAAW,iBACX,MAAM,YACN,GAAG,eACD,gBAAgB;CAEpB,MAAM,EAAE,MAAM,gBAAgB,cACtB,SAAS,YAAY,WAAW,EACtC,CAAC,UAAU,WAAW,CACvB;CAED,MAAM,UAAU;AAEhB,QACE,oBAAC;EACC,WAAW,GAAG,SAAS,EAAE,MAAM,CAAC,EAAE,iBAAiB,UAAU;EAC7D,MAAK;EACL,GAAI;EACJ,GAAI;YAEH,SACE,eAAe,KAAK,GACnB,OAEA,oBAAC;GACC,OAAO,SAAS;GAChB,MAAM,QAAQ;GACd,aAAa,eAAe;GAC5B,UAAU,YAAY;GACtB,WAAW,aAAa;GACxB,QAAQ;GACH;GACC;GACO;GACb,OAAO;IACP;GAED;EAGZ;AAED,KAAK,cAAc;AAEnB,mBAAe"}
@@ -1,11 +1,11 @@
1
1
  import { IconProps } from "../type.mjs";
2
- import * as react41 from "react";
2
+ import * as react11 from "react";
3
3
  import { ReactNode } from "react";
4
4
 
5
5
  //#region src/Icon/components/IconProvider.d.ts
6
6
  type IconContentConfig = Omit<IconProps, 'icon' | 'ref'>;
7
- declare const IconContext: react41.Context<IconContentConfig>;
8
- declare const IconProvider: react41.NamedExoticComponent<{
7
+ declare const IconContext: react11.Context<IconContentConfig>;
8
+ declare const IconProvider: react11.NamedExoticComponent<{
9
9
  children: ReactNode;
10
10
  config?: IconContentConfig;
11
11
  }>;
package/es/Icon/style.mjs CHANGED
@@ -1,19 +1,28 @@
1
- import { createStyles, keyframes } from "antd-style";
1
+ import { createStaticStyles, keyframes } from "antd-style";
2
+ import { cva } from "class-variance-authority";
2
3
 
3
4
  //#region src/Icon/style.ts
4
- const useStyles = createStyles(({ css: css$1 }) => {
5
- return { spin: css$1`
6
- animation: ${keyframes`
5
+ const spin = keyframes`
7
6
  0% {
8
7
  rotate: 0deg;
9
8
  }
10
9
  100% {
11
10
  rotate: 360deg;
12
11
  }
13
- `} 1s linear infinite;
12
+ `;
13
+ const styles = createStaticStyles(({ css: css$1 }) => {
14
+ return { spin: css$1`
15
+ animation: ${spin} 1s linear infinite;
14
16
  ` };
15
17
  });
18
+ const variants = cva("anticon", {
19
+ defaultVariants: { spin: false },
20
+ variants: { spin: {
21
+ false: null,
22
+ true: styles.spin
23
+ } }
24
+ });
16
25
 
17
26
  //#endregion
18
- export { useStyles };
27
+ export { variants };
19
28
  //# sourceMappingURL=style.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"style.mjs","names":[],"sources":["../../src/Icon/style.ts"],"sourcesContent":["import { createStyles, keyframes } from 'antd-style';\n\nexport const useStyles = createStyles(({ css }) => {\n const spin = keyframes`\n 0% {\n rotate: 0deg;\n }\n 100% {\n rotate: 360deg;\n }\n `;\n return {\n spin: css`\n animation: ${spin} 1s linear infinite;\n `,\n };\n});\n"],"mappings":";;;AAEA,MAAa,YAAY,cAAc,EAAE,iBAAU;AASjD,QAAO,EACL,MAAM,KAAG;mBATE,SAAS;;;;;;;IAUA;OAErB;EACD"}
1
+ {"version":3,"file":"style.mjs","names":[],"sources":["../../src/Icon/style.ts"],"sourcesContent":["import { createStaticStyles, keyframes } from 'antd-style';\nimport { cva } from 'class-variance-authority';\n\nconst spin = keyframes`\n 0% {\n rotate: 0deg;\n }\n 100% {\n rotate: 360deg;\n }\n`;\n\nexport const styles = createStaticStyles(({ css }) => {\n return {\n spin: css`\n animation: ${spin} 1s linear infinite;\n `,\n };\n});\n\nexport const variants = cva('anticon', {\n defaultVariants: {\n spin: false,\n },\n /* eslint-disable sort-keys-fix/sort-keys-fix */\n variants: {\n spin: {\n false: null,\n true: styles.spin,\n },\n },\n /* eslint-enable sort-keys-fix/sort-keys-fix */\n});\n"],"mappings":";;;;AAGA,MAAM,OAAO,SAAS;;;;;;;;AAStB,MAAa,SAAS,oBAAoB,EAAE,iBAAU;AACpD,QAAO,EACL,MAAM,KAAG;mBACM,KAAK;OAErB;EACD;AAEF,MAAa,WAAW,IAAI,WAAW;CACrC,iBAAiB,EACf,MAAM,OACP;CAED,UAAU,EACR,MAAM;EACJ,OAAO;EACP,MAAM,OAAO;EACd,EACF;CAEF,CAAC"}
@@ -1,31 +1,24 @@
1
1
  'use client';
2
2
 
3
3
  import FlexBasic_default from "../Flex/FlexBasic.mjs";
4
- import { FALLBACK_DARK, FALLBACK_LIGHT, useStyles } from "./style.mjs";
4
+ import { FALLBACK_DARK, FALLBACK_LIGHT, styles, variants } from "./style.mjs";
5
5
  import usePreview_default from "./components/usePreview.mjs";
6
- import { memo, useMemo } from "react";
6
+ import { memo } from "react";
7
7
  import { jsx, jsxs } from "react/jsx-runtime";
8
8
  import { Image, Skeleton } from "antd";
9
- import { cva } from "class-variance-authority";
9
+ import { cssVar, cx, useThemeMode } from "antd-style";
10
10
 
11
11
  //#region src/Image/Image.tsx
12
12
  const Image$1 = memo(({ ref, style, preview, isLoading, maxHeight = "100%", maxWidth = "100%", minHeight, minWidth, actions, className, alwaysShowActions, variant = "filled", objectFit = "cover", classNames, styles: customStyles, onClick, width, height, ...rest }) => {
13
- const { styles, cx, theme } = useStyles({ alwaysShowActions });
13
+ const { isDarkMode } = useThemeMode();
14
+ const actionsClassName = alwaysShowActions ? styles.actionsVisible : styles.actionsHidden;
14
15
  const mergePreivew = usePreview_default(preview);
15
- const variants = useMemo(() => cva(styles.root, {
16
- defaultVariants: { variant: "filled" },
17
- variants: { variant: {
18
- filled: styles.filled,
19
- outlined: styles.outlined,
20
- borderless: styles.borderless
21
- } }
22
- }), [styles]);
23
16
  if (isLoading) return /* @__PURE__ */ jsx("div", {
24
17
  onClick,
25
18
  children: /* @__PURE__ */ jsx(Skeleton.Avatar, {
26
19
  active: true,
27
20
  style: {
28
- borderRadius: theme.borderRadius,
21
+ borderRadius: cssVar.borderRadius,
29
22
  height,
30
23
  maxHeight,
31
24
  maxWidth,
@@ -40,12 +33,12 @@ const Image$1 = memo(({ ref, style, preview, isLoading, maxHeight = "100%", maxW
40
33
  ref,
41
34
  style,
42
35
  children: [actions && /* @__PURE__ */ jsx("div", {
43
- className: styles.actions,
36
+ className: cx(actionsClassName, alwaysShowActions ? "" : "actions-hidden"),
44
37
  children: actions
45
38
  }), /* @__PURE__ */ jsx(Image, {
46
39
  className: cx(styles.image, classNames?.image),
47
40
  classNames: { root: cx(styles.wrapper, classNames?.wrapper) },
48
- fallback: theme.isDarkMode ? FALLBACK_DARK : FALLBACK_LIGHT,
41
+ fallback: isDarkMode ? FALLBACK_DARK : FALLBACK_LIGHT,
49
42
  height,
50
43
  loading: "lazy",
51
44
  onClick,
@@ -1 +1 @@
1
- {"version":3,"file":"Image.mjs","names":["Image","usePreview","Flexbox","AntImage"],"sources":["../../src/Image/Image.tsx"],"sourcesContent":["'use client';\n\nimport { Image as AntImage, Skeleton } from 'antd';\nimport { cva } from 'class-variance-authority';\nimport { memo, useMemo } from 'react';\n\nimport { Flexbox } from '@/Flex';\n\nimport usePreview from './components/usePreview';\nimport { FALLBACK_DARK, FALLBACK_LIGHT, useStyles } from './style';\nimport type { ImageProps } from './type';\n\nconst Image = memo<ImageProps>(\n ({\n ref,\n style,\n preview,\n isLoading,\n maxHeight = '100%',\n maxWidth = '100%',\n minHeight,\n minWidth,\n actions,\n className,\n alwaysShowActions,\n variant = 'filled',\n objectFit = 'cover',\n classNames,\n styles: customStyles,\n onClick,\n width,\n height,\n ...rest\n }) => {\n const { styles, cx, theme } = useStyles({\n alwaysShowActions,\n });\n const mergePreivew = usePreview(preview);\n\n const variants = useMemo(\n () =>\n cva(styles.root, {\n defaultVariants: {\n variant: 'filled',\n },\n /* eslint-disable sort-keys-fix/sort-keys-fix */\n variants: {\n variant: {\n filled: styles.filled,\n outlined: styles.outlined,\n borderless: styles.borderless,\n },\n },\n /* eslint-enable sort-keys-fix/sort-keys-fix */\n }),\n [styles],\n );\n\n if (isLoading)\n return (\n <div onClick={onClick}>\n <Skeleton.Avatar\n active\n style={{\n borderRadius: theme.borderRadius,\n height,\n maxHeight,\n maxWidth,\n minHeight,\n minWidth,\n width,\n }}\n />\n </div>\n );\n\n return (\n <Flexbox className={cx(variants({ variant }), className)} ref={ref} style={style}>\n {actions && <div className={styles.actions}>{actions}</div>}\n <AntImage\n className={cx(styles.image, classNames?.image)}\n classNames={{\n root: cx(styles.wrapper, classNames?.wrapper),\n }}\n fallback={theme.isDarkMode ? FALLBACK_DARK : FALLBACK_LIGHT}\n height={height}\n loading={'lazy'}\n onClick={onClick}\n preview={preview === false ? false : (mergePreivew as any)}\n style={{\n maxHeight,\n maxWidth,\n minHeight,\n minWidth,\n objectFit: objectFit || 'cover',\n ...customStyles?.image,\n }}\n styles={{\n root: customStyles?.wrapper,\n }}\n width={width}\n {...rest}\n />\n </Flexbox>\n );\n },\n);\n\nImage.displayName = 'Image';\n\nexport default Image;\n"],"mappings":";;;;;;;;;;;AAYA,MAAMA,UAAQ,MACX,EACC,KACA,OACA,SACA,WACA,YAAY,QACZ,WAAW,QACX,WACA,UACA,SACA,WACA,mBACA,UAAU,UACV,YAAY,SACZ,YACA,QAAQ,cACR,SACA,OACA,QACA,GAAG,WACC;CACJ,MAAM,EAAE,QAAQ,IAAI,UAAU,UAAU,EACtC,mBACD,CAAC;CACF,MAAM,eAAeC,mBAAW,QAAQ;CAExC,MAAM,WAAW,cAEb,IAAI,OAAO,MAAM;EACf,iBAAiB,EACf,SAAS,UACV;EAED,UAAU,EACR,SAAS;GACP,QAAQ,OAAO;GACf,UAAU,OAAO;GACjB,YAAY,OAAO;GACpB,EACF;EAEF,CAAC,EACJ,CAAC,OAAO,CACT;AAED,KAAI,UACF,QACE,oBAAC;EAAa;YACZ,oBAAC,SAAS;GACR;GACA,OAAO;IACL,cAAc,MAAM;IACpB;IACA;IACA;IACA;IACA;IACA;IACD;IACD;GACE;AAGV,QACE,qBAACC;EAAQ,WAAW,GAAG,SAAS,EAAE,SAAS,CAAC,EAAE,UAAU;EAAO;EAAY;aACxE,WAAW,oBAAC;GAAI,WAAW,OAAO;aAAU;IAAc,EAC3D,oBAACC;GACC,WAAW,GAAG,OAAO,OAAO,YAAY,MAAM;GAC9C,YAAY,EACV,MAAM,GAAG,OAAO,SAAS,YAAY,QAAQ,EAC9C;GACD,UAAU,MAAM,aAAa,gBAAgB;GACrC;GACR,SAAS;GACA;GACT,SAAS,YAAY,QAAQ,QAAS;GACtC,OAAO;IACL;IACA;IACA;IACA;IACA,WAAW,aAAa;IACxB,GAAG,cAAc;IAClB;GACD,QAAQ,EACN,MAAM,cAAc,SACrB;GACM;GACP,GAAI;IACJ;GACM;EAGf;AAED,QAAM,cAAc;AAEpB,oBAAeH"}
1
+ {"version":3,"file":"Image.mjs","names":["Image","usePreview","Flexbox","AntImage"],"sources":["../../src/Image/Image.tsx"],"sourcesContent":["'use client';\n\nimport { Image as AntImage, Skeleton } from 'antd';\nimport { cssVar, cx, useThemeMode } from 'antd-style';\nimport { memo } from 'react';\n\nimport { Flexbox } from '@/Flex';\n\nimport usePreview from './components/usePreview';\nimport { FALLBACK_DARK, FALLBACK_LIGHT, styles, variants } from './style';\nimport type { ImageProps } from './type';\n\nconst Image = memo<ImageProps>(\n ({\n ref,\n style,\n preview,\n isLoading,\n maxHeight = '100%',\n maxWidth = '100%',\n minHeight,\n minWidth,\n actions,\n className,\n alwaysShowActions,\n variant = 'filled',\n objectFit = 'cover',\n classNames,\n styles: customStyles,\n onClick,\n width,\n height,\n ...rest\n }) => {\n const { isDarkMode } = useThemeMode();\n const actionsClassName = alwaysShowActions ? styles.actionsVisible : styles.actionsHidden;\n const mergePreivew = usePreview(preview);\n\n if (isLoading)\n return (\n <div onClick={onClick}>\n <Skeleton.Avatar\n active\n style={{\n borderRadius: cssVar.borderRadius,\n height,\n maxHeight,\n maxWidth,\n minHeight,\n minWidth,\n width,\n }}\n />\n </div>\n );\n\n return (\n <Flexbox className={cx(variants({ variant }), className)} ref={ref} style={style}>\n {actions && (\n <div className={cx(actionsClassName, alwaysShowActions ? '' : 'actions-hidden')}>\n {actions}\n </div>\n )}\n <AntImage\n className={cx(styles.image, classNames?.image)}\n classNames={{\n root: cx(styles.wrapper, classNames?.wrapper),\n }}\n fallback={isDarkMode ? FALLBACK_DARK : FALLBACK_LIGHT}\n height={height}\n loading={'lazy'}\n onClick={onClick}\n preview={preview === false ? false : (mergePreivew as any)}\n style={{\n maxHeight,\n maxWidth,\n minHeight,\n minWidth,\n objectFit: objectFit || 'cover',\n ...customStyles?.image,\n }}\n styles={{\n root: customStyles?.wrapper,\n }}\n width={width}\n {...rest}\n />\n </Flexbox>\n );\n },\n);\n\nImage.displayName = 'Image';\n\nexport default Image;\n"],"mappings":";;;;;;;;;;;AAYA,MAAMA,UAAQ,MACX,EACC,KACA,OACA,SACA,WACA,YAAY,QACZ,WAAW,QACX,WACA,UACA,SACA,WACA,mBACA,UAAU,UACV,YAAY,SACZ,YACA,QAAQ,cACR,SACA,OACA,QACA,GAAG,WACC;CACJ,MAAM,EAAE,eAAe,cAAc;CACrC,MAAM,mBAAmB,oBAAoB,OAAO,iBAAiB,OAAO;CAC5E,MAAM,eAAeC,mBAAW,QAAQ;AAExC,KAAI,UACF,QACE,oBAAC;EAAa;YACZ,oBAAC,SAAS;GACR;GACA,OAAO;IACL,cAAc,OAAO;IACrB;IACA;IACA;IACA;IACA;IACA;IACD;IACD;GACE;AAGV,QACE,qBAACC;EAAQ,WAAW,GAAG,SAAS,EAAE,SAAS,CAAC,EAAE,UAAU;EAAO;EAAY;aACxE,WACC,oBAAC;GAAI,WAAW,GAAG,kBAAkB,oBAAoB,KAAK,iBAAiB;aAC5E;IACG,EAER,oBAACC;GACC,WAAW,GAAG,OAAO,OAAO,YAAY,MAAM;GAC9C,YAAY,EACV,MAAM,GAAG,OAAO,SAAS,YAAY,QAAQ,EAC9C;GACD,UAAU,aAAa,gBAAgB;GAC/B;GACR,SAAS;GACA;GACT,SAAS,YAAY,QAAQ,QAAS;GACtC,OAAO;IACL;IACA;IACA;IACA;IACA,WAAW,aAAa;IACxB,GAAG,cAAc;IAClB;GACD,QAAQ,EACN,MAAM,cAAc,SACrB;GACM;GACP,GAAI;IACJ;GACM;EAGf;AAED,QAAM,cAAc;AAEpB,oBAAeH"}
@@ -1,8 +1,8 @@
1
1
  import { PreviewGroupProps } from "./type.mjs";
2
- import * as react44 from "react";
2
+ import * as react8 from "react";
3
3
 
4
4
  //#region src/Image/PreviewGroup.d.ts
5
- declare const PreviewGroup: react44.NamedExoticComponent<PreviewGroupProps>;
5
+ declare const PreviewGroup: react8.NamedExoticComponent<PreviewGroupProps>;
6
6
  //#endregion
7
7
  export { PreviewGroup };
8
8
  //# sourceMappingURL=PreviewGroup.d.mts.map
@@ -1,13 +1,12 @@
1
1
  import FlexBasic_default from "../../Flex/FlexBasic.mjs";
2
2
  import ActionIcon_default from "../../ActionIcon/ActionIcon.mjs";
3
- import { useStyles } from "../style.mjs";
3
+ import { styles } from "../style.mjs";
4
4
  import { memo } from "react";
5
5
  import { jsx, jsxs } from "react/jsx-runtime";
6
6
  import { FlipHorizontal, FlipVertical, RotateCcw, RotateCw, ZoomIn, ZoomOut } from "lucide-react";
7
7
 
8
8
  //#region src/Image/components/Toolbar.tsx
9
9
  const Toolbar = memo(({ children, info, minScale, maxScale }) => {
10
- const { styles } = useStyles();
11
10
  const { transform: { scale }, actions: { onFlipY, onFlipX, onRotateLeft, onRotateRight, onZoomOut, onZoomIn } } = info;
12
11
  return /* @__PURE__ */ jsxs(FlexBasic_default, {
13
12
  className: styles.toolbar,
@@ -1 +1 @@
1
- {"version":3,"file":"Toolbar.mjs","names":["Flexbox","ActionIcon"],"sources":["../../../src/Image/components/Toolbar.tsx"],"sourcesContent":["import { FlipHorizontal, FlipVertical, RotateCcw, RotateCw, ZoomIn, ZoomOut } from 'lucide-react';\nimport type { ToolbarRenderInfoType } from 'rc-image/lib/Preview';\nimport { type ReactNode, memo } from 'react';\n\nimport ActionIcon from '@/ActionIcon';\nimport { Flexbox } from '@/Flex';\n\nimport { useStyles } from '../style';\n\nexport interface ToolbarProps {\n children?: ReactNode;\n info: Omit<ToolbarRenderInfoType, 'current' | 'total'>;\n maxScale: number;\n minScale: number;\n}\n\nconst Toolbar = memo<ToolbarProps>(({ children, info, minScale, maxScale }) => {\n const { styles } = useStyles();\n const {\n transform: { scale },\n actions: { onFlipY, onFlipX, onRotateLeft, onRotateRight, onZoomOut, onZoomIn },\n } = info;\n\n return (\n <Flexbox className={styles.toolbar} gap={4} horizontal>\n <ActionIcon icon={FlipHorizontal} onClick={onFlipX} />\n <ActionIcon icon={FlipVertical} onClick={onFlipY} />\n <ActionIcon icon={RotateCcw} onClick={onRotateLeft} />\n <ActionIcon icon={RotateCw} onClick={onRotateRight} />\n <ActionIcon disabled={scale === minScale} icon={ZoomOut} onClick={onZoomOut} />\n <ActionIcon disabled={scale === maxScale} icon={ZoomIn} onClick={onZoomIn} />\n {children}\n </Flexbox>\n );\n});\n\nexport default Toolbar;\n"],"mappings":";;;;;;;;AAgBA,MAAM,UAAU,MAAoB,EAAE,UAAU,MAAM,UAAU,eAAe;CAC7E,MAAM,EAAE,WAAW,WAAW;CAC9B,MAAM,EACJ,WAAW,EAAE,SACb,SAAS,EAAE,SAAS,SAAS,cAAc,eAAe,WAAW,eACnE;AAEJ,QACE,qBAACA;EAAQ,WAAW,OAAO;EAAS,KAAK;EAAG;;GAC1C,oBAACC;IAAW,MAAM;IAAgB,SAAS;KAAW;GACtD,oBAACA;IAAW,MAAM;IAAc,SAAS;KAAW;GACpD,oBAACA;IAAW,MAAM;IAAW,SAAS;KAAgB;GACtD,oBAACA;IAAW,MAAM;IAAU,SAAS;KAAiB;GACtD,oBAACA;IAAW,UAAU,UAAU;IAAU,MAAM;IAAS,SAAS;KAAa;GAC/E,oBAACA;IAAW,UAAU,UAAU;IAAU,MAAM;IAAQ,SAAS;KAAY;GAC5E;;GACO;EAEZ;AAEF,sBAAe"}
1
+ {"version":3,"file":"Toolbar.mjs","names":["Flexbox","ActionIcon"],"sources":["../../../src/Image/components/Toolbar.tsx"],"sourcesContent":["import { FlipHorizontal, FlipVertical, RotateCcw, RotateCw, ZoomIn, ZoomOut } from 'lucide-react';\nimport type { ToolbarRenderInfoType } from 'rc-image/lib/Preview';\nimport { type ReactNode, memo } from 'react';\n\nimport ActionIcon from '@/ActionIcon';\nimport { Flexbox } from '@/Flex';\n\nimport { styles } from '../style';\n\nexport interface ToolbarProps {\n children?: ReactNode;\n info: Omit<ToolbarRenderInfoType, 'current' | 'total'>;\n maxScale: number;\n minScale: number;\n}\n\nconst Toolbar = memo<ToolbarProps>(({ children, info, minScale, maxScale }) => {\n const {\n transform: { scale },\n actions: { onFlipY, onFlipX, onRotateLeft, onRotateRight, onZoomOut, onZoomIn },\n } = info;\n\n return (\n <Flexbox className={styles.toolbar} gap={4} horizontal>\n <ActionIcon icon={FlipHorizontal} onClick={onFlipX} />\n <ActionIcon icon={FlipVertical} onClick={onFlipY} />\n <ActionIcon icon={RotateCcw} onClick={onRotateLeft} />\n <ActionIcon icon={RotateCw} onClick={onRotateRight} />\n <ActionIcon disabled={scale === minScale} icon={ZoomOut} onClick={onZoomOut} />\n <ActionIcon disabled={scale === maxScale} icon={ZoomIn} onClick={onZoomIn} />\n {children}\n </Flexbox>\n );\n});\n\nexport default Toolbar;\n"],"mappings":";;;;;;;;AAgBA,MAAM,UAAU,MAAoB,EAAE,UAAU,MAAM,UAAU,eAAe;CAC7E,MAAM,EACJ,WAAW,EAAE,SACb,SAAS,EAAE,SAAS,SAAS,cAAc,eAAe,WAAW,eACnE;AAEJ,QACE,qBAACA;EAAQ,WAAW,OAAO;EAAS,KAAK;EAAG;;GAC1C,oBAACC;IAAW,MAAM;IAAgB,SAAS;KAAW;GACtD,oBAACA;IAAW,MAAM;IAAc,SAAS;KAAW;GACpD,oBAACA;IAAW,MAAM;IAAW,SAAS;KAAgB;GACtD,oBAACA;IAAW,MAAM;IAAU,SAAS;KAAiB;GACtD,oBAACA;IAAW,UAAU,UAAU;IAAU,MAAM;IAAS,SAAS;KAAa;GAC/E,oBAACA;IAAW,UAAU,UAAU;IAAU,MAAM;IAAQ,SAAS;KAAY;GAC5E;;GACO;EAEZ;AAEF,sBAAe"}
@@ -1,15 +1,15 @@
1
1
  import Icon_default from "../../Icon/Icon.mjs";
2
- import { useStyles } from "../style.mjs";
2
+ import { styles } from "../style.mjs";
3
3
  import Preview_default from "./Preview.mjs";
4
4
  import Toolbar_default from "./Toolbar.mjs";
5
5
  import { useMemo, useState } from "react";
6
6
  import { jsx } from "react/jsx-runtime";
7
+ import { cx } from "antd-style";
7
8
  import { X } from "lucide-react";
8
9
 
9
10
  //#region src/Image/components/usePreview.tsx
10
11
  const usePreview = (props) => {
11
12
  const [visible, setVisible] = useState(false);
12
- const { cx, styles } = useStyles();
13
13
  return useMemo(() => {
14
14
  if (props === false) return props;
15
15
  const { onVisibleChange, onOpenChange, minScale = .32, maxScale = 32, toolbarAddon, rootClassName, imageRender, toolbarRender, actionsRender, ...rest } = props === true ? {} : props || {};
@@ -1 +1 @@
1
- {"version":3,"file":"usePreview.mjs","names":["Toolbar","Icon","Preview"],"sources":["../../../src/Image/components/usePreview.tsx"],"sourcesContent":["import type { ImageProps as AntdImageProps } from 'antd';\nimport { X } from 'lucide-react';\nimport { useMemo, useState } from 'react';\n\nimport Icon from '@/Icon';\n\nimport { useStyles } from '../style';\nimport type { ImagePreviewOptions } from '../type';\nimport Preview from './Preview';\nimport Toolbar from './Toolbar';\n\nexport const usePreview = (\n props: ImagePreviewOptions | boolean | undefined,\n): AntdImageProps['preview'] => {\n const [visible, setVisible] = useState(false);\n const { cx, styles } = useStyles();\n\n return useMemo(() => {\n if (props === false) return props;\n\n const {\n onVisibleChange,\n onOpenChange,\n minScale = 0.32,\n maxScale = 32,\n toolbarAddon,\n rootClassName,\n imageRender,\n toolbarRender,\n actionsRender,\n ...rest\n }: ImagePreviewOptions = (props === true ? {} : props || {}) as ImagePreviewOptions;\n\n return {\n actionsRender:\n actionsRender ||\n ((_, info) => {\n const originalNode = (\n <Toolbar info={info} maxScale={maxScale} minScale={minScale}>\n {toolbarAddon}\n </Toolbar>\n );\n // 向后兼容 toolbarRender\n if (toolbarRender) return toolbarRender(originalNode, info);\n return originalNode;\n }),\n closeIcon: <Icon color={'#fff'} icon={X} />,\n imageRender: (originalNode, info) => {\n const node = <Preview visible={visible}>{originalNode}</Preview>;\n if (imageRender) return imageRender(node, info);\n return node;\n },\n maxScale,\n minScale,\n onOpenChange: (open: boolean) => {\n setVisible(open);\n // 支持新的 onOpenChange\n onOpenChange?.(open);\n // 向后兼容旧的 onVisibleChange\n onVisibleChange?.(open, !open);\n },\n rootClassName: cx(styles.preview, rootClassName),\n styles: { mask: { backdropFilter: 'blur(8px)' } },\n ...rest,\n };\n }, [props, visible, styles]);\n};\n\nexport default usePreview;\n"],"mappings":";;;;;;;;;AAWA,MAAa,cACX,UAC8B;CAC9B,MAAM,CAAC,SAAS,cAAc,SAAS,MAAM;CAC7C,MAAM,EAAE,IAAI,WAAW,WAAW;AAElC,QAAO,cAAc;AACnB,MAAI,UAAU,MAAO,QAAO;EAE5B,MAAM,EACJ,iBACA,cACA,WAAW,KACX,WAAW,IACX,cACA,eACA,aACA,eACA,eACA,GAAG,SACqB,UAAU,OAAO,EAAE,GAAG,SAAS,EAAE;AAE3D,SAAO;GACL,eACE,mBACE,GAAG,SAAS;IACZ,MAAM,eACJ,oBAACA;KAAc;KAAgB;KAAoB;eAChD;MACO;AAGZ,QAAI,cAAe,QAAO,cAAc,cAAc,KAAK;AAC3D,WAAO;;GAEX,WAAW,oBAACC;IAAK,OAAO;IAAQ,MAAM;KAAK;GAC3C,cAAc,cAAc,SAAS;IACnC,MAAM,OAAO,oBAACC;KAAiB;eAAU;MAAuB;AAChE,QAAI,YAAa,QAAO,YAAY,MAAM,KAAK;AAC/C,WAAO;;GAET;GACA;GACA,eAAe,SAAkB;AAC/B,eAAW,KAAK;AAEhB,mBAAe,KAAK;AAEpB,sBAAkB,MAAM,CAAC,KAAK;;GAEhC,eAAe,GAAG,OAAO,SAAS,cAAc;GAChD,QAAQ,EAAE,MAAM,EAAE,gBAAgB,aAAa,EAAE;GACjD,GAAG;GACJ;IACA;EAAC;EAAO;EAAS;EAAO,CAAC;;AAG9B,yBAAe"}
1
+ {"version":3,"file":"usePreview.mjs","names":["Toolbar","Icon","Preview"],"sources":["../../../src/Image/components/usePreview.tsx"],"sourcesContent":["import type { ImageProps as AntdImageProps } from 'antd';\nimport { cx } from 'antd-style';\nimport { X } from 'lucide-react';\nimport { useMemo, useState } from 'react';\n\nimport Icon from '@/Icon';\n\nimport { styles } from '../style';\nimport type { ImagePreviewOptions } from '../type';\nimport Preview from './Preview';\nimport Toolbar from './Toolbar';\n\nexport const usePreview = (\n props: ImagePreviewOptions | boolean | undefined,\n): AntdImageProps['preview'] => {\n const [visible, setVisible] = useState(false);\n\n return useMemo(() => {\n if (props === false) return props;\n\n const {\n onVisibleChange,\n onOpenChange,\n minScale = 0.32,\n maxScale = 32,\n toolbarAddon,\n rootClassName,\n imageRender,\n toolbarRender,\n actionsRender,\n ...rest\n }: ImagePreviewOptions = (props === true ? {} : props || {}) as ImagePreviewOptions;\n\n return {\n actionsRender:\n actionsRender ||\n ((_, info) => {\n const originalNode = (\n <Toolbar info={info} maxScale={maxScale} minScale={minScale}>\n {toolbarAddon}\n </Toolbar>\n );\n // 向后兼容 toolbarRender\n if (toolbarRender) return toolbarRender(originalNode, info);\n return originalNode;\n }),\n closeIcon: <Icon color={'#fff'} icon={X} />,\n imageRender: (originalNode, info) => {\n const node = <Preview visible={visible}>{originalNode}</Preview>;\n if (imageRender) return imageRender(node, info);\n return node;\n },\n maxScale,\n minScale,\n onOpenChange: (open: boolean) => {\n setVisible(open);\n // 支持新的 onOpenChange\n onOpenChange?.(open);\n // 向后兼容旧的 onVisibleChange\n onVisibleChange?.(open, !open);\n },\n rootClassName: cx(styles.preview, rootClassName),\n styles: { mask: { backdropFilter: 'blur(8px)' } },\n ...rest,\n };\n }, [props, visible, styles]);\n};\n\nexport default usePreview;\n"],"mappings":";;;;;;;;;;AAYA,MAAa,cACX,UAC8B;CAC9B,MAAM,CAAC,SAAS,cAAc,SAAS,MAAM;AAE7C,QAAO,cAAc;AACnB,MAAI,UAAU,MAAO,QAAO;EAE5B,MAAM,EACJ,iBACA,cACA,WAAW,KACX,WAAW,IACX,cACA,eACA,aACA,eACA,eACA,GAAG,SACqB,UAAU,OAAO,EAAE,GAAG,SAAS,EAAE;AAE3D,SAAO;GACL,eACE,mBACE,GAAG,SAAS;IACZ,MAAM,eACJ,oBAACA;KAAc;KAAgB;KAAoB;eAChD;MACO;AAGZ,QAAI,cAAe,QAAO,cAAc,cAAc,KAAK;AAC3D,WAAO;;GAEX,WAAW,oBAACC;IAAK,OAAO;IAAQ,MAAM;KAAK;GAC3C,cAAc,cAAc,SAAS;IACnC,MAAM,OAAO,oBAACC;KAAiB;eAAU;MAAuB;AAChE,QAAI,YAAa,QAAO,YAAY,MAAM,KAAK;AAC/C,WAAO;;GAET;GACA;GACA,eAAe,SAAkB;AAC/B,eAAW,KAAK;AAEhB,mBAAe,KAAK;AAEpB,sBAAkB,MAAM,CAAC,KAAK;;GAEhC,eAAe,GAAG,OAAO,SAAS,cAAc;GAChD,QAAQ,EAAE,MAAM,EAAE,gBAAgB,aAAa,EAAE;GACjD,GAAG;GACJ;IACA;EAAC;EAAO;EAAS;EAAO,CAAC;;AAG9B,yBAAe"}
@@ -1,15 +1,15 @@
1
1
  import Icon_default from "../../Icon/Icon.mjs";
2
- import { useStyles } from "../style.mjs";
2
+ import { styles } from "../style.mjs";
3
3
  import Preview_default from "./Preview.mjs";
4
4
  import Toolbar_default from "./Toolbar.mjs";
5
5
  import { useMemo, useState } from "react";
6
6
  import { jsx } from "react/jsx-runtime";
7
+ import { cx } from "antd-style";
7
8
  import { X } from "lucide-react";
8
9
 
9
10
  //#region src/Image/components/usePreviewGroup.tsx
10
11
  const usePreview = (props) => {
11
12
  const [visible, setVisible] = useState(false);
12
- const { cx, styles: componentStyles } = useStyles();
13
13
  return useMemo(() => {
14
14
  if (props === false) return props;
15
15
  const { onVisibleChange, onOpenChange, minScale = .32, maxScale = 32, toolbarAddon, rootClassName, imageRender, toolbarRender, ...rest } = props === true ? {} : props || {};
@@ -24,7 +24,7 @@ const usePreview = (props) => {
24
24
  if (toolbarRender) return toolbarRender(originalNode, info);
25
25
  return originalNode;
26
26
  },
27
- classNames: { root: cx(componentStyles.preview, rootClassName) },
27
+ classNames: { root: cx(styles.preview, rootClassName) },
28
28
  closeIcon: /* @__PURE__ */ jsx(Icon_default, {
29
29
  color: "#fff",
30
30
  icon: X
@@ -49,7 +49,7 @@ const usePreview = (props) => {
49
49
  }, [
50
50
  props,
51
51
  visible,
52
- componentStyles
52
+ styles
53
53
  ]);
54
54
  };
55
55
  var usePreviewGroup_default = usePreview;
@@ -1 +1 @@
1
- {"version":3,"file":"usePreviewGroup.mjs","names":["Toolbar","Icon","Preview"],"sources":["../../../src/Image/components/usePreviewGroup.tsx"],"sourcesContent":["import type { GroupPreviewConfig } from 'antd/es/image/PreviewGroup';\nimport { X } from 'lucide-react';\nimport { useMemo, useState } from 'react';\n\nimport Icon from '@/Icon';\n\nimport { useStyles } from '../style';\nimport type { PreviewGroupPreviewOptions } from '../type';\nimport Preview from './Preview';\nimport Toolbar from './Toolbar';\n\nexport const usePreview = (\n props: PreviewGroupPreviewOptions | boolean | undefined,\n): GroupPreviewConfig | boolean => {\n const [visible, setVisible] = useState(false);\n const { cx, styles: componentStyles } = useStyles();\n\n return useMemo(() => {\n if (props === false) return props;\n\n const {\n onVisibleChange,\n onOpenChange,\n minScale = 0.32,\n maxScale = 32,\n toolbarAddon,\n rootClassName,\n imageRender,\n toolbarRender,\n ...rest\n }: PreviewGroupPreviewOptions = (\n props === true ? {} : props || {}\n ) as PreviewGroupPreviewOptions;\n\n return {\n actionsRender: (_, info) => {\n const originalNode = (\n <Toolbar info={info} maxScale={maxScale} minScale={minScale}>\n {toolbarAddon}\n </Toolbar>\n );\n if (toolbarRender) return toolbarRender(originalNode, info);\n return originalNode;\n },\n classNames: {\n root: cx(componentStyles.preview, rootClassName),\n },\n closeIcon: <Icon color={'#fff'} icon={X} />,\n imageRender: (originalNode, info) => {\n const node = <Preview visible={visible}>{originalNode}</Preview>;\n if (imageRender) return imageRender(node, info);\n return node;\n },\n maxScale,\n minScale,\n onOpenChange: (open: boolean, info: { current: number }) => {\n setVisible(open);\n // 支持新的 onOpenChange\n onOpenChange?.(open, info);\n // 向后兼容旧的 onVisibleChange (注意参数差异)\n onVisibleChange?.(open, !open, info.current);\n },\n ...rest,\n };\n }, [props, visible, componentStyles]);\n};\n\nexport default usePreview;\n"],"mappings":";;;;;;;;;AAWA,MAAa,cACX,UACiC;CACjC,MAAM,CAAC,SAAS,cAAc,SAAS,MAAM;CAC7C,MAAM,EAAE,IAAI,QAAQ,oBAAoB,WAAW;AAEnD,QAAO,cAAc;AACnB,MAAI,UAAU,MAAO,QAAO;EAE5B,MAAM,EACJ,iBACA,cACA,WAAW,KACX,WAAW,IACX,cACA,eACA,aACA,eACA,GAAG,SAEH,UAAU,OAAO,EAAE,GAAG,SAAS,EAAE;AAGnC,SAAO;GACL,gBAAgB,GAAG,SAAS;IAC1B,MAAM,eACJ,oBAACA;KAAc;KAAgB;KAAoB;eAChD;MACO;AAEZ,QAAI,cAAe,QAAO,cAAc,cAAc,KAAK;AAC3D,WAAO;;GAET,YAAY,EACV,MAAM,GAAG,gBAAgB,SAAS,cAAc,EACjD;GACD,WAAW,oBAACC;IAAK,OAAO;IAAQ,MAAM;KAAK;GAC3C,cAAc,cAAc,SAAS;IACnC,MAAM,OAAO,oBAACC;KAAiB;eAAU;MAAuB;AAChE,QAAI,YAAa,QAAO,YAAY,MAAM,KAAK;AAC/C,WAAO;;GAET;GACA;GACA,eAAe,MAAe,SAA8B;AAC1D,eAAW,KAAK;AAEhB,mBAAe,MAAM,KAAK;AAE1B,sBAAkB,MAAM,CAAC,MAAM,KAAK,QAAQ;;GAE9C,GAAG;GACJ;IACA;EAAC;EAAO;EAAS;EAAgB,CAAC;;AAGvC,8BAAe"}
1
+ {"version":3,"file":"usePreviewGroup.mjs","names":["Toolbar","componentStyles","Icon","Preview"],"sources":["../../../src/Image/components/usePreviewGroup.tsx"],"sourcesContent":["import { cx } from 'antd-style';\nimport type { GroupPreviewConfig } from 'antd/es/image/PreviewGroup';\nimport { X } from 'lucide-react';\nimport { useMemo, useState } from 'react';\n\nimport Icon from '@/Icon';\n\nimport { styles as componentStyles } from '../style';\nimport type { PreviewGroupPreviewOptions } from '../type';\nimport Preview from './Preview';\nimport Toolbar from './Toolbar';\n\nexport const usePreview = (\n props: PreviewGroupPreviewOptions | boolean | undefined,\n): GroupPreviewConfig | boolean => {\n const [visible, setVisible] = useState(false);\n\n return useMemo(() => {\n if (props === false) return props;\n\n const {\n onVisibleChange,\n onOpenChange,\n minScale = 0.32,\n maxScale = 32,\n toolbarAddon,\n rootClassName,\n imageRender,\n toolbarRender,\n ...rest\n }: PreviewGroupPreviewOptions = (\n props === true ? {} : props || {}\n ) as PreviewGroupPreviewOptions;\n\n return {\n actionsRender: (_, info) => {\n const originalNode = (\n <Toolbar info={info} maxScale={maxScale} minScale={minScale}>\n {toolbarAddon}\n </Toolbar>\n );\n if (toolbarRender) return toolbarRender(originalNode, info);\n return originalNode;\n },\n classNames: {\n root: cx(componentStyles.preview, rootClassName),\n },\n closeIcon: <Icon color={'#fff'} icon={X} />,\n imageRender: (originalNode, info) => {\n const node = <Preview visible={visible}>{originalNode}</Preview>;\n if (imageRender) return imageRender(node, info);\n return node;\n },\n maxScale,\n minScale,\n onOpenChange: (open: boolean, info: { current: number }) => {\n setVisible(open);\n // 支持新的 onOpenChange\n onOpenChange?.(open, info);\n // 向后兼容旧的 onVisibleChange (注意参数差异)\n onVisibleChange?.(open, !open, info.current);\n },\n ...rest,\n };\n }, [props, visible, componentStyles]);\n};\n\nexport default usePreview;\n"],"mappings":";;;;;;;;;;AAYA,MAAa,cACX,UACiC;CACjC,MAAM,CAAC,SAAS,cAAc,SAAS,MAAM;AAE7C,QAAO,cAAc;AACnB,MAAI,UAAU,MAAO,QAAO;EAE5B,MAAM,EACJ,iBACA,cACA,WAAW,KACX,WAAW,IACX,cACA,eACA,aACA,eACA,GAAG,SAEH,UAAU,OAAO,EAAE,GAAG,SAAS,EAAE;AAGnC,SAAO;GACL,gBAAgB,GAAG,SAAS;IAC1B,MAAM,eACJ,oBAACA;KAAc;KAAgB;KAAoB;eAChD;MACO;AAEZ,QAAI,cAAe,QAAO,cAAc,cAAc,KAAK;AAC3D,WAAO;;GAET,YAAY,EACV,MAAM,GAAGC,OAAgB,SAAS,cAAc,EACjD;GACD,WAAW,oBAACC;IAAK,OAAO;IAAQ,MAAM;KAAK;GAC3C,cAAc,cAAc,SAAS;IACnC,MAAM,OAAO,oBAACC;KAAiB;eAAU;MAAuB;AAChE,QAAI,YAAa,QAAO,YAAY,MAAM,KAAK;AAC/C,WAAO;;GAET;GACA;GACA,eAAe,MAAe,SAA8B;AAC1D,eAAW,KAAK;AAEhB,mBAAe,MAAM,KAAK;AAE1B,sBAAkB,MAAM,CAAC,MAAM,KAAK,QAAQ;;GAE9C,GAAG;GACJ;IACA;EAAC;EAAO;EAASF;EAAgB,CAAC;;AAGvC,8BAAe"}