antd-mobile 5.0.0-rc.1 → 5.0.0-rc.5

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 (457) hide show
  1. package/2x/README.md +2 -0
  2. package/2x/cjs/components/action-sheet/action-sheet.d.ts +3 -3
  3. package/2x/cjs/components/cascader/cascader.css +40 -0
  4. package/2x/cjs/components/cascader/cascader.d.ts +20 -0
  5. package/2x/cjs/components/cascader/cascader.js +130 -0
  6. package/2x/cjs/components/cascader/index.d.ts +9 -0
  7. package/2x/cjs/components/cascader/index.js +20 -0
  8. package/2x/cjs/components/cascader/prompt.d.ts +2 -0
  9. package/2x/cjs/components/cascader/prompt.js +51 -0
  10. package/2x/cjs/components/cascader-view/cascader-view.css +40 -0
  11. package/2x/cjs/components/cascader-view/cascader-view.d.ts +20 -0
  12. package/2x/cjs/components/cascader-view/cascader-view.js +189 -0
  13. package/2x/cjs/components/cascader-view/index.d.ts +4 -0
  14. package/2x/cjs/components/cascader-view/index.js +13 -0
  15. package/2x/cjs/components/cascader-view/use-cascader-value-extend.d.ts +2 -0
  16. package/2x/cjs/components/cascader-view/use-cascader-value-extend.js +97 -0
  17. package/2x/cjs/components/collapse/collapse.d.ts +2 -0
  18. package/2x/cjs/components/collapse/collapse.js +21 -5
  19. package/2x/cjs/components/date-picker/date-picker-date-utils.d.ts +3 -2
  20. package/2x/cjs/components/date-picker/date-picker-date-utils.js +33 -12
  21. package/2x/cjs/components/date-picker/date-picker-utils.d.ts +5 -2
  22. package/2x/cjs/components/date-picker/date-picker-utils.js +3 -3
  23. package/2x/cjs/components/date-picker/date-picker-week-utils.d.ts +3 -2
  24. package/2x/cjs/components/date-picker/date-picker-week-utils.js +28 -6
  25. package/2x/cjs/components/date-picker/date-picker.d.ts +2 -1
  26. package/2x/cjs/components/date-picker/date-picker.js +5 -8
  27. package/2x/cjs/components/date-picker/index.d.ts +1 -0
  28. package/2x/cjs/components/date-picker-view/date-picker-view.d.ts +2 -1
  29. package/2x/cjs/components/date-picker-view/date-picker-view.js +1 -1
  30. package/2x/cjs/components/date-picker-view/index.d.ts +1 -0
  31. package/2x/cjs/components/dialog/dialog.css +1 -1
  32. package/2x/cjs/components/dialog/dialog.js +11 -4
  33. package/2x/cjs/components/dropdown/dropdown.css +13 -11
  34. package/2x/cjs/components/dropdown/dropdown.d.ts +13 -4
  35. package/2x/cjs/components/dropdown/dropdown.js +13 -11
  36. package/2x/cjs/components/dropdown/index.d.ts +14 -3
  37. package/2x/cjs/components/dropdown/index.js +8 -1
  38. package/2x/cjs/components/dropdown/item.d.ts +1 -1
  39. package/2x/cjs/components/dropdown/item.js +10 -4
  40. package/2x/cjs/components/form/form-item.css +4 -1
  41. package/2x/cjs/components/form/form.css +4 -0
  42. package/2x/cjs/components/form/form.d.ts +3 -0
  43. package/2x/cjs/components/form/form.js +3 -1
  44. package/2x/cjs/components/form/index.css +8 -1
  45. package/2x/cjs/components/form/index.d.ts +1 -0
  46. package/2x/cjs/components/image-uploader/image-uploader.d.ts +9 -6
  47. package/2x/cjs/components/image-uploader/image-uploader.js +8 -6
  48. package/2x/cjs/components/image-uploader/index.d.ts +1 -1
  49. package/2x/cjs/components/image-viewer/image-viewer.d.ts +1 -7
  50. package/2x/cjs/components/image-viewer/image-viewer.js +3 -101
  51. package/2x/cjs/components/image-viewer/index.d.ts +2 -1
  52. package/2x/cjs/components/image-viewer/index.js +5 -2
  53. package/2x/cjs/components/image-viewer/methods.d.ts +8 -1
  54. package/2x/cjs/components/image-viewer/methods.js +129 -1
  55. package/2x/cjs/components/list/list.css +7 -5
  56. package/2x/cjs/components/list/list.d.ts +1 -1
  57. package/2x/cjs/components/list/list.js +1 -3
  58. package/2x/cjs/components/mask/mask.js +5 -0
  59. package/2x/cjs/components/modal/alert.d.ts +7 -0
  60. package/2x/cjs/components/modal/alert.js +33 -0
  61. package/2x/cjs/components/modal/confirm.d.ts +9 -0
  62. package/2x/cjs/components/modal/confirm.js +116 -0
  63. package/2x/cjs/components/modal/index.d.ts +16 -0
  64. package/2x/cjs/components/modal/index.js +26 -0
  65. package/2x/cjs/components/modal/modal-action-button.d.ts +14 -0
  66. package/2x/cjs/components/modal/modal-action-button.js +109 -0
  67. package/2x/cjs/components/modal/modal.css +89 -0
  68. package/2x/cjs/components/modal/modal.d.ts +26 -0
  69. package/2x/cjs/components/modal/modal.js +193 -0
  70. package/2x/cjs/components/modal/show.d.ts +8 -0
  71. package/2x/cjs/components/modal/show.js +62 -0
  72. package/2x/cjs/components/notice-bar/notice-bar.css +1 -1
  73. package/2x/cjs/components/number-keyboard/number-keyboard.css +2 -2
  74. package/2x/cjs/components/number-keyboard/number-keyboard.js +57 -11
  75. package/2x/cjs/components/page-indicator/page-indicator.css +1 -1
  76. package/2x/cjs/components/passcode-input/index.d.ts +4 -0
  77. package/2x/cjs/components/passcode-input/index.js +13 -0
  78. package/2x/cjs/components/passcode-input/passcode-input.css +166 -0
  79. package/2x/cjs/components/passcode-input/passcode-input.d.ts +35 -0
  80. package/2x/cjs/components/passcode-input/passcode-input.js +169 -0
  81. package/2x/cjs/components/picker/picker.js +1 -0
  82. package/2x/cjs/components/picker-view/column.js +47 -3
  83. package/2x/cjs/components/picker-view/picker-view.css +45 -5
  84. package/2x/cjs/components/picker-view/picker-view.js +7 -3
  85. package/2x/cjs/components/popup/popup.js +4 -0
  86. package/2x/cjs/components/search-bar/search-bar.css +1 -1
  87. package/2x/cjs/components/swipe-action/swipe-action.css +2 -1
  88. package/2x/cjs/components/swiper/swiper.js +4 -4
  89. package/2x/cjs/components/switch/switch.css +19 -16
  90. package/2x/cjs/components/switch/switch.d.ts +1 -1
  91. package/2x/cjs/components/tag/tag.css +3 -2
  92. package/2x/cjs/components/toast/index.d.ts +2 -1
  93. package/2x/cjs/components/toast/index.js +2 -1
  94. package/2x/cjs/components/toast/methods.d.ts +1 -0
  95. package/2x/cjs/components/toast/methods.js +18 -1
  96. package/2x/cjs/components/toast/toast.css +7 -4
  97. package/2x/cjs/components/toast/toast.js +3 -1
  98. package/2x/cjs/components/virtual-input/virtual-input.css +27 -9
  99. package/2x/cjs/components/virtual-input/virtual-input.d.ts +4 -0
  100. package/2x/cjs/components/virtual-input/virtual-input.js +47 -17
  101. package/2x/cjs/index.d.ts +11 -8
  102. package/2x/cjs/index.js +43 -19
  103. package/2x/cjs/locales/base.d.ts +6 -0
  104. package/2x/cjs/locales/base.js +6 -0
  105. package/2x/cjs/locales/en-US.d.ts +6 -0
  106. package/2x/cjs/locales/zh-CN.d.ts +6 -0
  107. package/2x/cjs/locales/zh-CN.js +6 -0
  108. package/2x/cjs/utils/memo-with-event-marks.d.ts +2 -0
  109. package/2x/cjs/utils/memo-with-event-marks.js +23 -0
  110. package/2x/es/components/action-sheet/action-sheet.d.ts +3 -3
  111. package/2x/es/components/cascader/cascader.css +40 -0
  112. package/2x/es/components/cascader/cascader.d.ts +20 -0
  113. package/2x/es/components/cascader/cascader.js +104 -0
  114. package/2x/es/components/cascader/index.d.ts +9 -0
  115. package/2x/es/components/cascader/index.js +7 -0
  116. package/2x/es/components/cascader/prompt.d.ts +2 -0
  117. package/2x/es/components/cascader/prompt.js +37 -0
  118. package/2x/es/components/cascader-view/cascader-view.css +40 -0
  119. package/2x/es/components/cascader-view/cascader-view.d.ts +20 -0
  120. package/2x/es/components/cascader-view/cascader-view.js +130 -0
  121. package/2x/es/components/cascader-view/index.d.ts +4 -0
  122. package/2x/es/components/cascader-view/index.js +3 -0
  123. package/2x/es/components/cascader-view/use-cascader-value-extend.d.ts +2 -0
  124. package/2x/es/components/cascader-view/use-cascader-value-extend.js +52 -0
  125. package/2x/es/components/collapse/collapse.d.ts +2 -0
  126. package/2x/es/components/collapse/collapse.js +21 -5
  127. package/2x/es/components/date-picker/date-picker-date-utils.d.ts +3 -2
  128. package/2x/es/components/date-picker/date-picker-date-utils.js +33 -11
  129. package/2x/es/components/date-picker/date-picker-utils.d.ts +5 -2
  130. package/2x/es/components/date-picker/date-picker-utils.js +3 -3
  131. package/2x/es/components/date-picker/date-picker-week-utils.d.ts +3 -2
  132. package/2x/es/components/date-picker/date-picker-week-utils.js +28 -5
  133. package/2x/es/components/date-picker/date-picker.d.ts +2 -1
  134. package/2x/es/components/date-picker/date-picker.js +4 -7
  135. package/2x/es/components/date-picker/index.d.ts +1 -0
  136. package/2x/es/components/date-picker-view/date-picker-view.d.ts +2 -1
  137. package/2x/es/components/date-picker-view/date-picker-view.js +1 -1
  138. package/2x/es/components/date-picker-view/index.d.ts +1 -0
  139. package/2x/es/components/dialog/dialog.css +1 -1
  140. package/2x/es/components/dialog/dialog.js +9 -4
  141. package/2x/es/components/dropdown/dropdown.css +13 -11
  142. package/2x/es/components/dropdown/dropdown.d.ts +13 -4
  143. package/2x/es/components/dropdown/dropdown.js +14 -12
  144. package/2x/es/components/dropdown/index.d.ts +14 -3
  145. package/2x/es/components/dropdown/index.js +5 -1
  146. package/2x/es/components/dropdown/item.d.ts +1 -1
  147. package/2x/es/components/dropdown/item.js +9 -4
  148. package/2x/es/components/form/form-item.css +4 -1
  149. package/2x/es/components/form/form.css +4 -0
  150. package/2x/es/components/form/form.d.ts +3 -0
  151. package/2x/es/components/form/form.js +3 -1
  152. package/2x/es/components/form/index.css +8 -1
  153. package/2x/es/components/form/index.d.ts +1 -0
  154. package/2x/es/components/image-uploader/image-uploader.d.ts +9 -6
  155. package/2x/es/components/image-uploader/image-uploader.js +8 -6
  156. package/2x/es/components/image-uploader/index.d.ts +1 -1
  157. package/2x/es/components/image-viewer/image-viewer.d.ts +1 -7
  158. package/2x/es/components/image-viewer/image-viewer.js +2 -91
  159. package/2x/es/components/image-viewer/index.d.ts +2 -1
  160. package/2x/es/components/image-viewer/index.js +4 -2
  161. package/2x/es/components/image-viewer/methods.d.ts +8 -1
  162. package/2x/es/components/image-viewer/methods.js +109 -0
  163. package/2x/es/components/list/list.css +7 -5
  164. package/2x/es/components/list/list.d.ts +1 -1
  165. package/2x/es/components/list/list.js +1 -3
  166. package/2x/es/components/mask/mask.js +4 -0
  167. package/2x/es/components/modal/alert.d.ts +7 -0
  168. package/2x/es/components/modal/alert.js +23 -0
  169. package/2x/es/components/modal/confirm.d.ts +9 -0
  170. package/2x/es/components/modal/confirm.js +106 -0
  171. package/2x/es/components/modal/index.d.ts +16 -0
  172. package/2x/es/components/modal/index.js +11 -0
  173. package/2x/es/components/modal/modal-action-button.d.ts +14 -0
  174. package/2x/es/components/modal/modal-action-button.js +90 -0
  175. package/2x/es/components/modal/modal.css +89 -0
  176. package/2x/es/components/modal/modal.d.ts +26 -0
  177. package/2x/es/components/modal/modal.js +164 -0
  178. package/2x/es/components/modal/show.d.ts +8 -0
  179. package/2x/es/components/modal/show.js +48 -0
  180. package/2x/es/components/notice-bar/notice-bar.css +1 -1
  181. package/2x/es/components/number-keyboard/number-keyboard.css +2 -2
  182. package/2x/es/components/number-keyboard/number-keyboard.js +56 -11
  183. package/2x/es/components/page-indicator/page-indicator.css +1 -1
  184. package/2x/es/components/passcode-input/index.d.ts +4 -0
  185. package/2x/es/components/passcode-input/index.js +3 -0
  186. package/2x/es/components/passcode-input/passcode-input.css +166 -0
  187. package/2x/es/components/passcode-input/passcode-input.d.ts +35 -0
  188. package/2x/es/components/passcode-input/passcode-input.js +149 -0
  189. package/2x/es/components/picker/picker.js +1 -0
  190. package/2x/es/components/picker-view/column.js +47 -3
  191. package/2x/es/components/picker-view/picker-view.css +45 -5
  192. package/2x/es/components/picker-view/picker-view.js +7 -3
  193. package/2x/es/components/popup/popup.js +3 -0
  194. package/2x/es/components/search-bar/search-bar.css +1 -1
  195. package/2x/es/components/swipe-action/swipe-action.css +2 -1
  196. package/2x/es/components/swiper/swiper.js +4 -4
  197. package/2x/es/components/switch/switch.css +19 -16
  198. package/2x/es/components/switch/switch.d.ts +1 -1
  199. package/2x/es/components/tag/tag.css +3 -2
  200. package/2x/es/components/toast/index.d.ts +2 -1
  201. package/2x/es/components/toast/index.js +3 -2
  202. package/2x/es/components/toast/methods.d.ts +1 -0
  203. package/2x/es/components/toast/methods.js +16 -1
  204. package/2x/es/components/toast/toast.css +7 -4
  205. package/2x/es/components/toast/toast.js +2 -1
  206. package/2x/es/components/virtual-input/virtual-input.css +27 -9
  207. package/2x/es/components/virtual-input/virtual-input.d.ts +4 -0
  208. package/2x/es/components/virtual-input/virtual-input.js +47 -18
  209. package/2x/es/index.d.ts +11 -8
  210. package/2x/es/index.js +11 -8
  211. package/2x/es/locales/base.d.ts +6 -0
  212. package/2x/es/locales/base.js +6 -0
  213. package/2x/es/locales/en-US.d.ts +6 -0
  214. package/2x/es/locales/zh-CN.d.ts +6 -0
  215. package/2x/es/locales/zh-CN.js +6 -0
  216. package/2x/es/utils/memo-with-event-marks.d.ts +2 -0
  217. package/2x/es/utils/memo-with-event-marks.js +15 -0
  218. package/2x/package.json +3 -3
  219. package/README.md +2 -0
  220. package/cjs/components/action-sheet/action-sheet.d.ts +3 -3
  221. package/cjs/components/cascader/cascader.css +35 -0
  222. package/cjs/components/cascader/cascader.d.ts +20 -0
  223. package/cjs/components/cascader/cascader.js +130 -0
  224. package/cjs/components/cascader/index.d.ts +9 -0
  225. package/cjs/components/cascader/index.js +20 -0
  226. package/cjs/components/cascader/prompt.d.ts +2 -0
  227. package/cjs/components/cascader/prompt.js +51 -0
  228. package/cjs/components/cascader-view/cascader-view.css +33 -0
  229. package/cjs/components/cascader-view/cascader-view.d.ts +20 -0
  230. package/cjs/components/cascader-view/cascader-view.js +189 -0
  231. package/cjs/components/cascader-view/index.d.ts +4 -0
  232. package/cjs/components/cascader-view/index.js +13 -0
  233. package/cjs/components/cascader-view/use-cascader-value-extend.d.ts +2 -0
  234. package/cjs/components/cascader-view/use-cascader-value-extend.js +97 -0
  235. package/cjs/components/collapse/collapse.d.ts +2 -0
  236. package/cjs/components/collapse/collapse.js +21 -5
  237. package/cjs/components/date-picker/date-picker-date-utils.d.ts +3 -2
  238. package/cjs/components/date-picker/date-picker-date-utils.js +33 -12
  239. package/cjs/components/date-picker/date-picker-utils.d.ts +5 -2
  240. package/cjs/components/date-picker/date-picker-utils.js +3 -3
  241. package/cjs/components/date-picker/date-picker-week-utils.d.ts +3 -2
  242. package/cjs/components/date-picker/date-picker-week-utils.js +28 -6
  243. package/cjs/components/date-picker/date-picker.d.ts +2 -1
  244. package/cjs/components/date-picker/date-picker.js +5 -8
  245. package/cjs/components/date-picker/index.d.ts +1 -0
  246. package/cjs/components/date-picker-view/date-picker-view.d.ts +2 -1
  247. package/cjs/components/date-picker-view/date-picker-view.js +1 -1
  248. package/cjs/components/date-picker-view/index.d.ts +1 -0
  249. package/cjs/components/dialog/dialog.css +1 -1
  250. package/cjs/components/dialog/dialog.js +11 -4
  251. package/cjs/components/dropdown/dropdown.css +12 -11
  252. package/cjs/components/dropdown/dropdown.d.ts +13 -4
  253. package/cjs/components/dropdown/dropdown.js +13 -11
  254. package/cjs/components/dropdown/index.d.ts +14 -3
  255. package/cjs/components/dropdown/index.js +8 -1
  256. package/cjs/components/dropdown/item.d.ts +1 -1
  257. package/cjs/components/dropdown/item.js +10 -4
  258. package/cjs/components/form/form-item.css +4 -1
  259. package/cjs/components/form/form.css +3 -0
  260. package/cjs/components/form/form.d.ts +3 -0
  261. package/cjs/components/form/form.js +3 -1
  262. package/cjs/components/form/index.css +7 -1
  263. package/cjs/components/form/index.d.ts +1 -0
  264. package/cjs/components/image-uploader/image-uploader.d.ts +9 -6
  265. package/cjs/components/image-uploader/image-uploader.js +8 -6
  266. package/cjs/components/image-uploader/index.d.ts +1 -1
  267. package/cjs/components/image-viewer/image-viewer.d.ts +1 -7
  268. package/cjs/components/image-viewer/image-viewer.js +3 -101
  269. package/cjs/components/image-viewer/index.d.ts +2 -1
  270. package/cjs/components/image-viewer/index.js +5 -2
  271. package/cjs/components/image-viewer/methods.d.ts +8 -1
  272. package/cjs/components/image-viewer/methods.js +129 -1
  273. package/cjs/components/list/list.css +6 -4
  274. package/cjs/components/list/list.d.ts +1 -1
  275. package/cjs/components/list/list.js +1 -3
  276. package/cjs/components/mask/mask.js +5 -0
  277. package/cjs/components/modal/alert.d.ts +7 -0
  278. package/cjs/components/modal/alert.js +33 -0
  279. package/cjs/components/modal/confirm.d.ts +9 -0
  280. package/cjs/components/modal/confirm.js +116 -0
  281. package/cjs/components/modal/index.d.ts +16 -0
  282. package/cjs/components/modal/index.js +26 -0
  283. package/cjs/components/modal/modal-action-button.d.ts +14 -0
  284. package/cjs/components/modal/modal-action-button.js +109 -0
  285. package/cjs/components/modal/modal.css +75 -0
  286. package/cjs/components/modal/modal.d.ts +26 -0
  287. package/cjs/components/modal/modal.js +193 -0
  288. package/cjs/components/modal/show.d.ts +8 -0
  289. package/cjs/components/modal/show.js +62 -0
  290. package/cjs/components/notice-bar/notice-bar.css +1 -1
  291. package/cjs/components/number-keyboard/number-keyboard.css +2 -2
  292. package/cjs/components/number-keyboard/number-keyboard.js +57 -11
  293. package/cjs/components/page-indicator/page-indicator.css +1 -1
  294. package/cjs/components/passcode-input/index.d.ts +4 -0
  295. package/cjs/components/passcode-input/index.js +13 -0
  296. package/cjs/components/passcode-input/passcode-input.css +136 -0
  297. package/cjs/components/passcode-input/passcode-input.d.ts +35 -0
  298. package/cjs/components/passcode-input/passcode-input.js +169 -0
  299. package/cjs/components/picker/picker.js +1 -0
  300. package/cjs/components/picker-view/column.js +47 -3
  301. package/cjs/components/picker-view/picker-view.css +39 -5
  302. package/cjs/components/picker-view/picker-view.js +7 -3
  303. package/cjs/components/popup/popup.js +4 -0
  304. package/cjs/components/search-bar/search-bar.css +1 -1
  305. package/cjs/components/swipe-action/swipe-action.css +2 -1
  306. package/cjs/components/swiper/swiper.js +4 -4
  307. package/cjs/components/switch/switch.css +19 -16
  308. package/cjs/components/switch/switch.d.ts +1 -1
  309. package/cjs/components/tag/tag.css +3 -2
  310. package/cjs/components/toast/index.d.ts +2 -1
  311. package/cjs/components/toast/index.js +2 -1
  312. package/cjs/components/toast/methods.d.ts +1 -0
  313. package/cjs/components/toast/methods.js +18 -1
  314. package/cjs/components/toast/toast.css +7 -4
  315. package/cjs/components/toast/toast.js +3 -1
  316. package/cjs/components/virtual-input/virtual-input.css +24 -8
  317. package/cjs/components/virtual-input/virtual-input.d.ts +4 -0
  318. package/cjs/components/virtual-input/virtual-input.js +47 -17
  319. package/cjs/index.d.ts +11 -8
  320. package/cjs/index.js +43 -19
  321. package/cjs/locales/base.d.ts +6 -0
  322. package/cjs/locales/base.js +6 -0
  323. package/cjs/locales/en-US.d.ts +6 -0
  324. package/cjs/locales/zh-CN.d.ts +6 -0
  325. package/cjs/locales/zh-CN.js +6 -0
  326. package/cjs/utils/memo-with-event-marks.d.ts +2 -0
  327. package/cjs/utils/memo-with-event-marks.js +23 -0
  328. package/es/components/action-sheet/action-sheet.d.ts +3 -3
  329. package/es/components/cascader/cascader.css +35 -0
  330. package/es/components/cascader/cascader.d.ts +20 -0
  331. package/es/components/cascader/cascader.js +104 -0
  332. package/es/components/cascader/index.d.ts +9 -0
  333. package/es/components/cascader/index.js +7 -0
  334. package/es/components/cascader/prompt.d.ts +2 -0
  335. package/es/components/cascader/prompt.js +37 -0
  336. package/es/components/cascader-view/cascader-view.css +33 -0
  337. package/es/components/cascader-view/cascader-view.d.ts +20 -0
  338. package/es/components/cascader-view/cascader-view.js +130 -0
  339. package/es/components/cascader-view/index.d.ts +4 -0
  340. package/es/components/cascader-view/index.js +3 -0
  341. package/es/components/cascader-view/use-cascader-value-extend.d.ts +2 -0
  342. package/es/components/cascader-view/use-cascader-value-extend.js +52 -0
  343. package/es/components/collapse/collapse.d.ts +2 -0
  344. package/es/components/collapse/collapse.js +21 -5
  345. package/es/components/date-picker/date-picker-date-utils.d.ts +3 -2
  346. package/es/components/date-picker/date-picker-date-utils.js +33 -11
  347. package/es/components/date-picker/date-picker-utils.d.ts +5 -2
  348. package/es/components/date-picker/date-picker-utils.js +3 -3
  349. package/es/components/date-picker/date-picker-week-utils.d.ts +3 -2
  350. package/es/components/date-picker/date-picker-week-utils.js +28 -5
  351. package/es/components/date-picker/date-picker.d.ts +2 -1
  352. package/es/components/date-picker/date-picker.js +4 -7
  353. package/es/components/date-picker/index.d.ts +1 -0
  354. package/es/components/date-picker-view/date-picker-view.d.ts +2 -1
  355. package/es/components/date-picker-view/date-picker-view.js +1 -1
  356. package/es/components/date-picker-view/index.d.ts +1 -0
  357. package/es/components/dialog/dialog.css +1 -1
  358. package/es/components/dialog/dialog.js +9 -4
  359. package/es/components/dropdown/dropdown.css +12 -11
  360. package/es/components/dropdown/dropdown.d.ts +13 -4
  361. package/es/components/dropdown/dropdown.js +14 -12
  362. package/es/components/dropdown/index.d.ts +14 -3
  363. package/es/components/dropdown/index.js +5 -1
  364. package/es/components/dropdown/item.d.ts +1 -1
  365. package/es/components/dropdown/item.js +9 -4
  366. package/es/components/form/form-item.css +4 -1
  367. package/es/components/form/form.css +3 -0
  368. package/es/components/form/form.d.ts +3 -0
  369. package/es/components/form/form.js +3 -1
  370. package/es/components/form/index.css +7 -1
  371. package/es/components/form/index.d.ts +1 -0
  372. package/es/components/image-uploader/image-uploader.d.ts +9 -6
  373. package/es/components/image-uploader/image-uploader.js +8 -6
  374. package/es/components/image-uploader/index.d.ts +1 -1
  375. package/es/components/image-viewer/image-viewer.d.ts +1 -7
  376. package/es/components/image-viewer/image-viewer.js +2 -91
  377. package/es/components/image-viewer/index.d.ts +2 -1
  378. package/es/components/image-viewer/index.js +4 -2
  379. package/es/components/image-viewer/methods.d.ts +8 -1
  380. package/es/components/image-viewer/methods.js +109 -0
  381. package/es/components/list/list.css +6 -4
  382. package/es/components/list/list.d.ts +1 -1
  383. package/es/components/list/list.js +1 -3
  384. package/es/components/mask/mask.js +4 -0
  385. package/es/components/modal/alert.d.ts +7 -0
  386. package/es/components/modal/alert.js +23 -0
  387. package/es/components/modal/confirm.d.ts +9 -0
  388. package/es/components/modal/confirm.js +106 -0
  389. package/es/components/modal/index.d.ts +16 -0
  390. package/es/components/modal/index.js +11 -0
  391. package/es/components/modal/modal-action-button.d.ts +14 -0
  392. package/es/components/modal/modal-action-button.js +90 -0
  393. package/es/components/modal/modal.css +75 -0
  394. package/es/components/modal/modal.d.ts +26 -0
  395. package/es/components/modal/modal.js +164 -0
  396. package/es/components/modal/show.d.ts +8 -0
  397. package/es/components/modal/show.js +48 -0
  398. package/es/components/notice-bar/notice-bar.css +1 -1
  399. package/es/components/number-keyboard/number-keyboard.css +2 -2
  400. package/es/components/number-keyboard/number-keyboard.js +56 -11
  401. package/es/components/page-indicator/page-indicator.css +1 -1
  402. package/es/components/passcode-input/index.d.ts +4 -0
  403. package/es/components/passcode-input/index.js +3 -0
  404. package/es/components/passcode-input/passcode-input.css +136 -0
  405. package/es/components/passcode-input/passcode-input.d.ts +35 -0
  406. package/es/components/passcode-input/passcode-input.js +149 -0
  407. package/es/components/picker/picker.js +1 -0
  408. package/es/components/picker-view/column.js +47 -3
  409. package/es/components/picker-view/picker-view.css +39 -5
  410. package/es/components/picker-view/picker-view.js +7 -3
  411. package/es/components/popup/popup.js +3 -0
  412. package/es/components/search-bar/search-bar.css +1 -1
  413. package/es/components/swipe-action/swipe-action.css +2 -1
  414. package/es/components/swiper/swiper.js +4 -4
  415. package/es/components/switch/switch.css +19 -16
  416. package/es/components/switch/switch.d.ts +1 -1
  417. package/es/components/tag/tag.css +3 -2
  418. package/es/components/toast/index.d.ts +2 -1
  419. package/es/components/toast/index.js +3 -2
  420. package/es/components/toast/methods.d.ts +1 -0
  421. package/es/components/toast/methods.js +16 -1
  422. package/es/components/toast/toast.css +7 -4
  423. package/es/components/toast/toast.js +2 -1
  424. package/es/components/virtual-input/virtual-input.css +24 -8
  425. package/es/components/virtual-input/virtual-input.d.ts +4 -0
  426. package/es/components/virtual-input/virtual-input.js +47 -18
  427. package/es/index.d.ts +11 -8
  428. package/es/index.js +11 -8
  429. package/es/locales/base.d.ts +6 -0
  430. package/es/locales/base.js +6 -0
  431. package/es/locales/en-US.d.ts +6 -0
  432. package/es/locales/zh-CN.d.ts +6 -0
  433. package/es/locales/zh-CN.js +6 -0
  434. package/es/utils/memo-with-event-marks.d.ts +2 -0
  435. package/es/utils/memo-with-event-marks.js +15 -0
  436. package/package.json +3 -3
  437. package/umd/antd-mobile.js +1 -1
  438. package/2x/cjs/components/desense-text/desense-text.css +0 -10
  439. package/2x/cjs/components/desense-text/desense-text.d.ts +0 -10
  440. package/2x/cjs/components/desense-text/desense-text.js +0 -50
  441. package/2x/cjs/components/desense-text/index.d.ts +0 -4
  442. package/2x/cjs/components/desense-text/index.js +0 -13
  443. package/2x/es/components/desense-text/desense-text.css +0 -10
  444. package/2x/es/components/desense-text/desense-text.d.ts +0 -10
  445. package/2x/es/components/desense-text/desense-text.js +0 -32
  446. package/2x/es/components/desense-text/index.d.ts +0 -4
  447. package/2x/es/components/desense-text/index.js +0 -3
  448. package/cjs/components/desense-text/desense-text.css +0 -9
  449. package/cjs/components/desense-text/desense-text.d.ts +0 -10
  450. package/cjs/components/desense-text/desense-text.js +0 -50
  451. package/cjs/components/desense-text/index.d.ts +0 -4
  452. package/cjs/components/desense-text/index.js +0 -13
  453. package/es/components/desense-text/desense-text.css +0 -9
  454. package/es/components/desense-text/desense-text.d.ts +0 -10
  455. package/es/components/desense-text/desense-text.js +0 -32
  456. package/es/components/desense-text/index.d.ts +0 -4
  457. package/es/components/desense-text/index.js +0 -3
@@ -4,8 +4,7 @@
4
4
  flex: 1;
5
5
  }
6
6
 
7
- .adm-number-keyboard.confirmed-style {
8
- width: 75%;
7
+ .adm-number-keyboard-main.confirmed-style .sign-key {
9
8
  background-color: var(--adm-color-white);
10
9
  }
11
10
 
@@ -125,6 +124,7 @@
125
124
  color: var(--adm-color-white);
126
125
  height: 288px;
127
126
  font-size: 32px;
127
+ border: none;
128
128
  }
129
129
 
130
130
  .adm-number-keyboard-bs-key {
@@ -21,6 +21,8 @@ var _nativeProps = require("../../utils/native-props");
21
21
 
22
22
  var _safeArea = _interopRequireDefault(require("../safe-area"));
23
23
 
24
+ var _ahooks = require("ahooks");
25
+
24
26
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
25
27
 
26
28
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
@@ -46,8 +48,7 @@ var NumberKeyboard = function NumberKeyboard(p) {
46
48
  customKey = props.customKey,
47
49
  randomOrder = props.randomOrder,
48
50
  showCloseButton = props.showCloseButton,
49
- onInput = props.onInput,
50
- onDelete = props.onDelete;
51
+ onInput = props.onInput;
51
52
  var keyboardRef = (0, _react.useRef)(null);
52
53
  var keys = (0, _react.useMemo)(function () {
53
54
  var defaultKeys = ['1', '2', '3', '4', '5', '6', '7', '8', '9'];
@@ -62,11 +63,33 @@ var NumberKeyboard = function NumberKeyboard(p) {
62
63
  }
63
64
 
64
65
  return keyList;
65
- }, [customKey, confirmText, randomOrder, randomOrder && visible]); // 点击键盘按键
66
+ }, [customKey, confirmText, randomOrder, randomOrder && visible]);
67
+ var timeoutRef = (0, _react.useRef)(-1);
68
+ var intervalRef = (0, _react.useRef)(-1);
69
+ var onDelete = (0, _ahooks.usePersistFn)(function () {
70
+ var _a;
71
+
72
+ (_a = props.onDelete) === null || _a === void 0 ? void 0 : _a.call(props);
73
+ });
74
+
75
+ var onBackspacePressStart = function onBackspacePressStart() {
76
+ timeoutRef.current = window.setTimeout(function () {
77
+ onDelete();
78
+ intervalRef.current = window.setInterval(onDelete, 150);
79
+ }, 700);
80
+ };
81
+
82
+ var onBackspacePressEnd = function onBackspacePressEnd() {
83
+ clearTimeout(timeoutRef.current);
84
+ clearInterval(intervalRef.current);
85
+ }; // 点击键盘按键
86
+
66
87
 
67
- var onKeyPress = function onKeyPress(key) {
88
+ var onKeyPress = function onKeyPress(e, key) {
68
89
  var _a, _b;
69
90
 
91
+ e.preventDefault();
92
+
70
93
  switch (key) {
71
94
  case 'BACKSPACE':
72
95
  onDelete === null || onDelete === void 0 ? void 0 : onDelete();
@@ -82,7 +105,8 @@ var NumberKeyboard = function NumberKeyboard(p) {
82
105
  break;
83
106
 
84
107
  default:
85
- onInput === null || onInput === void 0 ? void 0 : onInput(key);
108
+ // customKey 不存在时,点击该键不应该触发 onInput
109
+ if (key !== '') onInput === null || onInput === void 0 ? void 0 : onInput(key);
86
110
  break;
87
111
  }
88
112
  }; // 渲染 title 和 close button
@@ -119,8 +143,20 @@ var NumberKeyboard = function NumberKeyboard(p) {
119
143
  return /*#__PURE__*/_react["default"].createElement("div", {
120
144
  key: key,
121
145
  className: className,
122
- onClick: function onClick() {
123
- return key && onKeyPress(key);
146
+ onTouchStart: function onTouchStart() {
147
+ if (key === 'BACKSPACE') {
148
+ onBackspacePressStart();
149
+ }
150
+ },
151
+ onTouchEnd: function onTouchEnd(e) {
152
+ onKeyPress(e, key);
153
+
154
+ if (key === 'BACKSPACE') {
155
+ onBackspacePressEnd();
156
+ }
157
+ },
158
+ onMouseUp: function onMouseUp(e) {
159
+ onKeyPress(e, key);
124
160
  },
125
161
  title: key,
126
162
  role: 'button'
@@ -151,15 +187,25 @@ var NumberKeyboard = function NumberKeyboard(p) {
151
187
  className: classPrefix + "-confirm"
152
188
  }, /*#__PURE__*/_react["default"].createElement("div", {
153
189
  className: classPrefix + "-key extra-key bs-key",
154
- onClick: function onClick() {
155
- return onKeyPress('BACKSPACE');
190
+ onTouchStart: function onTouchStart() {
191
+ onBackspacePressStart();
192
+ },
193
+ onTouchEnd: function onTouchEnd(e) {
194
+ onKeyPress(e, 'BACKSPACE');
195
+ onBackspacePressEnd();
196
+ },
197
+ onMouseUp: function onMouseUp(e) {
198
+ return onKeyPress(e, 'BACKSPACE');
156
199
  },
157
200
  title: 'BACKSPACE',
158
201
  role: 'button'
159
202
  }, /*#__PURE__*/_react["default"].createElement(_antdMobileIcons.TextDeletionOutline, null)), /*#__PURE__*/_react["default"].createElement("div", {
160
203
  className: classPrefix + "-key extra-key ok-key",
161
- onClick: function onClick() {
162
- return onKeyPress('OK');
204
+ onTouchEnd: function onTouchEnd(e) {
205
+ return onKeyPress(e, 'OK');
206
+ },
207
+ onMouseUp: function onMouseUp(e) {
208
+ return onKeyPress(e, 'OK');
163
209
  },
164
210
  role: 'button'
165
211
  }, confirmText))), props.safeArea && /*#__PURE__*/_react["default"].createElement("div", {
@@ -1,6 +1,6 @@
1
1
  .adm-page-indicator {
2
2
  display: flex;
3
- width: fit-content;
3
+ width: auto;
4
4
  --dot-color: rgba(0, 0, 0, 0.2);
5
5
  --active-dot-color: var(--adm-color-primary);
6
6
  --dot-size: 6px;
@@ -0,0 +1,4 @@
1
+ import './passcode-input.less';
2
+ import { PasscodeInput } from './passcode-input';
3
+ export type { PasscodeInputProps } from './passcode-input';
4
+ export default PasscodeInput;
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ require("./passcode-input.css");
9
+
10
+ var _passcodeInput2 = require("./passcode-input");
11
+
12
+ var _default = _passcodeInput2.PasscodeInput;
13
+ exports["default"] = _default;
@@ -0,0 +1,166 @@
1
+ .adm-passcode-input {
2
+ position: relative;
3
+ display: inline-block;
4
+ --cell-size: 80px;
5
+ --cell-gap: 12px;
6
+ --dot-size: 20px;
7
+ --border-color: #e5e5e5;
8
+ --border-radius: 16px;
9
+ }
10
+
11
+ .adm-passcode-input-cell-container {
12
+ display: inline-flex;
13
+ vertical-align: top;
14
+ }
15
+
16
+ .adm-passcode-input-cell {
17
+ flex: none;
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ box-sizing: border-box;
22
+ font-size: 36px;
23
+ width: var(--cell-size);
24
+ height: var(--cell-size);
25
+ background: var(--adm-color-white);
26
+ }
27
+
28
+ .adm-passcode-input:not(.seperated) {
29
+ border-radius: var(--border-radius);
30
+ overflow: hidden;
31
+ border: 2px solid var(--border-color);
32
+ }
33
+
34
+ .adm-passcode-input:not(.seperated) .adm-passcode-input-cell:not(:last-child) {
35
+ border-right: 2px solid var(--border-color);
36
+ }
37
+
38
+ .adm-passcode-input:not(.seperated).focused {
39
+ border-color: var(--adm-color-primary);
40
+ box-shadow: 0 0 4px 0 var(--adm-color-primary);
41
+ outline: none;
42
+ }
43
+
44
+ .adm-passcode-input:not(.seperated).error {
45
+ border-color: var(--adm-color-danger);
46
+ box-shadow: 0 0 4px 0 var(--adm-color-danger);
47
+ animation: 100ms ease-in-out 0s 3 normal none running adm-shake-horizontal;
48
+ }
49
+
50
+ .adm-passcode-input.seperated .adm-passcode-input-cell {
51
+ border-radius: var(--border-radius);
52
+ border: 2px solid var(--border-color);
53
+ }
54
+
55
+ .adm-passcode-input.seperated .adm-passcode-input-cell:not(:last-child) {
56
+ margin-right: var(--cell-gap);
57
+ }
58
+
59
+ .adm-passcode-input.seperated .adm-passcode-input-cell.focused {
60
+ border-color: var(--adm-color-primary);
61
+ box-shadow: 0 0 4px 0 var(--adm-color-primary);
62
+ }
63
+
64
+ .adm-passcode-input.seperated.focused {
65
+ outline: none;
66
+ }
67
+
68
+ .adm-passcode-input.seperated.error {
69
+ animation: 100ms ease-in-out 0s 3 normal none running adm-shake-horizontal;
70
+ }
71
+
72
+ .adm-passcode-input.seperated.error .adm-passcode-input-cell {
73
+ border-color: var(--adm-color-danger);
74
+ box-shadow: 0 0 4px 0 var(--adm-color-danger);
75
+ }
76
+
77
+ .adm-passcode-input-cell.dot::before {
78
+ content: '';
79
+ width: var(--dot-size);
80
+ height: var(--dot-size);
81
+ border-radius: 50%;
82
+ background: var(--adm-color-text);
83
+ }
84
+
85
+ .adm-passcode-input-cell.caret::after {
86
+ content: '';
87
+ width: 4px;
88
+ height: 1.1em;
89
+ margin-left: 2px;
90
+ background: var(--adm-color-primary);
91
+ animation: 1s linear infinite adm-caret-blink;
92
+ }
93
+
94
+ .adm-passcode-input > .adm-passcode-input-native-input {
95
+ position: absolute;
96
+ left: -200vw;
97
+ top: 0;
98
+ display: block;
99
+ width: 100px;
100
+ height: 40px;
101
+ opacity: 0.5;
102
+ }
103
+
104
+ @keyframes adm-shake-horizontal {
105
+ 0% {
106
+ transform: translateX(0);
107
+ }
108
+
109
+ 10% {
110
+ transform: translateX(-8px);
111
+ }
112
+
113
+ 20% {
114
+ transform: translateX(10px);
115
+ }
116
+
117
+ 30% {
118
+ transform: translateX(-2px);
119
+ }
120
+
121
+ 40% {
122
+ transform: translateX(16px);
123
+ }
124
+
125
+ 50% {
126
+ transform: translateX(0);
127
+ }
128
+
129
+ 60% {
130
+ transform: translateX(-16px);
131
+ }
132
+
133
+ 70% {
134
+ transform: translateX(2px);
135
+ }
136
+
137
+ 80% {
138
+ transform: translateX(-10px);
139
+ }
140
+
141
+ 90% {
142
+ transform: translateX(8px);
143
+ }
144
+
145
+ 100% {
146
+ transform: translateX(0);
147
+ }
148
+ }
149
+
150
+ @keyframes adm-caret-blink {
151
+ from {
152
+ opacity: 1;
153
+ }
154
+
155
+ 60% {
156
+ opacity: 1;
157
+ }
158
+
159
+ 80% {
160
+ opacity: 0;
161
+ }
162
+
163
+ to {
164
+ opacity: 0;
165
+ }
166
+ }
@@ -0,0 +1,35 @@
1
+ import React, { ReactElement } from 'react';
2
+ import { NativeProps } from '../../utils/native-props';
3
+ import type { NumberKeyboardProps } from '../number-keyboard';
4
+ export declare type PasscodeInputProps = {
5
+ value?: string;
6
+ defaultValue?: string;
7
+ onChange?: (val: string) => void;
8
+ length?: number;
9
+ plain?: boolean;
10
+ error?: boolean;
11
+ caret?: boolean;
12
+ seperated?: boolean;
13
+ onBlur?: () => void;
14
+ onFocus?: () => void;
15
+ keyboard?: ReactElement<NumberKeyboardProps>;
16
+ onFill?: (val: string) => void;
17
+ } & NativeProps<'--cell-gap' | '--cell-size'>;
18
+ export declare type PasscodeInputRef = {
19
+ focus: () => void;
20
+ blur: () => void;
21
+ };
22
+ export declare const PasscodeInput: React.ForwardRefExoticComponent<{
23
+ value?: string | undefined;
24
+ defaultValue?: string | undefined;
25
+ onChange?: ((val: string) => void) | undefined;
26
+ length?: number | undefined;
27
+ plain?: boolean | undefined;
28
+ error?: boolean | undefined;
29
+ caret?: boolean | undefined;
30
+ seperated?: boolean | undefined;
31
+ onBlur?: (() => void) | undefined;
32
+ onFocus?: (() => void) | undefined;
33
+ keyboard?: React.ReactElement<NumberKeyboardProps, string | ((props: any) => React.ReactElement<any, any> | null) | (new (props: any) => React.Component<any, any, any>)> | undefined;
34
+ onFill?: ((val: string) => void) | undefined;
35
+ } & NativeProps<"--cell-size" | "--cell-gap"> & React.RefAttributes<PasscodeInputRef>>;
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.PasscodeInput = void 0;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _withDefaultProps = require("../../utils/with-default-props");
11
+
12
+ var _nativeProps = require("../../utils/native-props");
13
+
14
+ var _classnames = _interopRequireDefault(require("classnames"));
15
+
16
+ var _bound = require("../../utils/bound");
17
+
18
+ var _usePropsValue2 = require("../../utils/use-props-value");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
+
22
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
+
24
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
+
26
+ var classPrefix = 'adm-passcode-input';
27
+ var defaultProps = {
28
+ defaultValue: '',
29
+ length: 6,
30
+ plain: false,
31
+ error: false,
32
+ seperated: false,
33
+ caret: true
34
+ };
35
+ var PasscodeInput = /*#__PURE__*/(0, _react.forwardRef)(function (p, ref) {
36
+ var props = (0, _withDefaultProps.mergeProps)(defaultProps, p); // 防止 length 值不合法
37
+
38
+ var cellLength = props.length > 0 && props.length < Infinity ? Math.floor(props.length) : defaultProps.length;
39
+
40
+ var _useState = (0, _react.useState)(false),
41
+ focused = _useState[0],
42
+ setFocused = _useState[1];
43
+
44
+ var _usePropsValue = (0, _usePropsValue2.usePropsValue)(props),
45
+ value = _usePropsValue[0],
46
+ setValue = _usePropsValue[1];
47
+
48
+ var rootRef = (0, _react.useRef)(null);
49
+ var nativeInputRef = (0, _react.useRef)(null);
50
+ (0, _react.useEffect)(function () {
51
+ var _a;
52
+
53
+ if (value.length >= cellLength) {
54
+ (_a = props.onFill) === null || _a === void 0 ? void 0 : _a.call(props, value);
55
+ }
56
+ }, [props.onFill, value, cellLength]);
57
+
58
+ var onFocus = function onFocus() {
59
+ var _a, _b;
60
+
61
+ if (!props.keyboard) {
62
+ (_a = nativeInputRef.current) === null || _a === void 0 ? void 0 : _a.focus();
63
+ }
64
+
65
+ setFocused(true);
66
+ (_b = props.onFocus) === null || _b === void 0 ? void 0 : _b.call(props);
67
+ };
68
+
69
+ (0, _react.useEffect)(function () {
70
+ if (!focused) return;
71
+ var timeout = window.setTimeout(function () {
72
+ var _a;
73
+
74
+ (_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.scrollIntoView({
75
+ block: 'center',
76
+ inline: 'center',
77
+ behavior: 'smooth'
78
+ });
79
+ }, 100);
80
+ return function () {
81
+ window.clearTimeout(timeout);
82
+ };
83
+ }, [focused]);
84
+
85
+ var onBlur = function onBlur() {
86
+ var _a;
87
+
88
+ setFocused(false);
89
+ (_a = props.onBlur) === null || _a === void 0 ? void 0 : _a.call(props);
90
+ };
91
+
92
+ (0, _react.useImperativeHandle)(ref, function () {
93
+ return {
94
+ focus: function focus() {
95
+ var _a;
96
+
97
+ return (_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.focus();
98
+ },
99
+ blur: function blur() {
100
+ var _a, _b;
101
+
102
+ (_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.blur();
103
+ (_b = nativeInputRef.current) === null || _b === void 0 ? void 0 : _b.blur();
104
+ }
105
+ };
106
+ });
107
+
108
+ var renderCells = function renderCells() {
109
+ var cells = [];
110
+ var chars = value.split('');
111
+ var caretIndex = chars.length; // 光标位置index等于当前文字长度
112
+
113
+ var focusedIndex = (0, _bound.bound)(chars.length, 0, cellLength - 1);
114
+
115
+ for (var i = 0; i < cellLength; i++) {
116
+ cells.push( /*#__PURE__*/_react["default"].createElement("div", {
117
+ className: (0, _classnames["default"])(classPrefix + "-cell", {
118
+ caret: props.caret && caretIndex === i && focused,
119
+ focused: focusedIndex === i && focused,
120
+ dot: !props.plain && chars[i]
121
+ }),
122
+ key: i
123
+ }, chars[i] && props.plain ? chars[i] : ''));
124
+ }
125
+
126
+ return cells;
127
+ };
128
+
129
+ var cls = (0, _classnames["default"])(classPrefix, {
130
+ focused: focused,
131
+ error: props.error,
132
+ seperated: props.seperated
133
+ });
134
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, (0, _nativeProps.withNativeProps)(props, /*#__PURE__*/_react["default"].createElement("div", {
135
+ ref: rootRef,
136
+ tabIndex: 0,
137
+ className: cls,
138
+ onFocus: onFocus,
139
+ onBlur: onBlur
140
+ }, /*#__PURE__*/_react["default"].createElement("div", {
141
+ className: classPrefix + "-cell-container"
142
+ }, renderCells()), /*#__PURE__*/_react["default"].createElement("input", {
143
+ ref: nativeInputRef,
144
+ className: classPrefix + "-native-input",
145
+ value: value,
146
+ type: 'text',
147
+ pattern: '[0-9]*',
148
+ inputMode: 'numeric',
149
+ onChange: function onChange(e) {
150
+ setValue(e.target.value.slice(0, props.length));
151
+ }
152
+ }))), props.keyboard && /*#__PURE__*/_react["default"].cloneElement(props.keyboard, {
153
+ visible: focused,
154
+ onInput: function onInput(v) {
155
+ if (value.length < cellLength) {
156
+ setValue((value + v).slice(0, props.length));
157
+ }
158
+ },
159
+ onDelete: function onDelete() {
160
+ setValue(value.slice(0, -1));
161
+ },
162
+ onClose: function onClose() {
163
+ var _a;
164
+
165
+ (_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.blur();
166
+ }
167
+ }));
168
+ });
169
+ exports.PasscodeInput = PasscodeInput;
@@ -127,6 +127,7 @@ var Picker = /*#__PURE__*/(0, _react.memo)(function (p) {
127
127
  afterShow: props.afterShow,
128
128
  afterClose: props.afterClose,
129
129
  onClick: props.onClick,
130
+ forceRender: true,
130
131
  stopPropagation: props.stopPropagation
131
132
  }, pickerElement);
132
133
 
@@ -106,14 +106,55 @@ var Column = function Column(props) {
106
106
  touch: true
107
107
  }
108
108
  });
109
+ var selectedIndex = null;
110
+
111
+ function renderAccessible() {
112
+ console.log('selectedIndex', selectedIndex);
113
+
114
+ if (selectedIndex === null) {
115
+ return null;
116
+ }
117
+
118
+ var current = column[selectedIndex];
119
+ var previousIndex = selectedIndex - 1;
120
+ var nextIndex = selectedIndex + 1;
121
+ var previous = column[previousIndex];
122
+ var next = column[nextIndex];
123
+ return /*#__PURE__*/_react["default"].createElement("div", {
124
+ className: 'adm-picker-view-column-accessible'
125
+ }, /*#__PURE__*/_react["default"].createElement("div", {
126
+ className: 'adm-picker-view-column-accessible-current',
127
+ role: 'button',
128
+ "aria-label": current ? "\u5F53\u524D\u9009\u62E9\u7684\u662F\uFF1A" + current.label : '当前未选择'
129
+ }, "-"), /*#__PURE__*/_react["default"].createElement("div", null, previous && /*#__PURE__*/_react["default"].createElement("div", {
130
+ className: 'adm-picker-view-column-accessible-button',
131
+ onClick: function onClick() {
132
+ scrollSelect(previousIndex);
133
+ },
134
+ role: 'button',
135
+ "aria-label": "\u9009\u62E9\u4E0A\u4E00\u9879\uFF1A" + previous.label
136
+ }, "-")), /*#__PURE__*/_react["default"].createElement("div", null, next && /*#__PURE__*/_react["default"].createElement("div", {
137
+ className: 'adm-picker-view-column-accessible-button',
138
+ onClick: function onClick() {
139
+ scrollSelect(nextIndex);
140
+ },
141
+ role: 'button',
142
+ "aria-label": "\u9009\u62E9\u4E0B\u4E00\u9879\uFF1A" + next.label
143
+ }, "-")));
144
+ }
145
+
109
146
  return /*#__PURE__*/_react["default"].createElement("div", Object.assign({
110
147
  className: classPrefix + "-column"
111
148
  }, bind()), /*#__PURE__*/_react["default"].createElement(_web.animated.div, {
112
149
  style: {
113
150
  y: y
114
151
  },
115
- className: classPrefix + "-column-wheel"
152
+ className: classPrefix + "-column-wheel",
153
+ "aria-hidden": true
116
154
  }, column.map(function (item, index) {
155
+ var selected = props.value === item.value;
156
+ if (selected) selectedIndex = index;
157
+
117
158
  function handleClick() {
118
159
  draggingRef.current = false;
119
160
  scrollSelect(index);
@@ -121,12 +162,15 @@ var Column = function Column(props) {
121
162
 
122
163
  return /*#__PURE__*/_react["default"].createElement("div", {
123
164
  key: item.value,
165
+ "data-selected": item.value === value,
124
166
  className: classPrefix + "-column-item",
125
- onClick: handleClick
167
+ onClick: handleClick,
168
+ "aria-hidden": !selected,
169
+ "aria-label": selected ? 'active' : ''
126
170
  }, /*#__PURE__*/_react["default"].createElement("div", {
127
171
  className: classPrefix + "-column-item-label"
128
172
  }, item.label));
129
- })));
173
+ })), renderAccessible());
130
174
  };
131
175
 
132
176
  exports.Column = Column;
@@ -13,6 +13,7 @@
13
13
  user-select: none;
14
14
  touch-action: none;
15
15
  position: relative;
16
+ z-index: 0;
16
17
  }
17
18
 
18
19
  .adm-picker-view-column-wheel {
@@ -56,22 +57,61 @@
56
57
  white-space: nowrap;
57
58
  }
58
59
 
60
+ .adm-picker-view-column-accessible {
61
+ width: 100%;
62
+ height: 100%;
63
+ pointer-events: none;
64
+ opacity: 0;
65
+ display: flex;
66
+ flex-direction: column;
67
+ position: relative;
68
+ }
69
+
70
+ .adm-picker-view-column-accessible > * {
71
+ flex: 1;
72
+ text-overflow: ellipsis;
73
+ }
74
+
75
+ .adm-picker-view-column-accessible-current {
76
+ position: absolute;
77
+ width: 100%;
78
+ height: 100%;
79
+ }
80
+
81
+ .adm-picker-view-column-accessible-button {
82
+ width: 100%;
83
+ height: 100%;
84
+ }
85
+
59
86
  .adm-picker-view-mask {
60
87
  position: absolute;
88
+ z-index: 100;
61
89
  left: 0;
90
+ top: 0;
62
91
  width: 100%;
63
- height: calc(50% - 24px);
92
+ height: 100%;
93
+ display: flex;
94
+ flex-direction: column;
64
95
  pointer-events: none;
65
96
  }
66
97
 
67
- .adm-picker-view-mask-top {
68
- top: -10px;
98
+ .adm-picker-view-mask-top,
99
+ .adm-picker-view-mask-bottom {
100
+ flex: auto;
101
+ }
102
+
103
+ .adm-picker-view-mask-middle {
104
+ height: 68px;
105
+ box-sizing: border-box;
106
+ flex: none;
107
+ border-top: solid 2px var(--adm-border-color);
69
108
  border-bottom: solid 2px var(--adm-border-color);
109
+ }
110
+
111
+ .adm-picker-view-mask-top {
70
112
  background: linear-gradient(0deg, rgba(255, 255, 255, 0.7) 50%, #ffffff);
71
113
  }
72
114
 
73
115
  .adm-picker-view-mask-bottom {
74
- bottom: -10px;
75
- border-top: solid 2px var(--adm-border-color);
76
116
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.7) 50%, #ffffff);
77
117
  }