naive-ui 2.41.1 → 2.43.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (685) hide show
  1. package/dist/index.js +3349 -1068
  2. package/dist/index.mjs +3339 -1070
  3. package/dist/index.prod.js +1 -1
  4. package/dist/index.prod.mjs +1 -1
  5. package/es/_internal/icon/src/styles/index.cssr.mjs +0 -1
  6. package/es/_internal/icons/replaceable.mjs +1 -1
  7. package/es/_internal/scrollbar/src/Scrollbar.d.ts +3 -3
  8. package/es/_internal/select-menu/src/SelectMenu.d.ts +4 -4
  9. package/es/_internal/selection/src/Selection.d.ts +115 -13
  10. package/es/_internal/selection/styles/light.d.ts +14 -1
  11. package/es/_mixins/use-theme.mjs +1 -1
  12. package/es/_utils/index.d.ts +1 -0
  13. package/es/_utils/naive/prop.d.ts +19 -10
  14. package/es/_utils/naive/prop.mjs +21 -21
  15. package/es/_utils/ts/ts.d.ts +3 -0
  16. package/es/alert/src/Alert.d.ts +2 -2
  17. package/es/anchor/index.d.ts +1 -0
  18. package/es/anchor/src/AnchorAdapter.d.ts +1 -1
  19. package/es/anchor/src/BaseAnchor.mjs +29 -5
  20. package/es/anchor/src/Link.d.ts +3 -2
  21. package/es/anchor/src/Link.mjs +5 -2
  22. package/es/anchor/src/public-types.d.ts +5 -0
  23. package/es/anchor/src/public-types.mjs +1 -0
  24. package/es/auto-complete/src/AutoComplete.d.ts +155 -14
  25. package/es/auto-complete/styles/light.d.ts +14 -1
  26. package/es/avatar-group/index.d.ts +3 -2
  27. package/es/avatar-group/src/AvatarGroup.d.ts +1 -4
  28. package/es/avatar-group/src/generic-public-types.d.ts +18 -0
  29. package/es/avatar-group/src/generic-public-types.mjs +1 -0
  30. package/es/avatar-group/src/public-types.d.ts +10 -0
  31. package/es/avatar-group/src/public-types.mjs +1 -0
  32. package/es/back-top/src/BackTop.d.ts +1 -1
  33. package/es/badge/src/Badge.d.ts +1 -1
  34. package/es/button/src/Button.d.ts +1 -1
  35. package/es/card/src/Card.d.ts +7 -2
  36. package/es/card/src/Card.mjs +3 -1
  37. package/es/carousel/src/Carousel.d.ts +4 -4
  38. package/es/carousel/src/Carousel.mjs +2 -2
  39. package/es/carousel/src/CarouselDots.d.ts +2 -2
  40. package/es/carousel/src/CarouselItem.mjs +1 -1
  41. package/es/cascader/src/Cascader.d.ts +163 -20
  42. package/es/cascader/src/CascaderMenu.d.ts +56 -4
  43. package/es/cascader/src/CascaderOption.d.ts +56 -4
  44. package/es/cascader/src/CascaderSelectMenu.d.ts +57 -5
  45. package/es/cascader/src/CascaderSubmenu.d.ts +56 -4
  46. package/es/cascader/styles/light.d.ts +14 -1
  47. package/es/color-picker/src/ColorInputUnit.d.ts +26 -2
  48. package/es/color-picker/src/ColorPicker.d.ts +128 -11
  49. package/es/color-picker/src/ColorPickerTrigger.mjs +2 -1
  50. package/es/color-picker/src/utils.d.ts +2 -0
  51. package/es/color-picker/src/utils.mjs +23 -0
  52. package/es/color-picker/styles/light.d.ts +17 -4
  53. package/es/components.d.ts +1 -0
  54. package/es/components.mjs +1 -0
  55. package/es/config-provider/src/ConfigProvider.d.ts +1 -1
  56. package/es/config-provider/src/ConfigProvider.mjs +1 -1
  57. package/es/config-provider/src/internal-interface.d.ts +2 -0
  58. package/es/data-table/src/DataTable.d.ts +690 -68
  59. package/es/data-table/src/HeaderButton/FilterButton.d.ts +334 -26
  60. package/es/data-table/src/HeaderButton/FilterMenu.d.ts +332 -24
  61. package/es/data-table/src/TableParts/Body.d.ts +332 -24
  62. package/es/data-table/src/TableParts/Cell.mjs +1 -1
  63. package/es/data-table/src/TableParts/Header.d.ts +332 -24
  64. package/es/data-table/src/interface.d.ts +253 -18
  65. package/es/data-table/src/use-sorter.d.ts +2 -5
  66. package/es/data-table/src/use-table-data.d.ts +1 -4
  67. package/es/data-table/src/utils.mjs +4 -1
  68. package/es/data-table/styles/light.d.ts +84 -6
  69. package/es/date-picker/src/DatePicker.d.ts +229 -23
  70. package/es/date-picker/src/DatePicker.mjs +1 -1
  71. package/es/date-picker/src/panel/date.d.ts +110 -10
  72. package/es/date-picker/src/panel/daterange.d.ts +111 -11
  73. package/es/date-picker/src/panel/datetime.d.ts +111 -11
  74. package/es/date-picker/src/panel/datetime.mjs +1 -1
  75. package/es/date-picker/src/panel/datetimerange.d.ts +112 -12
  76. package/es/date-picker/src/panel/datetimerange.mjs +2 -2
  77. package/es/date-picker/src/panel/month.d.ts +110 -10
  78. package/es/date-picker/src/panel/monthrange.d.ts +111 -11
  79. package/es/date-picker/src/panel/panelHeader.d.ts +436 -36
  80. package/es/date-picker/src/panel/use-calendar.d.ts +109 -9
  81. package/es/date-picker/src/panel/use-dual-calendar.d.ts +110 -10
  82. package/es/date-picker/src/panel/use-dual-calendar.mjs +3 -3
  83. package/es/date-picker/src/panel/use-panel-common.d.ts +109 -9
  84. package/es/date-picker/src/panel/use-panel-common.mjs +1 -1
  85. package/es/date-picker/src/props.d.ts +85 -7
  86. package/es/date-picker/src/props.mjs +1 -1
  87. package/es/date-picker/src/utils.d.ts +2 -1
  88. package/es/date-picker/src/utils.mjs +4 -1
  89. package/es/date-picker/styles/light.d.ts +28 -2
  90. package/es/dialog/src/Dialog.d.ts +9 -6
  91. package/es/dialog/src/Dialog.mjs +1 -0
  92. package/es/dialog/src/DialogEnvironment.d.ts +11 -4
  93. package/es/dialog/src/DialogEnvironment.mjs +3 -0
  94. package/es/dialog/src/DialogProvider.d.ts +38 -34
  95. package/es/dialog/src/dialogProps.d.ts +2 -1
  96. package/es/dialog/src/dialogProps.mjs +2 -1
  97. package/es/drawer/src/Drawer.d.ts +4 -4
  98. package/es/drawer/src/DrawerBodyWrapper.d.ts +1 -1
  99. package/es/dropdown/src/Dropdown.d.ts +165 -24
  100. package/es/dropdown/src/DropdownMenu.d.ts +2 -2
  101. package/es/dropdown/src/DropdownOption.d.ts +2 -2
  102. package/es/dropdown/styles/light.d.ts +16 -3
  103. package/es/dynamic-input/src/DynamicInput.d.ts +153 -12
  104. package/es/dynamic-input/src/InputPreset.d.ts +52 -4
  105. package/es/dynamic-input/src/PairPreset.d.ts +52 -4
  106. package/es/dynamic-input/styles/light.d.ts +14 -1
  107. package/es/dynamic-tags/src/DynamicTags.d.ts +153 -12
  108. package/es/dynamic-tags/styles/light.d.ts +14 -1
  109. package/es/element/src/Element.mjs +1 -1
  110. package/es/ellipsis/src/Ellipsis.d.ts +154 -11
  111. package/es/ellipsis/src/PerformantEllipsis.d.ts +84 -6
  112. package/es/ellipsis/styles/light.d.ts +14 -1
  113. package/es/empty/src/Empty.d.ts +1 -1
  114. package/es/form/src/FormItem.d.ts +8 -2
  115. package/es/form/src/FormItem.mjs +6 -3
  116. package/es/form/src/FormItemCol.d.ts +7 -1
  117. package/es/form/src/FormItemGridItem.d.ts +7 -1
  118. package/es/form/src/FormItemRow.d.ts +7 -1
  119. package/es/form/src/utils.d.ts +1 -1
  120. package/es/form/src/utils.mjs +1 -1
  121. package/es/global-style/src/GlobalStyle.mjs +1 -1
  122. package/es/gradient-text/src/GradientText.d.ts +2 -2
  123. package/es/grid/src/GridItem.d.ts +1 -1
  124. package/es/heatmap/index.d.ts +6 -0
  125. package/es/heatmap/index.mjs +4 -0
  126. package/es/heatmap/src/ColorIndicator.d.ts +25 -0
  127. package/es/heatmap/src/ColorIndicator.mjs +41 -0
  128. package/es/heatmap/src/Heatmap.d.ts +385 -0
  129. package/es/heatmap/src/Heatmap.mjs +333 -0
  130. package/es/heatmap/src/Rect.d.ts +57 -0
  131. package/es/heatmap/src/Rect.mjs +67 -0
  132. package/es/heatmap/src/animationStyle.d.ts +6 -0
  133. package/es/heatmap/src/animationStyle.mjs +51 -0
  134. package/es/heatmap/src/interface.d.ts +7 -0
  135. package/es/heatmap/src/interface.mjs +1 -0
  136. package/es/heatmap/src/public-types.d.ts +16 -0
  137. package/es/heatmap/src/public-types.mjs +1 -0
  138. package/es/heatmap/src/styles/index.cssr.d.ts +2 -0
  139. package/es/heatmap/src/styles/index.cssr.mjs +102 -0
  140. package/es/heatmap/src/styles/rtl.cssr.d.ts +2 -0
  141. package/es/heatmap/src/styles/rtl.cssr.mjs +4 -0
  142. package/es/heatmap/src/theme.d.ts +8 -0
  143. package/es/heatmap/src/theme.mjs +7 -0
  144. package/es/heatmap/src/utils/index.d.ts +32 -0
  145. package/es/heatmap/src/utils/index.mjs +148 -0
  146. package/es/heatmap/styles/dark.d.ts +3 -0
  147. package/es/heatmap/styles/dark.mjs +16 -0
  148. package/es/heatmap/styles/index.d.ts +3 -0
  149. package/es/heatmap/styles/index.mjs +2 -0
  150. package/es/heatmap/styles/light.d.ts +31 -0
  151. package/es/heatmap/styles/light.mjs +45 -0
  152. package/es/heatmap/styles/rtl.d.ts +2 -0
  153. package/es/heatmap/styles/rtl.mjs +5 -0
  154. package/es/highlight/src/utils.mjs +10 -10
  155. package/es/icon/src/styles/index.cssr.mjs +0 -1
  156. package/es/image/index.d.ts +3 -1
  157. package/es/image/index.mjs +2 -1
  158. package/es/image/src/Image.d.ts +133 -23
  159. package/es/image/src/Image.mjs +48 -23
  160. package/es/image/src/ImageGroup.d.ts +200 -35
  161. package/es/image/src/ImageGroup.mjs +130 -26
  162. package/es/image/src/ImagePreview.d.ts +258 -23
  163. package/es/image/src/ImagePreview.mjs +84 -42
  164. package/es/image/src/interface.d.ts +42 -3
  165. package/es/image/src/public-types.d.ts +14 -0
  166. package/es/image/styles/light.d.ts +14 -1
  167. package/es/input/src/Input.d.ts +146 -12
  168. package/es/input/src/Input.mjs +6 -4
  169. package/es/input/src/InputGroupLabel.d.ts +129 -22
  170. package/es/input/src/InputGroupLabel.mjs +14 -8
  171. package/es/input/styles/dark.d.ts +139 -2
  172. package/es/input/styles/dark.mjs +114 -108
  173. package/es/input/styles/light.d.ts +76 -3
  174. package/es/input/styles/light.mjs +7 -2
  175. package/es/input-number/src/InputNumber.d.ts +152 -11
  176. package/es/input-number/styles/light.d.ts +14 -1
  177. package/es/input-otp/src/InputOtp.d.ts +158 -12
  178. package/es/input-otp/src/InputOtp.mjs +12 -4
  179. package/es/input-otp/src/public-types.d.ts +1 -0
  180. package/es/input-otp/src/styles/index.cssr.mjs +12 -3
  181. package/es/input-otp/styles/dark.mjs +1 -1
  182. package/es/input-otp/styles/light.d.ts +14 -1
  183. package/es/layout/src/LayoutSider.d.ts +1 -1
  184. package/es/legacy-transfer/src/Transfer.d.ts +154 -13
  185. package/es/legacy-transfer/src/TransferFilter.d.ts +52 -4
  186. package/es/legacy-transfer/src/TransferList.d.ts +52 -4
  187. package/es/legacy-transfer/src/TransferListItem.d.ts +52 -4
  188. package/es/legacy-transfer/styles/light.d.ts +14 -1
  189. package/es/locales/common/arDZ.mjs +6 -0
  190. package/es/locales/common/azAZ.mjs +6 -0
  191. package/es/locales/common/csCZ.mjs +6 -0
  192. package/es/locales/common/daDK.d.ts +3 -0
  193. package/es/locales/common/daDK.mjs +130 -0
  194. package/es/locales/common/deDE.mjs +6 -0
  195. package/es/locales/common/enGB.mjs +6 -0
  196. package/es/locales/common/enUS.d.ts +6 -0
  197. package/es/locales/common/enUS.mjs +6 -0
  198. package/es/locales/common/eo.mjs +6 -0
  199. package/es/locales/common/esAR.mjs +6 -0
  200. package/es/locales/common/etEE.mjs +6 -0
  201. package/es/locales/common/faIR.mjs +6 -0
  202. package/es/locales/common/frFR.mjs +6 -0
  203. package/es/locales/common/idID.mjs +6 -0
  204. package/es/locales/common/itIT.mjs +6 -0
  205. package/es/locales/common/jaJP.mjs +6 -0
  206. package/es/locales/common/kmKH.mjs +6 -0
  207. package/es/locales/common/koKR.mjs +6 -0
  208. package/es/locales/common/nbNO.mjs +6 -0
  209. package/es/locales/common/nlNL.mjs +6 -0
  210. package/es/locales/common/plPL.mjs +6 -0
  211. package/es/locales/common/ptBR.mjs +6 -0
  212. package/es/locales/common/ruRU.mjs +6 -0
  213. package/es/locales/common/skSK.mjs +6 -0
  214. package/es/locales/common/svSE.mjs +8 -2
  215. package/es/locales/common/thTH.mjs +6 -0
  216. package/es/locales/common/trTR.mjs +6 -0
  217. package/es/locales/common/ugCN.mjs +6 -0
  218. package/es/locales/common/ukUA.mjs +6 -0
  219. package/es/locales/common/uzUZ.mjs +6 -0
  220. package/es/locales/common/viVN.mjs +6 -0
  221. package/es/locales/common/zhCN.mjs +6 -0
  222. package/es/locales/common/zhTW.mjs +6 -0
  223. package/es/locales/date/daDK.d.ts +3 -0
  224. package/es/locales/date/daDK.mjs +6 -0
  225. package/es/locales/index.d.ts +2 -0
  226. package/es/locales/index.mjs +2 -0
  227. package/es/locales/utils/index.mjs +1 -1
  228. package/es/log/src/Log.d.ts +1 -1
  229. package/es/log/src/Log.mjs +1 -1
  230. package/es/marquee/src/Marquee.mjs +12 -10
  231. package/es/mention/src/Mention.d.ts +155 -14
  232. package/es/mention/styles/light.d.ts +14 -1
  233. package/es/menu/src/Menu.d.ts +314 -28
  234. package/es/menu/src/MenuOption.d.ts +113 -9
  235. package/es/menu/src/MenuOption.mjs +4 -3
  236. package/es/menu/src/MenuOptionContent.d.ts +1 -1
  237. package/es/menu/src/MenuOptionGroup.d.ts +1 -1
  238. package/es/menu/src/MenuOptionGroup.mjs +11 -4
  239. package/es/menu/src/Submenu.d.ts +114 -10
  240. package/es/menu/src/use-menu-child.d.ts +2 -0
  241. package/es/menu/src/use-menu-child.mjs +2 -1
  242. package/es/menu/styles/light.d.ts +33 -7
  243. package/es/message/src/Message.d.ts +1 -0
  244. package/es/message/src/Message.mjs +3 -1
  245. package/es/message/src/MessageProvider.d.ts +10 -1
  246. package/es/message/src/styles/index.cssr.mjs +1 -0
  247. package/es/message/styles/light.d.ts +1 -0
  248. package/es/message/styles/light.mjs +2 -1
  249. package/es/modal/src/BodyWrapper.d.ts +13 -7
  250. package/es/modal/src/BodyWrapper.mjs +4 -3
  251. package/es/modal/src/Modal.d.ts +32 -15
  252. package/es/modal/src/Modal.mjs +14 -6
  253. package/es/modal/src/ModalEnvironment.d.ts +22 -10
  254. package/es/modal/src/ModalEnvironment.mjs +1 -1
  255. package/es/modal/src/ModalProvider.d.ts +2 -1
  256. package/es/modal/src/ModalProvider.mjs +4 -2
  257. package/es/modal/src/presetProps.d.ts +3 -2
  258. package/es/modal/src/styles/index.cssr.mjs +4 -2
  259. package/es/notification/src/Notification.d.ts +2 -2
  260. package/es/notification/src/NotificationEnvironment.d.ts +1 -1
  261. package/es/notification/src/NotificationProvider.d.ts +5 -5
  262. package/es/number-animation/src/NumberAnimation.mjs +1 -1
  263. package/es/pagination/src/Pagination.d.ts +460 -33
  264. package/es/pagination/styles/light.d.ts +42 -3
  265. package/es/popconfirm/src/Popconfirm.d.ts +163 -22
  266. package/es/popconfirm/src/Popconfirm.mjs +3 -3
  267. package/es/popconfirm/src/PopconfirmPanel.d.ts +3 -3
  268. package/es/popconfirm/styles/light.d.ts +14 -1
  269. package/es/popover/src/Popover.d.ts +133 -16
  270. package/es/popover/src/PopoverBody.d.ts +129 -12
  271. package/es/popover/src/PopoverBody.mjs +8 -4
  272. package/es/popover/src/styles/index.cssr.mjs +1 -1
  273. package/es/popover/src/styles/rtl.cssr.d.ts +2 -0
  274. package/es/popover/src/styles/rtl.cssr.mjs +5 -0
  275. package/es/popover/styles/dark.mjs +4 -0
  276. package/es/popover/styles/index.d.ts +1 -0
  277. package/es/popover/styles/index.mjs +2 -1
  278. package/es/popover/styles/light.d.ts +27 -2
  279. package/es/popover/styles/light.mjs +7 -2
  280. package/es/popover/styles/rtl.d.ts +2 -0
  281. package/es/popover/styles/rtl.mjs +7 -0
  282. package/es/popselect/src/Popselect.d.ts +217 -76
  283. package/es/popselect/src/PopselectPanel.d.ts +55 -7
  284. package/es/popselect/styles/light.d.ts +14 -1
  285. package/es/progress/src/Circle.d.ts +1 -1
  286. package/es/progress/src/Circle.mjs +14 -3
  287. package/es/progress/src/Progress.d.ts +1 -1
  288. package/es/radio/src/Radio.mjs +5 -5
  289. package/es/radio/src/RadioButton.d.ts +2 -2
  290. package/es/radio/src/styles/radio.cssr.mjs +3 -7
  291. package/es/rate/src/Rate.d.ts +1 -1
  292. package/es/result/src/Result.d.ts +1 -1
  293. package/es/select/src/Select.d.ts +164 -21
  294. package/es/select/styles/light.d.ts +14 -1
  295. package/es/styles.d.ts +3 -3
  296. package/es/styles.mjs +3 -3
  297. package/es/tabs/src/Tab.d.ts +3 -3
  298. package/es/tabs/src/Tabs.d.ts +1 -1
  299. package/es/tabs/src/Tabs.mjs +1 -1
  300. package/es/tabs/src/styles/index.cssr.mjs +4 -4
  301. package/es/tag/src/Tag.d.ts +1 -1
  302. package/es/theme-editor/src/ThemeEditor.mjs +1 -1
  303. package/es/themes/dark.mjs +2 -0
  304. package/es/themes/light.mjs +2 -0
  305. package/es/time-picker/src/Panel.d.ts +59 -11
  306. package/es/time-picker/src/TimePicker.d.ts +156 -15
  307. package/es/time-picker/styles/light.d.ts +14 -1
  308. package/es/timeline/src/TimelineItem.d.ts +1 -1
  309. package/es/tooltip/src/Tooltip.d.ts +166 -25
  310. package/es/tooltip/styles/light.d.ts +16 -3
  311. package/es/transfer/src/Transfer.d.ts +154 -13
  312. package/es/transfer/src/TransferFilter.d.ts +52 -4
  313. package/es/transfer/src/TransferList.d.ts +52 -4
  314. package/es/transfer/src/TransferListItem.d.ts +52 -4
  315. package/es/transfer/styles/light.d.ts +14 -1
  316. package/es/tree/src/Tree.d.ts +42 -38
  317. package/es/tree/src/Tree.mjs +3 -1
  318. package/es/tree/src/TreeNode.d.ts +2 -2
  319. package/es/tree/src/TreeNodeContent.d.ts +3 -3
  320. package/es/tree/src/styles/index.cssr.mjs +7 -2
  321. package/es/tree/styles/light.d.ts +4 -4
  322. package/es/tree-select/src/TreeSelect.d.ts +172 -29
  323. package/es/tree-select/styles/index.d.ts +1 -0
  324. package/es/tree-select/styles/index.mjs +2 -1
  325. package/es/tree-select/styles/light.d.ts +22 -9
  326. package/es/tree-select/styles/rtl.d.ts +2 -0
  327. package/es/tree-select/styles/rtl.mjs +11 -0
  328. package/es/typography/src/create-header.d.ts +1 -1
  329. package/es/typography/src/headers.d.ts +6 -6
  330. package/es/upload/src/Upload.d.ts +1 -0
  331. package/es/upload/src/Upload.mjs +6 -3
  332. package/es/upload/src/UploadFile.d.ts +8 -6
  333. package/es/upload/src/UploadFile.mjs +1 -1
  334. package/es/upload/src/icons.d.ts +2 -2
  335. package/es/upload/src/icons.mjs +22 -18
  336. package/es/upload/src/styles/rtl.cssr.d.ts +2 -0
  337. package/es/upload/src/styles/rtl.cssr.mjs +5 -0
  338. package/es/upload/styles/index.d.ts +1 -0
  339. package/es/upload/styles/index.mjs +2 -1
  340. package/es/upload/styles/rtl.d.ts +2 -0
  341. package/es/upload/styles/rtl.mjs +5 -0
  342. package/es/version.d.ts +1 -1
  343. package/es/version.mjs +1 -1
  344. package/es/virtual-list/src/VirtualList.d.ts +1 -1
  345. package/generic/AvatarGroup.vue +26 -0
  346. package/generic/index.ts +1 -0
  347. package/lib/_internal/icon/src/styles/index.cssr.js +0 -1
  348. package/lib/_internal/scrollbar/src/Scrollbar.d.ts +3 -3
  349. package/lib/_internal/select-menu/src/SelectMenu.d.ts +4 -4
  350. package/lib/_internal/selection/src/Selection.d.ts +115 -13
  351. package/lib/_internal/selection/styles/light.d.ts +14 -1
  352. package/lib/_utils/index.d.ts +1 -0
  353. package/lib/_utils/naive/prop.d.ts +19 -10
  354. package/lib/_utils/naive/prop.js +21 -21
  355. package/lib/_utils/ts/ts.d.ts +3 -0
  356. package/lib/alert/src/Alert.d.ts +2 -2
  357. package/lib/anchor/index.d.ts +1 -0
  358. package/lib/anchor/src/AnchorAdapter.d.ts +1 -1
  359. package/lib/anchor/src/AnchorAdapter.js +17 -7
  360. package/lib/anchor/src/BaseAnchor.js +30 -5
  361. package/lib/anchor/src/Link.d.ts +3 -2
  362. package/lib/anchor/src/Link.js +4 -1
  363. package/lib/anchor/src/public-types.d.ts +5 -0
  364. package/lib/anchor/src/public-types.js +2 -0
  365. package/lib/auto-complete/src/AutoComplete.d.ts +155 -14
  366. package/lib/auto-complete/styles/light.d.ts +14 -1
  367. package/lib/avatar-group/index.d.ts +3 -2
  368. package/lib/avatar-group/src/AvatarGroup.d.ts +1 -4
  369. package/lib/avatar-group/src/generic-public-types.d.ts +18 -0
  370. package/lib/avatar-group/src/generic-public-types.js +2 -0
  371. package/lib/avatar-group/src/public-types.d.ts +10 -0
  372. package/lib/avatar-group/src/public-types.js +2 -0
  373. package/lib/back-top/src/BackTop.d.ts +1 -1
  374. package/lib/badge/src/Badge.d.ts +1 -1
  375. package/lib/button/src/Button.d.ts +1 -1
  376. package/lib/card/src/Card.d.ts +7 -2
  377. package/lib/card/src/Card.js +3 -2
  378. package/lib/carousel/src/Carousel.d.ts +4 -4
  379. package/lib/carousel/src/Carousel.js +19 -9
  380. package/lib/carousel/src/CarouselDots.d.ts +2 -2
  381. package/lib/cascader/src/Cascader.d.ts +163 -20
  382. package/lib/cascader/src/CascaderMenu.d.ts +56 -4
  383. package/lib/cascader/src/CascaderOption.d.ts +56 -4
  384. package/lib/cascader/src/CascaderSelectMenu.d.ts +57 -5
  385. package/lib/cascader/src/CascaderSubmenu.d.ts +56 -4
  386. package/lib/cascader/styles/light.d.ts +14 -1
  387. package/lib/color-picker/src/ColorInputUnit.d.ts +26 -2
  388. package/lib/color-picker/src/ColorPicker.d.ts +128 -11
  389. package/lib/color-picker/src/ColorPickerTrigger.js +2 -1
  390. package/lib/color-picker/src/utils.d.ts +2 -0
  391. package/lib/color-picker/src/utils.js +26 -0
  392. package/lib/color-picker/styles/light.d.ts +14 -1
  393. package/lib/components.d.ts +1 -0
  394. package/lib/components.js +1 -0
  395. package/lib/config-provider/src/ConfigProvider.d.ts +1 -1
  396. package/lib/config-provider/src/internal-interface.d.ts +2 -0
  397. package/lib/data-table/src/DataTable.d.ts +674 -52
  398. package/lib/data-table/src/HeaderButton/FilterButton.d.ts +333 -25
  399. package/lib/data-table/src/HeaderButton/FilterMenu.d.ts +332 -24
  400. package/lib/data-table/src/TableParts/Body.d.ts +332 -24
  401. package/lib/data-table/src/TableParts/Header.d.ts +332 -24
  402. package/lib/data-table/src/interface.d.ts +253 -18
  403. package/lib/data-table/src/use-sorter.d.ts +2 -5
  404. package/lib/data-table/src/use-table-data.d.ts +1 -4
  405. package/lib/data-table/src/utils.js +2 -1
  406. package/lib/data-table/styles/light.d.ts +84 -6
  407. package/lib/date-picker/src/DatePicker.d.ts +229 -23
  408. package/lib/date-picker/src/DatePicker.js +1 -1
  409. package/lib/date-picker/src/panel/date.d.ts +110 -10
  410. package/lib/date-picker/src/panel/daterange.d.ts +111 -11
  411. package/lib/date-picker/src/panel/datetime.d.ts +110 -10
  412. package/lib/date-picker/src/panel/datetime.js +1 -1
  413. package/lib/date-picker/src/panel/datetimerange.d.ts +111 -11
  414. package/lib/date-picker/src/panel/datetimerange.js +2 -2
  415. package/lib/date-picker/src/panel/month.d.ts +110 -10
  416. package/lib/date-picker/src/panel/monthrange.d.ts +111 -11
  417. package/lib/date-picker/src/panel/panelHeader.d.ts +436 -36
  418. package/lib/date-picker/src/panel/use-calendar.d.ts +109 -9
  419. package/lib/date-picker/src/panel/use-dual-calendar.d.ts +110 -10
  420. package/lib/date-picker/src/panel/use-dual-calendar.js +3 -3
  421. package/lib/date-picker/src/panel/use-panel-common.d.ts +109 -9
  422. package/lib/date-picker/src/panel/use-panel-common.js +1 -1
  423. package/lib/date-picker/src/props.d.ts +85 -7
  424. package/lib/date-picker/src/props.js +1 -1
  425. package/lib/date-picker/src/utils.d.ts +2 -1
  426. package/lib/date-picker/src/utils.js +5 -1
  427. package/lib/date-picker/styles/light.d.ts +28 -2
  428. package/lib/dialog/src/Dialog.d.ts +5 -2
  429. package/lib/dialog/src/Dialog.js +1 -1
  430. package/lib/dialog/src/DialogEnvironment.d.ts +11 -4
  431. package/lib/dialog/src/DialogEnvironment.js +3 -3
  432. package/lib/dialog/src/DialogProvider.d.ts +38 -34
  433. package/lib/dialog/src/dialogProps.d.ts +2 -1
  434. package/lib/dialog/src/dialogProps.js +2 -1
  435. package/lib/drawer/src/Drawer.d.ts +4 -4
  436. package/lib/drawer/src/DrawerBodyWrapper.d.ts +1 -1
  437. package/lib/dropdown/src/Dropdown.d.ts +162 -21
  438. package/lib/dropdown/src/DropdownMenu.d.ts +2 -2
  439. package/lib/dropdown/styles/light.d.ts +14 -1
  440. package/lib/dynamic-input/src/DynamicInput.d.ts +153 -12
  441. package/lib/dynamic-input/src/InputPreset.d.ts +52 -4
  442. package/lib/dynamic-input/src/PairPreset.d.ts +52 -4
  443. package/lib/dynamic-input/styles/light.d.ts +14 -1
  444. package/lib/dynamic-tags/src/DynamicTags.d.ts +153 -12
  445. package/lib/dynamic-tags/styles/light.d.ts +14 -1
  446. package/lib/ellipsis/src/Ellipsis.d.ts +154 -11
  447. package/lib/ellipsis/src/PerformantEllipsis.d.ts +84 -6
  448. package/lib/ellipsis/src/PerformantEllipsis.js +17 -7
  449. package/lib/ellipsis/styles/light.d.ts +14 -1
  450. package/lib/empty/src/Empty.d.ts +1 -1
  451. package/lib/form/src/FormItem.d.ts +8 -2
  452. package/lib/form/src/FormItem.js +3 -2
  453. package/lib/form/src/FormItemCol.d.ts +7 -1
  454. package/lib/form/src/FormItemCol.js +17 -7
  455. package/lib/form/src/FormItemGridItem.d.ts +7 -1
  456. package/lib/form/src/FormItemGridItem.js +17 -7
  457. package/lib/form/src/FormItemRow.d.ts +7 -1
  458. package/lib/form/src/FormItemRow.js +17 -7
  459. package/lib/form/src/utils.d.ts +1 -1
  460. package/lib/gradient-text/src/GradientText.d.ts +2 -2
  461. package/lib/grid/src/GridItem.d.ts +1 -1
  462. package/lib/heatmap/index.d.ts +6 -0
  463. package/lib/heatmap/index.js +27 -0
  464. package/lib/heatmap/src/ColorIndicator.d.ts +25 -0
  465. package/lib/heatmap/src/ColorIndicator.js +27 -0
  466. package/lib/heatmap/src/Heatmap.d.ts +385 -0
  467. package/lib/heatmap/src/Heatmap.js +248 -0
  468. package/lib/heatmap/src/Rect.d.ts +57 -0
  469. package/lib/heatmap/src/Rect.js +64 -0
  470. package/lib/heatmap/src/animationStyle.d.ts +6 -0
  471. package/lib/heatmap/src/animationStyle.js +52 -0
  472. package/lib/heatmap/src/interface.d.ts +7 -0
  473. package/lib/heatmap/src/interface.js +2 -0
  474. package/lib/heatmap/src/public-types.d.ts +16 -0
  475. package/lib/heatmap/src/public-types.js +2 -0
  476. package/lib/heatmap/src/styles/index.cssr.d.ts +2 -0
  477. package/lib/heatmap/src/styles/index.cssr.js +107 -0
  478. package/lib/heatmap/src/styles/rtl.cssr.d.ts +2 -0
  479. package/lib/heatmap/src/styles/rtl.cssr.js +9 -0
  480. package/lib/heatmap/src/theme.d.ts +8 -0
  481. package/lib/heatmap/src/theme.js +10 -0
  482. package/lib/heatmap/src/utils/index.d.ts +32 -0
  483. package/lib/heatmap/src/utils/index.js +135 -0
  484. package/lib/heatmap/styles/dark.d.ts +3 -0
  485. package/lib/heatmap/styles/dark.js +13 -0
  486. package/lib/heatmap/styles/index.d.ts +3 -0
  487. package/lib/heatmap/styles/index.js +10 -0
  488. package/lib/heatmap/styles/light.d.ts +31 -0
  489. package/lib/heatmap/styles/light.js +39 -0
  490. package/lib/heatmap/styles/rtl.d.ts +2 -0
  491. package/lib/heatmap/styles/rtl.js +11 -0
  492. package/lib/highlight/src/utils.js +10 -21
  493. package/lib/icon/src/styles/index.cssr.js +0 -1
  494. package/lib/image/index.d.ts +3 -1
  495. package/lib/image/index.js +4 -1
  496. package/lib/image/src/Image.d.ts +133 -23
  497. package/lib/image/src/Image.js +43 -23
  498. package/lib/image/src/ImageGroup.d.ts +200 -35
  499. package/lib/image/src/ImageGroup.js +111 -26
  500. package/lib/image/src/ImagePreview.d.ts +258 -23
  501. package/lib/image/src/ImagePreview.js +60 -33
  502. package/lib/image/src/interface.d.ts +42 -3
  503. package/lib/image/src/public-types.d.ts +14 -0
  504. package/lib/image/styles/light.d.ts +14 -1
  505. package/lib/input/src/Input.d.ts +146 -12
  506. package/lib/input/src/Input.js +24 -12
  507. package/lib/input/src/InputGroupLabel.d.ts +129 -22
  508. package/lib/input/src/InputGroupLabel.js +8 -6
  509. package/lib/input/styles/dark.d.ts +139 -2
  510. package/lib/input/styles/dark.js +35 -29
  511. package/lib/input/styles/light.d.ts +76 -3
  512. package/lib/input/styles/light.js +7 -2
  513. package/lib/input-number/src/InputNumber.d.ts +152 -11
  514. package/lib/input-number/styles/light.d.ts +14 -1
  515. package/lib/input-otp/src/InputOtp.d.ts +158 -12
  516. package/lib/input-otp/src/InputOtp.js +12 -16
  517. package/lib/input-otp/src/public-types.d.ts +1 -0
  518. package/lib/input-otp/src/styles/index.cssr.js +11 -2
  519. package/lib/input-otp/styles/dark.js +1 -1
  520. package/lib/input-otp/styles/light.d.ts +14 -1
  521. package/lib/layout/src/LayoutSider.d.ts +1 -1
  522. package/lib/legacy-transfer/src/Transfer.d.ts +154 -13
  523. package/lib/legacy-transfer/src/TransferFilter.d.ts +52 -4
  524. package/lib/legacy-transfer/src/TransferList.d.ts +52 -4
  525. package/lib/legacy-transfer/src/TransferListItem.d.ts +52 -4
  526. package/lib/legacy-transfer/styles/light.d.ts +14 -1
  527. package/lib/locales/common/arDZ.js +6 -0
  528. package/lib/locales/common/azAZ.js +6 -0
  529. package/lib/locales/common/csCZ.js +6 -0
  530. package/lib/locales/common/daDK.d.ts +3 -0
  531. package/lib/locales/common/daDK.js +132 -0
  532. package/lib/locales/common/deDE.js +6 -0
  533. package/lib/locales/common/enGB.js +6 -0
  534. package/lib/locales/common/enUS.d.ts +6 -0
  535. package/lib/locales/common/enUS.js +6 -0
  536. package/lib/locales/common/eo.js +6 -0
  537. package/lib/locales/common/esAR.js +6 -0
  538. package/lib/locales/common/etEE.js +6 -0
  539. package/lib/locales/common/faIR.js +6 -0
  540. package/lib/locales/common/frFR.js +6 -0
  541. package/lib/locales/common/idID.js +6 -0
  542. package/lib/locales/common/itIT.js +6 -0
  543. package/lib/locales/common/jaJP.js +6 -0
  544. package/lib/locales/common/kmKH.js +6 -0
  545. package/lib/locales/common/koKR.js +6 -0
  546. package/lib/locales/common/nbNO.js +6 -0
  547. package/lib/locales/common/nlNL.js +6 -0
  548. package/lib/locales/common/plPL.js +6 -0
  549. package/lib/locales/common/ptBR.js +6 -0
  550. package/lib/locales/common/ruRU.js +6 -0
  551. package/lib/locales/common/skSK.js +6 -0
  552. package/lib/locales/common/svSE.js +8 -2
  553. package/lib/locales/common/thTH.js +6 -0
  554. package/lib/locales/common/trTR.js +6 -0
  555. package/lib/locales/common/ugCN.js +6 -0
  556. package/lib/locales/common/ukUA.js +6 -0
  557. package/lib/locales/common/uzUZ.js +6 -0
  558. package/lib/locales/common/viVN.js +6 -0
  559. package/lib/locales/common/zhCN.js +6 -0
  560. package/lib/locales/common/zhTW.js +6 -0
  561. package/lib/locales/date/daDK.d.ts +3 -0
  562. package/lib/locales/date/daDK.js +8 -0
  563. package/lib/locales/index.d.ts +2 -0
  564. package/lib/locales/index.js +6 -2
  565. package/lib/log/src/Log.d.ts +1 -1
  566. package/lib/marquee/src/Marquee.js +4 -3
  567. package/lib/mention/src/Mention.d.ts +155 -14
  568. package/lib/mention/styles/light.d.ts +14 -1
  569. package/lib/menu/src/Menu.d.ts +314 -28
  570. package/lib/menu/src/MenuOption.d.ts +113 -9
  571. package/lib/menu/src/MenuOption.js +6 -4
  572. package/lib/menu/src/MenuOptionContent.d.ts +1 -1
  573. package/lib/menu/src/MenuOptionGroup.d.ts +1 -1
  574. package/lib/menu/src/MenuOptionGroup.js +8 -2
  575. package/lib/menu/src/Submenu.d.ts +114 -10
  576. package/lib/menu/src/use-menu-child.d.ts +2 -0
  577. package/lib/menu/src/use-menu-child.js +2 -1
  578. package/lib/menu/styles/light.d.ts +28 -2
  579. package/lib/message/src/Message.d.ts +1 -0
  580. package/lib/message/src/Message.js +3 -2
  581. package/lib/message/src/MessageProvider.d.ts +10 -1
  582. package/lib/message/src/styles/index.cssr.js +1 -0
  583. package/lib/message/styles/light.d.ts +1 -0
  584. package/lib/message/styles/light.js +1 -1
  585. package/lib/modal/src/BodyWrapper.d.ts +10 -4
  586. package/lib/modal/src/BodyWrapper.js +7 -3
  587. package/lib/modal/src/Modal.d.ts +28 -11
  588. package/lib/modal/src/Modal.js +10 -4
  589. package/lib/modal/src/ModalEnvironment.d.ts +22 -10
  590. package/lib/modal/src/ModalEnvironment.js +18 -8
  591. package/lib/modal/src/ModalProvider.d.ts +2 -1
  592. package/lib/modal/src/ModalProvider.js +4 -2
  593. package/lib/modal/src/presetProps.d.ts +2 -1
  594. package/lib/modal/src/styles/index.cssr.js +3 -1
  595. package/lib/notification/src/Notification.d.ts +2 -2
  596. package/lib/notification/src/NotificationEnvironment.d.ts +1 -1
  597. package/lib/notification/src/NotificationProvider.d.ts +5 -5
  598. package/lib/pagination/src/Pagination.d.ts +460 -33
  599. package/lib/pagination/styles/light.d.ts +42 -3
  600. package/lib/popconfirm/src/Popconfirm.d.ts +159 -18
  601. package/lib/popconfirm/src/Popconfirm.js +20 -15
  602. package/lib/popconfirm/src/PopconfirmPanel.d.ts +1 -1
  603. package/lib/popconfirm/styles/light.d.ts +14 -1
  604. package/lib/popover/src/Popover.d.ts +133 -16
  605. package/lib/popover/src/Popover.js +17 -7
  606. package/lib/popover/src/PopoverBody.d.ts +129 -12
  607. package/lib/popover/src/PopoverBody.js +5 -2
  608. package/lib/popover/src/styles/rtl.cssr.d.ts +2 -0
  609. package/lib/popover/src/styles/rtl.cssr.js +10 -0
  610. package/lib/popover/styles/dark.js +4 -0
  611. package/lib/popover/styles/index.d.ts +1 -0
  612. package/lib/popover/styles/index.js +3 -1
  613. package/lib/popover/styles/light.d.ts +27 -2
  614. package/lib/popover/styles/light.js +7 -2
  615. package/lib/popover/styles/rtl.d.ts +2 -0
  616. package/lib/popover/styles/rtl.js +13 -0
  617. package/lib/popselect/src/Popselect.d.ts +213 -72
  618. package/lib/popselect/src/Popselect.js +17 -7
  619. package/lib/popselect/src/PopselectPanel.d.ts +55 -7
  620. package/lib/popselect/styles/light.d.ts +14 -1
  621. package/lib/preset.js +17 -7
  622. package/lib/progress/src/Circle.d.ts +1 -1
  623. package/lib/progress/src/Circle.js +11 -2
  624. package/lib/progress/src/Progress.d.ts +1 -1
  625. package/lib/radio/src/Radio.js +2 -2
  626. package/lib/radio/src/RadioButton.d.ts +2 -2
  627. package/lib/radio/src/styles/radio.cssr.js +3 -7
  628. package/lib/rate/src/Rate.d.ts +1 -1
  629. package/lib/result/src/Result.d.ts +1 -1
  630. package/lib/select/src/Select.d.ts +164 -21
  631. package/lib/select/styles/light.d.ts +14 -1
  632. package/lib/styles.d.ts +3 -3
  633. package/lib/styles.js +5 -2
  634. package/lib/tabs/src/Tab.d.ts +3 -3
  635. package/lib/tabs/src/Tabs.d.ts +1 -1
  636. package/lib/tabs/src/styles/index.cssr.js +4 -4
  637. package/lib/tag/src/Tag.d.ts +1 -1
  638. package/lib/themes/dark.js +103 -101
  639. package/lib/themes/light.js +102 -100
  640. package/lib/time-picker/src/Panel.d.ts +59 -11
  641. package/lib/time-picker/src/TimePicker.d.ts +156 -15
  642. package/lib/time-picker/styles/light.d.ts +14 -1
  643. package/lib/timeline/src/TimelineItem.d.ts +1 -1
  644. package/lib/tooltip/src/Tooltip.d.ts +159 -18
  645. package/lib/tooltip/styles/light.d.ts +14 -1
  646. package/lib/transfer/src/Transfer.d.ts +154 -13
  647. package/lib/transfer/src/TransferFilter.d.ts +52 -4
  648. package/lib/transfer/src/TransferList.d.ts +52 -4
  649. package/lib/transfer/src/TransferListItem.d.ts +52 -4
  650. package/lib/transfer/styles/light.d.ts +14 -1
  651. package/lib/tree/src/Tree.d.ts +42 -38
  652. package/lib/tree/src/Tree.js +4 -3
  653. package/lib/tree/src/TreeNode.d.ts +2 -2
  654. package/lib/tree/src/TreeNodeContent.d.ts +3 -3
  655. package/lib/tree/src/styles/index.cssr.js +7 -2
  656. package/lib/tree-select/src/TreeSelect.d.ts +169 -26
  657. package/lib/tree-select/styles/index.d.ts +1 -0
  658. package/lib/tree-select/styles/index.js +3 -1
  659. package/lib/tree-select/styles/light.d.ts +14 -1
  660. package/lib/tree-select/styles/rtl.d.ts +2 -0
  661. package/lib/tree-select/styles/rtl.js +20 -0
  662. package/lib/typography/src/create-header.d.ts +1 -1
  663. package/lib/typography/src/headers.d.ts +6 -6
  664. package/lib/upload/src/Upload.d.ts +1 -0
  665. package/lib/upload/src/Upload.js +4 -3
  666. package/lib/upload/src/UploadFile.d.ts +4 -2
  667. package/lib/upload/src/UploadFile.js +1 -1
  668. package/lib/upload/src/icons.d.ts +2 -2
  669. package/lib/upload/src/icons.js +12 -7
  670. package/lib/upload/src/styles/rtl.cssr.d.ts +2 -0
  671. package/lib/upload/src/styles/rtl.cssr.js +10 -0
  672. package/lib/upload/styles/index.d.ts +1 -0
  673. package/lib/upload/styles/index.js +3 -1
  674. package/lib/upload/styles/rtl.d.ts +2 -0
  675. package/lib/upload/styles/rtl.js +11 -0
  676. package/lib/version.d.ts +1 -1
  677. package/lib/version.js +1 -1
  678. package/lib/virtual-list/src/VirtualList.d.ts +1 -1
  679. package/package.json +30 -19
  680. package/volar.d.ts +24 -22
  681. package/web-types.json +599 -61
  682. package/es/avatar-group/src/interface.d.ts +0 -8
  683. package/lib/avatar-group/src/interface.d.ts +0 -8
  684. /package/es/{avatar-group/src/interface.mjs → _utils/ts/ts.mjs} +0 -0
  685. /package/lib/{avatar-group/src/interface.js → _utils/ts/ts.js} +0 -0
@@ -1,4 +1,4 @@
1
- import { defineComponent, h, inject, onBeforeUnmount, onMounted, provide, ref, toRef, watchEffect } from 'vue';
1
+ import { computed, defineComponent, h, inject, onBeforeUnmount, onMounted, provide, ref, toRef, watchEffect } from 'vue';
2
2
  import { useConfig } from "../../_mixins/index.mjs";
3
3
  import { resolveSlot } from "../../_utils/index.mjs";
4
4
  import { isImageSupportNativeLazy } from "../../_utils/env/is-native-lazy-load.mjs";
@@ -26,6 +26,7 @@ export const imageProps = Object.assign({
26
26
  onError: Function,
27
27
  onLoad: Function
28
28
  }, imagePreviewSharedProps);
29
+ let uuid = 0;
29
30
  export default defineComponent({
30
31
  name: 'Image',
31
32
  props: imageProps,
@@ -39,24 +40,30 @@ export default defineComponent({
39
40
  const {
40
41
  mergedClsPrefixRef
41
42
  } = imageGroupHandle || useConfig(props);
43
+ const mergedPreviewSrcRef = computed(() => {
44
+ return props.previewSrc || props.src;
45
+ });
46
+ const previewShowRef = ref(false);
47
+ const imageId = uuid++;
48
+ const showPreview = () => {
49
+ if (props.previewDisabled || showErrorRef.value) return;
50
+ if (imageGroupHandle) {
51
+ imageGroupHandle.setThumbnailEl(imageRef.value);
52
+ imageGroupHandle.toggleShow(`r${imageId}`);
53
+ return;
54
+ }
55
+ const {
56
+ value: previewInst
57
+ } = previewInstRef;
58
+ if (!previewInst) return;
59
+ previewInst.setThumbnailEl(imageRef.value);
60
+ previewShowRef.value = true;
61
+ };
42
62
  const exposedMethods = {
43
63
  click: () => {
44
- if (props.previewDisabled || showErrorRef.value) return;
45
- const mergedPreviewSrc = props.previewSrc || props.src;
46
- if (imageGroupHandle) {
47
- imageGroupHandle.setPreviewSrc(mergedPreviewSrc);
48
- imageGroupHandle.setThumbnailEl(imageRef.value);
49
- imageGroupHandle.toggleShow();
50
- return;
51
- }
52
- const {
53
- value: previewInst
54
- } = previewInstRef;
55
- if (!previewInst) return;
56
- previewInst.setPreviewSrc(mergedPreviewSrc);
57
- previewInst.setThumbnailEl(imageRef.value);
58
- previewInst.toggleShow();
59
- }
64
+ showPreview();
65
+ },
66
+ showPreview
60
67
  };
61
68
  const shouldStartLoadingRef = ref(!props.lazy);
62
69
  onMounted(() => {
@@ -83,6 +90,21 @@ export default defineComponent({
83
90
  void (props.src || ((_a = props.imgProps) === null || _a === void 0 ? void 0 : _a.src));
84
91
  showErrorRef.value = false;
85
92
  });
93
+ watchEffect(onInvalidate => {
94
+ var _a;
95
+ const unregister = (_a = imageGroupHandle === null || imageGroupHandle === void 0 ? void 0 : imageGroupHandle.registerImageUrl) === null || _a === void 0 ? void 0 : _a.call(imageGroupHandle, imageId, mergedPreviewSrcRef.value || '');
96
+ onInvalidate(() => {
97
+ unregister === null || unregister === void 0 ? void 0 : unregister();
98
+ });
99
+ });
100
+ function onImgClick(e) {
101
+ var _a, _b;
102
+ exposedMethods.showPreview();
103
+ (_b = (_a = props.imgProps) === null || _a === void 0 ? void 0 : _a.onClick) === null || _b === void 0 ? void 0 : _b.call(_a, e);
104
+ }
105
+ function onPreviewClose() {
106
+ previewShowRef.value = false;
107
+ }
86
108
  const loadedRef = ref(false);
87
109
  provide(imageContextKey, {
88
110
  previewedImgPropsRef: toRef(props, 'previewedImgProps')
@@ -92,14 +114,14 @@ export default defineComponent({
92
114
  groupId: imageGroupHandle === null || imageGroupHandle === void 0 ? void 0 : imageGroupHandle.groupId,
93
115
  previewInstRef,
94
116
  imageRef,
117
+ mergedPreviewSrc: mergedPreviewSrcRef,
95
118
  showError: showErrorRef,
96
119
  shouldStartLoading: shouldStartLoadingRef,
97
120
  loaded: loadedRef,
98
121
  mergedOnClick: e => {
99
- var _a, _b;
100
- exposedMethods.click();
101
- (_b = (_a = props.imgProps) === null || _a === void 0 ? void 0 : _a.onClick) === null || _b === void 0 ? void 0 : _b.call(_a, e);
122
+ onImgClick(e);
102
123
  },
124
+ onPreviewClose,
103
125
  mergedOnError: e => {
104
126
  if (!shouldStartLoadingRef.value) return;
105
127
  showErrorRef.value = true;
@@ -122,7 +144,8 @@ export default defineComponent({
122
144
  onLoad === null || onLoad === void 0 ? void 0 : onLoad(e);
123
145
  imgPropsOnLoad === null || imgPropsOnLoad === void 0 ? void 0 : imgPropsOnLoad(e);
124
146
  loadedRef.value = true;
125
- }
147
+ },
148
+ previewShow: previewShowRef
126
149
  }, exposedMethods);
127
150
  },
128
151
  render() {
@@ -165,11 +188,13 @@ export default defineComponent({
165
188
  }), this.groupId ? imgNode : h(NImagePreview, {
166
189
  theme: this.theme,
167
190
  themeOverrides: this.themeOverrides,
168
- clsPrefix: mergedClsPrefix,
169
191
  ref: "previewInstRef",
170
192
  showToolbar: this.showToolbar,
171
193
  showToolbarTooltip: this.showToolbarTooltip,
172
- renderToolbar: this.renderToolbar
194
+ renderToolbar: this.renderToolbar,
195
+ src: this.mergedPreviewSrc,
196
+ show: !this.previewDisabled && this.previewShow,
197
+ onClose: this.onPreviewClose
173
198
  }, {
174
199
  default: () => imgNode
175
200
  }), !loaded && placeholderNode);
@@ -1,22 +1,38 @@
1
- import type { ImagePreviewInst } from './ImagePreview';
2
- import type { ImageRenderToolbar } from './public-types';
3
- import { type Ref } from 'vue';
4
- import { type ExtractPublicPropTypes } from '../../_utils';
1
+ import type { PropType, Ref } from 'vue';
2
+ import type { ExtractPublicPropTypes, MaybeArray } from '../../_utils';
3
+ import type { ImagePreviewInst, ImageRenderToolbar } from './public-types';
5
4
  export declare const imageGroupInjectionKey: import("vue").InjectionKey<ImagePreviewInst & {
6
5
  groupId: string;
7
6
  mergedClsPrefixRef: Ref<string>;
8
7
  renderToolbarRef: Ref<ImageRenderToolbar | undefined>;
8
+ registerImageUrl: (id: number, url: string) => () => void;
9
+ toggleShow: (imageId: string) => void;
9
10
  }>;
10
11
  export declare const imageGroupProps: {
11
- onPreviewPrev: import("vue").PropType<() => void>;
12
- onPreviewNext: import("vue").PropType<() => void>;
12
+ srcList: PropType<string[]>;
13
+ current: NumberConstructor;
14
+ defaultCurrent: {
15
+ type: NumberConstructor;
16
+ default: number;
17
+ };
18
+ show: {
19
+ type: BooleanConstructor;
20
+ default: undefined;
21
+ };
22
+ defaultShow: BooleanConstructor;
23
+ onUpdateShow: PropType<MaybeArray<(show: boolean) => void>>;
24
+ 'onUpdate:show': PropType<MaybeArray<(show: boolean) => void>>;
25
+ onUpdateCurrent: PropType<MaybeArray<(current: number) => void>>;
26
+ 'onUpdate:current': PropType<MaybeArray<(current: number) => void>>;
27
+ onPreviewPrev: PropType<() => void>;
28
+ onPreviewNext: PropType<() => void>;
13
29
  showToolbar: {
14
30
  type: BooleanConstructor;
15
31
  default: boolean;
16
32
  };
17
33
  showToolbarTooltip: BooleanConstructor;
18
- renderToolbar: import("vue").PropType<ImageRenderToolbar>;
19
- theme: import("vue").PropType<import("../../_mixins").Theme<"Image", {
34
+ renderToolbar: PropType<ImageRenderToolbar>;
35
+ theme: PropType<import("../../_mixins").Theme<"Image", {
20
36
  toolbarIconColor: string;
21
37
  toolbarColor: string;
22
38
  toolbarBoxShadow: string;
@@ -42,10 +58,23 @@ export declare const imageGroupProps: {
42
58
  arrowOffsetVertical: string;
43
59
  arrowHeight: string;
44
60
  padding: string;
45
- }, any>;
61
+ }, {
62
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
63
+ height: string;
64
+ width: string;
65
+ borderRadius: string;
66
+ color: string;
67
+ colorHover: string;
68
+ railInsetHorizontalBottom: string;
69
+ railInsetHorizontalTop: string;
70
+ railInsetVerticalRight: string;
71
+ railInsetVerticalLeft: string;
72
+ railColor: string;
73
+ }, any>;
74
+ }>;
46
75
  }>;
47
76
  }>>;
48
- themeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
77
+ themeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
49
78
  toolbarIconColor: string;
50
79
  toolbarColor: string;
51
80
  toolbarBoxShadow: string;
@@ -71,10 +100,23 @@ export declare const imageGroupProps: {
71
100
  arrowOffsetVertical: string;
72
101
  arrowHeight: string;
73
102
  padding: string;
74
- }, any>;
103
+ }, {
104
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
105
+ height: string;
106
+ width: string;
107
+ borderRadius: string;
108
+ color: string;
109
+ colorHover: string;
110
+ railInsetHorizontalBottom: string;
111
+ railInsetHorizontalTop: string;
112
+ railInsetVerticalRight: string;
113
+ railInsetVerticalLeft: string;
114
+ railColor: string;
115
+ }, any>;
116
+ }>;
75
117
  }>;
76
118
  }>>>;
77
- builtinThemeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
119
+ builtinThemeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
78
120
  toolbarIconColor: string;
79
121
  toolbarColor: string;
80
122
  toolbarBoxShadow: string;
@@ -100,21 +142,49 @@ export declare const imageGroupProps: {
100
142
  arrowOffsetVertical: string;
101
143
  arrowHeight: string;
102
144
  padding: string;
103
- }, any>;
145
+ }, {
146
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
147
+ height: string;
148
+ width: string;
149
+ borderRadius: string;
150
+ color: string;
151
+ colorHover: string;
152
+ railInsetHorizontalBottom: string;
153
+ railInsetHorizontalTop: string;
154
+ railInsetVerticalRight: string;
155
+ railInsetVerticalLeft: string;
156
+ railColor: string;
157
+ }, any>;
158
+ }>;
104
159
  }>;
105
160
  }>>>;
106
161
  };
107
162
  export type ImageGroupProps = ExtractPublicPropTypes<typeof imageGroupProps>;
108
163
  declare const _default: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
109
- onPreviewPrev: import("vue").PropType<() => void>;
110
- onPreviewNext: import("vue").PropType<() => void>;
164
+ srcList: PropType<string[]>;
165
+ current: NumberConstructor;
166
+ defaultCurrent: {
167
+ type: NumberConstructor;
168
+ default: number;
169
+ };
170
+ show: {
171
+ type: BooleanConstructor;
172
+ default: undefined;
173
+ };
174
+ defaultShow: BooleanConstructor;
175
+ onUpdateShow: PropType<MaybeArray<(show: boolean) => void>>;
176
+ 'onUpdate:show': PropType<MaybeArray<(show: boolean) => void>>;
177
+ onUpdateCurrent: PropType<MaybeArray<(current: number) => void>>;
178
+ 'onUpdate:current': PropType<MaybeArray<(current: number) => void>>;
179
+ onPreviewPrev: PropType<() => void>;
180
+ onPreviewNext: PropType<() => void>;
111
181
  showToolbar: {
112
182
  type: BooleanConstructor;
113
183
  default: boolean;
114
184
  };
115
185
  showToolbarTooltip: BooleanConstructor;
116
- renderToolbar: import("vue").PropType<ImageRenderToolbar>;
117
- theme: import("vue").PropType<import("../../_mixins").Theme<"Image", {
186
+ renderToolbar: PropType<ImageRenderToolbar>;
187
+ theme: PropType<import("../../_mixins").Theme<"Image", {
118
188
  toolbarIconColor: string;
119
189
  toolbarColor: string;
120
190
  toolbarBoxShadow: string;
@@ -140,10 +210,23 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
140
210
  arrowOffsetVertical: string;
141
211
  arrowHeight: string;
142
212
  padding: string;
143
- }, any>;
213
+ }, {
214
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
215
+ height: string;
216
+ width: string;
217
+ borderRadius: string;
218
+ color: string;
219
+ colorHover: string;
220
+ railInsetHorizontalBottom: string;
221
+ railInsetHorizontalTop: string;
222
+ railInsetVerticalRight: string;
223
+ railInsetVerticalLeft: string;
224
+ railColor: string;
225
+ }, any>;
226
+ }>;
144
227
  }>;
145
228
  }>>;
146
- themeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
229
+ themeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
147
230
  toolbarIconColor: string;
148
231
  toolbarColor: string;
149
232
  toolbarBoxShadow: string;
@@ -169,10 +252,23 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
169
252
  arrowOffsetVertical: string;
170
253
  arrowHeight: string;
171
254
  padding: string;
172
- }, any>;
255
+ }, {
256
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
257
+ height: string;
258
+ width: string;
259
+ borderRadius: string;
260
+ color: string;
261
+ colorHover: string;
262
+ railInsetHorizontalBottom: string;
263
+ railInsetHorizontalTop: string;
264
+ railInsetVerticalRight: string;
265
+ railInsetVerticalLeft: string;
266
+ railColor: string;
267
+ }, any>;
268
+ }>;
173
269
  }>;
174
270
  }>>>;
175
- builtinThemeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
271
+ builtinThemeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
176
272
  toolbarIconColor: string;
177
273
  toolbarColor: string;
178
274
  toolbarBoxShadow: string;
@@ -198,32 +294,59 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
198
294
  arrowOffsetVertical: string;
199
295
  arrowHeight: string;
200
296
  padding: string;
201
- }, any>;
297
+ }, {
298
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
299
+ height: string;
300
+ width: string;
301
+ borderRadius: string;
302
+ color: string;
303
+ colorHover: string;
304
+ railInsetHorizontalBottom: string;
305
+ railInsetHorizontalTop: string;
306
+ railInsetVerticalRight: string;
307
+ railInsetVerticalLeft: string;
308
+ railColor: string;
309
+ }, any>;
310
+ }>;
202
311
  }>;
203
312
  }>>>;
204
313
  }>, {
205
314
  mergedClsPrefix: Ref<string, string>;
206
315
  previewInstRef: Ref<{
207
316
  setThumbnailEl: (e: HTMLImageElement | null) => void;
208
- setPreviewSrc: (src?: string) => void;
209
- toggleShow: () => void;
210
317
  } | null, ImagePreviewInst | {
211
318
  setThumbnailEl: (e: HTMLImageElement | null) => void;
212
- setPreviewSrc: (src?: string) => void;
213
- toggleShow: () => void;
214
319
  } | null>;
320
+ mergedShow: import("vue").ComputedRef<boolean>;
321
+ src: import("vue").ComputedRef<string | undefined>;
322
+ onClose: () => void;
215
323
  next: () => void;
216
324
  prev: () => void;
217
325
  }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
218
- onPreviewPrev: import("vue").PropType<() => void>;
219
- onPreviewNext: import("vue").PropType<() => void>;
326
+ srcList: PropType<string[]>;
327
+ current: NumberConstructor;
328
+ defaultCurrent: {
329
+ type: NumberConstructor;
330
+ default: number;
331
+ };
332
+ show: {
333
+ type: BooleanConstructor;
334
+ default: undefined;
335
+ };
336
+ defaultShow: BooleanConstructor;
337
+ onUpdateShow: PropType<MaybeArray<(show: boolean) => void>>;
338
+ 'onUpdate:show': PropType<MaybeArray<(show: boolean) => void>>;
339
+ onUpdateCurrent: PropType<MaybeArray<(current: number) => void>>;
340
+ 'onUpdate:current': PropType<MaybeArray<(current: number) => void>>;
341
+ onPreviewPrev: PropType<() => void>;
342
+ onPreviewNext: PropType<() => void>;
220
343
  showToolbar: {
221
344
  type: BooleanConstructor;
222
345
  default: boolean;
223
346
  };
224
347
  showToolbarTooltip: BooleanConstructor;
225
- renderToolbar: import("vue").PropType<ImageRenderToolbar>;
226
- theme: import("vue").PropType<import("../../_mixins").Theme<"Image", {
348
+ renderToolbar: PropType<ImageRenderToolbar>;
349
+ theme: PropType<import("../../_mixins").Theme<"Image", {
227
350
  toolbarIconColor: string;
228
351
  toolbarColor: string;
229
352
  toolbarBoxShadow: string;
@@ -249,10 +372,23 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
249
372
  arrowOffsetVertical: string;
250
373
  arrowHeight: string;
251
374
  padding: string;
252
- }, any>;
375
+ }, {
376
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
377
+ height: string;
378
+ width: string;
379
+ borderRadius: string;
380
+ color: string;
381
+ colorHover: string;
382
+ railInsetHorizontalBottom: string;
383
+ railInsetHorizontalTop: string;
384
+ railInsetVerticalRight: string;
385
+ railInsetVerticalLeft: string;
386
+ railColor: string;
387
+ }, any>;
388
+ }>;
253
389
  }>;
254
390
  }>>;
255
- themeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
391
+ themeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
256
392
  toolbarIconColor: string;
257
393
  toolbarColor: string;
258
394
  toolbarBoxShadow: string;
@@ -278,10 +414,23 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
278
414
  arrowOffsetVertical: string;
279
415
  arrowHeight: string;
280
416
  padding: string;
281
- }, any>;
417
+ }, {
418
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
419
+ height: string;
420
+ width: string;
421
+ borderRadius: string;
422
+ color: string;
423
+ colorHover: string;
424
+ railInsetHorizontalBottom: string;
425
+ railInsetHorizontalTop: string;
426
+ railInsetVerticalRight: string;
427
+ railInsetVerticalLeft: string;
428
+ railColor: string;
429
+ }, any>;
430
+ }>;
282
431
  }>;
283
432
  }>>>;
284
- builtinThemeOverrides: import("vue").PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
433
+ builtinThemeOverrides: PropType<import("../../_mixins/use-theme").ExtractThemeOverrides<import("../../_mixins").Theme<"Image", {
285
434
  toolbarIconColor: string;
286
435
  toolbarColor: string;
287
436
  toolbarBoxShadow: string;
@@ -307,11 +456,27 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
307
456
  arrowOffsetVertical: string;
308
457
  arrowHeight: string;
309
458
  padding: string;
310
- }, any>;
459
+ }, {
460
+ Scrollbar: import("../../_mixins").Theme<"Scrollbar", {
461
+ height: string;
462
+ width: string;
463
+ borderRadius: string;
464
+ color: string;
465
+ colorHover: string;
466
+ railInsetHorizontalBottom: string;
467
+ railInsetHorizontalTop: string;
468
+ railInsetVerticalRight: string;
469
+ railInsetVerticalLeft: string;
470
+ railColor: string;
471
+ }, any>;
472
+ }>;
311
473
  }>;
312
474
  }>>>;
313
475
  }>> & Readonly<{}>, {
476
+ show: boolean;
477
+ defaultShow: boolean;
314
478
  showToolbar: boolean;
315
479
  showToolbarTooltip: boolean;
480
+ defaultCurrent: number;
316
481
  }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
317
482
  export default _default;
@@ -1,56 +1,155 @@
1
1
  import { createId } from 'seemly';
2
- import { defineComponent, getCurrentInstance, h, provide, ref, toRef } from 'vue';
2
+ import { useMergedState } from 'vooks';
3
+ import { computed, defineComponent, h, provide, ref, toRef } from 'vue';
3
4
  import { useConfig } from "../../_mixins/index.mjs";
4
- import { createInjectionKey } from "../../_utils/index.mjs";
5
+ import { call, createInjectionKey, throwError } from "../../_utils/index.mjs";
5
6
  import NImagePreview from "./ImagePreview.mjs";
6
7
  import { imagePreviewSharedProps } from "./interface.mjs";
7
8
  export const imageGroupInjectionKey = createInjectionKey('n-image-group');
8
- export const imageGroupProps = imagePreviewSharedProps;
9
+ export const imageGroupProps = Object.assign(Object.assign({}, imagePreviewSharedProps), {
10
+ srcList: Array,
11
+ current: Number,
12
+ defaultCurrent: {
13
+ type: Number,
14
+ default: 0
15
+ },
16
+ show: {
17
+ type: Boolean,
18
+ default: undefined
19
+ },
20
+ defaultShow: Boolean,
21
+ onUpdateShow: [Function, Array],
22
+ 'onUpdate:show': [Function, Array],
23
+ onUpdateCurrent: [Function, Array],
24
+ 'onUpdate:current': [Function, Array]
25
+ });
9
26
  export default defineComponent({
10
27
  name: 'ImageGroup',
11
28
  props: imageGroupProps,
12
29
  setup(props) {
13
- let currentSrc;
14
30
  const {
15
31
  mergedClsPrefixRef
16
32
  } = useConfig(props);
17
33
  const groupId = `c${createId()}`;
18
- const vm = getCurrentInstance();
19
34
  const previewInstRef = ref(null);
20
- const setPreviewSrc = src => {
21
- var _a;
22
- currentSrc = src;
23
- (_a = previewInstRef.value) === null || _a === void 0 ? void 0 : _a.setPreviewSrc(src);
35
+ const uncontrolledShowRef = ref(props.defaultShow);
36
+ const controlledShowRef = toRef(props, 'show');
37
+ const mergedShowRef = useMergedState(controlledShowRef, uncontrolledShowRef);
38
+ const registeredImageUrlMap = ref(new Map());
39
+ const mergedImageUrlMap = computed(() => {
40
+ if (props.srcList) {
41
+ const map = new Map();
42
+ props.srcList.forEach((url, index) => {
43
+ map.set(`p${index}`, url);
44
+ });
45
+ return map;
46
+ }
47
+ return registeredImageUrlMap.value;
48
+ });
49
+ const imageIdListRef = computed(() => Array.from(mergedImageUrlMap.value.keys()));
50
+ const imageCountGetter = () => imageIdListRef.value.length;
51
+ function registerImageUrl(id, url) {
52
+ if (props.srcList) {
53
+ throwError('image-group', '`n-image` can\'t be placed inside `n-image-group` when image group\'s `src-list` prop is set.');
54
+ }
55
+ const sid = `r${id}`;
56
+ if (!registeredImageUrlMap.value.has(`r${sid}`)) {
57
+ registeredImageUrlMap.value.set(sid, url);
58
+ }
59
+ return function unregisterPreviewUrl() {
60
+ if (!registeredImageUrlMap.value.has(sid)) {
61
+ registeredImageUrlMap.value.delete(sid);
62
+ }
63
+ };
64
+ }
65
+ const uncontrolledCurrentRef = ref(props.defaultCurrent);
66
+ const controlledCurrentRef = toRef(props, 'current');
67
+ const mergedCurrentRef = useMergedState(controlledCurrentRef, uncontrolledCurrentRef);
68
+ const setCurrentIndex = index => {
69
+ if (index !== mergedCurrentRef.value) {
70
+ const {
71
+ onUpdateCurrent,
72
+ 'onUpdate:current': _onUpdateCurrent
73
+ } = props;
74
+ if (onUpdateCurrent) {
75
+ call(onUpdateCurrent, index);
76
+ }
77
+ if (_onUpdateCurrent) {
78
+ call(_onUpdateCurrent, index);
79
+ }
80
+ uncontrolledCurrentRef.value = index;
81
+ }
82
+ };
83
+ const currentId = computed(() => imageIdListRef.value[mergedCurrentRef.value]);
84
+ const setCurrentId = nextId => {
85
+ const nextIndex = imageIdListRef.value.indexOf(nextId);
86
+ if (nextIndex !== mergedCurrentRef.value) {
87
+ setCurrentIndex(nextIndex);
88
+ }
24
89
  };
90
+ const currentUrl = computed(() => mergedImageUrlMap.value.get(currentId.value));
91
+ function doUpdateShow(value) {
92
+ const {
93
+ onUpdateShow,
94
+ 'onUpdate:show': _onUpdateShow
95
+ } = props;
96
+ if (onUpdateShow) {
97
+ call(onUpdateShow, value);
98
+ }
99
+ if (_onUpdateShow) {
100
+ call(_onUpdateShow, value);
101
+ }
102
+ uncontrolledShowRef.value = value;
103
+ }
104
+ function onClose() {
105
+ doUpdateShow(false);
106
+ }
107
+ const nextIndex = computed(() => {
108
+ const findNext = (start, end) => {
109
+ for (let i = start; i <= end; i++) {
110
+ const id = imageIdListRef.value[i];
111
+ if (mergedImageUrlMap.value.get(id)) {
112
+ return i;
113
+ }
114
+ }
115
+ return undefined;
116
+ };
117
+ const next = findNext(mergedCurrentRef.value + 1, imageCountGetter() - 1);
118
+ return next === undefined ? findNext(0, mergedCurrentRef.value - 1) : next;
119
+ });
120
+ const prevIndex = computed(() => {
121
+ const findPrev = (start, end) => {
122
+ for (let i = start; i >= end; i--) {
123
+ const id = imageIdListRef.value[i];
124
+ if (mergedImageUrlMap.value.get(id)) {
125
+ return i;
126
+ }
127
+ }
128
+ return undefined;
129
+ };
130
+ const prev = findPrev(mergedCurrentRef.value - 1, 0);
131
+ return prev === undefined ? findPrev(imageCountGetter() - 1, mergedCurrentRef.value + 1) : prev;
132
+ });
25
133
  function go(step) {
26
134
  var _a, _b;
27
- if (!(vm === null || vm === void 0 ? void 0 : vm.proxy)) return;
28
- const container = vm.proxy.$el.parentElement;
29
- // use dom api since we can't get the correct order before all children are rendered
30
- const imgs = container.querySelectorAll(`[data-group-id=${groupId}]:not([data-error=true])`);
31
- if (!imgs.length) return;
32
- const index = Array.from(imgs).findIndex(img => img.dataset.previewSrc === currentSrc);
33
- if (~index) {
34
- setPreviewSrc(imgs[(index + step + imgs.length) % imgs.length].dataset.previewSrc);
35
- } else {
36
- setPreviewSrc(imgs[0].dataset.previewSrc);
37
- }
38
135
  if (step === 1) {
136
+ prevIndex.value !== undefined && setCurrentIndex(nextIndex.value);
39
137
  (_a = props.onPreviewNext) === null || _a === void 0 ? void 0 : _a.call(props);
40
138
  } else {
139
+ nextIndex.value !== undefined && setCurrentIndex(prevIndex.value);
41
140
  (_b = props.onPreviewPrev) === null || _b === void 0 ? void 0 : _b.call(props);
42
141
  }
43
142
  }
44
143
  provide(imageGroupInjectionKey, {
45
144
  mergedClsPrefixRef,
46
- setPreviewSrc,
145
+ registerImageUrl,
47
146
  setThumbnailEl: el => {
48
147
  var _a;
49
148
  (_a = previewInstRef.value) === null || _a === void 0 ? void 0 : _a.setThumbnailEl(el);
50
149
  },
51
- toggleShow: () => {
52
- var _a;
53
- (_a = previewInstRef.value) === null || _a === void 0 ? void 0 : _a.toggleShow();
150
+ toggleShow: imageId => {
151
+ doUpdateShow(true);
152
+ setCurrentId(imageId);
54
153
  },
55
154
  groupId,
56
155
  renderToolbarRef: toRef(props, 'renderToolbar')
@@ -58,6 +157,9 @@ export default defineComponent({
58
157
  return {
59
158
  mergedClsPrefix: mergedClsPrefixRef,
60
159
  previewInstRef,
160
+ mergedShow: mergedShowRef,
161
+ src: currentUrl,
162
+ onClose,
61
163
  next: () => {
62
164
  go(1);
63
165
  },
@@ -70,13 +172,15 @@ export default defineComponent({
70
172
  return h(NImagePreview, {
71
173
  theme: this.theme,
72
174
  themeOverrides: this.themeOverrides,
73
- clsPrefix: this.mergedClsPrefix,
74
175
  ref: "previewInstRef",
75
176
  onPrev: this.prev,
76
177
  onNext: this.next,
178
+ src: this.src,
179
+ show: this.mergedShow,
77
180
  showToolbar: this.showToolbar,
78
181
  showToolbarTooltip: this.showToolbarTooltip,
79
- renderToolbar: this.renderToolbar
182
+ renderToolbar: this.renderToolbar,
183
+ onClose: this.onClose
80
184
  }, this.$slots);
81
185
  }
82
186
  });