antd-mobile 0.0.0-dev-626cbf51f → 0.0.0-dev.bc248f5c7

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 (1071) hide show
  1. package/2x/README.md +43 -26
  2. package/2x/bundle/antd-mobile.cjs.js +64 -0
  3. package/2x/bundle/antd-mobile.compatible.umd.js +25799 -0
  4. package/2x/bundle/antd-mobile.es.js +18494 -0
  5. package/2x/bundle/antd-mobile.umd.js +64 -0
  6. package/2x/bundle/css-vars-patch.css +399 -0
  7. package/2x/bundle/style.css +4794 -0
  8. package/2x/cjs/components/action-sheet/action-sheet.css +27 -12
  9. package/2x/cjs/components/action-sheet/action-sheet.d.ts +3 -5
  10. package/2x/cjs/components/action-sheet/action-sheet.js +14 -18
  11. package/2x/cjs/components/badge/badge.css +3 -3
  12. package/2x/cjs/components/badge/badge.d.ts +3 -1
  13. package/2x/cjs/components/badge/badge.js +5 -2
  14. package/2x/cjs/components/badge/index.d.ts +1 -1
  15. package/2x/cjs/components/button/button.css +7 -6
  16. package/2x/cjs/components/button/button.d.ts +10 -4
  17. package/2x/cjs/components/button/button.js +6 -2
  18. package/2x/cjs/components/button/button.patch.css +106 -0
  19. package/2x/cjs/components/calendar/calendar.css +9 -5
  20. package/2x/cjs/components/calendar/calendar.d.ts +4 -3
  21. package/2x/cjs/components/calendar/calendar.js +4 -4
  22. package/2x/cjs/components/calendar/index.d.ts +1 -1
  23. package/2x/cjs/components/capsule-tabs/capsule-tabs.css +4 -24
  24. package/2x/cjs/components/card/card.css +3 -3
  25. package/2x/cjs/components/cascader/cascader.css +2 -2
  26. package/2x/cjs/components/cascader/cascader.d.ts +32 -4
  27. package/2x/cjs/components/cascader/cascader.js +42 -20
  28. package/2x/cjs/components/cascader/index.d.ts +22 -2
  29. package/2x/cjs/components/cascader-view/cascader-view.css +2 -2
  30. package/2x/cjs/components/cascader-view/cascader-view.d.ts +3 -1
  31. package/2x/cjs/components/cascader-view/cascader-view.js +20 -9
  32. package/2x/cjs/components/cascader-view/use-cascader-value-extend.js +5 -14
  33. package/2x/cjs/components/center-popup/center-popup.css +40 -0
  34. package/2x/cjs/components/center-popup/center-popup.d.ts +7 -0
  35. package/2x/cjs/components/center-popup/center-popup.js +131 -0
  36. package/2x/cjs/components/center-popup/center-popup.patch.css +13 -0
  37. package/2x/cjs/components/center-popup/index.d.ts +4 -0
  38. package/2x/cjs/components/center-popup/index.js +13 -0
  39. package/2x/cjs/components/check-list/check-list.css +1 -1
  40. package/2x/cjs/components/checkbox/checkbox.css +3 -3
  41. package/2x/cjs/components/checkbox/checkbox.d.ts +22 -2
  42. package/2x/cjs/components/checkbox/checkbox.js +14 -4
  43. package/2x/cjs/components/checkbox/index.d.ts +17 -2
  44. package/2x/cjs/components/checkbox/native-input.js +10 -8
  45. package/2x/cjs/components/date-picker/date-picker-date-utils.js +12 -15
  46. package/2x/cjs/components/date-picker/date-picker-week-utils.js +12 -15
  47. package/2x/cjs/components/date-picker/date-picker.d.ts +7 -3
  48. package/2x/cjs/components/date-picker/date-picker.js +6 -2
  49. package/2x/cjs/components/date-picker/index.d.ts +6 -2
  50. package/2x/cjs/components/date-picker-view/date-picker-view.d.ts +1 -1
  51. package/2x/cjs/components/date-picker-view/date-picker-view.js +2 -0
  52. package/2x/cjs/components/dialog/dialog.css +22 -34
  53. package/2x/cjs/components/dialog/dialog.d.ts +4 -15
  54. package/2x/cjs/components/dialog/dialog.js +27 -71
  55. package/2x/cjs/components/dialog/show.d.ts +1 -1
  56. package/2x/cjs/components/divider/divider.css +2 -2
  57. package/2x/cjs/components/dropdown/dropdown.css +5 -5
  58. package/2x/cjs/components/dropdown/dropdown.d.ts +5 -1
  59. package/2x/cjs/components/dropdown/index.d.ts +5 -1
  60. package/2x/cjs/components/ellipsis/ellipsis.js +1 -2
  61. package/2x/cjs/components/empty/empty.css +2 -1
  62. package/2x/cjs/components/error-block/create-error-block.d.ts +12 -0
  63. package/2x/cjs/components/error-block/create-error-block.js +59 -0
  64. package/2x/cjs/components/error-block/error-block.css +4 -4
  65. package/2x/cjs/components/error-block/error-block.d.ts +2 -11
  66. package/2x/cjs/components/error-block/error-block.js +7 -53
  67. package/2x/cjs/components/error-block/error-block.patch.css +29 -0
  68. package/2x/cjs/components/error-block/images/busy.d.ts +1 -0
  69. package/2x/cjs/components/error-block/images/default.d.ts +1 -0
  70. package/2x/cjs/components/error-block/images/disconnected.d.ts +1 -0
  71. package/2x/cjs/components/error-block/images/empty.d.ts +1 -0
  72. package/2x/cjs/components/error-block/images/index.d.ts +4 -2
  73. package/2x/cjs/components/error-block/images/index.js +25 -10
  74. package/2x/cjs/components/error-block/index.d.ts +5 -1
  75. package/2x/cjs/components/error-block/index.js +8 -0
  76. package/2x/cjs/components/floating-bubble/floating-bubble.css +1 -0
  77. package/2x/cjs/components/floating-panel/floating-panel.css +7 -4
  78. package/2x/cjs/components/floating-panel/floating-panel.d.ts +5 -1
  79. package/2x/cjs/components/form/context.d.ts +1 -1
  80. package/2x/cjs/components/form/form-item.css +3 -2
  81. package/2x/cjs/components/form/form-item.js +12 -12
  82. package/2x/cjs/components/form/form-subscribe.d.ts +7 -2
  83. package/2x/cjs/components/form/form-subscribe.js +28 -16
  84. package/2x/cjs/components/form/form.css +3 -3
  85. package/2x/cjs/components/form/form.d.ts +5 -1
  86. package/2x/cjs/components/form/index.css +6 -5
  87. package/2x/cjs/components/form/index.d.ts +6 -2
  88. package/2x/cjs/components/grid/grid.css +1 -0
  89. package/2x/cjs/components/image/broken-image-icon.d.ts +1 -0
  90. package/2x/cjs/components/image/broken-image-icon.js +21 -0
  91. package/2x/cjs/components/image/image-icon.d.ts +1 -0
  92. package/2x/cjs/components/image/image-icon.js +21 -0
  93. package/2x/cjs/components/image/image.css +4 -2
  94. package/2x/cjs/components/image/image.d.ts +3 -1
  95. package/2x/cjs/components/image/image.js +14 -7
  96. package/2x/cjs/components/image/image.patch.css +12 -0
  97. package/2x/cjs/components/image/test/image.test.d.ts +1 -0
  98. package/2x/cjs/components/image/test/image.test.js +83 -0
  99. package/2x/cjs/components/image-uploader/image-uploader.css +4 -4
  100. package/2x/cjs/components/image-uploader/image-uploader.js +1 -4
  101. package/2x/cjs/components/image-viewer/image-viewer.css +11 -2
  102. package/2x/cjs/components/image-viewer/image-viewer.d.ts +5 -2
  103. package/2x/cjs/components/image-viewer/image-viewer.js +24 -4
  104. package/2x/cjs/components/image-viewer/index.d.ts +2 -1
  105. package/2x/cjs/components/image-viewer/slide.js +75 -56
  106. package/2x/cjs/components/index-bar/index-bar.css +6 -4
  107. package/2x/cjs/components/index-bar/index-bar.d.ts +7 -1
  108. package/2x/cjs/components/index-bar/index-bar.js +6 -0
  109. package/2x/cjs/components/index-bar/index.d.ts +6 -1
  110. package/2x/cjs/components/infinite-scroll/infinite-scroll.css +6 -1
  111. package/2x/cjs/components/infinite-scroll/infinite-scroll.d.ts +2 -2
  112. package/2x/cjs/components/infinite-scroll/infinite-scroll.js +67 -25
  113. package/2x/cjs/components/input/input.css +12 -2
  114. package/2x/cjs/components/input/input.d.ts +11 -4
  115. package/2x/cjs/components/input/input.js +35 -6
  116. package/2x/cjs/components/jumbo-tabs/jumbo-tabs.css +6 -24
  117. package/2x/cjs/components/list/index.d.ts +10 -2
  118. package/2x/cjs/components/list/list.css +12 -10
  119. package/2x/cjs/components/list/list.d.ts +14 -3
  120. package/2x/cjs/components/list/list.js +16 -6
  121. package/2x/cjs/components/mask/mask.js +9 -7
  122. package/2x/cjs/components/mask/mask.patch.css +3 -0
  123. package/2x/cjs/components/modal/modal-action-button.d.ts +2 -2
  124. package/2x/cjs/components/modal/modal.css +13 -36
  125. package/2x/cjs/components/modal/modal.d.ts +4 -15
  126. package/2x/cjs/components/modal/modal.js +23 -77
  127. package/2x/cjs/components/modal/modal.patch.css +29 -0
  128. package/2x/cjs/components/modal/show.d.ts +1 -1
  129. package/2x/cjs/components/nav-bar/nav-bar.css +2 -2
  130. package/2x/cjs/components/notice-bar/notice-bar.css +13 -4
  131. package/2x/cjs/components/notice-bar/notice-bar.js +5 -3
  132. package/2x/cjs/components/number-keyboard/number-keyboard.css +18 -21
  133. package/2x/cjs/components/number-keyboard/number-keyboard.d.ts +2 -6
  134. package/2x/cjs/components/number-keyboard/number-keyboard.js +32 -24
  135. package/2x/cjs/components/page-indicator/page-indicator.patch.css +31 -0
  136. package/2x/cjs/components/passcode-input/index.d.ts +1 -1
  137. package/2x/cjs/components/passcode-input/passcode-input.css +14 -14
  138. package/2x/cjs/components/passcode-input/passcode-input.d.ts +5 -1
  139. package/2x/cjs/components/passcode-input/passcode-input.js +16 -8
  140. package/2x/cjs/components/picker/index.d.ts +14 -6
  141. package/2x/cjs/components/picker/picker.css +12 -7
  142. package/2x/cjs/components/picker/picker.d.ts +10 -6
  143. package/2x/cjs/components/picker/picker.js +15 -10
  144. package/2x/cjs/components/picker-view/picker-view.css +21 -6
  145. package/2x/cjs/components/picker-view/picker-view.d.ts +2 -0
  146. package/2x/cjs/components/picker-view/picker-view.js +10 -3
  147. package/2x/cjs/components/picker-view/wheel.js +11 -9
  148. package/2x/cjs/components/popover/index.d.ts +5 -1
  149. package/2x/cjs/components/popover/popover-menu.css +1 -1
  150. package/2x/cjs/components/popover/popover-menu.patch.css +31 -0
  151. package/2x/cjs/components/popover/popover.css +6 -2
  152. package/2x/cjs/components/popover/popover.d.ts +5 -1
  153. package/2x/cjs/components/popover/popover.js +3 -1
  154. package/2x/cjs/components/popover/popover.patch.css +24 -0
  155. package/2x/cjs/components/popup/popup-base-props.d.ts +35 -0
  156. package/2x/cjs/components/popup/popup-base-props.js +18 -0
  157. package/2x/cjs/components/popup/popup.css +33 -1
  158. package/2x/cjs/components/popup/popup.d.ts +4 -20
  159. package/2x/cjs/components/popup/popup.js +43 -18
  160. package/2x/cjs/components/progress-bar/progress-bar.css +17 -3
  161. package/2x/cjs/components/progress-bar/progress-bar.d.ts +4 -2
  162. package/2x/cjs/components/progress-bar/progress-bar.js +27 -5
  163. package/2x/cjs/components/radio/radio.css +2 -2
  164. package/2x/cjs/components/radio/radio.js +3 -3
  165. package/2x/cjs/components/rate/rate.css +3 -2
  166. package/2x/cjs/components/rate/rate.js +41 -8
  167. package/2x/cjs/components/rate/star.d.ts +2 -0
  168. package/2x/cjs/components/rate/star.js +27 -0
  169. package/2x/cjs/components/result/result.css +3 -3
  170. package/2x/cjs/components/result/result.d.ts +1 -1
  171. package/2x/cjs/components/result/result.js +7 -1
  172. package/2x/cjs/components/safe-area/safe-area.css +3 -2
  173. package/2x/cjs/components/scroll-mask/scroll-mask.css +2 -2
  174. package/2x/cjs/components/scroll-mask/scroll-mask.patch.css +7 -0
  175. package/2x/cjs/components/search-bar/search-bar.css +4 -4
  176. package/2x/cjs/components/search-bar/search-bar.d.ts +5 -1
  177. package/2x/cjs/components/search-bar/search-bar.js +17 -10
  178. package/2x/cjs/components/selector/selector.css +3 -3
  179. package/2x/cjs/components/side-bar/corner.js +1 -1
  180. package/2x/cjs/components/side-bar/side-bar.css +4 -3
  181. package/2x/cjs/components/side-bar/side-bar.d.ts +2 -1
  182. package/2x/cjs/components/side-bar/side-bar.js +1 -0
  183. package/2x/cjs/components/slider/slider.css +30 -24
  184. package/2x/cjs/components/slider/slider.d.ts +3 -2
  185. package/2x/cjs/components/slider/slider.js +6 -3
  186. package/2x/cjs/components/slider/thumb-icon.js +20 -18
  187. package/2x/cjs/components/slider/thumb.d.ts +4 -2
  188. package/2x/cjs/components/slider/thumb.js +31 -5
  189. package/2x/cjs/components/space/space.patch.css +16 -0
  190. package/2x/cjs/components/spin-loading/spin-loading.css +0 -3
  191. package/2x/cjs/components/spin-loading/spin-loading.js +6 -2
  192. package/2x/cjs/components/spin-loading/spin-loading.patch.css +14 -0
  193. package/2x/cjs/components/stepper/stepper.css +3 -3
  194. package/2x/cjs/components/stepper/stepper.js +14 -3
  195. package/2x/cjs/components/steps/steps.css +3 -3
  196. package/2x/cjs/components/swipe-action/swipe-action.css +2 -1
  197. package/2x/cjs/components/swipe-action/swipe-action.d.ts +7 -1
  198. package/2x/cjs/components/swipe-action/swipe-action.js +20 -7
  199. package/2x/cjs/components/swiper/index.d.ts +10 -2
  200. package/2x/cjs/components/swiper/swiper.css +1 -0
  201. package/2x/cjs/components/swiper/swiper.d.ts +5 -1
  202. package/2x/cjs/components/swiper/swiper.js +19 -8
  203. package/2x/cjs/components/swiper/swiper.patch.css +26 -0
  204. package/2x/cjs/components/switch/switch.css +4 -4
  205. package/2x/cjs/components/switch/switch.d.ts +2 -1
  206. package/2x/cjs/components/switch/switch.js +26 -4
  207. package/2x/cjs/components/tab-bar/tab-bar.css +9 -5
  208. package/2x/cjs/components/tab-bar/tab-bar.js +2 -1
  209. package/2x/cjs/components/tabs/tabs.css +9 -7
  210. package/2x/cjs/components/tabs/tabs.d.ts +1 -1
  211. package/2x/cjs/components/tabs/tabs.patch.css +29 -0
  212. package/2x/cjs/components/tag/tag.css +1 -1
  213. package/2x/cjs/components/text-area/text-area.css +8 -2
  214. package/2x/cjs/components/text-area/text-area.d.ts +6 -1
  215. package/2x/cjs/components/text-area/text-area.js +7 -1
  216. package/2x/cjs/components/toast/methods.js +32 -73
  217. package/2x/cjs/components/toast/toast.css +2 -2
  218. package/2x/cjs/components/toast/toast.d.ts +2 -1
  219. package/2x/cjs/components/toast/toast.js +6 -2
  220. package/2x/cjs/components/toast/toast.patch.css +13 -0
  221. package/2x/cjs/components/tree-select/tree-select.css +1 -1
  222. package/2x/cjs/components/virtual-input/virtual-input.css +2 -2
  223. package/2x/cjs/components/virtual-input/virtual-input.d.ts +5 -1
  224. package/2x/cjs/components/water-mark/water-mark.js +3 -2
  225. package/2x/cjs/global/css-vars-patch.css +399 -0
  226. package/2x/cjs/global/global.css +36 -4
  227. package/2x/cjs/global/index.js +2 -1
  228. package/2x/cjs/global/theme-dark.css +14 -0
  229. package/2x/cjs/global/theme-default.css +32 -0
  230. package/2x/cjs/index.d.ts +3 -0
  231. package/2x/cjs/index.js +29 -1
  232. package/2x/cjs/locales/base.d.ts +21 -0
  233. package/2x/cjs/locales/base.js +22 -1
  234. package/2x/cjs/locales/en-US.d.ts +21 -0
  235. package/2x/cjs/locales/es-ES.d.ts +21 -0
  236. package/2x/cjs/locales/fa-IR.d.ts +21 -0
  237. package/2x/cjs/locales/fr-FR.d.ts +127 -0
  238. package/2x/cjs/locales/fr-FR.js +119 -0
  239. package/2x/cjs/locales/id-ID.d.ts +127 -0
  240. package/2x/cjs/locales/id-ID.js +134 -0
  241. package/2x/cjs/locales/kk-KZ.d.ts +127 -0
  242. package/2x/cjs/locales/kk-KZ.js +124 -0
  243. package/2x/cjs/locales/ko-KR.d.ts +21 -0
  244. package/2x/cjs/locales/zh-CN.d.ts +21 -0
  245. package/2x/cjs/locales/zh-CN.js +22 -1
  246. package/2x/cjs/locales/zh-HK.d.ts +21 -0
  247. package/2x/cjs/locales/zh-TW.d.ts +21 -0
  248. package/2x/cjs/utils/get-scroll-parent.js +1 -1
  249. package/2x/cjs/utils/matrix.d.ts +10 -0
  250. package/2x/cjs/utils/matrix.js +60 -0
  251. package/2x/cjs/utils/measure-css-length.js +2 -2
  252. package/2x/cjs/utils/merge-locale.d.ts +1 -1
  253. package/2x/cjs/utils/merge-locale.js +15 -5
  254. package/2x/cjs/utils/native-props.d.ts +3 -3
  255. package/2x/cjs/utils/reduce-and-restore-motion.d.ts +4 -0
  256. package/2x/cjs/utils/reduce-and-restore-motion.js +53 -0
  257. package/2x/cjs/utils/render-imperatively.d.ts +4 -1
  258. package/2x/cjs/utils/render-imperatively.js +23 -11
  259. package/2x/cjs/utils/render.js +14 -2
  260. package/2x/cjs/utils/use-drag-and-pinch.d.ts +1 -1
  261. package/2x/cjs/utils/use-inner-visible.d.ts +1 -0
  262. package/2x/cjs/utils/use-inner-visible.js +18 -0
  263. package/2x/cjs/utils/use-props-value.d.ts +1 -1
  264. package/2x/cjs/utils/use-props-value.js +6 -8
  265. package/2x/cjs/utils/use-resize-effect.js +3 -1
  266. package/2x/cjs/utils/use-tab-list-scroll.js +1 -1
  267. package/2x/cjs/utils/with-default-props.js +2 -6
  268. package/2x/es/components/action-sheet/action-sheet.css +27 -12
  269. package/2x/es/components/action-sheet/action-sheet.d.ts +3 -5
  270. package/2x/es/components/action-sheet/action-sheet.js +14 -17
  271. package/2x/es/components/badge/badge.css +3 -3
  272. package/2x/es/components/badge/badge.d.ts +3 -1
  273. package/2x/es/components/badge/badge.js +3 -2
  274. package/2x/es/components/badge/index.d.ts +1 -1
  275. package/2x/es/components/button/button.css +7 -6
  276. package/2x/es/components/button/button.d.ts +10 -4
  277. package/2x/es/components/button/button.js +6 -2
  278. package/2x/es/components/button/button.patch.css +106 -0
  279. package/2x/es/components/calendar/calendar.css +9 -5
  280. package/2x/es/components/calendar/calendar.d.ts +4 -3
  281. package/2x/es/components/calendar/calendar.js +4 -4
  282. package/2x/es/components/calendar/index.d.ts +1 -1
  283. package/2x/es/components/capsule-tabs/capsule-tabs.css +4 -24
  284. package/2x/es/components/card/card.css +3 -3
  285. package/2x/es/components/cascader/cascader.css +2 -2
  286. package/2x/es/components/cascader/cascader.d.ts +32 -4
  287. package/2x/es/components/cascader/cascader.js +43 -19
  288. package/2x/es/components/cascader/index.d.ts +22 -2
  289. package/2x/es/components/cascader-view/cascader-view.css +2 -2
  290. package/2x/es/components/cascader-view/cascader-view.d.ts +3 -1
  291. package/2x/es/components/cascader-view/cascader-view.js +19 -9
  292. package/2x/es/components/cascader-view/use-cascader-value-extend.js +5 -14
  293. package/2x/es/components/center-popup/center-popup.css +40 -0
  294. package/2x/es/components/center-popup/center-popup.d.ts +7 -0
  295. package/2x/es/components/center-popup/center-popup.js +99 -0
  296. package/2x/es/components/center-popup/center-popup.patch.css +13 -0
  297. package/2x/es/components/center-popup/index.d.ts +4 -0
  298. package/2x/es/components/center-popup/index.js +3 -0
  299. package/2x/es/components/check-list/check-list.css +1 -1
  300. package/2x/es/components/checkbox/checkbox.css +3 -3
  301. package/2x/es/components/checkbox/checkbox.d.ts +22 -2
  302. package/2x/es/components/checkbox/checkbox.js +15 -3
  303. package/2x/es/components/checkbox/index.d.ts +17 -2
  304. package/2x/es/components/checkbox/native-input.js +9 -8
  305. package/2x/es/components/date-picker/date-picker-date-utils.js +12 -15
  306. package/2x/es/components/date-picker/date-picker-week-utils.js +12 -15
  307. package/2x/es/components/date-picker/date-picker.d.ts +7 -3
  308. package/2x/es/components/date-picker/date-picker.js +6 -2
  309. package/2x/es/components/date-picker/index.d.ts +6 -2
  310. package/2x/es/components/date-picker-view/date-picker-view.d.ts +1 -1
  311. package/2x/es/components/date-picker-view/date-picker-view.js +2 -0
  312. package/2x/es/components/dialog/dialog.css +22 -34
  313. package/2x/es/components/dialog/dialog.d.ts +4 -15
  314. package/2x/es/components/dialog/dialog.js +26 -61
  315. package/2x/es/components/dialog/show.d.ts +1 -1
  316. package/2x/es/components/divider/divider.css +2 -2
  317. package/2x/es/components/dropdown/dropdown.css +5 -5
  318. package/2x/es/components/dropdown/dropdown.d.ts +5 -1
  319. package/2x/es/components/dropdown/index.d.ts +5 -1
  320. package/2x/es/components/ellipsis/ellipsis.js +1 -2
  321. package/2x/es/components/empty/empty.css +2 -1
  322. package/2x/es/components/error-block/create-error-block.d.ts +12 -0
  323. package/2x/es/components/error-block/create-error-block.js +44 -0
  324. package/2x/es/components/error-block/error-block.css +4 -4
  325. package/2x/es/components/error-block/error-block.d.ts +2 -11
  326. package/2x/es/components/error-block/error-block.js +8 -46
  327. package/2x/es/components/error-block/error-block.patch.css +29 -0
  328. package/2x/es/components/error-block/images/busy.d.ts +1 -0
  329. package/2x/es/components/error-block/images/default.d.ts +1 -0
  330. package/2x/es/components/error-block/images/disconnected.d.ts +1 -0
  331. package/2x/es/components/error-block/images/empty.d.ts +1 -0
  332. package/2x/es/components/error-block/images/index.d.ts +4 -2
  333. package/2x/es/components/error-block/images/index.js +4 -10
  334. package/2x/es/components/error-block/index.d.ts +5 -1
  335. package/2x/es/components/error-block/index.js +1 -0
  336. package/2x/es/components/floating-bubble/floating-bubble.css +1 -0
  337. package/2x/es/components/floating-panel/floating-panel.css +7 -4
  338. package/2x/es/components/floating-panel/floating-panel.d.ts +5 -1
  339. package/2x/es/components/form/context.d.ts +1 -1
  340. package/2x/es/components/form/form-item.css +3 -2
  341. package/2x/es/components/form/form-item.js +11 -10
  342. package/2x/es/components/form/form-subscribe.d.ts +7 -2
  343. package/2x/es/components/form/form-subscribe.js +21 -14
  344. package/2x/es/components/form/form.css +3 -3
  345. package/2x/es/components/form/form.d.ts +5 -1
  346. package/2x/es/components/form/index.css +6 -5
  347. package/2x/es/components/form/index.d.ts +6 -2
  348. package/2x/es/components/grid/grid.css +1 -0
  349. package/2x/es/components/image/broken-image-icon.d.ts +1 -0
  350. package/2x/es/components/image/broken-image-icon.js +9 -0
  351. package/2x/es/components/image/image-icon.d.ts +1 -0
  352. package/2x/es/components/image/image-icon.js +9 -0
  353. package/2x/es/components/image/image.css +4 -2
  354. package/2x/es/components/image/image.d.ts +3 -1
  355. package/2x/es/components/image/image.js +12 -6
  356. package/2x/es/components/image/image.patch.css +12 -0
  357. package/2x/es/components/image/test/image.test.d.ts +1 -0
  358. package/2x/es/components/image/test/image.test.js +70 -0
  359. package/2x/es/components/image-uploader/image-uploader.css +4 -4
  360. package/2x/es/components/image-uploader/image-uploader.js +2 -5
  361. package/2x/es/components/image-viewer/image-viewer.css +11 -2
  362. package/2x/es/components/image-viewer/image-viewer.d.ts +5 -2
  363. package/2x/es/components/image-viewer/image-viewer.js +24 -5
  364. package/2x/es/components/image-viewer/index.d.ts +2 -1
  365. package/2x/es/components/image-viewer/slide.js +73 -56
  366. package/2x/es/components/index-bar/index-bar.css +6 -4
  367. package/2x/es/components/index-bar/index-bar.d.ts +7 -1
  368. package/2x/es/components/index-bar/index-bar.js +6 -0
  369. package/2x/es/components/index-bar/index.d.ts +6 -1
  370. package/2x/es/components/infinite-scroll/infinite-scroll.css +6 -1
  371. package/2x/es/components/infinite-scroll/infinite-scroll.d.ts +2 -2
  372. package/2x/es/components/infinite-scroll/infinite-scroll.js +67 -26
  373. package/2x/es/components/input/input.css +12 -2
  374. package/2x/es/components/input/input.d.ts +11 -4
  375. package/2x/es/components/input/input.js +33 -6
  376. package/2x/es/components/jumbo-tabs/jumbo-tabs.css +6 -24
  377. package/2x/es/components/list/index.d.ts +10 -2
  378. package/2x/es/components/list/list.css +12 -10
  379. package/2x/es/components/list/list.d.ts +14 -3
  380. package/2x/es/components/list/list.js +12 -4
  381. package/2x/es/components/mask/mask.js +10 -8
  382. package/2x/es/components/mask/mask.patch.css +3 -0
  383. package/2x/es/components/modal/modal-action-button.d.ts +2 -2
  384. package/2x/es/components/modal/modal.css +13 -36
  385. package/2x/es/components/modal/modal.d.ts +4 -15
  386. package/2x/es/components/modal/modal.js +22 -66
  387. package/2x/es/components/modal/modal.patch.css +29 -0
  388. package/2x/es/components/modal/show.d.ts +1 -1
  389. package/2x/es/components/nav-bar/nav-bar.css +2 -2
  390. package/2x/es/components/notice-bar/notice-bar.css +13 -4
  391. package/2x/es/components/notice-bar/notice-bar.js +5 -3
  392. package/2x/es/components/number-keyboard/number-keyboard.css +18 -21
  393. package/2x/es/components/number-keyboard/number-keyboard.d.ts +2 -6
  394. package/2x/es/components/number-keyboard/number-keyboard.js +32 -24
  395. package/2x/es/components/page-indicator/page-indicator.patch.css +31 -0
  396. package/2x/es/components/passcode-input/index.d.ts +1 -1
  397. package/2x/es/components/passcode-input/passcode-input.css +14 -14
  398. package/2x/es/components/passcode-input/passcode-input.d.ts +5 -1
  399. package/2x/es/components/passcode-input/passcode-input.js +15 -8
  400. package/2x/es/components/picker/index.d.ts +14 -6
  401. package/2x/es/components/picker/picker.css +12 -7
  402. package/2x/es/components/picker/picker.d.ts +10 -6
  403. package/2x/es/components/picker/picker.js +15 -9
  404. package/2x/es/components/picker-view/picker-view.css +21 -6
  405. package/2x/es/components/picker-view/picker-view.d.ts +2 -0
  406. package/2x/es/components/picker-view/picker-view.js +7 -3
  407. package/2x/es/components/picker-view/wheel.js +11 -9
  408. package/2x/es/components/popover/index.d.ts +5 -1
  409. package/2x/es/components/popover/popover-menu.css +1 -1
  410. package/2x/es/components/popover/popover-menu.patch.css +31 -0
  411. package/2x/es/components/popover/popover.css +6 -2
  412. package/2x/es/components/popover/popover.d.ts +5 -1
  413. package/2x/es/components/popover/popover.js +3 -1
  414. package/2x/es/components/popover/popover.patch.css +24 -0
  415. package/2x/es/components/popup/popup-base-props.d.ts +35 -0
  416. package/2x/es/components/popup/popup-base-props.js +11 -0
  417. package/2x/es/components/popup/popup.css +33 -1
  418. package/2x/es/components/popup/popup.d.ts +4 -20
  419. package/2x/es/components/popup/popup.js +41 -19
  420. package/2x/es/components/progress-bar/progress-bar.css +17 -3
  421. package/2x/es/components/progress-bar/progress-bar.d.ts +4 -2
  422. package/2x/es/components/progress-bar/progress-bar.js +25 -5
  423. package/2x/es/components/radio/radio.css +2 -2
  424. package/2x/es/components/radio/radio.js +3 -3
  425. package/2x/es/components/rate/rate.css +3 -2
  426. package/2x/es/components/rate/rate.js +34 -7
  427. package/2x/es/components/rate/star.d.ts +2 -0
  428. package/2x/es/components/rate/star.js +15 -0
  429. package/2x/es/components/result/result.css +3 -3
  430. package/2x/es/components/result/result.d.ts +1 -1
  431. package/2x/es/components/result/result.js +6 -1
  432. package/2x/es/components/safe-area/safe-area.css +3 -2
  433. package/2x/es/components/scroll-mask/scroll-mask.css +2 -2
  434. package/2x/es/components/scroll-mask/scroll-mask.patch.css +7 -0
  435. package/2x/es/components/search-bar/search-bar.css +4 -4
  436. package/2x/es/components/search-bar/search-bar.d.ts +5 -1
  437. package/2x/es/components/search-bar/search-bar.js +17 -10
  438. package/2x/es/components/selector/selector.css +3 -3
  439. package/2x/es/components/side-bar/corner.js +1 -1
  440. package/2x/es/components/side-bar/side-bar.css +4 -3
  441. package/2x/es/components/side-bar/side-bar.d.ts +2 -1
  442. package/2x/es/components/side-bar/side-bar.js +2 -0
  443. package/2x/es/components/slider/slider.css +30 -24
  444. package/2x/es/components/slider/slider.d.ts +3 -2
  445. package/2x/es/components/slider/slider.js +6 -3
  446. package/2x/es/components/slider/thumb-icon.js +20 -18
  447. package/2x/es/components/slider/thumb.d.ts +4 -2
  448. package/2x/es/components/slider/thumb.js +28 -6
  449. package/2x/es/components/space/space.patch.css +16 -0
  450. package/2x/es/components/spin-loading/spin-loading.css +0 -3
  451. package/2x/es/components/spin-loading/spin-loading.js +5 -2
  452. package/2x/es/components/spin-loading/spin-loading.patch.css +14 -0
  453. package/2x/es/components/stepper/stepper.css +3 -3
  454. package/2x/es/components/stepper/stepper.js +13 -3
  455. package/2x/es/components/steps/steps.css +3 -3
  456. package/2x/es/components/swipe-action/swipe-action.css +2 -1
  457. package/2x/es/components/swipe-action/swipe-action.d.ts +7 -1
  458. package/2x/es/components/swipe-action/swipe-action.js +20 -7
  459. package/2x/es/components/swiper/index.d.ts +10 -2
  460. package/2x/es/components/swiper/swiper.css +1 -0
  461. package/2x/es/components/swiper/swiper.d.ts +5 -1
  462. package/2x/es/components/swiper/swiper.js +19 -8
  463. package/2x/es/components/swiper/swiper.patch.css +26 -0
  464. package/2x/es/components/switch/switch.css +4 -4
  465. package/2x/es/components/switch/switch.d.ts +2 -1
  466. package/2x/es/components/switch/switch.js +24 -4
  467. package/2x/es/components/tab-bar/tab-bar.css +9 -5
  468. package/2x/es/components/tab-bar/tab-bar.js +3 -1
  469. package/2x/es/components/tabs/tabs.css +9 -7
  470. package/2x/es/components/tabs/tabs.d.ts +1 -1
  471. package/2x/es/components/tabs/tabs.patch.css +29 -0
  472. package/2x/es/components/tag/tag.css +1 -1
  473. package/2x/es/components/text-area/text-area.css +8 -2
  474. package/2x/es/components/text-area/text-area.d.ts +6 -1
  475. package/2x/es/components/text-area/text-area.js +7 -1
  476. package/2x/es/components/toast/methods.js +29 -67
  477. package/2x/es/components/toast/toast.css +2 -2
  478. package/2x/es/components/toast/toast.d.ts +2 -1
  479. package/2x/es/components/toast/toast.js +6 -2
  480. package/2x/es/components/toast/toast.patch.css +13 -0
  481. package/2x/es/components/tree-select/tree-select.css +1 -1
  482. package/2x/es/components/virtual-input/virtual-input.css +2 -2
  483. package/2x/es/components/virtual-input/virtual-input.d.ts +5 -1
  484. package/2x/es/components/water-mark/water-mark.js +3 -2
  485. package/2x/es/global/css-vars-patch.css +399 -0
  486. package/2x/es/global/global.css +36 -4
  487. package/2x/es/global/index.js +2 -1
  488. package/2x/es/global/theme-dark.css +14 -0
  489. package/2x/es/global/theme-default.css +32 -0
  490. package/2x/es/index.d.ts +3 -0
  491. package/2x/es/index.js +4 -1
  492. package/2x/es/locales/base.d.ts +21 -0
  493. package/2x/es/locales/base.js +22 -1
  494. package/2x/es/locales/en-US.d.ts +21 -0
  495. package/2x/es/locales/es-ES.d.ts +21 -0
  496. package/2x/es/locales/fa-IR.d.ts +21 -0
  497. package/2x/es/locales/fr-FR.d.ts +127 -0
  498. package/2x/es/locales/fr-FR.js +109 -0
  499. package/2x/es/locales/id-ID.d.ts +127 -0
  500. package/2x/es/locales/id-ID.js +124 -0
  501. package/2x/es/locales/kk-KZ.d.ts +127 -0
  502. package/2x/es/locales/kk-KZ.js +114 -0
  503. package/2x/es/locales/ko-KR.d.ts +21 -0
  504. package/2x/es/locales/zh-CN.d.ts +21 -0
  505. package/2x/es/locales/zh-CN.js +22 -1
  506. package/2x/es/locales/zh-HK.d.ts +21 -0
  507. package/2x/es/locales/zh-TW.d.ts +21 -0
  508. package/2x/es/utils/get-scroll-parent.js +1 -1
  509. package/2x/es/utils/matrix.d.ts +10 -0
  510. package/2x/es/utils/matrix.js +27 -0
  511. package/2x/es/utils/measure-css-length.js +2 -2
  512. package/2x/es/utils/merge-locale.d.ts +1 -1
  513. package/2x/es/utils/merge-locale.js +17 -3
  514. package/2x/es/utils/native-props.d.ts +3 -3
  515. package/2x/es/utils/reduce-and-restore-motion.d.ts +4 -0
  516. package/2x/es/utils/reduce-and-restore-motion.js +36 -0
  517. package/2x/es/utils/render-imperatively.d.ts +4 -1
  518. package/2x/es/utils/render-imperatively.js +23 -11
  519. package/2x/es/utils/render.js +14 -2
  520. package/2x/es/utils/use-drag-and-pinch.d.ts +1 -1
  521. package/2x/es/utils/use-inner-visible.d.ts +1 -0
  522. package/2x/es/utils/use-inner-visible.js +9 -0
  523. package/2x/es/utils/use-props-value.d.ts +1 -1
  524. package/2x/es/utils/use-props-value.js +6 -8
  525. package/2x/es/utils/use-resize-effect.js +3 -1
  526. package/2x/es/utils/use-tab-list-scroll.js +1 -1
  527. package/2x/es/utils/with-default-props.js +2 -4
  528. package/2x/package.json +11 -15
  529. package/2x/umd/antd-mobile.js +25799 -0
  530. package/README.md +43 -26
  531. package/bundle/antd-mobile.cjs.js +52 -18748
  532. package/bundle/antd-mobile.compatible.umd.js +25799 -0
  533. package/bundle/antd-mobile.es.js +16511 -16690
  534. package/bundle/antd-mobile.umd.js +64 -0
  535. package/bundle/css-vars-patch.css +312 -0
  536. package/bundle/style.css +1 -3950
  537. package/cjs/components/action-sheet/action-sheet.css +24 -12
  538. package/cjs/components/action-sheet/action-sheet.d.ts +3 -5
  539. package/cjs/components/action-sheet/action-sheet.js +14 -18
  540. package/cjs/components/badge/badge.css +3 -3
  541. package/cjs/components/badge/badge.d.ts +3 -1
  542. package/cjs/components/badge/badge.js +5 -2
  543. package/cjs/components/badge/index.d.ts +1 -1
  544. package/cjs/components/button/button.css +8 -7
  545. package/cjs/components/button/button.d.ts +10 -4
  546. package/cjs/components/button/button.js +6 -2
  547. package/cjs/components/button/button.patch.css +86 -0
  548. package/cjs/components/calendar/calendar.css +8 -5
  549. package/cjs/components/calendar/calendar.d.ts +4 -3
  550. package/cjs/components/calendar/calendar.js +4 -4
  551. package/cjs/components/calendar/index.d.ts +1 -1
  552. package/cjs/components/capsule-tabs/capsule-tabs.css +4 -21
  553. package/cjs/components/card/card.css +3 -3
  554. package/cjs/components/cascader/cascader.css +2 -2
  555. package/cjs/components/cascader/cascader.d.ts +32 -4
  556. package/cjs/components/cascader/cascader.js +42 -20
  557. package/cjs/components/cascader/index.d.ts +22 -2
  558. package/cjs/components/cascader-view/cascader-view.css +2 -2
  559. package/cjs/components/cascader-view/cascader-view.d.ts +3 -1
  560. package/cjs/components/cascader-view/cascader-view.js +20 -9
  561. package/cjs/components/cascader-view/use-cascader-value-extend.js +5 -14
  562. package/cjs/components/center-popup/center-popup.css +36 -0
  563. package/cjs/components/center-popup/center-popup.d.ts +7 -0
  564. package/cjs/components/center-popup/center-popup.js +131 -0
  565. package/cjs/components/center-popup/center-popup.patch.css +11 -0
  566. package/cjs/components/center-popup/index.d.ts +4 -0
  567. package/cjs/components/center-popup/index.js +13 -0
  568. package/cjs/components/check-list/check-list.css +1 -1
  569. package/cjs/components/checkbox/checkbox.css +3 -3
  570. package/cjs/components/checkbox/checkbox.d.ts +22 -2
  571. package/cjs/components/checkbox/checkbox.js +14 -4
  572. package/cjs/components/checkbox/index.d.ts +17 -2
  573. package/cjs/components/checkbox/native-input.js +10 -8
  574. package/cjs/components/date-picker/date-picker-date-utils.js +12 -15
  575. package/cjs/components/date-picker/date-picker-week-utils.js +12 -15
  576. package/cjs/components/date-picker/date-picker.d.ts +7 -3
  577. package/cjs/components/date-picker/date-picker.js +6 -2
  578. package/cjs/components/date-picker/index.d.ts +6 -2
  579. package/cjs/components/date-picker-view/date-picker-view.d.ts +1 -1
  580. package/cjs/components/date-picker-view/date-picker-view.js +2 -0
  581. package/cjs/components/dialog/dialog.css +23 -34
  582. package/cjs/components/dialog/dialog.d.ts +4 -15
  583. package/cjs/components/dialog/dialog.js +27 -71
  584. package/cjs/components/dialog/show.d.ts +1 -1
  585. package/cjs/components/divider/divider.css +2 -2
  586. package/cjs/components/dropdown/dropdown.css +5 -5
  587. package/cjs/components/dropdown/dropdown.d.ts +5 -1
  588. package/cjs/components/dropdown/index.d.ts +5 -1
  589. package/cjs/components/ellipsis/ellipsis.js +1 -2
  590. package/cjs/components/empty/empty.css +2 -1
  591. package/cjs/components/error-block/create-error-block.d.ts +12 -0
  592. package/cjs/components/error-block/create-error-block.js +59 -0
  593. package/cjs/components/error-block/error-block.css +4 -4
  594. package/cjs/components/error-block/error-block.d.ts +2 -11
  595. package/cjs/components/error-block/error-block.js +7 -53
  596. package/cjs/components/error-block/error-block.patch.css +23 -0
  597. package/cjs/components/error-block/images/busy.d.ts +1 -0
  598. package/cjs/components/error-block/images/default.d.ts +1 -0
  599. package/cjs/components/error-block/images/disconnected.d.ts +1 -0
  600. package/cjs/components/error-block/images/empty.d.ts +1 -0
  601. package/cjs/components/error-block/images/index.d.ts +4 -2
  602. package/cjs/components/error-block/images/index.js +25 -10
  603. package/cjs/components/error-block/index.d.ts +5 -1
  604. package/cjs/components/error-block/index.js +8 -0
  605. package/cjs/components/floating-bubble/floating-bubble.css +2 -1
  606. package/cjs/components/floating-panel/floating-panel.css +8 -5
  607. package/cjs/components/floating-panel/floating-panel.d.ts +5 -1
  608. package/cjs/components/form/context.d.ts +1 -1
  609. package/cjs/components/form/form-item.css +4 -3
  610. package/cjs/components/form/form-item.js +12 -12
  611. package/cjs/components/form/form-subscribe.d.ts +7 -2
  612. package/cjs/components/form/form-subscribe.js +28 -16
  613. package/cjs/components/form/form.css +3 -3
  614. package/cjs/components/form/form.d.ts +5 -1
  615. package/cjs/components/form/index.css +7 -6
  616. package/cjs/components/form/index.d.ts +6 -2
  617. package/cjs/components/grid/grid.css +2 -1
  618. package/cjs/components/image/broken-image-icon.d.ts +1 -0
  619. package/cjs/components/image/broken-image-icon.js +21 -0
  620. package/cjs/components/image/image-icon.d.ts +1 -0
  621. package/cjs/components/image/image-icon.js +21 -0
  622. package/cjs/components/image/image.css +4 -2
  623. package/cjs/components/image/image.d.ts +3 -1
  624. package/cjs/components/image/image.js +14 -7
  625. package/cjs/components/image/image.patch.css +10 -0
  626. package/cjs/components/image/test/image.test.d.ts +1 -0
  627. package/cjs/components/image/test/image.test.js +83 -0
  628. package/cjs/components/image-uploader/image-uploader.css +4 -4
  629. package/cjs/components/image-uploader/image-uploader.js +1 -4
  630. package/cjs/components/image-viewer/image-viewer.css +11 -3
  631. package/cjs/components/image-viewer/image-viewer.d.ts +5 -2
  632. package/cjs/components/image-viewer/image-viewer.js +24 -4
  633. package/cjs/components/image-viewer/index.d.ts +2 -1
  634. package/cjs/components/image-viewer/slide.js +75 -56
  635. package/cjs/components/index-bar/index-bar.css +7 -5
  636. package/cjs/components/index-bar/index-bar.d.ts +7 -1
  637. package/cjs/components/index-bar/index-bar.js +6 -0
  638. package/cjs/components/index-bar/index.d.ts +6 -1
  639. package/cjs/components/infinite-scroll/infinite-scroll.css +5 -1
  640. package/cjs/components/infinite-scroll/infinite-scroll.d.ts +2 -2
  641. package/cjs/components/infinite-scroll/infinite-scroll.js +67 -25
  642. package/cjs/components/input/input.css +11 -3
  643. package/cjs/components/input/input.d.ts +11 -4
  644. package/cjs/components/input/input.js +35 -6
  645. package/cjs/components/jumbo-tabs/jumbo-tabs.css +6 -21
  646. package/cjs/components/list/index.d.ts +10 -2
  647. package/cjs/components/list/list.css +12 -10
  648. package/cjs/components/list/list.d.ts +14 -3
  649. package/cjs/components/list/list.js +16 -6
  650. package/cjs/components/mask/mask.js +9 -7
  651. package/cjs/components/mask/mask.patch.css +3 -0
  652. package/cjs/components/modal/modal-action-button.d.ts +2 -2
  653. package/cjs/components/modal/modal.css +15 -36
  654. package/cjs/components/modal/modal.d.ts +4 -15
  655. package/cjs/components/modal/modal.js +23 -77
  656. package/cjs/components/modal/modal.patch.css +23 -0
  657. package/cjs/components/modal/show.d.ts +1 -1
  658. package/cjs/components/nav-bar/nav-bar.css +2 -2
  659. package/cjs/components/notice-bar/notice-bar.css +12 -4
  660. package/cjs/components/notice-bar/notice-bar.js +5 -3
  661. package/cjs/components/number-keyboard/number-keyboard.css +19 -21
  662. package/cjs/components/number-keyboard/number-keyboard.d.ts +2 -6
  663. package/cjs/components/number-keyboard/number-keyboard.js +32 -24
  664. package/cjs/components/page-indicator/page-indicator.patch.css +25 -0
  665. package/cjs/components/passcode-input/index.d.ts +1 -1
  666. package/cjs/components/passcode-input/passcode-input.css +14 -14
  667. package/cjs/components/passcode-input/passcode-input.d.ts +5 -1
  668. package/cjs/components/passcode-input/passcode-input.js +16 -8
  669. package/cjs/components/picker/index.d.ts +14 -6
  670. package/cjs/components/picker/picker.css +11 -7
  671. package/cjs/components/picker/picker.d.ts +10 -6
  672. package/cjs/components/picker/picker.js +15 -10
  673. package/cjs/components/picker-view/picker-view.css +21 -7
  674. package/cjs/components/picker-view/picker-view.d.ts +2 -0
  675. package/cjs/components/picker-view/picker-view.js +10 -3
  676. package/cjs/components/picker-view/wheel.js +11 -9
  677. package/cjs/components/popover/index.d.ts +5 -1
  678. package/cjs/components/popover/popover-menu.css +1 -1
  679. package/cjs/components/popover/popover-menu.patch.css +24 -0
  680. package/cjs/components/popover/popover.css +7 -3
  681. package/cjs/components/popover/popover.d.ts +5 -1
  682. package/cjs/components/popover/popover.js +3 -1
  683. package/cjs/components/popover/popover.patch.css +19 -0
  684. package/cjs/components/popup/popup-base-props.d.ts +35 -0
  685. package/cjs/components/popup/popup-base-props.js +18 -0
  686. package/cjs/components/popup/popup.css +27 -1
  687. package/cjs/components/popup/popup.d.ts +4 -20
  688. package/cjs/components/popup/popup.js +43 -18
  689. package/cjs/components/progress-bar/progress-bar.css +15 -3
  690. package/cjs/components/progress-bar/progress-bar.d.ts +4 -2
  691. package/cjs/components/progress-bar/progress-bar.js +27 -5
  692. package/cjs/components/radio/radio.css +2 -2
  693. package/cjs/components/radio/radio.js +3 -3
  694. package/cjs/components/rate/rate.css +3 -2
  695. package/cjs/components/rate/rate.js +41 -8
  696. package/cjs/components/rate/star.d.ts +2 -0
  697. package/cjs/components/rate/star.js +27 -0
  698. package/cjs/components/result/result.css +3 -3
  699. package/cjs/components/result/result.d.ts +1 -1
  700. package/cjs/components/result/result.js +7 -1
  701. package/cjs/components/safe-area/safe-area.css +3 -2
  702. package/cjs/components/scroll-mask/scroll-mask.css +2 -2
  703. package/cjs/components/scroll-mask/scroll-mask.patch.css +6 -0
  704. package/cjs/components/search-bar/search-bar.css +4 -4
  705. package/cjs/components/search-bar/search-bar.d.ts +5 -1
  706. package/cjs/components/search-bar/search-bar.js +17 -10
  707. package/cjs/components/selector/selector.css +3 -3
  708. package/cjs/components/side-bar/corner.js +1 -1
  709. package/cjs/components/side-bar/side-bar.css +5 -4
  710. package/cjs/components/side-bar/side-bar.d.ts +2 -1
  711. package/cjs/components/side-bar/side-bar.js +1 -0
  712. package/cjs/components/slider/slider.css +33 -27
  713. package/cjs/components/slider/slider.d.ts +3 -2
  714. package/cjs/components/slider/slider.js +6 -3
  715. package/cjs/components/slider/thumb-icon.js +20 -18
  716. package/cjs/components/slider/thumb.d.ts +4 -2
  717. package/cjs/components/slider/thumb.js +31 -5
  718. package/cjs/components/space/space.patch.css +13 -0
  719. package/cjs/components/spin-loading/spin-loading.css +0 -3
  720. package/cjs/components/spin-loading/spin-loading.js +6 -2
  721. package/cjs/components/spin-loading/spin-loading.patch.css +12 -0
  722. package/cjs/components/stepper/stepper.css +3 -3
  723. package/cjs/components/stepper/stepper.js +14 -3
  724. package/cjs/components/steps/steps.css +3 -3
  725. package/cjs/components/swipe-action/swipe-action.css +2 -1
  726. package/cjs/components/swipe-action/swipe-action.d.ts +7 -1
  727. package/cjs/components/swipe-action/swipe-action.js +20 -7
  728. package/cjs/components/swiper/index.d.ts +10 -2
  729. package/cjs/components/swiper/swiper.css +1 -0
  730. package/cjs/components/swiper/swiper.d.ts +5 -1
  731. package/cjs/components/swiper/swiper.js +19 -8
  732. package/cjs/components/swiper/swiper.patch.css +21 -0
  733. package/cjs/components/switch/switch.css +4 -4
  734. package/cjs/components/switch/switch.d.ts +2 -1
  735. package/cjs/components/switch/switch.js +26 -4
  736. package/cjs/components/tab-bar/tab-bar.css +8 -5
  737. package/cjs/components/tab-bar/tab-bar.js +2 -1
  738. package/cjs/components/tabs/tabs.css +9 -7
  739. package/cjs/components/tabs/tabs.d.ts +1 -1
  740. package/cjs/components/tabs/tabs.patch.css +23 -0
  741. package/cjs/components/tag/tag.css +1 -1
  742. package/cjs/components/text-area/text-area.css +8 -3
  743. package/cjs/components/text-area/text-area.d.ts +6 -1
  744. package/cjs/components/text-area/text-area.js +7 -1
  745. package/cjs/components/toast/methods.js +32 -73
  746. package/cjs/components/toast/toast.css +2 -2
  747. package/cjs/components/toast/toast.d.ts +2 -1
  748. package/cjs/components/toast/toast.js +6 -2
  749. package/cjs/components/toast/toast.patch.css +11 -0
  750. package/cjs/components/tree-select/tree-select.css +1 -1
  751. package/cjs/components/virtual-input/virtual-input.css +2 -2
  752. package/cjs/components/virtual-input/virtual-input.d.ts +5 -1
  753. package/cjs/components/water-mark/water-mark.js +3 -2
  754. package/cjs/global/css-vars-patch.css +312 -0
  755. package/cjs/global/global.css +36 -5
  756. package/cjs/global/index.js +2 -1
  757. package/cjs/global/theme-dark.css +14 -0
  758. package/cjs/global/theme-default.css +32 -0
  759. package/cjs/index.d.ts +3 -0
  760. package/cjs/index.js +29 -1
  761. package/cjs/locales/base.d.ts +21 -0
  762. package/cjs/locales/base.js +22 -1
  763. package/cjs/locales/en-US.d.ts +21 -0
  764. package/cjs/locales/es-ES.d.ts +21 -0
  765. package/cjs/locales/fa-IR.d.ts +21 -0
  766. package/cjs/locales/fr-FR.d.ts +127 -0
  767. package/cjs/locales/fr-FR.js +119 -0
  768. package/cjs/locales/id-ID.d.ts +127 -0
  769. package/cjs/locales/id-ID.js +134 -0
  770. package/cjs/locales/kk-KZ.d.ts +127 -0
  771. package/cjs/locales/kk-KZ.js +124 -0
  772. package/cjs/locales/ko-KR.d.ts +21 -0
  773. package/cjs/locales/zh-CN.d.ts +21 -0
  774. package/cjs/locales/zh-CN.js +22 -1
  775. package/cjs/locales/zh-HK.d.ts +21 -0
  776. package/cjs/locales/zh-TW.d.ts +21 -0
  777. package/cjs/utils/get-scroll-parent.js +1 -1
  778. package/cjs/utils/matrix.d.ts +10 -0
  779. package/cjs/utils/matrix.js +60 -0
  780. package/cjs/utils/measure-css-length.js +2 -2
  781. package/cjs/utils/merge-locale.d.ts +1 -1
  782. package/cjs/utils/merge-locale.js +15 -5
  783. package/cjs/utils/native-props.d.ts +3 -3
  784. package/cjs/utils/reduce-and-restore-motion.d.ts +4 -0
  785. package/cjs/utils/reduce-and-restore-motion.js +53 -0
  786. package/cjs/utils/render-imperatively.d.ts +4 -1
  787. package/cjs/utils/render-imperatively.js +23 -11
  788. package/cjs/utils/render.js +14 -2
  789. package/cjs/utils/use-drag-and-pinch.d.ts +1 -1
  790. package/cjs/utils/use-inner-visible.d.ts +1 -0
  791. package/cjs/utils/use-inner-visible.js +18 -0
  792. package/cjs/utils/use-props-value.d.ts +1 -1
  793. package/cjs/utils/use-props-value.js +6 -8
  794. package/cjs/utils/use-resize-effect.js +3 -1
  795. package/cjs/utils/use-tab-list-scroll.js +1 -1
  796. package/cjs/utils/with-default-props.js +2 -6
  797. package/es/components/action-sheet/action-sheet.css +24 -12
  798. package/es/components/action-sheet/action-sheet.d.ts +3 -5
  799. package/es/components/action-sheet/action-sheet.js +14 -17
  800. package/es/components/badge/badge.css +3 -3
  801. package/es/components/badge/badge.d.ts +3 -1
  802. package/es/components/badge/badge.js +3 -2
  803. package/es/components/badge/index.d.ts +1 -1
  804. package/es/components/button/button.css +8 -7
  805. package/es/components/button/button.d.ts +10 -4
  806. package/es/components/button/button.js +6 -2
  807. package/es/components/button/button.patch.css +86 -0
  808. package/es/components/calendar/calendar.css +8 -5
  809. package/es/components/calendar/calendar.d.ts +4 -3
  810. package/es/components/calendar/calendar.js +4 -4
  811. package/es/components/calendar/index.d.ts +1 -1
  812. package/es/components/capsule-tabs/capsule-tabs.css +4 -21
  813. package/es/components/card/card.css +3 -3
  814. package/es/components/cascader/cascader.css +2 -2
  815. package/es/components/cascader/cascader.d.ts +32 -4
  816. package/es/components/cascader/cascader.js +43 -19
  817. package/es/components/cascader/index.d.ts +22 -2
  818. package/es/components/cascader-view/cascader-view.css +2 -2
  819. package/es/components/cascader-view/cascader-view.d.ts +3 -1
  820. package/es/components/cascader-view/cascader-view.js +19 -9
  821. package/es/components/cascader-view/use-cascader-value-extend.js +5 -14
  822. package/es/components/center-popup/center-popup.css +36 -0
  823. package/es/components/center-popup/center-popup.d.ts +7 -0
  824. package/es/components/center-popup/center-popup.js +99 -0
  825. package/es/components/center-popup/center-popup.patch.css +11 -0
  826. package/es/components/center-popup/index.d.ts +4 -0
  827. package/es/components/center-popup/index.js +3 -0
  828. package/es/components/check-list/check-list.css +1 -1
  829. package/es/components/checkbox/checkbox.css +3 -3
  830. package/es/components/checkbox/checkbox.d.ts +22 -2
  831. package/es/components/checkbox/checkbox.js +15 -3
  832. package/es/components/checkbox/index.d.ts +17 -2
  833. package/es/components/checkbox/native-input.js +9 -8
  834. package/es/components/date-picker/date-picker-date-utils.js +12 -15
  835. package/es/components/date-picker/date-picker-week-utils.js +12 -15
  836. package/es/components/date-picker/date-picker.d.ts +7 -3
  837. package/es/components/date-picker/date-picker.js +6 -2
  838. package/es/components/date-picker/index.d.ts +6 -2
  839. package/es/components/date-picker-view/date-picker-view.d.ts +1 -1
  840. package/es/components/date-picker-view/date-picker-view.js +2 -0
  841. package/es/components/dialog/dialog.css +23 -34
  842. package/es/components/dialog/dialog.d.ts +4 -15
  843. package/es/components/dialog/dialog.js +26 -61
  844. package/es/components/dialog/show.d.ts +1 -1
  845. package/es/components/divider/divider.css +2 -2
  846. package/es/components/dropdown/dropdown.css +5 -5
  847. package/es/components/dropdown/dropdown.d.ts +5 -1
  848. package/es/components/dropdown/index.d.ts +5 -1
  849. package/es/components/ellipsis/ellipsis.js +1 -2
  850. package/es/components/empty/empty.css +2 -1
  851. package/es/components/error-block/create-error-block.d.ts +12 -0
  852. package/es/components/error-block/create-error-block.js +44 -0
  853. package/es/components/error-block/error-block.css +4 -4
  854. package/es/components/error-block/error-block.d.ts +2 -11
  855. package/es/components/error-block/error-block.js +8 -46
  856. package/es/components/error-block/error-block.patch.css +23 -0
  857. package/es/components/error-block/images/busy.d.ts +1 -0
  858. package/es/components/error-block/images/default.d.ts +1 -0
  859. package/es/components/error-block/images/disconnected.d.ts +1 -0
  860. package/es/components/error-block/images/empty.d.ts +1 -0
  861. package/es/components/error-block/images/index.d.ts +4 -2
  862. package/es/components/error-block/images/index.js +4 -10
  863. package/es/components/error-block/index.d.ts +5 -1
  864. package/es/components/error-block/index.js +1 -0
  865. package/es/components/floating-bubble/floating-bubble.css +2 -1
  866. package/es/components/floating-panel/floating-panel.css +8 -5
  867. package/es/components/floating-panel/floating-panel.d.ts +5 -1
  868. package/es/components/form/context.d.ts +1 -1
  869. package/es/components/form/form-item.css +4 -3
  870. package/es/components/form/form-item.js +11 -10
  871. package/es/components/form/form-subscribe.d.ts +7 -2
  872. package/es/components/form/form-subscribe.js +21 -14
  873. package/es/components/form/form.css +3 -3
  874. package/es/components/form/form.d.ts +5 -1
  875. package/es/components/form/index.css +7 -6
  876. package/es/components/form/index.d.ts +6 -2
  877. package/es/components/grid/grid.css +2 -1
  878. package/es/components/image/broken-image-icon.d.ts +1 -0
  879. package/es/components/image/broken-image-icon.js +9 -0
  880. package/es/components/image/image-icon.d.ts +1 -0
  881. package/es/components/image/image-icon.js +9 -0
  882. package/es/components/image/image.css +4 -2
  883. package/es/components/image/image.d.ts +3 -1
  884. package/es/components/image/image.js +12 -6
  885. package/es/components/image/image.patch.css +10 -0
  886. package/es/components/image/test/image.test.d.ts +1 -0
  887. package/es/components/image/test/image.test.js +70 -0
  888. package/es/components/image-uploader/image-uploader.css +4 -4
  889. package/es/components/image-uploader/image-uploader.js +2 -5
  890. package/es/components/image-viewer/image-viewer.css +11 -3
  891. package/es/components/image-viewer/image-viewer.d.ts +5 -2
  892. package/es/components/image-viewer/image-viewer.js +24 -5
  893. package/es/components/image-viewer/index.d.ts +2 -1
  894. package/es/components/image-viewer/slide.js +73 -56
  895. package/es/components/index-bar/index-bar.css +7 -5
  896. package/es/components/index-bar/index-bar.d.ts +7 -1
  897. package/es/components/index-bar/index-bar.js +6 -0
  898. package/es/components/index-bar/index.d.ts +6 -1
  899. package/es/components/infinite-scroll/infinite-scroll.css +5 -1
  900. package/es/components/infinite-scroll/infinite-scroll.d.ts +2 -2
  901. package/es/components/infinite-scroll/infinite-scroll.js +67 -26
  902. package/es/components/input/input.css +11 -3
  903. package/es/components/input/input.d.ts +11 -4
  904. package/es/components/input/input.js +33 -6
  905. package/es/components/jumbo-tabs/jumbo-tabs.css +6 -21
  906. package/es/components/list/index.d.ts +10 -2
  907. package/es/components/list/list.css +12 -10
  908. package/es/components/list/list.d.ts +14 -3
  909. package/es/components/list/list.js +12 -4
  910. package/es/components/mask/mask.js +10 -8
  911. package/es/components/mask/mask.patch.css +3 -0
  912. package/es/components/modal/modal-action-button.d.ts +2 -2
  913. package/es/components/modal/modal.css +15 -36
  914. package/es/components/modal/modal.d.ts +4 -15
  915. package/es/components/modal/modal.js +22 -66
  916. package/es/components/modal/modal.patch.css +23 -0
  917. package/es/components/modal/show.d.ts +1 -1
  918. package/es/components/nav-bar/nav-bar.css +2 -2
  919. package/es/components/notice-bar/notice-bar.css +12 -4
  920. package/es/components/notice-bar/notice-bar.js +5 -3
  921. package/es/components/number-keyboard/number-keyboard.css +19 -21
  922. package/es/components/number-keyboard/number-keyboard.d.ts +2 -6
  923. package/es/components/number-keyboard/number-keyboard.js +32 -24
  924. package/es/components/page-indicator/page-indicator.patch.css +25 -0
  925. package/es/components/passcode-input/index.d.ts +1 -1
  926. package/es/components/passcode-input/passcode-input.css +14 -14
  927. package/es/components/passcode-input/passcode-input.d.ts +5 -1
  928. package/es/components/passcode-input/passcode-input.js +15 -8
  929. package/es/components/picker/index.d.ts +14 -6
  930. package/es/components/picker/picker.css +11 -7
  931. package/es/components/picker/picker.d.ts +10 -6
  932. package/es/components/picker/picker.js +15 -9
  933. package/es/components/picker-view/picker-view.css +21 -7
  934. package/es/components/picker-view/picker-view.d.ts +2 -0
  935. package/es/components/picker-view/picker-view.js +7 -3
  936. package/es/components/picker-view/wheel.js +11 -9
  937. package/es/components/popover/index.d.ts +5 -1
  938. package/es/components/popover/popover-menu.css +1 -1
  939. package/es/components/popover/popover-menu.patch.css +24 -0
  940. package/es/components/popover/popover.css +7 -3
  941. package/es/components/popover/popover.d.ts +5 -1
  942. package/es/components/popover/popover.js +3 -1
  943. package/es/components/popover/popover.patch.css +19 -0
  944. package/es/components/popup/popup-base-props.d.ts +35 -0
  945. package/es/components/popup/popup-base-props.js +11 -0
  946. package/es/components/popup/popup.css +27 -1
  947. package/es/components/popup/popup.d.ts +4 -20
  948. package/es/components/popup/popup.js +41 -19
  949. package/es/components/progress-bar/progress-bar.css +15 -3
  950. package/es/components/progress-bar/progress-bar.d.ts +4 -2
  951. package/es/components/progress-bar/progress-bar.js +25 -5
  952. package/es/components/radio/radio.css +2 -2
  953. package/es/components/radio/radio.js +3 -3
  954. package/es/components/rate/rate.css +3 -2
  955. package/es/components/rate/rate.js +34 -7
  956. package/es/components/rate/star.d.ts +2 -0
  957. package/es/components/rate/star.js +15 -0
  958. package/es/components/result/result.css +3 -3
  959. package/es/components/result/result.d.ts +1 -1
  960. package/es/components/result/result.js +6 -1
  961. package/es/components/safe-area/safe-area.css +3 -2
  962. package/es/components/scroll-mask/scroll-mask.css +2 -2
  963. package/es/components/scroll-mask/scroll-mask.patch.css +6 -0
  964. package/es/components/search-bar/search-bar.css +4 -4
  965. package/es/components/search-bar/search-bar.d.ts +5 -1
  966. package/es/components/search-bar/search-bar.js +17 -10
  967. package/es/components/selector/selector.css +3 -3
  968. package/es/components/side-bar/corner.js +1 -1
  969. package/es/components/side-bar/side-bar.css +5 -4
  970. package/es/components/side-bar/side-bar.d.ts +2 -1
  971. package/es/components/side-bar/side-bar.js +2 -0
  972. package/es/components/slider/slider.css +33 -27
  973. package/es/components/slider/slider.d.ts +3 -2
  974. package/es/components/slider/slider.js +6 -3
  975. package/es/components/slider/thumb-icon.js +20 -18
  976. package/es/components/slider/thumb.d.ts +4 -2
  977. package/es/components/slider/thumb.js +28 -6
  978. package/es/components/space/space.patch.css +13 -0
  979. package/es/components/spin-loading/spin-loading.css +0 -3
  980. package/es/components/spin-loading/spin-loading.js +5 -2
  981. package/es/components/spin-loading/spin-loading.patch.css +12 -0
  982. package/es/components/stepper/stepper.css +3 -3
  983. package/es/components/stepper/stepper.js +13 -3
  984. package/es/components/steps/steps.css +3 -3
  985. package/es/components/swipe-action/swipe-action.css +2 -1
  986. package/es/components/swipe-action/swipe-action.d.ts +7 -1
  987. package/es/components/swipe-action/swipe-action.js +20 -7
  988. package/es/components/swiper/index.d.ts +10 -2
  989. package/es/components/swiper/swiper.css +1 -0
  990. package/es/components/swiper/swiper.d.ts +5 -1
  991. package/es/components/swiper/swiper.js +19 -8
  992. package/es/components/swiper/swiper.patch.css +21 -0
  993. package/es/components/switch/switch.css +4 -4
  994. package/es/components/switch/switch.d.ts +2 -1
  995. package/es/components/switch/switch.js +24 -4
  996. package/es/components/tab-bar/tab-bar.css +8 -5
  997. package/es/components/tab-bar/tab-bar.js +3 -1
  998. package/es/components/tabs/tabs.css +9 -7
  999. package/es/components/tabs/tabs.d.ts +1 -1
  1000. package/es/components/tabs/tabs.patch.css +23 -0
  1001. package/es/components/tag/tag.css +1 -1
  1002. package/es/components/text-area/text-area.css +8 -3
  1003. package/es/components/text-area/text-area.d.ts +6 -1
  1004. package/es/components/text-area/text-area.js +7 -1
  1005. package/es/components/toast/methods.js +29 -67
  1006. package/es/components/toast/toast.css +2 -2
  1007. package/es/components/toast/toast.d.ts +2 -1
  1008. package/es/components/toast/toast.js +6 -2
  1009. package/es/components/toast/toast.patch.css +11 -0
  1010. package/es/components/tree-select/tree-select.css +1 -1
  1011. package/es/components/virtual-input/virtual-input.css +2 -2
  1012. package/es/components/virtual-input/virtual-input.d.ts +5 -1
  1013. package/es/components/water-mark/water-mark.js +3 -2
  1014. package/es/global/css-vars-patch.css +312 -0
  1015. package/es/global/global.css +36 -5
  1016. package/es/global/index.js +2 -1
  1017. package/es/global/theme-dark.css +14 -0
  1018. package/es/global/theme-default.css +32 -0
  1019. package/es/index.d.ts +3 -0
  1020. package/es/index.js +4 -1
  1021. package/es/locales/base.d.ts +21 -0
  1022. package/es/locales/base.js +22 -1
  1023. package/es/locales/en-US.d.ts +21 -0
  1024. package/es/locales/es-ES.d.ts +21 -0
  1025. package/es/locales/fa-IR.d.ts +21 -0
  1026. package/es/locales/fr-FR.d.ts +127 -0
  1027. package/es/locales/fr-FR.js +109 -0
  1028. package/es/locales/id-ID.d.ts +127 -0
  1029. package/es/locales/id-ID.js +124 -0
  1030. package/es/locales/kk-KZ.d.ts +127 -0
  1031. package/es/locales/kk-KZ.js +114 -0
  1032. package/es/locales/ko-KR.d.ts +21 -0
  1033. package/es/locales/zh-CN.d.ts +21 -0
  1034. package/es/locales/zh-CN.js +22 -1
  1035. package/es/locales/zh-HK.d.ts +21 -0
  1036. package/es/locales/zh-TW.d.ts +21 -0
  1037. package/es/utils/get-scroll-parent.js +1 -1
  1038. package/es/utils/matrix.d.ts +10 -0
  1039. package/es/utils/matrix.js +27 -0
  1040. package/es/utils/measure-css-length.js +2 -2
  1041. package/es/utils/merge-locale.d.ts +1 -1
  1042. package/es/utils/merge-locale.js +17 -3
  1043. package/es/utils/native-props.d.ts +3 -3
  1044. package/es/utils/reduce-and-restore-motion.d.ts +4 -0
  1045. package/es/utils/reduce-and-restore-motion.js +36 -0
  1046. package/es/utils/render-imperatively.d.ts +4 -1
  1047. package/es/utils/render-imperatively.js +23 -11
  1048. package/es/utils/render.js +14 -2
  1049. package/es/utils/use-drag-and-pinch.d.ts +1 -1
  1050. package/es/utils/use-inner-visible.d.ts +1 -0
  1051. package/es/utils/use-inner-visible.js +9 -0
  1052. package/es/utils/use-props-value.d.ts +1 -1
  1053. package/es/utils/use-props-value.js +6 -8
  1054. package/es/utils/use-resize-effect.js +3 -1
  1055. package/es/utils/use-tab-list-scroll.js +1 -1
  1056. package/es/utils/with-default-props.js +2 -4
  1057. package/package.json +11 -15
  1058. package/umd/antd-mobile.js +1 -1
  1059. package/umd/antd-mobile.js.LICENSE.txt +12 -0
  1060. package/2x/cjs/components/form/form-imperative-item.d.ts +0 -5
  1061. package/2x/cjs/components/form/form-imperative-item.js +0 -57
  1062. package/2x/cjs/global/theme.css +0 -16
  1063. package/2x/es/components/form/form-imperative-item.d.ts +0 -5
  1064. package/2x/es/components/form/form-imperative-item.js +0 -38
  1065. package/2x/es/global/theme.css +0 -16
  1066. package/cjs/components/form/form-imperative-item.d.ts +0 -5
  1067. package/cjs/components/form/form-imperative-item.js +0 -57
  1068. package/cjs/global/theme.css +0 -16
  1069. package/es/components/form/form-imperative-item.d.ts +0 -5
  1070. package/es/components/form/form-imperative-item.js +0 -38
  1071. package/es/global/theme.css +0 -16
@@ -1,21 +1,23 @@
1
1
  import { mergeProps } from '../../utils/with-default-props';
2
2
  import React, { useState, useRef } from 'react';
3
3
  import { withNativeProps } from '../../utils/native-props';
4
- import { PictureOutline, PictureWrongOutline } from 'antd-mobile-icons';
5
4
  import { staged } from 'staged-components';
6
5
  import { toCSSLength } from '../../utils/to-css-length';
7
6
  import { LazyDetector } from './lazy-detector';
8
7
  import { useIsomorphicUpdateLayoutEffect } from '../../utils/use-isomorphic-update-layout-effect';
8
+ import { ImageIcon } from './image-icon';
9
+ import { BrokenImageIcon } from './broken-image-icon';
9
10
  const classPrefix = `adm-image`;
10
11
  const defaultProps = {
11
12
  fit: 'fill',
12
13
  placeholder: React.createElement("div", {
13
14
  className: `${classPrefix}-tip`
14
- }, React.createElement(PictureOutline, null)),
15
+ }, React.createElement(ImageIcon, null)),
15
16
  fallback: React.createElement("div", {
16
17
  className: `${classPrefix}-tip`
17
- }, React.createElement(PictureWrongOutline, null)),
18
- lazy: false
18
+ }, React.createElement(BrokenImageIcon, null)),
19
+ lazy: false,
20
+ draggable: false
19
21
  };
20
22
  export const Image = staged(p => {
21
23
  const props = mergeProps(defaultProps, p);
@@ -64,7 +66,8 @@ export const Image = staged(p => {
64
66
  referrerPolicy: props.referrerPolicy,
65
67
  sizes: props.sizes,
66
68
  srcSet: srcSet,
67
- useMap: props.useMap
69
+ useMap: props.useMap,
70
+ draggable: props.draggable
68
71
  });
69
72
  return React.createElement(React.Fragment, null, !loaded && props.placeholder, img);
70
73
  }
@@ -73,16 +76,19 @@ export const Image = staged(p => {
73
76
 
74
77
  if (props.width) {
75
78
  style['--width'] = toCSSLength(props.width);
79
+ style['width'] = toCSSLength(props.width);
76
80
  }
77
81
 
78
82
  if (props.height) {
79
83
  style['--height'] = toCSSLength(props.height);
84
+ style['height'] = toCSSLength(props.height);
80
85
  }
81
86
 
82
87
  return withNativeProps(props, React.createElement("div", {
83
88
  ref: ref,
84
89
  className: classPrefix,
85
- style: style
90
+ style: style,
91
+ onClick: props.onContainerClick
86
92
  }, props.lazy && !initialized && React.createElement(LazyDetector, {
87
93
  onActive: () => {
88
94
  setInitialized(true);
@@ -0,0 +1,12 @@
1
+ .adm-image {
2
+ width: auto;
3
+ height: auto;
4
+ }
5
+
6
+ .adm-image-tip {
7
+ background-color: #f5f5f5;
8
+ }
9
+
10
+ .adm-image-tip > svg {
11
+ color: #999999;
12
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,70 @@
1
+ import React from 'react';
2
+ import { fireEvent, render, act } from 'testing';
3
+ import Image from '../index';
4
+ const classPrefix = `adm-image`;
5
+ const demoSrc = 'https://images.unsplash.com/photo-1567945716310-4745a6b7844b?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=300&q=60';
6
+ describe('Image', () => {
7
+ test('onContainerClick can work', () => {
8
+ const onContainerClick = jest.fn();
9
+ const {
10
+ getByTestId
11
+ } = render(React.createElement(Image, {
12
+ src: demoSrc,
13
+ onContainerClick: onContainerClick,
14
+ "data-testid": 'img'
15
+ }));
16
+ fireEvent.click(getByTestId('img'));
17
+ expect(onContainerClick).toBeCalledTimes(1);
18
+ });
19
+ test('load successfully', () => {
20
+ render(React.createElement(Image, {
21
+ src: demoSrc
22
+ }));
23
+ const img = document.querySelectorAll(`.${classPrefix}-img`)[0];
24
+ fireEvent.load(img);
25
+ expect(img).toHaveAttribute('src', demoSrc);
26
+ });
27
+ test('load failed', () => {
28
+ render(React.createElement(Image, {
29
+ src: '404'
30
+ }));
31
+ const img = document.querySelectorAll(`.${classPrefix}-img`)[0];
32
+ fireEvent.error(img);
33
+ expect(img).not.toBeInTheDocument();
34
+ expect(document.querySelectorAll(`.${classPrefix}-tip`)[0]).toBeInTheDocument();
35
+ });
36
+ test('lazy load should be work', () => {
37
+ // mock useInViewport
38
+ // https://github.com/alibaba/hooks/blob/master/packages/hooks/src/useInViewport/__tests__/index.test.ts
39
+ const mockIntersectionObserver = jest.fn().mockReturnValue({
40
+ observe: () => null,
41
+ disconnect: () => null
42
+ });
43
+ window.IntersectionObserver = mockIntersectionObserver;
44
+ render(React.createElement(Image, {
45
+ src: demoSrc,
46
+ lazy: true
47
+ }));
48
+ const img = document.querySelectorAll(`.${classPrefix}-img`)[0];
49
+ expect(img).not.toHaveAttribute('src');
50
+ const calls = mockIntersectionObserver.mock.calls;
51
+ const [onChange] = calls[calls.length - 1];
52
+ act(() => {
53
+ onChange([{
54
+ isIntersecting: true
55
+ }]);
56
+ });
57
+ expect(img).toHaveAttribute('src', demoSrc);
58
+ });
59
+ test('renders with width and height', () => {
60
+ const {
61
+ getByTestId
62
+ } = render(React.createElement(Image, {
63
+ src: demoSrc,
64
+ width: 100,
65
+ height: 100,
66
+ "data-testid": 'image'
67
+ }));
68
+ expect(getByTestId('image')).toHaveStyle('--width: 100px;--height: 100px');
69
+ });
70
+ });
@@ -28,7 +28,7 @@
28
28
  background-color: rgba(0, 0, 0, 0.7);
29
29
  border-radius: 0 0 0 24px;
30
30
  font-size: 16px;
31
- color: #fff;
31
+ color: var(--adm-color-white);
32
32
  cursor: pointer;
33
33
  }
34
34
 
@@ -44,7 +44,7 @@
44
44
  right: 0;
45
45
  bottom: 0;
46
46
  left: 0;
47
- color: #fff;
47
+ color: var(--adm-color-white);
48
48
  background-color: rgba(50, 50, 51, 0.88);
49
49
  }
50
50
 
@@ -61,7 +61,7 @@
61
61
  .adm-image-uploader-cell-mask-message {
62
62
  display: inline-block;
63
63
  padding: 12px 8px;
64
- font-size: 24px;
64
+ font-size: var(--adm-font-size-4);
65
65
  }
66
66
 
67
67
  .adm-image-uploader-cell-image {
@@ -74,7 +74,7 @@
74
74
  }
75
75
 
76
76
  .adm-image-uploader-upload-button-wrap .adm-image-uploader-upload-button {
77
- background-color: #f5f5f5;
77
+ background-color: var(--adm-color-box);
78
78
  text-align: center;
79
79
  line-height: var(--cell-size);
80
80
  display: block;
@@ -5,7 +5,7 @@ import { mergeProps } from '../../utils/with-default-props';
5
5
  import ImageViewer from '../image-viewer';
6
6
  import PreviewItem from './preview-item';
7
7
  import { usePropsValue } from '../../utils/use-props-value';
8
- import { useIsomorphicLayoutEffect, useMemoizedFn, useUnmount } from 'ahooks';
8
+ import { useIsomorphicLayoutEffect, useUnmount } from 'ahooks';
9
9
  import Space from '../space';
10
10
  import { withNativeProps } from '../../utils/native-props';
11
11
  import { useConfig } from '../config-provider';
@@ -28,9 +28,6 @@ export const ImageUploader = p => {
28
28
  } = useConfig();
29
29
  const props = mergeProps(defaultProps, p);
30
30
  const [value, setValue] = usePropsValue(props);
31
- const updateValue = useMemoizedFn(updater => {
32
- setValue(updater(value));
33
- });
34
31
  const [tasks, setTasks] = useState([]);
35
32
  useIsomorphicLayoutEffect(() => {
36
33
  setTasks(prev => prev.filter(task => {
@@ -109,7 +106,7 @@ export const ImageUploader = p => {
109
106
  return task;
110
107
  });
111
108
  });
112
- updateValue(prev => {
109
+ setValue(prev => {
113
110
  const newVal = Object.assign({}, result);
114
111
  return [...prev, newVal];
115
112
  });
@@ -1,15 +1,23 @@
1
1
  .adm-image-viewer-content {
2
2
  width: 100vw;
3
3
  height: 100vh;
4
- max-height: -webkit-fill-available;
5
4
  touch-action: none;
5
+ -webkit-user-select: none;
6
6
  user-select: none;
7
7
  }
8
8
 
9
+ .adm-image-viewer-footer {
10
+ position: absolute;
11
+ width: 100%;
12
+ bottom: 0;
13
+ z-index: 1;
14
+ }
15
+
9
16
  .adm-image-viewer-slides {
10
17
  height: 100%;
11
18
  position: relative;
12
19
  z-index: 1;
20
+ cursor: -webkit-grab;
13
21
  cursor: grab;
14
22
  touch-action: none;
15
23
  }
@@ -37,6 +45,7 @@
37
45
  top: 0;
38
46
  width: 100%;
39
47
  height: 100%;
48
+ cursor: -webkit-grab;
40
49
  cursor: grab;
41
50
  touch-action: none;
42
51
  }
@@ -62,5 +71,5 @@
62
71
  top: 24px;
63
72
  transform: translateX(-50%);
64
73
  color: #e6e6e6;
65
- font-size: 28px;
74
+ font-size: var(--adm-font-size-6);
66
75
  }
@@ -8,16 +8,19 @@ export declare type ImageViewerProps = {
8
8
  visible?: boolean;
9
9
  onClose?: () => void;
10
10
  afterClose?: () => void;
11
+ renderFooter?: (image: string) => React.ReactNode;
11
12
  };
12
13
  export declare const ImageViewer: FC<ImageViewerProps>;
13
14
  export declare type MultiImageViewerRef = SlidesRef;
14
- export declare type MultiImageViewerProps = Omit<ImageViewerProps, 'image'> & {
15
+ export declare type MultiImageViewerProps = Omit<ImageViewerProps, 'image' | 'renderFooter'> & {
15
16
  images?: string[];
16
17
  defaultIndex?: number;
17
18
  onIndexChange?: (index: number) => void;
19
+ renderFooter?: (image: string, index: number) => React.ReactNode;
18
20
  };
19
- export declare const MultiImageViewer: React.ForwardRefExoticComponent<Omit<ImageViewerProps, "image"> & {
21
+ export declare const MultiImageViewer: React.ForwardRefExoticComponent<Omit<ImageViewerProps, "image" | "renderFooter"> & {
20
22
  images?: string[] | undefined;
21
23
  defaultIndex?: number | undefined;
22
24
  onIndexChange?: ((index: number) => void) | undefined;
25
+ renderFooter?: ((image: string, index: number) => React.ReactNode) | undefined;
23
26
  } & React.RefAttributes<SlidesRef>>;
@@ -1,7 +1,8 @@
1
- import React, { forwardRef, useImperativeHandle, useRef, useState } from 'react';
1
+ import React, { forwardRef, useImperativeHandle, useRef, useState, useCallback } from 'react';
2
2
  import { mergeProps } from '../../utils/with-default-props';
3
3
  import { renderToContainer } from '../../utils/render-to-container';
4
4
  import Mask from '../mask';
5
+ import SafeArea from '../safe-area';
5
6
  import { Slide } from './slide';
6
7
  import { Slides } from './slides';
7
8
  const classPrefix = `adm-image-viewer`;
@@ -11,6 +12,8 @@ const defaultProps = {
11
12
  visible: false
12
13
  };
13
14
  export const ImageViewer = p => {
15
+ var _a;
16
+
14
17
  const props = mergeProps(defaultProps, p);
15
18
  const node = React.createElement(Mask, {
16
19
  visible: props.visible,
@@ -27,6 +30,10 @@ export const ImageViewer = p => {
27
30
  (_a = props.onClose) === null || _a === void 0 ? void 0 : _a.call(props);
28
31
  },
29
32
  maxZoom: props.maxZoom
33
+ })), props.image && React.createElement("div", {
34
+ className: `${classPrefix}-footer`
35
+ }, (_a = props.renderFooter) === null || _a === void 0 ? void 0 : _a.call(props, props.image), React.createElement(SafeArea, {
36
+ position: 'bottom'
30
37
  })));
31
38
  return renderToContainer(props.getContainer, node);
32
39
  };
@@ -34,17 +41,25 @@ const multiDefaultProps = Object.assign(Object.assign({}, defaultProps), {
34
41
  defaultIndex: 0
35
42
  });
36
43
  export const MultiImageViewer = forwardRef((p, ref) => {
44
+ var _a;
45
+
37
46
  const props = mergeProps(multiDefaultProps, p);
38
- const [defaultIndex, setDefaultIndex] = useState(props.defaultIndex);
47
+ const [index, setIndex] = useState(props.defaultIndex);
39
48
  const slidesRef = useRef(null);
40
49
  useImperativeHandle(ref, () => ({
41
50
  swipeTo: (index, immediate) => {
42
51
  var _a;
43
52
 
44
- setDefaultIndex(index);
53
+ setIndex(index);
45
54
  (_a = slidesRef.current) === null || _a === void 0 ? void 0 : _a.swipeTo(index, immediate);
46
55
  }
47
56
  }));
57
+ const onSlideChange = useCallback(index => {
58
+ var _a;
59
+
60
+ setIndex(index);
61
+ (_a = props.onIndexChange) === null || _a === void 0 ? void 0 : _a.call(props, index);
62
+ }, [props.onIndexChange]);
48
63
  const node = React.createElement(Mask, {
49
64
  visible: props.visible,
50
65
  disableBodyScroll: false,
@@ -54,8 +69,8 @@ export const MultiImageViewer = forwardRef((p, ref) => {
54
69
  className: `${classPrefix}-content`
55
70
  }, props.images && React.createElement(Slides, {
56
71
  ref: slidesRef,
57
- defaultIndex: defaultIndex,
58
- onIndexChange: props.onIndexChange,
72
+ defaultIndex: index,
73
+ onIndexChange: onSlideChange,
59
74
  images: props.images,
60
75
  onTap: () => {
61
76
  var _a;
@@ -63,6 +78,10 @@ export const MultiImageViewer = forwardRef((p, ref) => {
63
78
  (_a = props.onClose) === null || _a === void 0 ? void 0 : _a.call(props);
64
79
  },
65
80
  maxZoom: props.maxZoom
81
+ })), props.images && React.createElement("div", {
82
+ className: `${classPrefix}-footer`
83
+ }, (_a = props.renderFooter) === null || _a === void 0 ? void 0 : _a.call(props, props.images[index], index), React.createElement(SafeArea, {
84
+ position: 'bottom'
66
85
  })));
67
86
  return renderToContainer(props.getContainer, node);
68
87
  });
@@ -4,10 +4,11 @@ import { showMultiImageViewer, showImageViewer, clearImageViewer } from './metho
4
4
  export type { ImageViewerProps, MultiImageViewerProps, MultiImageViewerRef, } from './image-viewer';
5
5
  export type { ImageViewerShowHandler } from './methods';
6
6
  declare const _default: import("react").FC<import("./image-viewer").ImageViewerProps> & {
7
- Multi: import("react").ForwardRefExoticComponent<Omit<import("./image-viewer").ImageViewerProps, "image"> & {
7
+ Multi: import("react").ForwardRefExoticComponent<Omit<import("./image-viewer").ImageViewerProps, "image" | "renderFooter"> & {
8
8
  images?: string[] | undefined;
9
9
  defaultIndex?: number | undefined;
10
10
  onIndexChange?: ((index: number) => void) | undefined;
11
+ renderFooter?: ((image: string, index: number) => import("react").ReactNode) | undefined;
11
12
  } & import("react").RefAttributes<import("./slides").SlidesRef>> & {
12
13
  show: typeof showMultiImageViewer;
13
14
  };
@@ -1,8 +1,10 @@
1
1
  import React, { useRef } from 'react';
2
2
  import { useSpring, animated } from '@react-spring/web';
3
+ import { useSize } from 'ahooks';
3
4
  import { rubberbandIfOutOfBounds } from '../../utils/rubberband';
4
5
  import { useDragAndPinch } from '../../utils/use-drag-and-pinch';
5
6
  import { bound } from '../../utils/bound';
7
+ import * as mat from '../../utils/matrix';
6
8
  const classPrefix = `adm-image-viewer`;
7
9
  export const Slide = props => {
8
10
  const {
@@ -11,54 +13,71 @@ export const Slide = props => {
11
13
  const controlRef = useRef(null);
12
14
  const imgRef = useRef(null);
13
15
  const [{
14
- zoom,
15
- x,
16
- y
16
+ matrix
17
17
  }, api] = useSpring(() => ({
18
- zoom: 1,
19
- x: 0,
20
- y: 0,
18
+ matrix: mat.create(),
21
19
  config: {
22
20
  tension: 200
23
21
  }
24
22
  }));
23
+ const controlSize = useSize(controlRef);
24
+ const imgSize = useSize(imgRef);
25
25
  const pinchLockRef = useRef(false);
26
26
 
27
- function boundXY([x, y], rubberband) {
28
- const currentZoom = zoom.get();
29
- let xOffset = 0,
30
- yOffset = 0;
27
+ const boundMatrix = (nextMatrix, type, last = false) => {
28
+ if (!controlSize || !imgSize) return nextMatrix;
29
+ const controlLeft = -controlSize.width / 2;
30
+ const controlTop = -controlSize.height / 2;
31
+ const imgLeft = -imgSize.width / 2;
32
+ const imgTop = -imgSize.height / 2;
33
+ const zoom = mat.getScaleX(nextMatrix);
34
+ const scaledImgWidth = zoom * imgSize.width;
35
+ const scaledImgHeight = zoom * imgSize.height;
36
+ const [x, y] = mat.apply(nextMatrix, [imgLeft, imgTop]);
31
37
 
32
- if (imgRef.current && controlRef.current) {
33
- xOffset = ((currentZoom * imgRef.current.width || 0) - controlRef.current.clientWidth) / 2;
34
- yOffset = ((currentZoom * imgRef.current.height || 0) - controlRef.current.clientHeight) / 2;
38
+ if (type === 'translate') {
39
+ let boundedX = x;
40
+ let boundedY = y;
41
+
42
+ if (scaledImgWidth > controlSize.width) {
43
+ const minX = controlLeft - (scaledImgWidth - controlSize.width);
44
+ const maxX = controlLeft;
45
+ boundedX = last ? bound(x, minX, maxX) : rubberbandIfOutOfBounds(x, minX, maxX, zoom * 50);
46
+ } else {
47
+ boundedX = -scaledImgWidth / 2;
48
+ }
49
+
50
+ if (scaledImgHeight > controlSize.height) {
51
+ const minY = controlTop - (scaledImgHeight - controlSize.height);
52
+ const maxY = controlTop;
53
+ boundedY = last ? bound(y, minY, maxY) : rubberbandIfOutOfBounds(y, minY, maxY, zoom * 50);
54
+ } else {
55
+ boundedY = -scaledImgHeight / 2;
56
+ }
57
+
58
+ return mat.translate(nextMatrix, boundedX - x, boundedY - y);
35
59
  }
36
60
 
37
- xOffset = xOffset > 0 ? xOffset : 0;
38
- yOffset = yOffset > 0 ? yOffset : 0;
39
- const bounds = {
40
- left: -xOffset,
41
- right: xOffset,
42
- top: -yOffset,
43
- bottom: yOffset
44
- };
45
-
46
- if (rubberband) {
47
- return [rubberbandIfOutOfBounds(x, bounds.left, bounds.right, currentZoom * 50), rubberbandIfOutOfBounds(y, bounds.top, bounds.bottom, currentZoom * 50)];
48
- } else {
49
- return [bound(x, bounds.left, bounds.right), bound(y, bounds.top, bounds.bottom)];
61
+ if (type === 'scale' && last) {
62
+ const [boundedX, boundedY] = [scaledImgWidth > controlSize.width ? bound(x, controlLeft - (scaledImgWidth - controlSize.width), controlLeft) : -scaledImgWidth / 2, scaledImgHeight > controlSize.height ? bound(y, controlTop - (scaledImgHeight - controlSize.height), controlTop) : -scaledImgHeight / 2];
63
+ return mat.translate(nextMatrix, boundedX - x, boundedY - y);
50
64
  }
51
- }
65
+
66
+ return nextMatrix;
67
+ };
52
68
 
53
69
  useDragAndPinch({
54
70
  onDrag: state => {
71
+ if (state.first) return;
72
+ if (state.pinching) return state.cancel();
73
+
55
74
  if (state.tap && state.elapsedTime > 0 && state.elapsedTime < 1000) {
56
75
  // 判断点击时间>0是为了过滤掉非正常操作,例如用户长按选择图片之后的取消操作(也是一次点击)
57
76
  props.onTap();
58
77
  return;
59
78
  }
60
79
 
61
- const currentZoom = zoom.get();
80
+ const currentZoom = mat.getScaleX(matrix.get());
62
81
 
63
82
  if (dragLockRef) {
64
83
  dragLockRef.current = currentZoom !== 1;
@@ -66,24 +85,16 @@ export const Slide = props => {
66
85
 
67
86
  if (!pinchLockRef.current && currentZoom <= 1) {
68
87
  api.start({
69
- x: 0,
70
- y: 0
88
+ matrix: mat.create()
71
89
  });
72
90
  } else {
73
- if (state.last) {
74
- const [x, y] = boundXY([state.offset[0] + state.velocity[0] * state.direction[0] * 200, state.offset[1] + state.velocity[1] * state.direction[1] * 200], false);
75
- api.start({
76
- x,
77
- y
78
- });
79
- } else {
80
- const [x, y] = boundXY(state.offset, true);
81
- api.start({
82
- x,
83
- y,
84
- immediate: true
85
- });
86
- }
91
+ const currentMatrix = matrix.get();
92
+ const offset = [state.offset[0] - mat.getTranslateX(currentMatrix), state.offset[1] - mat.getTranslateY(currentMatrix)];
93
+ const nextMatrix = mat.translate(currentMatrix, ...(state.last ? [offset[0] + state.velocity[0] * state.direction[0] * 200, offset[1] + state.velocity[1] * state.direction[1] * 200] : offset));
94
+ api.start({
95
+ matrix: boundMatrix(nextMatrix, 'translate', state.last),
96
+ immediate: !state.last
97
+ });
87
98
  }
88
99
  },
89
100
  onPinch: state => {
@@ -93,22 +104,30 @@ export const Slide = props => {
93
104
  const [d] = state.offset;
94
105
  if (d < 0) return;
95
106
  const nextZoom = state.last ? bound(d, 1, props.maxZoom) : d;
96
- api.start({
97
- zoom: nextZoom,
98
- immediate: !state.last
99
- });
100
107
  (_a = props.onZoomChange) === null || _a === void 0 ? void 0 : _a.call(props, nextZoom);
101
108
 
102
109
  if (state.last && nextZoom <= 1) {
103
110
  api.start({
104
- x: 0,
105
- y: 0
111
+ matrix: mat.create()
106
112
  });
107
113
 
108
114
  if (dragLockRef) {
109
115
  dragLockRef.current = false;
110
116
  }
111
117
  } else {
118
+ if (!controlSize) return;
119
+ const currentMatrix = matrix.get();
120
+ const currentZoom = mat.getScaleX(currentMatrix);
121
+ const originOffsetX = state.origin[0] - controlSize.width / 2;
122
+ const originOffsetY = state.origin[1] - controlSize.height / 2;
123
+ let nextMatrix = mat.translate(currentMatrix, -originOffsetX, -originOffsetY);
124
+ nextMatrix = mat.scale(nextMatrix, nextZoom / currentZoom);
125
+ nextMatrix = mat.translate(nextMatrix, originOffsetX, originOffsetY);
126
+ api.start({
127
+ matrix: boundMatrix(nextMatrix, 'scale', state.last),
128
+ immediate: !state.last
129
+ });
130
+
112
131
  if (dragLockRef) {
113
132
  dragLockRef.current = true;
114
133
  }
@@ -118,13 +137,13 @@ export const Slide = props => {
118
137
  target: controlRef,
119
138
  drag: {
120
139
  // filterTaps: true,
121
- from: () => [x.get(), y.get()],
140
+ from: () => [mat.getTranslateX(matrix.get()), mat.getTranslateY(matrix.get())],
122
141
  pointer: {
123
142
  touch: true
124
143
  }
125
144
  },
126
145
  pinch: {
127
- from: () => [zoom.get(), 0],
146
+ from: () => [mat.getScaleX(matrix.get()), 0],
128
147
  pointer: {
129
148
  touch: true
130
149
  }
@@ -133,7 +152,7 @@ export const Slide = props => {
133
152
  return React.createElement("div", {
134
153
  className: `${classPrefix}-slide`,
135
154
  onPointerMove: e => {
136
- if (zoom.get() !== 1) {
155
+ if (mat.getScaleX(matrix.get()) !== 1) {
137
156
  e.stopPropagation();
138
157
  }
139
158
  }
@@ -143,9 +162,7 @@ export const Slide = props => {
143
162
  }, React.createElement(animated.div, {
144
163
  className: `${classPrefix}-image-wrapper`,
145
164
  style: {
146
- translateX: x,
147
- translateY: y,
148
- scale: zoom
165
+ matrix
149
166
  }
150
167
  }, React.createElement("img", {
151
168
  ref: imgRef,
@@ -24,8 +24,8 @@
24
24
  height: 70px;
25
25
  padding: 0 24px;
26
26
  color: var(--adm-color-weak);
27
- font-size: 26px;
28
- background-color: #f5f5f5;
27
+ font-size: var(--adm-font-size-main);
28
+ background-color: var(--adm-color-box);
29
29
  }
30
30
 
31
31
  .adm-index-bar-sidebar {
@@ -36,7 +36,8 @@
36
36
  z-index: 910;
37
37
  overflow: visible;
38
38
  color: var(--adm-color-weak);
39
- font-size: 24px;
39
+ font-size: var(--adm-font-size-4);
40
+ -webkit-user-select: none;
40
41
  user-select: none;
41
42
  touch-action: none;
42
43
  }
@@ -78,7 +79,7 @@
78
79
  }
79
80
 
80
81
  .adm-index-bar-sidebar-item-active {
81
- color: #fff;
82
+ color: var(--adm-color-white);
82
83
  background-color: var(--adm-color-primary);
83
84
  border-radius: 50%;
84
85
  }
@@ -88,6 +89,7 @@
88
89
  }
89
90
 
90
91
  .adm-index-bar-sticky .adm-index-bar-anchor-title {
92
+ position: -webkit-sticky;
91
93
  position: sticky;
92
94
  z-index: 900;
93
95
  top: var(--sticky-offset-top);
@@ -2,6 +2,7 @@ import React, { ReactNode } from 'react';
2
2
  import { NativeProps } from '../../utils/native-props';
3
3
  export declare type IndexBarProps = {
4
4
  sticky?: boolean;
5
+ onIndexChange?: (index: string) => void;
5
6
  children?: React.ReactNode;
6
7
  } & NativeProps<'--sticky-offset-top'>;
7
8
  export declare type IndexBarRef = {
@@ -9,5 +10,10 @@ export declare type IndexBarRef = {
9
10
  };
10
11
  export declare const IndexBar: React.ForwardRefExoticComponent<{
11
12
  sticky?: boolean | undefined;
13
+ onIndexChange?: ((index: string) => void) | undefined;
12
14
  children?: React.ReactNode;
13
- } & NativeProps<"--sticky-offset-top"> & React.RefAttributes<IndexBarRef>>;
15
+ } & {
16
+ className?: string | undefined;
17
+ style?: (React.CSSProperties & Partial<Record<"--sticky-offset-top", string>>) | undefined;
18
+ tabIndex?: number | undefined;
19
+ } & React.AriaAttributes & React.RefAttributes<IndexBarRef>>;
@@ -49,6 +49,8 @@ export const IndexBar = forwardRef((p, ref) => {
49
49
  }));
50
50
 
51
51
  function scrollTo(index) {
52
+ var _a;
53
+
52
54
  const body = bodyRef.current;
53
55
  if (!body) return;
54
56
  const children = body.children;
@@ -61,6 +63,7 @@ export const IndexBar = forwardRef((p, ref) => {
61
63
  if (panelIndex === index) {
62
64
  body.scrollTop = panel.offsetTop;
63
65
  setActiveIndex(index);
66
+ activeIndex !== index && ((_a = props.onIndexChange) === null || _a === void 0 ? void 0 : _a.call(props, index));
64
67
  return;
65
68
  }
66
69
  }
@@ -69,6 +72,8 @@ export const IndexBar = forwardRef((p, ref) => {
69
72
  const {
70
73
  run: checkActiveIndex
71
74
  } = useThrottleFn(() => {
75
+ var _a;
76
+
72
77
  const body = bodyRef.current;
73
78
  if (!body) return;
74
79
  const scrollTop = body.scrollTop;
@@ -82,6 +87,7 @@ export const IndexBar = forwardRef((p, ref) => {
82
87
 
83
88
  if (panel.offsetTop + panel.clientHeight - titleHeight > scrollTop) {
84
89
  setActiveIndex(panelIndex);
90
+ activeIndex !== panelIndex && ((_a = props.onIndexChange) === null || _a === void 0 ? void 0 : _a.call(props, panelIndex));
85
91
  return;
86
92
  }
87
93
  }