@arco-design/mobile-react 2.31.6 → 2.33.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (885) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/LICENSE +21 -0
  3. package/README.en-US.md +2 -2
  4. package/README.md +2 -2
  5. package/cjs/_helpers/index.d.ts +1 -0
  6. package/cjs/_helpers/index.js +9 -0
  7. package/cjs/_helpers/react-dom.js +18 -10
  8. package/cjs/avatar/index.js +3 -1
  9. package/cjs/avatar/type.d.ts +6 -0
  10. package/cjs/carousel/index.js +18 -1
  11. package/cjs/steps/index.d.ts +1 -1
  12. package/cjs/steps/index.js +6 -1
  13. package/cjs/steps/style/css/index.css +42 -4
  14. package/cjs/steps/style/index.less +58 -6
  15. package/cjs/steps/type.d.ts +5 -0
  16. package/dist/index.js +146 -97
  17. package/dist/index.min.js +4 -4
  18. package/dist/style.css +27 -4
  19. package/dist/style.min.css +1 -1
  20. package/esm/_helpers/index.d.ts +1 -0
  21. package/esm/_helpers/index.js +1 -0
  22. package/esm/_helpers/react-dom.js +15 -11
  23. package/esm/avatar/index.js +3 -1
  24. package/esm/avatar/type.d.ts +6 -0
  25. package/esm/carousel/index.js +18 -1
  26. package/esm/steps/index.d.ts +1 -1
  27. package/esm/steps/index.js +7 -2
  28. package/esm/steps/style/css/index.css +42 -4
  29. package/esm/steps/style/index.less +58 -6
  30. package/esm/steps/type.d.ts +5 -0
  31. package/esnext/_helpers/hooks.d.ts +290 -0
  32. package/esnext/_helpers/hooks.js +660 -0
  33. package/esnext/_helpers/index.d.ts +93 -0
  34. package/esnext/_helpers/index.js +110 -0
  35. package/esnext/_helpers/react-dom.d.ts +13 -0
  36. package/esnext/_helpers/react-dom.js +51 -0
  37. package/esnext/_helpers/render.d.ts +17 -0
  38. package/esnext/_helpers/render.js +38 -0
  39. package/esnext/_helpers/type.d.ts +30 -0
  40. package/esnext/_helpers/type.js +1 -0
  41. package/esnext/action-sheet/index.d.ts +106 -0
  42. package/esnext/action-sheet/index.js +53 -0
  43. package/esnext/action-sheet/methods.d.ts +10 -0
  44. package/esnext/action-sheet/methods.js +4 -0
  45. package/esnext/action-sheet/style/css/index.css +741 -0
  46. package/esnext/action-sheet/style/css/index.d.ts +3 -0
  47. package/esnext/action-sheet/style/css/index.js +3 -0
  48. package/esnext/action-sheet/style/index.d.ts +3 -0
  49. package/esnext/action-sheet/style/index.js +3 -0
  50. package/esnext/action-sheet/style/index.less +119 -0
  51. package/esnext/avatar/group.d.ts +9 -0
  52. package/esnext/avatar/group.js +35 -0
  53. package/esnext/avatar/index.d.ts +17 -0
  54. package/esnext/avatar/index.js +87 -0
  55. package/esnext/avatar/style/css/index.css +792 -0
  56. package/esnext/avatar/style/css/index.d.ts +3 -0
  57. package/esnext/avatar/style/css/index.js +3 -0
  58. package/esnext/avatar/style/index.d.ts +3 -0
  59. package/esnext/avatar/style/index.js +3 -0
  60. package/esnext/avatar/style/index.less +201 -0
  61. package/esnext/avatar/type.d.ts +132 -0
  62. package/esnext/avatar/type.js +1 -0
  63. package/esnext/badge/index.d.ts +80 -0
  64. package/esnext/badge/index.js +29 -0
  65. package/esnext/badge/style/css/index.css +640 -0
  66. package/esnext/badge/style/css/index.d.ts +2 -0
  67. package/esnext/badge/style/css/index.js +2 -0
  68. package/esnext/badge/style/index.d.ts +2 -0
  69. package/esnext/badge/style/index.js +2 -0
  70. package/esnext/badge/style/index.less +109 -0
  71. package/esnext/button/hooks.d.ts +8 -0
  72. package/esnext/button/hooks.js +45 -0
  73. package/esnext/button/index.d.ts +141 -0
  74. package/esnext/button/index.js +61 -0
  75. package/esnext/button/style/css/index.css +816 -0
  76. package/esnext/button/style/css/index.d.ts +3 -0
  77. package/esnext/button/style/css/index.js +3 -0
  78. package/esnext/button/style/index.d.ts +3 -0
  79. package/esnext/button/style/index.js +3 -0
  80. package/esnext/button/style/index.less +242 -0
  81. package/esnext/carousel/index.d.ts +383 -0
  82. package/esnext/carousel/index.js +849 -0
  83. package/esnext/carousel/style/css/index.css +748 -0
  84. package/esnext/carousel/style/css/index.d.ts +2 -0
  85. package/esnext/carousel/style/css/index.js +2 -0
  86. package/esnext/carousel/style/index.d.ts +2 -0
  87. package/esnext/carousel/style/index.js +2 -0
  88. package/esnext/carousel/style/index.less +263 -0
  89. package/esnext/cell/arrow.d.ts +2 -0
  90. package/esnext/cell/arrow.js +5 -0
  91. package/esnext/cell/cell.d.ts +3 -0
  92. package/esnext/cell/cell.js +24 -0
  93. package/esnext/cell/group.d.ts +7 -0
  94. package/esnext/cell/group.js +26 -0
  95. package/esnext/cell/index.d.ts +14 -0
  96. package/esnext/cell/index.js +16 -0
  97. package/esnext/cell/style/css/index.css +1008 -0
  98. package/esnext/cell/style/css/index.d.ts +2 -0
  99. package/esnext/cell/style/css/index.js +2 -0
  100. package/esnext/cell/style/index.d.ts +2 -0
  101. package/esnext/cell/style/index.js +2 -0
  102. package/esnext/cell/style/index.less +214 -0
  103. package/esnext/cell/type.d.ts +125 -0
  104. package/esnext/cell/type.js +1 -0
  105. package/esnext/checkbox/checkbox.d.ts +3 -0
  106. package/esnext/checkbox/checkbox.js +106 -0
  107. package/esnext/checkbox/group.d.ts +4 -0
  108. package/esnext/checkbox/group.js +54 -0
  109. package/esnext/checkbox/hooks/index.d.ts +1 -0
  110. package/esnext/checkbox/hooks/index.js +1 -0
  111. package/esnext/checkbox/hooks/useMergeProps.d.ts +3 -0
  112. package/esnext/checkbox/hooks/useMergeProps.js +20 -0
  113. package/esnext/checkbox/index.d.ts +19 -0
  114. package/esnext/checkbox/index.js +22 -0
  115. package/esnext/checkbox/style/css/index.css +613 -0
  116. package/esnext/checkbox/style/css/index.d.ts +2 -0
  117. package/esnext/checkbox/style/css/index.js +2 -0
  118. package/esnext/checkbox/style/index.d.ts +2 -0
  119. package/esnext/checkbox/style/index.js +2 -0
  120. package/esnext/checkbox/style/index.less +119 -0
  121. package/esnext/checkbox/type.d.ts +162 -0
  122. package/esnext/checkbox/type.js +27 -0
  123. package/esnext/circle-progress/index.d.ts +141 -0
  124. package/esnext/circle-progress/index.js +75 -0
  125. package/esnext/circle-progress/style/css/index.css +582 -0
  126. package/esnext/circle-progress/style/css/index.d.ts +2 -0
  127. package/esnext/circle-progress/style/css/index.js +2 -0
  128. package/esnext/circle-progress/style/index.d.ts +2 -0
  129. package/esnext/circle-progress/style/index.js +2 -0
  130. package/esnext/circle-progress/style/index.less +101 -0
  131. package/esnext/collapse/collapse.d.ts +3 -0
  132. package/esnext/collapse/collapse.js +111 -0
  133. package/esnext/collapse/group.d.ts +21 -0
  134. package/esnext/collapse/group.js +80 -0
  135. package/esnext/collapse/index.d.ts +23 -0
  136. package/esnext/collapse/index.js +14 -0
  137. package/esnext/collapse/style/css/index.css +662 -0
  138. package/esnext/collapse/style/css/index.d.ts +2 -0
  139. package/esnext/collapse/style/css/index.js +2 -0
  140. package/esnext/collapse/style/index.d.ts +2 -0
  141. package/esnext/collapse/style/index.js +2 -0
  142. package/esnext/collapse/style/index.less +106 -0
  143. package/esnext/collapse/type.d.ts +139 -0
  144. package/esnext/collapse/type.js +1 -0
  145. package/esnext/collapse/utils.d.ts +8 -0
  146. package/esnext/collapse/utils.js +16 -0
  147. package/esnext/context-provider/index.d.ts +74 -0
  148. package/esnext/context-provider/index.js +99 -0
  149. package/esnext/context-provider/style/css/index.css +0 -0
  150. package/esnext/context-provider/style/css/index.d.ts +2 -0
  151. package/esnext/context-provider/style/css/index.js +2 -0
  152. package/esnext/context-provider/style/index.d.ts +2 -0
  153. package/esnext/context-provider/style/index.js +2 -0
  154. package/esnext/context-provider/style/index.less +1 -0
  155. package/esnext/count-down/hooks.d.ts +10 -0
  156. package/esnext/count-down/hooks.js +107 -0
  157. package/esnext/count-down/index.d.ts +13 -0
  158. package/esnext/count-down/index.js +37 -0
  159. package/esnext/count-down/singleton.d.ts +15 -0
  160. package/esnext/count-down/singleton.js +52 -0
  161. package/esnext/count-down/style/css/index.css +534 -0
  162. package/esnext/count-down/style/css/index.d.ts +2 -0
  163. package/esnext/count-down/style/css/index.js +2 -0
  164. package/esnext/count-down/style/index.d.ts +2 -0
  165. package/esnext/count-down/style/index.js +2 -0
  166. package/esnext/count-down/style/index.less +37 -0
  167. package/esnext/count-down/type.d.ts +112 -0
  168. package/esnext/count-down/type.js +1 -0
  169. package/esnext/count-down/util.d.ts +8 -0
  170. package/esnext/count-down/util.js +106 -0
  171. package/esnext/date-picker/helper.d.ts +5 -0
  172. package/esnext/date-picker/helper.js +38 -0
  173. package/esnext/date-picker/index.d.ts +24 -0
  174. package/esnext/date-picker/index.js +217 -0
  175. package/esnext/date-picker/style/css/index.css +526 -0
  176. package/esnext/date-picker/style/css/index.d.ts +3 -0
  177. package/esnext/date-picker/style/css/index.js +3 -0
  178. package/esnext/date-picker/style/index.d.ts +3 -0
  179. package/esnext/date-picker/style/index.js +3 -0
  180. package/esnext/date-picker/style/index.less +30 -0
  181. package/esnext/date-picker/type.d.ts +114 -0
  182. package/esnext/date-picker/type.js +1 -0
  183. package/esnext/dialog/index.d.ts +213 -0
  184. package/esnext/dialog/index.js +87 -0
  185. package/esnext/dialog/methods.d.ts +20 -0
  186. package/esnext/dialog/methods.js +42 -0
  187. package/esnext/dialog/style/css/index.css +1111 -0
  188. package/esnext/dialog/style/css/index.d.ts +3 -0
  189. package/esnext/dialog/style/css/index.js +3 -0
  190. package/esnext/dialog/style/index.d.ts +3 -0
  191. package/esnext/dialog/style/index.js +3 -0
  192. package/esnext/dialog/style/index.less +376 -0
  193. package/esnext/divider/index.d.ts +49 -0
  194. package/esnext/divider/index.js +32 -0
  195. package/esnext/divider/style/css/index.css +609 -0
  196. package/esnext/divider/style/css/index.d.ts +2 -0
  197. package/esnext/divider/style/css/index.js +2 -0
  198. package/esnext/divider/style/index.d.ts +2 -0
  199. package/esnext/divider/style/index.js +2 -0
  200. package/esnext/divider/style/index.less +101 -0
  201. package/esnext/dropdown/dropdown.d.ts +3 -0
  202. package/esnext/dropdown/dropdown.js +196 -0
  203. package/esnext/dropdown/index.d.ts +14 -0
  204. package/esnext/dropdown/index.js +16 -0
  205. package/esnext/dropdown/options.d.ts +4 -0
  206. package/esnext/dropdown/options.js +61 -0
  207. package/esnext/dropdown/style/css/index.css +653 -0
  208. package/esnext/dropdown/style/css/index.d.ts +2 -0
  209. package/esnext/dropdown/style/css/index.js +2 -0
  210. package/esnext/dropdown/style/index.d.ts +2 -0
  211. package/esnext/dropdown/style/index.js +2 -0
  212. package/esnext/dropdown/style/index.less +177 -0
  213. package/esnext/dropdown/type.d.ts +269 -0
  214. package/esnext/dropdown/type.js +1 -0
  215. package/esnext/dropdown-menu/dropdown-menu.d.ts +4 -0
  216. package/esnext/dropdown-menu/dropdown-menu.js +161 -0
  217. package/esnext/dropdown-menu/helper.d.ts +34 -0
  218. package/esnext/dropdown-menu/helper.js +88 -0
  219. package/esnext/dropdown-menu/index.d.ts +12 -0
  220. package/esnext/dropdown-menu/index.js +13 -0
  221. package/esnext/dropdown-menu/style/css/index.css +705 -0
  222. package/esnext/dropdown-menu/style/css/index.d.ts +3 -0
  223. package/esnext/dropdown-menu/style/css/index.js +3 -0
  224. package/esnext/dropdown-menu/style/index.d.ts +3 -0
  225. package/esnext/dropdown-menu/style/index.js +3 -0
  226. package/esnext/dropdown-menu/style/index.less +122 -0
  227. package/esnext/dropdown-menu/type.d.ts +168 -0
  228. package/esnext/dropdown-menu/type.js +1 -0
  229. package/esnext/ellipsis/components/js-ellipsis.d.ts +6 -0
  230. package/esnext/ellipsis/components/js-ellipsis.js +178 -0
  231. package/esnext/ellipsis/components/native-ellipsis.d.ts +5 -0
  232. package/esnext/ellipsis/components/native-ellipsis.js +15 -0
  233. package/esnext/ellipsis/index.d.ts +13 -0
  234. package/esnext/ellipsis/index.js +31 -0
  235. package/esnext/ellipsis/style/css/index.css +556 -0
  236. package/esnext/ellipsis/style/css/index.d.ts +2 -0
  237. package/esnext/ellipsis/style/css/index.js +2 -0
  238. package/esnext/ellipsis/style/index.d.ts +2 -0
  239. package/esnext/ellipsis/style/index.js +2 -0
  240. package/esnext/ellipsis/style/index.less +63 -0
  241. package/esnext/ellipsis/type.d.ts +107 -0
  242. package/esnext/ellipsis/type.js +1 -0
  243. package/esnext/ellipsis/utils/dom.d.ts +2 -0
  244. package/esnext/ellipsis/utils/dom.js +35 -0
  245. package/esnext/ellipsis/utils/is.d.ts +3 -0
  246. package/esnext/ellipsis/utils/is.js +3 -0
  247. package/esnext/form/form-item-context.d.ts +3 -0
  248. package/esnext/form/form-item-context.js +6 -0
  249. package/esnext/form/form-item.d.ts +4 -0
  250. package/esnext/form/form-item.js +218 -0
  251. package/esnext/form/index.d.ts +16 -0
  252. package/esnext/form/index.js +50 -0
  253. package/esnext/form/linked-container.d.ts +8 -0
  254. package/esnext/form/linked-container.js +29 -0
  255. package/esnext/form/style/css/index.css +670 -0
  256. package/esnext/form/style/css/index.d.ts +2 -0
  257. package/esnext/form/style/css/index.js +2 -0
  258. package/esnext/form/style/index.d.ts +2 -0
  259. package/esnext/form/style/index.js +2 -0
  260. package/esnext/form/style/index.less +172 -0
  261. package/esnext/form/type.d.ts +373 -0
  262. package/esnext/form/type.js +26 -0
  263. package/esnext/form/useForm.d.ts +18 -0
  264. package/esnext/form/useForm.js +203 -0
  265. package/esnext/form/utils.d.ts +7 -0
  266. package/esnext/form/utils.js +21 -0
  267. package/esnext/grid/index.d.ts +112 -0
  268. package/esnext/grid/index.js +79 -0
  269. package/esnext/grid/style/css/index.css +661 -0
  270. package/esnext/grid/style/css/index.d.ts +2 -0
  271. package/esnext/grid/style/css/index.js +2 -0
  272. package/esnext/grid/style/index.d.ts +2 -0
  273. package/esnext/grid/style/index.js +2 -0
  274. package/esnext/grid/style/index.less +157 -0
  275. package/esnext/icon/IconAdd/index.d.ts +7 -0
  276. package/esnext/icon/IconAdd/index.js +7 -0
  277. package/esnext/icon/IconArrowBack/index.d.ts +7 -0
  278. package/esnext/icon/IconArrowBack/index.js +7 -0
  279. package/esnext/icon/IconArrowDown/index.d.ts +7 -0
  280. package/esnext/icon/IconArrowDown/index.js +7 -0
  281. package/esnext/icon/IconArrowIn/index.d.ts +7 -0
  282. package/esnext/icon/IconArrowIn/index.js +7 -0
  283. package/esnext/icon/IconArrowUp/index.d.ts +7 -0
  284. package/esnext/icon/IconArrowUp/index.js +7 -0
  285. package/esnext/icon/IconCheck/index.d.ts +7 -0
  286. package/esnext/icon/IconCheck/index.js +7 -0
  287. package/esnext/icon/IconCheckBold/index.d.ts +7 -0
  288. package/esnext/icon/IconCheckBold/index.js +8 -0
  289. package/esnext/icon/IconCircleChecked/index.d.ts +7 -0
  290. package/esnext/icon/IconCircleChecked/index.js +7 -0
  291. package/esnext/icon/IconCircleDisabled/index.d.ts +7 -0
  292. package/esnext/icon/IconCircleDisabled/index.js +7 -0
  293. package/esnext/icon/IconCircleUnchecked/index.d.ts +7 -0
  294. package/esnext/icon/IconCircleUnchecked/index.js +7 -0
  295. package/esnext/icon/IconClear/index.d.ts +7 -0
  296. package/esnext/icon/IconClear/index.js +7 -0
  297. package/esnext/icon/IconClose/index.d.ts +7 -0
  298. package/esnext/icon/IconClose/index.js +7 -0
  299. package/esnext/icon/IconCloseBold/index.d.ts +7 -0
  300. package/esnext/icon/IconCloseBold/index.js +8 -0
  301. package/esnext/icon/IconDelete/index.d.ts +7 -0
  302. package/esnext/icon/IconDelete/index.js +7 -0
  303. package/esnext/icon/IconDownload/index.d.ts +7 -0
  304. package/esnext/icon/IconDownload/index.js +7 -0
  305. package/esnext/icon/IconEdit/index.d.ts +7 -0
  306. package/esnext/icon/IconEdit/index.js +7 -0
  307. package/esnext/icon/IconErrorCircle/index.d.ts +7 -0
  308. package/esnext/icon/IconErrorCircle/index.js +8 -0
  309. package/esnext/icon/IconEyeInvisible/index.d.ts +7 -0
  310. package/esnext/icon/IconEyeInvisible/index.js +7 -0
  311. package/esnext/icon/IconEyeVisible/index.d.ts +7 -0
  312. package/esnext/icon/IconEyeVisible/index.js +7 -0
  313. package/esnext/icon/IconEyelashInvisible/index.d.ts +7 -0
  314. package/esnext/icon/IconEyelashInvisible/index.js +7 -0
  315. package/esnext/icon/IconFile/index.d.ts +7 -0
  316. package/esnext/icon/IconFile/index.js +7 -0
  317. package/esnext/icon/IconGift/index.d.ts +7 -0
  318. package/esnext/icon/IconGift/index.js +8 -0
  319. package/esnext/icon/IconHeart/index.d.ts +7 -0
  320. package/esnext/icon/IconHeart/index.js +8 -0
  321. package/esnext/icon/IconHome/index.d.ts +7 -0
  322. package/esnext/icon/IconHome/index.js +7 -0
  323. package/esnext/icon/IconKeyboard/index.d.ts +7 -0
  324. package/esnext/icon/IconKeyboard/index.js +8 -0
  325. package/esnext/icon/IconKeyboardDelete/index.d.ts +7 -0
  326. package/esnext/icon/IconKeyboardDelete/index.js +8 -0
  327. package/esnext/icon/IconLikeCircle/index.d.ts +7 -0
  328. package/esnext/icon/IconLikeCircle/index.js +7 -0
  329. package/esnext/icon/IconMinus/index.d.ts +7 -0
  330. package/esnext/icon/IconMinus/index.js +8 -0
  331. package/esnext/icon/IconMore/index.d.ts +7 -0
  332. package/esnext/icon/IconMore/index.js +7 -0
  333. package/esnext/icon/IconNotice/index.d.ts +7 -0
  334. package/esnext/icon/IconNotice/index.js +8 -0
  335. package/esnext/icon/IconNoticeOff/index.d.ts +7 -0
  336. package/esnext/icon/IconNoticeOff/index.js +8 -0
  337. package/esnext/icon/IconPicture/index.d.ts +7 -0
  338. package/esnext/icon/IconPicture/index.js +7 -0
  339. package/esnext/icon/IconPlay/index.d.ts +7 -0
  340. package/esnext/icon/IconPlay/index.js +8 -0
  341. package/esnext/icon/IconQuestionCircle/index.d.ts +7 -0
  342. package/esnext/icon/IconQuestionCircle/index.js +7 -0
  343. package/esnext/icon/IconRefresh/index.d.ts +7 -0
  344. package/esnext/icon/IconRefresh/index.js +7 -0
  345. package/esnext/icon/IconSad/index.d.ts +7 -0
  346. package/esnext/icon/IconSad/index.js +7 -0
  347. package/esnext/icon/IconScan/index.d.ts +7 -0
  348. package/esnext/icon/IconScan/index.js +7 -0
  349. package/esnext/icon/IconSearch/index.d.ts +7 -0
  350. package/esnext/icon/IconSearch/index.js +7 -0
  351. package/esnext/icon/IconSetting/index.d.ts +7 -0
  352. package/esnext/icon/IconSetting/index.js +8 -0
  353. package/esnext/icon/IconShop/index.d.ts +7 -0
  354. package/esnext/icon/IconShop/index.js +8 -0
  355. package/esnext/icon/IconShopping/index.d.ts +7 -0
  356. package/esnext/icon/IconShopping/index.js +8 -0
  357. package/esnext/icon/IconSmileFill/index.d.ts +7 -0
  358. package/esnext/icon/IconSmileFill/index.js +7 -0
  359. package/esnext/icon/IconSound/index.d.ts +7 -0
  360. package/esnext/icon/IconSound/index.js +8 -0
  361. package/esnext/icon/IconSquareChecked/index.d.ts +7 -0
  362. package/esnext/icon/IconSquareChecked/index.js +7 -0
  363. package/esnext/icon/IconSquareDisabled/index.d.ts +7 -0
  364. package/esnext/icon/IconSquareDisabled/index.js +7 -0
  365. package/esnext/icon/IconSquareUnchecked/index.d.ts +7 -0
  366. package/esnext/icon/IconSquareUnchecked/index.js +7 -0
  367. package/esnext/icon/IconStar/index.d.ts +7 -0
  368. package/esnext/icon/IconStar/index.js +7 -0
  369. package/esnext/icon/IconStarFill/index.d.ts +7 -0
  370. package/esnext/icon/IconStarFill/index.js +8 -0
  371. package/esnext/icon/IconStarHalf/index.d.ts +7 -0
  372. package/esnext/icon/IconStarHalf/index.js +7 -0
  373. package/esnext/icon/IconSubway/index.d.ts +7 -0
  374. package/esnext/icon/IconSubway/index.js +8 -0
  375. package/esnext/icon/IconSuccessCircle/index.d.ts +7 -0
  376. package/esnext/icon/IconSuccessCircle/index.js +8 -0
  377. package/esnext/icon/IconTriDown/index.d.ts +7 -0
  378. package/esnext/icon/IconTriDown/index.js +8 -0
  379. package/esnext/icon/IconTriUp/index.d.ts +7 -0
  380. package/esnext/icon/IconTriUp/index.js +8 -0
  381. package/esnext/icon/IconUpload/index.d.ts +7 -0
  382. package/esnext/icon/IconUpload/index.js +7 -0
  383. package/esnext/icon/IconUser/index.d.ts +7 -0
  384. package/esnext/icon/IconUser/index.js +7 -0
  385. package/esnext/icon/IconUserFill/index.d.ts +7 -0
  386. package/esnext/icon/IconUserFill/index.js +7 -0
  387. package/esnext/icon/IconWarnCircle/index.d.ts +7 -0
  388. package/esnext/icon/IconWarnCircle/index.js +8 -0
  389. package/esnext/icon/IconWarnCircleFill/index.d.ts +7 -0
  390. package/esnext/icon/IconWarnCircleFill/index.js +8 -0
  391. package/esnext/icon/index.d.ts +59 -0
  392. package/esnext/icon/index.js +59 -0
  393. package/esnext/icon/type.d.ts +10 -0
  394. package/esnext/icon/type.js +1 -0
  395. package/esnext/image/index.d.ts +186 -0
  396. package/esnext/image/index.js +223 -0
  397. package/esnext/image/style/css/index.css +734 -0
  398. package/esnext/image/style/css/index.d.ts +3 -0
  399. package/esnext/image/style/css/index.js +3 -0
  400. package/esnext/image/style/index.d.ts +3 -0
  401. package/esnext/image/style/index.js +3 -0
  402. package/esnext/image/style/index.less +198 -0
  403. package/esnext/image-picker/add-icon.d.ts +2 -0
  404. package/esnext/image-picker/add-icon.js +5 -0
  405. package/esnext/image-picker/index.d.ts +16 -0
  406. package/esnext/image-picker/index.js +77 -0
  407. package/esnext/image-picker/style/css/index.css +688 -0
  408. package/esnext/image-picker/style/css/index.d.ts +4 -0
  409. package/esnext/image-picker/style/css/index.js +4 -0
  410. package/esnext/image-picker/style/index.d.ts +4 -0
  411. package/esnext/image-picker/style/index.js +4 -0
  412. package/esnext/image-picker/style/index.less +170 -0
  413. package/esnext/image-picker/type.d.ts +115 -0
  414. package/esnext/image-picker/type.js +1 -0
  415. package/esnext/image-preview/index.d.ts +296 -0
  416. package/esnext/image-preview/index.js +794 -0
  417. package/esnext/image-preview/methods.d.ts +13 -0
  418. package/esnext/image-preview/methods.js +46 -0
  419. package/esnext/image-preview/style/css/index.css +664 -0
  420. package/esnext/image-preview/style/css/index.d.ts +5 -0
  421. package/esnext/image-preview/style/css/index.js +5 -0
  422. package/esnext/image-preview/style/index.d.ts +5 -0
  423. package/esnext/image-preview/style/index.js +5 -0
  424. package/esnext/image-preview/style/index.less +140 -0
  425. package/esnext/index-bar/context.d.ts +3 -0
  426. package/esnext/index-bar/context.js +6 -0
  427. package/esnext/index-bar/group.d.ts +3 -0
  428. package/esnext/index-bar/group.js +33 -0
  429. package/esnext/index-bar/index.d.ts +15 -0
  430. package/esnext/index-bar/index.js +151 -0
  431. package/esnext/index-bar/side-bar.d.ts +3 -0
  432. package/esnext/index-bar/side-bar.js +44 -0
  433. package/esnext/index-bar/style/css/index.css +767 -0
  434. package/esnext/index-bar/style/css/index.d.ts +3 -0
  435. package/esnext/index-bar/style/css/index.js +3 -0
  436. package/esnext/index-bar/style/index.d.ts +3 -0
  437. package/esnext/index-bar/style/index.js +3 -0
  438. package/esnext/index-bar/style/index.less +189 -0
  439. package/esnext/index-bar/type.d.ts +195 -0
  440. package/esnext/index-bar/type.js +1 -0
  441. package/esnext/index-bar/utils.d.ts +6 -0
  442. package/esnext/index-bar/utils.js +44 -0
  443. package/esnext/index.d.ts +59 -0
  444. package/esnext/index.js +59 -0
  445. package/esnext/input/hooks.d.ts +14 -0
  446. package/esnext/input/hooks.js +174 -0
  447. package/esnext/input/index.d.ts +60 -0
  448. package/esnext/input/index.js +28 -0
  449. package/esnext/input/props.d.ts +182 -0
  450. package/esnext/input/props.js +1 -0
  451. package/esnext/input/style/css/index.css +759 -0
  452. package/esnext/input/style/css/index.d.ts +2 -0
  453. package/esnext/input/style/css/index.js +2 -0
  454. package/esnext/input/style/index.d.ts +2 -0
  455. package/esnext/input/style/index.js +2 -0
  456. package/esnext/input/style/index.less +195 -0
  457. package/esnext/keyboard/index.d.ts +13 -0
  458. package/esnext/keyboard/index.js +159 -0
  459. package/esnext/keyboard/style/css/index.css +633 -0
  460. package/esnext/keyboard/style/css/index.d.ts +3 -0
  461. package/esnext/keyboard/style/css/index.js +3 -0
  462. package/esnext/keyboard/style/index.d.ts +3 -0
  463. package/esnext/keyboard/style/index.js +3 -0
  464. package/esnext/keyboard/style/index.less +131 -0
  465. package/esnext/keyboard/type.d.ts +102 -0
  466. package/esnext/keyboard/type.js +1 -0
  467. package/esnext/load-more/index.d.ts +158 -0
  468. package/esnext/load-more/index.js +150 -0
  469. package/esnext/load-more/style/css/index.css +534 -0
  470. package/esnext/load-more/style/css/index.d.ts +2 -0
  471. package/esnext/load-more/style/css/index.js +2 -0
  472. package/esnext/load-more/style/index.d.ts +2 -0
  473. package/esnext/load-more/style/index.js +2 -0
  474. package/esnext/load-more/style/index.less +37 -0
  475. package/esnext/loading/index.d.ts +76 -0
  476. package/esnext/loading/index.js +123 -0
  477. package/esnext/loading/style/css/index.css +648 -0
  478. package/esnext/loading/style/css/index.d.ts +2 -0
  479. package/esnext/loading/style/css/index.js +2 -0
  480. package/esnext/loading/style/index.d.ts +2 -0
  481. package/esnext/loading/style/index.js +2 -0
  482. package/esnext/loading/style/index.less +147 -0
  483. package/esnext/masking/index.d.ts +225 -0
  484. package/esnext/masking/index.js +114 -0
  485. package/esnext/masking/methods.d.ts +23 -0
  486. package/esnext/masking/methods.js +56 -0
  487. package/esnext/masking/style/css/index.css +552 -0
  488. package/esnext/masking/style/css/index.d.ts +3 -0
  489. package/esnext/masking/style/css/index.js +3 -0
  490. package/esnext/masking/style/index.d.ts +3 -0
  491. package/esnext/masking/style/index.js +3 -0
  492. package/esnext/masking/style/index.less +55 -0
  493. package/esnext/nav-bar/back-icon.d.ts +5 -0
  494. package/esnext/nav-bar/back-icon.js +9 -0
  495. package/esnext/nav-bar/index.d.ts +135 -0
  496. package/esnext/nav-bar/index.js +96 -0
  497. package/esnext/nav-bar/style/css/index.css +706 -0
  498. package/esnext/nav-bar/style/css/index.d.ts +2 -0
  499. package/esnext/nav-bar/style/css/index.js +2 -0
  500. package/esnext/nav-bar/style/index.d.ts +2 -0
  501. package/esnext/nav-bar/style/index.js +2 -0
  502. package/esnext/nav-bar/style/index.less +150 -0
  503. package/esnext/notice-bar/index.d.ts +107 -0
  504. package/esnext/notice-bar/index.js +126 -0
  505. package/esnext/notice-bar/style/css/index.css +685 -0
  506. package/esnext/notice-bar/style/css/index.d.ts +2 -0
  507. package/esnext/notice-bar/style/css/index.js +2 -0
  508. package/esnext/notice-bar/style/index.d.ts +2 -0
  509. package/esnext/notice-bar/style/index.js +2 -0
  510. package/esnext/notice-bar/style/index.less +160 -0
  511. package/esnext/notify/index.d.ts +97 -0
  512. package/esnext/notify/index.js +123 -0
  513. package/esnext/notify/methods.d.ts +14 -0
  514. package/esnext/notify/methods.js +63 -0
  515. package/esnext/notify/style/css/index.css +591 -0
  516. package/esnext/notify/style/css/index.d.ts +2 -0
  517. package/esnext/notify/style/css/index.js +2 -0
  518. package/esnext/notify/style/index.d.ts +2 -0
  519. package/esnext/notify/style/index.js +2 -0
  520. package/esnext/notify/style/index.less +90 -0
  521. package/esnext/notify/type.d.ts +70 -0
  522. package/esnext/notify/type.js +1 -0
  523. package/esnext/pagination/arrow.d.ts +2 -0
  524. package/esnext/pagination/arrow.js +5 -0
  525. package/esnext/pagination/index.d.ts +124 -0
  526. package/esnext/pagination/index.js +104 -0
  527. package/esnext/pagination/style/css/index.css +708 -0
  528. package/esnext/pagination/style/css/index.d.ts +2 -0
  529. package/esnext/pagination/style/css/index.js +2 -0
  530. package/esnext/pagination/style/index.d.ts +2 -0
  531. package/esnext/pagination/style/index.js +2 -0
  532. package/esnext/pagination/style/index.less +176 -0
  533. package/esnext/picker/index.d.ts +50 -0
  534. package/esnext/picker/index.js +93 -0
  535. package/esnext/picker/style/css/index.css +592 -0
  536. package/esnext/picker/style/css/index.d.ts +4 -0
  537. package/esnext/picker/style/css/index.js +4 -0
  538. package/esnext/picker/style/index.d.ts +4 -0
  539. package/esnext/picker/style/index.js +4 -0
  540. package/esnext/picker/style/index.less +95 -0
  541. package/esnext/picker/type.d.ts +131 -0
  542. package/esnext/picker/type.js +1 -0
  543. package/esnext/picker-view/components/cascader.d.ts +25 -0
  544. package/esnext/picker-view/components/cascader.js +54 -0
  545. package/esnext/picker-view/components/multi-picker.d.ts +11 -0
  546. package/esnext/picker-view/components/multi-picker.js +32 -0
  547. package/esnext/picker-view/components/picker-cell.d.ts +28 -0
  548. package/esnext/picker-view/components/picker-cell.js +284 -0
  549. package/esnext/picker-view/index.d.ts +62 -0
  550. package/esnext/picker-view/index.js +135 -0
  551. package/esnext/picker-view/style/css/index.css +750 -0
  552. package/esnext/picker-view/style/css/index.d.ts +2 -0
  553. package/esnext/picker-view/style/css/index.js +2 -0
  554. package/esnext/picker-view/style/index.d.ts +2 -0
  555. package/esnext/picker-view/style/index.js +2 -0
  556. package/esnext/picker-view/style/index.less +125 -0
  557. package/esnext/picker-view/type.d.ts +89 -0
  558. package/esnext/picker-view/type.js +1 -0
  559. package/esnext/popover/hooks/index.d.ts +2 -0
  560. package/esnext/popover/hooks/index.js +2 -0
  561. package/esnext/popover/hooks/useEvent.d.ts +8 -0
  562. package/esnext/popover/hooks/useEvent.js +148 -0
  563. package/esnext/popover/hooks/usePosition.d.ts +18 -0
  564. package/esnext/popover/hooks/usePosition.js +419 -0
  565. package/esnext/popover/index.d.ts +14 -0
  566. package/esnext/popover/index.js +20 -0
  567. package/esnext/popover/menu.d.ts +3 -0
  568. package/esnext/popover/menu.js +80 -0
  569. package/esnext/popover/popover-inner.d.ts +3 -0
  570. package/esnext/popover/popover-inner.js +79 -0
  571. package/esnext/popover/popover.d.ts +3 -0
  572. package/esnext/popover/popover.js +132 -0
  573. package/esnext/popover/style/css/index.css +993 -0
  574. package/esnext/popover/style/css/index.d.ts +3 -0
  575. package/esnext/popover/style/css/index.js +3 -0
  576. package/esnext/popover/style/css/menu.css +673 -0
  577. package/esnext/popover/style/index.d.ts +3 -0
  578. package/esnext/popover/style/index.js +3 -0
  579. package/esnext/popover/style/index.less +353 -0
  580. package/esnext/popover/style/menu.less +163 -0
  581. package/esnext/popover/type.d.ts +447 -0
  582. package/esnext/popover/type.js +1 -0
  583. package/esnext/popup/index.d.ts +86 -0
  584. package/esnext/popup/index.js +39 -0
  585. package/esnext/popup/methods.d.ts +10 -0
  586. package/esnext/popup/methods.js +4 -0
  587. package/esnext/popup/style/css/index.css +638 -0
  588. package/esnext/popup/style/css/index.d.ts +3 -0
  589. package/esnext/popup/style/css/index.js +3 -0
  590. package/esnext/popup/style/index.d.ts +3 -0
  591. package/esnext/popup/style/index.js +3 -0
  592. package/esnext/popup/style/index.less +114 -0
  593. package/esnext/popup-swiper/index.d.ts +93 -0
  594. package/esnext/popup-swiper/index.js +192 -0
  595. package/esnext/popup-swiper/methods.d.ts +10 -0
  596. package/esnext/popup-swiper/methods.js +4 -0
  597. package/esnext/popup-swiper/style/css/index.css +531 -0
  598. package/esnext/popup-swiper/style/css/index.d.ts +3 -0
  599. package/esnext/popup-swiper/style/css/index.js +3 -0
  600. package/esnext/popup-swiper/style/index.d.ts +3 -0
  601. package/esnext/popup-swiper/style/index.js +3 -0
  602. package/esnext/popup-swiper/style/index.less +35 -0
  603. package/esnext/portal/index.d.ts +23 -0
  604. package/esnext/portal/index.js +18 -0
  605. package/esnext/portal/style/css/index.css +0 -0
  606. package/esnext/portal/style/css/index.d.ts +2 -0
  607. package/esnext/portal/style/css/index.js +2 -0
  608. package/esnext/portal/style/index.d.ts +2 -0
  609. package/esnext/portal/style/index.js +2 -0
  610. package/esnext/portal/style/index.less +1 -0
  611. package/esnext/progress/index.d.ts +126 -0
  612. package/esnext/progress/index.js +66 -0
  613. package/esnext/progress/style/css/index.css +692 -0
  614. package/esnext/progress/style/css/index.d.ts +2 -0
  615. package/esnext/progress/style/css/index.js +2 -0
  616. package/esnext/progress/style/index.d.ts +2 -0
  617. package/esnext/progress/style/index.js +2 -0
  618. package/esnext/progress/style/index.less +205 -0
  619. package/esnext/pull-refresh/android-pull-refresh.d.ts +3 -0
  620. package/esnext/pull-refresh/android-pull-refresh.js +168 -0
  621. package/esnext/pull-refresh/hooks.d.ts +30 -0
  622. package/esnext/pull-refresh/hooks.js +73 -0
  623. package/esnext/pull-refresh/index.d.ts +28 -0
  624. package/esnext/pull-refresh/index.js +21 -0
  625. package/esnext/pull-refresh/ios-pull-refresh.d.ts +3 -0
  626. package/esnext/pull-refresh/ios-pull-refresh.js +137 -0
  627. package/esnext/pull-refresh/model.d.ts +111 -0
  628. package/esnext/pull-refresh/model.js +8 -0
  629. package/esnext/pull-refresh/style/css/index.css +650 -0
  630. package/esnext/pull-refresh/style/css/index.d.ts +3 -0
  631. package/esnext/pull-refresh/style/css/index.js +3 -0
  632. package/esnext/pull-refresh/style/index.d.ts +3 -0
  633. package/esnext/pull-refresh/style/index.js +3 -0
  634. package/esnext/pull-refresh/style/index.less +131 -0
  635. package/esnext/radio/group.d.ts +5 -0
  636. package/esnext/radio/group.js +50 -0
  637. package/esnext/radio/index.d.ts +19 -0
  638. package/esnext/radio/index.js +22 -0
  639. package/esnext/radio/radio.d.ts +5 -0
  640. package/esnext/radio/radio.js +13 -0
  641. package/esnext/radio/style/css/index.css +604 -0
  642. package/esnext/radio/style/css/index.d.ts +2 -0
  643. package/esnext/radio/style/css/index.js +2 -0
  644. package/esnext/radio/style/index.d.ts +2 -0
  645. package/esnext/radio/style/index.js +2 -0
  646. package/esnext/radio/style/index.less +114 -0
  647. package/esnext/radio/type.d.ts +31 -0
  648. package/esnext/radio/type.js +1 -0
  649. package/esnext/rate/index.d.ts +109 -0
  650. package/esnext/rate/index.js +87 -0
  651. package/esnext/rate/style/css/index.css +595 -0
  652. package/esnext/rate/style/css/index.d.ts +2 -0
  653. package/esnext/rate/style/css/index.js +2 -0
  654. package/esnext/rate/style/index.d.ts +2 -0
  655. package/esnext/rate/style/index.js +2 -0
  656. package/esnext/rate/style/index.less +106 -0
  657. package/esnext/search-bar/association.d.ts +3 -0
  658. package/esnext/search-bar/association.js +51 -0
  659. package/esnext/search-bar/cancel-button.d.ts +10 -0
  660. package/esnext/search-bar/cancel-button.js +18 -0
  661. package/esnext/search-bar/highlight.d.ts +12 -0
  662. package/esnext/search-bar/highlight.js +46 -0
  663. package/esnext/search-bar/index.d.ts +13 -0
  664. package/esnext/search-bar/index.js +109 -0
  665. package/esnext/search-bar/style/css/index.css +765 -0
  666. package/esnext/search-bar/style/css/index.d.ts +2 -0
  667. package/esnext/search-bar/style/css/index.js +2 -0
  668. package/esnext/search-bar/style/index.d.ts +2 -0
  669. package/esnext/search-bar/style/index.js +2 -0
  670. package/esnext/search-bar/style/index.less +198 -0
  671. package/esnext/search-bar/type.d.ts +163 -0
  672. package/esnext/search-bar/type.js +1 -0
  673. package/esnext/show-monitor/index.d.ts +115 -0
  674. package/esnext/show-monitor/index.js +416 -0
  675. package/esnext/show-monitor/style/css/index.css +0 -0
  676. package/esnext/show-monitor/style/css/index.d.ts +2 -0
  677. package/esnext/show-monitor/style/css/index.js +2 -0
  678. package/esnext/show-monitor/style/index.d.ts +2 -0
  679. package/esnext/show-monitor/style/index.js +2 -0
  680. package/esnext/show-monitor/style/index.less +1 -0
  681. package/esnext/skeleton/elements.d.ts +7 -0
  682. package/esnext/skeleton/elements.js +117 -0
  683. package/esnext/skeleton/index.d.ts +19 -0
  684. package/esnext/skeleton/index.js +50 -0
  685. package/esnext/skeleton/skeleton-context.d.ts +3 -0
  686. package/esnext/skeleton/skeleton-context.js +5 -0
  687. package/esnext/skeleton/style/css/index.css +712 -0
  688. package/esnext/skeleton/style/css/index.d.ts +3 -0
  689. package/esnext/skeleton/style/css/index.js +3 -0
  690. package/esnext/skeleton/style/index.d.ts +3 -0
  691. package/esnext/skeleton/style/index.js +3 -0
  692. package/esnext/skeleton/style/index.less +182 -0
  693. package/esnext/skeleton/type.d.ts +105 -0
  694. package/esnext/skeleton/type.js +1 -0
  695. package/esnext/slider/hooks/index.d.ts +12 -0
  696. package/esnext/slider/hooks/index.js +33 -0
  697. package/esnext/slider/hooks/useSliderEvents.d.ts +17 -0
  698. package/esnext/slider/hooks/useSliderEvents.js +128 -0
  699. package/esnext/slider/hooks/useSliderIcon.d.ts +7 -0
  700. package/esnext/slider/hooks/useSliderIcon.js +41 -0
  701. package/esnext/slider/hooks/useSliderInit.d.ts +14 -0
  702. package/esnext/slider/hooks/useSliderInit.js +146 -0
  703. package/esnext/slider/hooks/useSliderStyle.d.ts +13 -0
  704. package/esnext/slider/hooks/useSliderStyle.js +39 -0
  705. package/esnext/slider/index.d.ts +163 -0
  706. package/esnext/slider/index.js +120 -0
  707. package/esnext/slider/marks.d.ts +11 -0
  708. package/esnext/slider/marks.js +17 -0
  709. package/esnext/slider/popover.d.ts +6 -0
  710. package/esnext/slider/popover.js +13 -0
  711. package/esnext/slider/style/css/index.css +863 -0
  712. package/esnext/slider/style/css/index.d.ts +3 -0
  713. package/esnext/slider/style/css/index.js +3 -0
  714. package/esnext/slider/style/index.d.ts +3 -0
  715. package/esnext/slider/style/index.js +3 -0
  716. package/esnext/slider/style/index.less +366 -0
  717. package/esnext/slider/thumb.d.ts +9 -0
  718. package/esnext/slider/thumb.js +21 -0
  719. package/esnext/stepper/hooks/useButtonClick.d.ts +11 -0
  720. package/esnext/stepper/hooks/useButtonClick.js +46 -0
  721. package/esnext/stepper/hooks/useInputEvent.d.ts +10 -0
  722. package/esnext/stepper/hooks/useInputEvent.js +41 -0
  723. package/esnext/stepper/hooks/useValue.d.ts +7 -0
  724. package/esnext/stepper/hooks/useValue.js +33 -0
  725. package/esnext/stepper/index.d.ts +16 -0
  726. package/esnext/stepper/index.js +81 -0
  727. package/esnext/stepper/style/css/index.css +636 -0
  728. package/esnext/stepper/style/css/index.d.ts +2 -0
  729. package/esnext/stepper/style/css/index.js +2 -0
  730. package/esnext/stepper/style/index.d.ts +2 -0
  731. package/esnext/stepper/style/index.js +2 -0
  732. package/esnext/stepper/style/index.less +161 -0
  733. package/esnext/stepper/type.d.ts +159 -0
  734. package/esnext/stepper/type.js +1 -0
  735. package/esnext/steps/index.d.ts +19 -0
  736. package/esnext/steps/index.js +53 -0
  737. package/esnext/steps/step.d.ts +4 -0
  738. package/esnext/steps/step.js +43 -0
  739. package/esnext/steps/style/css/index.css +915 -0
  740. package/esnext/steps/style/css/index.d.ts +2 -0
  741. package/esnext/steps/style/css/index.js +2 -0
  742. package/esnext/steps/style/index.d.ts +2 -0
  743. package/esnext/steps/style/index.js +2 -0
  744. package/esnext/steps/style/index.less +459 -0
  745. package/esnext/steps/type.d.ts +115 -0
  746. package/esnext/steps/type.js +1 -0
  747. package/esnext/sticky/index.d.ts +141 -0
  748. package/esnext/sticky/index.js +165 -0
  749. package/esnext/sticky/style/css/index.css +526 -0
  750. package/esnext/sticky/style/css/index.d.ts +2 -0
  751. package/esnext/sticky/style/css/index.js +2 -0
  752. package/esnext/sticky/style/index.d.ts +2 -0
  753. package/esnext/sticky/style/index.js +2 -0
  754. package/esnext/sticky/style/index.less +30 -0
  755. package/esnext/style.d.ts +60 -0
  756. package/esnext/style.js +60 -0
  757. package/esnext/swipe-action/index.d.ts +13 -0
  758. package/esnext/swipe-action/index.js +220 -0
  759. package/esnext/swipe-action/item.d.ts +11 -0
  760. package/esnext/swipe-action/item.js +20 -0
  761. package/esnext/swipe-action/style/css/index.css +620 -0
  762. package/esnext/swipe-action/style/css/index.d.ts +2 -0
  763. package/esnext/swipe-action/style/css/index.js +2 -0
  764. package/esnext/swipe-action/style/index.d.ts +2 -0
  765. package/esnext/swipe-action/style/index.js +2 -0
  766. package/esnext/swipe-action/style/index.less +132 -0
  767. package/esnext/swipe-action/type.d.ts +123 -0
  768. package/esnext/swipe-action/type.js +1 -0
  769. package/esnext/swipe-load/index.d.ts +13 -0
  770. package/esnext/swipe-load/index.js +255 -0
  771. package/esnext/swipe-load/style/css/index.css +561 -0
  772. package/esnext/swipe-load/style/css/index.d.ts +2 -0
  773. package/esnext/swipe-load/style/css/index.js +2 -0
  774. package/esnext/swipe-load/style/index.d.ts +2 -0
  775. package/esnext/swipe-load/style/index.js +2 -0
  776. package/esnext/swipe-load/style/index.less +66 -0
  777. package/esnext/swipe-load/type.d.ts +152 -0
  778. package/esnext/swipe-load/type.js +1 -0
  779. package/esnext/switch/index.d.ts +105 -0
  780. package/esnext/switch/index.js +83 -0
  781. package/esnext/switch/style/css/index.css +765 -0
  782. package/esnext/switch/style/css/index.d.ts +2 -0
  783. package/esnext/switch/style/css/index.js +2 -0
  784. package/esnext/switch/style/index.d.ts +2 -0
  785. package/esnext/switch/style/index.js +2 -0
  786. package/esnext/switch/style/index.less +217 -0
  787. package/esnext/tab-bar/index.d.ts +14 -0
  788. package/esnext/tab-bar/index.js +16 -0
  789. package/esnext/tab-bar/item.d.ts +3 -0
  790. package/esnext/tab-bar/item.js +31 -0
  791. package/esnext/tab-bar/style/css/index.css +617 -0
  792. package/esnext/tab-bar/style/css/index.d.ts +2 -0
  793. package/esnext/tab-bar/style/css/index.js +2 -0
  794. package/esnext/tab-bar/style/index.d.ts +2 -0
  795. package/esnext/tab-bar/style/index.js +2 -0
  796. package/esnext/tab-bar/style/index.less +96 -0
  797. package/esnext/tab-bar/tab-bar.d.ts +11 -0
  798. package/esnext/tab-bar/tab-bar.js +40 -0
  799. package/esnext/tab-bar/type.d.ts +95 -0
  800. package/esnext/tab-bar/type.js +1 -0
  801. package/esnext/tabs/index.d.ts +13 -0
  802. package/esnext/tabs/index.js +340 -0
  803. package/esnext/tabs/style/css/index.css +1162 -0
  804. package/esnext/tabs/style/css/index.d.ts +2 -0
  805. package/esnext/tabs/style/css/index.js +2 -0
  806. package/esnext/tabs/style/index.d.ts +2 -0
  807. package/esnext/tabs/style/index.js +2 -0
  808. package/esnext/tabs/style/index.less +559 -0
  809. package/esnext/tabs/tab-cell-underline.d.ts +4 -0
  810. package/esnext/tabs/tab-cell-underline.js +237 -0
  811. package/esnext/tabs/tab-cell.d.ts +4 -0
  812. package/esnext/tabs/tab-cell.js +258 -0
  813. package/esnext/tabs/tab-pane.d.ts +4 -0
  814. package/esnext/tabs/tab-pane.js +241 -0
  815. package/esnext/tabs/type.d.ts +629 -0
  816. package/esnext/tabs/type.js +1 -0
  817. package/esnext/tag/index.d.ts +14 -0
  818. package/esnext/tag/index.js +20 -0
  819. package/esnext/tag/list.d.ts +3 -0
  820. package/esnext/tag/list.js +47 -0
  821. package/esnext/tag/style/css/index.css +738 -0
  822. package/esnext/tag/style/css/index.d.ts +2 -0
  823. package/esnext/tag/style/css/index.js +2 -0
  824. package/esnext/tag/style/index.d.ts +2 -0
  825. package/esnext/tag/style/index.js +2 -0
  826. package/esnext/tag/style/index.less +188 -0
  827. package/esnext/tag/tag.d.ts +3 -0
  828. package/esnext/tag/tag.js +32 -0
  829. package/esnext/tag/type.d.ts +159 -0
  830. package/esnext/tag/type.js +1 -0
  831. package/esnext/textarea/index.d.ts +96 -0
  832. package/esnext/textarea/index.js +88 -0
  833. package/esnext/textarea/style/css/index.css +572 -0
  834. package/esnext/textarea/style/css/index.d.ts +3 -0
  835. package/esnext/textarea/style/css/index.js +3 -0
  836. package/esnext/textarea/style/index.d.ts +3 -0
  837. package/esnext/textarea/style/index.js +3 -0
  838. package/esnext/textarea/style/index.less +84 -0
  839. package/esnext/toast/index.d.ts +257 -0
  840. package/esnext/toast/index.js +142 -0
  841. package/esnext/toast/methods.d.ts +16 -0
  842. package/esnext/toast/methods.js +61 -0
  843. package/esnext/toast/style/css/index.css +658 -0
  844. package/esnext/toast/style/css/index.d.ts +4 -0
  845. package/esnext/toast/style/css/index.js +4 -0
  846. package/esnext/toast/style/index.d.ts +4 -0
  847. package/esnext/toast/style/index.js +4 -0
  848. package/esnext/toast/style/index.less +130 -0
  849. package/esnext/transition/index.d.ts +49 -0
  850. package/esnext/transition/index.js +15 -0
  851. package/esnext/transition/style/css/index.css +549 -0
  852. package/esnext/transition/style/css/index.d.ts +2 -0
  853. package/esnext/transition/style/css/index.js +2 -0
  854. package/esnext/transition/style/index.d.ts +2 -0
  855. package/esnext/transition/style/index.js +2 -0
  856. package/esnext/transition/style/index.less +53 -0
  857. package/esnext/uploader/index.d.ts +16 -0
  858. package/esnext/uploader/index.js +75 -0
  859. package/esnext/uploader/style/css/index.css +666 -0
  860. package/esnext/uploader/style/css/index.d.ts +4 -0
  861. package/esnext/uploader/style/css/index.js +4 -0
  862. package/esnext/uploader/style/index.d.ts +4 -0
  863. package/esnext/uploader/style/index.js +4 -0
  864. package/esnext/uploader/style/index.less +161 -0
  865. package/esnext/uploader/type.d.ts +108 -0
  866. package/esnext/uploader/type.js +1 -0
  867. package/esnext/uploader/upload/index.d.ts +2 -0
  868. package/esnext/uploader/upload/index.js +2 -0
  869. package/esnext/uploader/upload/type.d.ts +107 -0
  870. package/esnext/uploader/upload/type.js +1 -0
  871. package/esnext/uploader/upload/upload.d.ts +20 -0
  872. package/esnext/uploader/upload/upload.js +123 -0
  873. package/esnext-tsconfig.json +23 -0
  874. package/package.json +3 -3
  875. package/umd/_helpers/index.d.ts +1 -0
  876. package/umd/_helpers/index.js +10 -4
  877. package/umd/_helpers/react-dom.js +21 -14
  878. package/umd/avatar/index.js +3 -1
  879. package/umd/avatar/type.d.ts +6 -0
  880. package/umd/carousel/index.js +18 -1
  881. package/umd/steps/index.d.ts +1 -1
  882. package/umd/steps/index.js +6 -1
  883. package/umd/steps/style/css/index.css +42 -4
  884. package/umd/steps/style/index.less +58 -6
  885. package/umd/steps/type.d.ts +5 -0
@@ -0,0 +1,849 @@
1
+ import React, { useRef, useState, useEffect, forwardRef, useImperativeHandle, useCallback, useMemo, useContext, } from 'react';
2
+ import { nextTick, cls } from '@arco-design/mobile-utils';
3
+ import { ContextLayout, GlobalContext } from '../context-provider';
4
+ import { useRefState, useListenResize, useUpdateEffect, getStyleWithVendor, useSystem, useSwiperInnerScroll, useLatestRef, } from '../_helpers';
5
+ /**
6
+ * 轮播组件,支持自定义轮播索引样式及滑块宽度。**需要注意的是,如果正使用`fastclick`,需要为 touchstart 的 target 添加`needsclick`类**(<a href="https://github.com/ftlabs/fastclick#ignore-certain-elements-with-needsclick" target="_blank">详情戳这里</a>),以规避`fastclick`逻辑与组件内部的手势冲突。(如果使用了`list`属性则无需额外添加)
7
+ * @en Carousel component, supports custom carousel index style and slider width. **Note that if you are using `fastclick`, you need to add a `needsclick` class to the touchstart target ** (<a href="https://github.com/ftlabs/fastclick#ignore-certain-elements- with-needsclick" target="_blank">click here for details</a>) to avoid `fastclick` logic conflicts with gestures inside the component. (no need to add if `list` is set)
8
+ * @type 信息展示
9
+ * @type_en Data Display
10
+ * @name 轮播图
11
+ * @name_en Carousel
12
+ */
13
+ const Carousel = forwardRef((props, ref) => {
14
+ const { className, wrapStyle, style, children, list = [], animateDuration = 500, animateDurationSlide = 300, loop = true, autoPlay = true, autoPlayDirection = 'normal', swipeable = true, stayDuration = 4000, boxWidth, boxHeight, baseBoxWidth, baseBoxHeight, width = 0, height, initialIndex = 0, renderIndicator, indicatorPos = 'center', indicatorVerticalPos = 'left', indicatorOutside, showIndicator = true, hideSingleIndicator = true, indicatorType = 'square', indicatorClass = '', indicatorInverse, spaceBetween = 0, offsetBetween = 0, currentIndex, autoHeight = false, percentToChange = 0.3, distanceToChange = 10, speedToChange = 100, vertical, lazyloadCount, inactiveScale = 1, stopPropagation = true, fakeItem = false, allowEndBlank = false, bounceWhenNoLoop = false, bounceDampRate = 3, iOSVisibleOptimize = true, renderExtra, distanceProcessor, getInnerScrollContainer, onChange, onAfterChange, onTouchStart, onTouchMove, onTouchEnd, onTransitionStart, onTransitionEnd, onDistanceChange, stopTouchThreshold = 0, onTouchStopped, onPageVisibleChange, } = props;
15
+ const { useRtl } = useContext(GlobalContext);
16
+ const horizontalUseRtl = !vertical && useRtl;
17
+ const domRef = useRef(null);
18
+ const wrapRef = useRef(null);
19
+ const innerRef = useRef(null);
20
+ const itemsRef = useRef([]);
21
+ const fakeWrapRef = useRef(null);
22
+ const timerRef = useRef(null);
23
+ const movedChildRef = useRef(-1);
24
+ const touchStartTimeRef = useRef(0);
25
+ const touchStartedRef = useRef(false);
26
+ const touchMovedRef = useRef(false);
27
+ const [wrapWidth, setWrapWidth] = useState(baseBoxWidth || 0);
28
+ const [wrapHeight, setWrapHeight] = useState(baseBoxHeight || 0);
29
+ const touchStartXRef = useRef(0);
30
+ const touchStartYRef = useRef(0);
31
+ const scrollingRef = useRef(null);
32
+ const touchStoppedRef = useRef(false);
33
+ const bouncingRef = useRef(false);
34
+ const [currentItemHeight, setCurrentItemHeight] = useState('auto');
35
+ const [posAdjusting, posAdjustingRef, setPosAdjusting] = useRefState(false);
36
+ const [distance, distanceRef, setDistance] = useRefState(0);
37
+ const [isAutoJump, setIsAutoJump] = useState(true);
38
+ const [index, indexRef, setIndex] = useRefState(currentIndex !== void 0 ? currentIndex : initialIndex);
39
+ const [transforms, transformsRef, setTransforms] = useRefState([]);
40
+ const [direction, directionRef, setStateDirection] = useRefState((autoPlayDirection === 'reverse' || horizontalUseRtl) && autoPlay ? 'right' : 'left');
41
+ const lastDirectionRef = useRef('');
42
+ const lastShownIndexRef = useRef(-1);
43
+ const { allChildren, fakeTwoChildren } = getAllChildren();
44
+ const total = allChildren.length;
45
+ const shownTotal = fakeTwoChildren ? 2 : total;
46
+ const indicatorArr = useMemo(() => {
47
+ const arr = [];
48
+ for (let i = 0; i < shownTotal; i += 1) {
49
+ arr.push(i);
50
+ }
51
+ return arr;
52
+ }, [shownTotal]);
53
+ const rtlRatio = horizontalUseRtl ? -1 : 1;
54
+ const leftDirec = horizontalUseRtl ? 'right' : 'left';
55
+ const rightDirec = horizontalUseRtl ? 'left' : 'right';
56
+ const leftOffset = typeof offsetBetween === 'number' ? offsetBetween : offsetBetween.left || 0;
57
+ const rightOffset = typeof offsetBetween === 'number' ? offsetBetween : offsetBetween.right || 0;
58
+ const wrapSize = vertical ? wrapHeight : wrapWidth;
59
+ const childWidth = (width || wrapWidth) - spaceBetween - (leftOffset + rightOffset);
60
+ const childHeight = (height || wrapHeight) - spaceBetween - (leftOffset + rightOffset);
61
+ const childSize = vertical ? childHeight : childWidth;
62
+ const noLoop = !loop ||
63
+ (!vertical && Boolean(width)) ||
64
+ (vertical && Boolean(height)) ||
65
+ total < 2 ||
66
+ ((leftOffset > 0 || rightOffset > 0) && !fakeItem);
67
+ const shownIndex = getShownIndex(index);
68
+ const dynamicAnimateDuration = getDynamicDuration(isAutoJump);
69
+ const cubic = isAutoJump ? 'auto' : 'slide';
70
+ const indexFixed = currentIndex !== void 0;
71
+ const needTouchEvent = swipeable && !indexFixed && childSize > 0;
72
+ const userSetBoxWidth = boxWidth || baseBoxWidth;
73
+ const userSetBoxHeight = boxHeight || baseBoxHeight;
74
+ const noInterval = noLoop || !autoPlay || indexFixed || childSize <= 0;
75
+ const inactiveValidScale = useMemo(() => Math.max(0, Math.min(inactiveScale, 1)), [inactiveScale]);
76
+ const [fakeIndexes, setFakeIndexes] = useState([]);
77
+ const system = useSystem();
78
+ // 开启自动循环时iOS会有渲染问题需要强刷dom,但不需要autoPlay的不用强刷,这里判断下
79
+ // @en When the automatic loop is turned on, there will be rendering problems in iOS. Need to brush the dom, but if you don't need autoPlay, don't need to brush.
80
+ const needRefreshDom = !noInterval && system === 'ios' && iOSVisibleOptimize;
81
+ const setDirection = useCallback((newDirec) => {
82
+ setStateDirection(direc => {
83
+ lastDirectionRef.current = direc;
84
+ return newDirec;
85
+ });
86
+ }, []);
87
+ const wrapSizeRef = useLatestRef(wrapSize);
88
+ const updateDataRef = useLatestRef(updateData);
89
+ const setPlayIntervalRef = useLatestRef(setPlayInterval);
90
+ const handleTouchStart = useCallback((e) => {
91
+ if (onTouchStart && onTouchStart(e, shownTotal, getShownIndex(indexRef.current))) {
92
+ return;
93
+ }
94
+ if (posAdjustingRef.current) {
95
+ return;
96
+ }
97
+ // touchMove触发时,阻止handleTouchStart多次执行(如点击事件)
98
+ // @en When touchMove is triggered, prevent handleTouchStart from executing multiple times (such as click events)
99
+ if (touchStartedRef.current && touchMovedRef.current) {
100
+ return;
101
+ }
102
+ touchStartedRef.current = true;
103
+ touchMovedRef.current = false;
104
+ clear();
105
+ const evt = e.touches[0];
106
+ touchStartXRef.current = evt.clientX || 0;
107
+ touchStartYRef.current = evt.clientY || 0;
108
+ scrollingRef.current = null;
109
+ touchStoppedRef.current = false;
110
+ setPosAdjusting(false);
111
+ touchStartTimeRef.current = new Date().getTime();
112
+ }, [shownTotal, onTouchStart]);
113
+ const triggerTouchStopped = useCallback((posDis) => {
114
+ const needStop = Math.abs(posDis) > stopTouchThreshold;
115
+ if (!touchStoppedRef.current && needStop) {
116
+ onTouchStopped && onTouchStopped(posDis >= 0 ? -1 : 1);
117
+ }
118
+ touchStoppedRef.current = needStop;
119
+ }, [stopTouchThreshold, onTouchStopped]);
120
+ const handleTouchMove = useCallback((e) => {
121
+ if (onTouchMove && onTouchMove(e, shownTotal, getShownIndex(indexRef.current))) {
122
+ return;
123
+ }
124
+ stopPropagation && e.stopPropagation();
125
+ if (!touchStartedRef.current || posAdjustingRef.current) {
126
+ e.cancelable && e.preventDefault();
127
+ return;
128
+ }
129
+ touchMovedRef.current = true;
130
+ const evt = e.changedTouches[0];
131
+ const touchMoveX = Math.max(0, evt.clientX || 0);
132
+ const touchMoveY = evt.clientY || 0;
133
+ const posDisX = touchMoveX - touchStartXRef.current;
134
+ const posDisY = touchMoveY - touchStartYRef.current;
135
+ const absDisX = Math.abs(posDisX);
136
+ const absDisY = Math.abs(posDisY);
137
+ const originDis = vertical ? posDisY : posDisX;
138
+ const processor = distanceProcessor || ((dis, size, child) => child * (dis / size));
139
+ const posDis = processor(originDis, wrapSizeRef.current, childSize);
140
+ if (total < 2) {
141
+ triggerTouchStopped(posDis);
142
+ return;
143
+ }
144
+ if (scrollingRef.current === null) {
145
+ scrollingRef.current = vertical ? absDisY < absDisX : absDisX < absDisY;
146
+ }
147
+ // 如果是在滚动页面则禁用轮播图手势
148
+ // @en Disable carousel gestures if scrolling
149
+ if (scrollingRef.current) {
150
+ setDistance(0);
151
+ // bugfix: 未触发横滑就不触发touchend逻辑,且这个场景不需要触发onTouchStopped,因此直接设置touchStoppedRef
152
+ // @en bugfix: The touchend event will not be triggered if the horizontal swipe is not triggered, and this scene does not need to trigger onTouchStopped.
153
+ touchStoppedRef.current = true;
154
+ // 不会触发jumpTo,但touchstart时clear了,所以要手动设置一次interval
155
+ // @en JumpTo will not be triggered, but it is cleared in touchstart event, so need to manually set interval once
156
+ setPlayIntervalRef.current();
157
+ return;
158
+ }
159
+ setDirection(posDis >= 0 ? 'right' : 'left');
160
+ const comparedPos = posDis * rtlRatio;
161
+ if (noLoop &&
162
+ ((indexRef.current === 0 && comparedPos > 0) ||
163
+ (indexRef.current === total - 1 && comparedPos < 0))) {
164
+ triggerTouchStopped(posDis);
165
+ if (bounceWhenNoLoop && bounceDampRate) {
166
+ e.cancelable && e.preventDefault();
167
+ bouncingRef.current = true;
168
+ setDistance(posDis / bounceDampRate);
169
+ }
170
+ else {
171
+ setDistance(0);
172
+ }
173
+ return;
174
+ }
175
+ e.cancelable && e.preventDefault();
176
+ touchStoppedRef.current = false;
177
+ const maxDis = childSize;
178
+ setDistance(posDis > 0 ? Math.min(maxDis, posDis) : Math.max(-1 * maxDis, posDis));
179
+ }, [
180
+ shownTotal,
181
+ noLoop,
182
+ vertical,
183
+ childSize,
184
+ stopPropagation,
185
+ bounceWhenNoLoop,
186
+ bounceDampRate,
187
+ horizontalUseRtl,
188
+ onTouchMove,
189
+ triggerTouchStopped,
190
+ ]);
191
+ useImperativeHandle(ref, () => ({
192
+ dom: domRef.current,
193
+ wrap: wrapRef.current,
194
+ items: itemsRef.current,
195
+ noLoop,
196
+ updateData,
197
+ changeIndex,
198
+ }), [updateData, changeIndex]);
199
+ useListenResize(updateData, [updateData]);
200
+ useSwiperInnerScroll(getInnerScrollContainer);
201
+ const updateWhenVisible = useCallback(() => {
202
+ fakeWrapRef.current && (fakeWrapRef.current.style.display = 'none');
203
+ wrapRef.current && (wrapRef.current.style.display = '');
204
+ // 部分情况下页面隐藏后容器宽度变成0,因此页面返回后需重新取一次容器尺寸
205
+ // @en In some cases, the width of the container becomes 0 after the page is invisible, so the container size needs to be resized after the page is visible.
206
+ updateDataRef.current();
207
+ }, []);
208
+ const updateWhenInvisible = useCallback(() => {
209
+ clear();
210
+ if (wrapRef.current && fakeWrapRef.current) {
211
+ fakeWrapRef.current.style.height = `${wrapRef.current.offsetHeight || 0}px`;
212
+ fakeWrapRef.current.style.display = 'block';
213
+ wrapRef.current.style.display = 'none';
214
+ }
215
+ }, []);
216
+ useEffect(() => {
217
+ if (onPageVisibleChange) {
218
+ return onPageVisibleChange(updateWhenVisible, updateWhenInvisible);
219
+ }
220
+ // ios 在页面隐藏后返回时会有dom结构正确但渲染错乱的情况,因此在页面隐藏时先用占位符,返回后重新渲染一次dom
221
+ // @en In iOS, When the page is invisible, the DOM will be correct but the rendering is disordered. So use a placeholder when the page is invisible, and re-render the DOM after it is visible.
222
+ const update = () => {
223
+ if (document.visibilityState === 'visible') {
224
+ updateWhenVisible();
225
+ }
226
+ else {
227
+ updateWhenInvisible();
228
+ }
229
+ };
230
+ document.addEventListener('visibilitychange', update);
231
+ return () => {
232
+ document.removeEventListener('visibilitychange', update);
233
+ };
234
+ }, [onPageVisibleChange]);
235
+ useEffect(() => {
236
+ if (distanceToChange > 0 && distanceToChange < 1) {
237
+ console.warn(`[Carousel Props Warning] The value of the prop \`distanceToChange\` is too small(${distanceToChange}). Do you meant to use the prop \`percentToChange\`?`);
238
+ }
239
+ }, [distanceToChange]);
240
+ useEffect(() => {
241
+ if (vertical && !boxHeight) {
242
+ console.warn('[Carousel Rendering Warning] When the prop `vertical` is specified and the prop `boxHeight` is not specified, you need to set a fixed `height` style for the outermost element.');
243
+ }
244
+ }, [vertical, boxHeight]);
245
+ useEffect(() => {
246
+ if (wrapRef.current && needTouchEvent) {
247
+ wrapRef.current.addEventListener('touchstart', handleTouchStart);
248
+ wrapRef.current.addEventListener('touchmove', handleTouchMove);
249
+ }
250
+ return () => {
251
+ if (wrapRef.current && needTouchEvent) {
252
+ wrapRef.current.removeEventListener('touchstart', handleTouchStart);
253
+ wrapRef.current.removeEventListener('touchmove', handleTouchMove);
254
+ }
255
+ };
256
+ }, [handleTouchStart, handleTouchMove, needTouchEvent]);
257
+ useEffect(() => {
258
+ // 布局改变时重新计算
259
+ // @en Recalculate when layout changes
260
+ updateData();
261
+ return () => {
262
+ clear();
263
+ };
264
+ }, [
265
+ userSetBoxWidth,
266
+ userSetBoxHeight,
267
+ childWidth,
268
+ childHeight,
269
+ stayDuration,
270
+ noInterval,
271
+ autoPlayDirection,
272
+ ]);
273
+ useUpdateEffect(() => {
274
+ if (currentIndex !== void 0) {
275
+ jumpTo(currentIndex);
276
+ }
277
+ }, [currentIndex]);
278
+ useUpdateEffect(() => {
279
+ onDistanceChange && onDistanceChange(distance, wrapSize, index);
280
+ }, [distance, wrapSize, index]);
281
+ useEffect(() => {
282
+ // children改变,索引超出新children范围时兼容
283
+ // @en When children change, it needs to be compatible when the index exceeds the range of the new children
284
+ if (allChildren.length && indexRef.current >= allChildren.length) {
285
+ jumpTo(allChildren.length - 1, true, true);
286
+ }
287
+ else if (indexRef.current < 0) {
288
+ jumpTo(0, true, true);
289
+ }
290
+ }, [allChildren.length]);
291
+ useEffect(() => {
292
+ // bugfix: 修复ios轮播循环时闪动问题
293
+ // @en bugfix: Fix the flickering problem when the carousel loops in iOS
294
+ if (isAutoJump && posAdjusting) {
295
+ setTimeout(() => {
296
+ getFakeChild();
297
+ }, 100);
298
+ }
299
+ else {
300
+ getFakeChild();
301
+ }
302
+ }, [index, direction, childSize, total, horizontalUseRtl]);
303
+ useEffect(() => {
304
+ nextTick(() => {
305
+ updateLayoutData();
306
+ });
307
+ }, [shownIndex, autoHeight, allChildren]);
308
+ useUpdateEffect(() => {
309
+ if (typeof onChange === 'function') {
310
+ onChange(shownIndex);
311
+ }
312
+ }, [shownIndex]);
313
+ useEffect(() => {
314
+ return () => {
315
+ lastShownIndexRef.current = shownIndex;
316
+ };
317
+ }, [shownIndex]);
318
+ useEffect(() => {
319
+ if (!fakeItem || posAdjusting) {
320
+ return;
321
+ }
322
+ setCurrentFakeIndex();
323
+ }, [posAdjusting, index, direction, total, childSize, horizontalUseRtl]);
324
+ function getShownIndex(nowIndex) {
325
+ const validIndex = nowIndex === total ? 0 : nowIndex;
326
+ const shownInd = nowIndex === -1 ? total - 1 : validIndex;
327
+ return fakeTwoChildren ? shownInd % 2 : shownInd;
328
+ }
329
+ function getDynamicDuration(autoJump) {
330
+ return autoJump ? animateDuration : animateDurationSlide;
331
+ }
332
+ function setCurrentHeight() {
333
+ if (!innerRef.current || !autoHeight || vertical) {
334
+ return;
335
+ }
336
+ const allItemDom = itemsRef.current;
337
+ const nowIndex = getShownIndex(indexRef.current);
338
+ const currentHeight = (allItemDom[nowIndex] || {}).offsetHeight || 'auto';
339
+ setCurrentItemHeight(currentHeight);
340
+ }
341
+ function getAllChildren() {
342
+ let allChild = [];
343
+ let fakeTwo = false;
344
+ if (list && list.length) {
345
+ let actualList = list;
346
+ if (list.length === 2 && fakeItem) {
347
+ fakeTwo = true;
348
+ actualList = list.concat(list);
349
+ }
350
+ allChild = actualList.map((item, i) => (React.createElement(React.Fragment, null,
351
+ React.createElement("img", { key: i, className: "carousel-item-img needsclick", src: item.src, alt: "", onClick: item.onClick }),
352
+ item.text ? React.createElement("div", { className: "carousel-item-text" }, item.text) : null)));
353
+ }
354
+ else if (children && Object.prototype.toString.call(children) === '[object Array]') {
355
+ allChild = children;
356
+ if (allChild.length === 2 && fakeItem) {
357
+ fakeTwo = true;
358
+ allChild = [...allChild, ...allChild];
359
+ }
360
+ }
361
+ else {
362
+ allChild = children ? [children] : [];
363
+ }
364
+ return { allChildren: allChild, fakeTwoChildren: fakeTwo };
365
+ }
366
+ function getDefaultDirection() {
367
+ const nowIndex = indexRef.current;
368
+ if (nowIndex === total - 1) {
369
+ return horizontalUseRtl ? 'right' : 'left';
370
+ }
371
+ if (nowIndex === 0) {
372
+ return horizontalUseRtl ? 'left' : 'right';
373
+ }
374
+ return '';
375
+ }
376
+ function changeIndex(newIndex, rightNow, userSetDirec) {
377
+ if (posAdjustingRef.current) {
378
+ return;
379
+ }
380
+ if (userSetDirec) {
381
+ // rtl 模式取反
382
+ const direcMap = {
383
+ left: leftDirec,
384
+ right: rightDirec,
385
+ };
386
+ const direc = direcMap[userSetDirec];
387
+ setDirection(direc);
388
+ nextTick(() => {
389
+ jumpTo(newIndex, true, rightNow, direc);
390
+ });
391
+ }
392
+ else {
393
+ jumpTo(newIndex, true, rightNow);
394
+ }
395
+ }
396
+ function jumpTo(newIndex, autoJump = true, rightNow, direc) {
397
+ const oldIndex = getShownIndex(indexRef.current);
398
+ const changedIndex = newIndex !== oldIndex ? getShownIndex(newIndex) : -1;
399
+ if (direc) {
400
+ setDirection(direc);
401
+ }
402
+ else if (autoJump) {
403
+ setDirection(autoPlayDirection === 'reverse' || horizontalUseRtl ? 'right' : 'left');
404
+ }
405
+ else if (newIndex === indexRef.current) {
406
+ setDirection(distanceRef.current > 0 ? 'right' : 'left');
407
+ }
408
+ else {
409
+ setDirection('');
410
+ }
411
+ setPosAdjusting(true);
412
+ setIsAutoJump(autoJump);
413
+ setDistance(0);
414
+ setIndex(newIndex);
415
+ touchStartTimeRef.current = 0;
416
+ onTransitionStart && onTransitionStart();
417
+ setTimeout(() => {
418
+ setPosAdjusting(false);
419
+ nextTick(() => {
420
+ setDirection(getDefaultDirection());
421
+ const newTransform = transformsRef.current.slice();
422
+ let transChanged = false;
423
+ if (newIndex === -1 && movedChildRef.current >= 0) {
424
+ newTransform[movedChildRef.current] = 0;
425
+ transChanged = true;
426
+ setIndex(total - 1);
427
+ }
428
+ else if (newIndex === total && movedChildRef.current >= 0) {
429
+ newTransform[movedChildRef.current] = 0;
430
+ transChanged = true;
431
+ setIndex(0);
432
+ }
433
+ transChanged && setTransforms(newTransform);
434
+ setIsAutoJump(true);
435
+ onTransitionEnd && onTransitionEnd();
436
+ if (changedIndex >= 0) {
437
+ onAfterChange && onAfterChange(changedIndex, oldIndex);
438
+ }
439
+ nextTick(() => {
440
+ setPlayIntervalRef.current();
441
+ });
442
+ });
443
+ }, rightNow ? 0 : getDynamicDuration(autoJump));
444
+ autoJump && setDirection('');
445
+ }
446
+ function setPlayInterval() {
447
+ clear();
448
+ if (noInterval) {
449
+ return;
450
+ }
451
+ timerRef.current = delayTimeout(() => {
452
+ jumpTo(autoPlayDirection === 'reverse' ? indexRef.current - 1 : indexRef.current + 1);
453
+ }, stayDuration);
454
+ }
455
+ function updateLayoutData() {
456
+ if (wrapRef.current) {
457
+ setWrapWidth(wrapRef.current.offsetWidth);
458
+ setWrapHeight(wrapRef.current.offsetHeight);
459
+ }
460
+ setCurrentHeight();
461
+ }
462
+ function updateData() {
463
+ updateLayoutData();
464
+ setPlayIntervalRef.current();
465
+ }
466
+ function clear() {
467
+ if (timerRef.current) {
468
+ clearTimeout(timerRef.current);
469
+ timerRef.current = null;
470
+ }
471
+ }
472
+ function getFakeChild() {
473
+ if (noLoop) {
474
+ // 循环状态从有到无时,重置 transforms
475
+ // @en reset transforms when loop status changes to false
476
+ setTransforms([]);
477
+ return;
478
+ }
479
+ const nowIndex = indexRef.current;
480
+ const newTransform = transformsRef.current.slice();
481
+ const dis = Math.max(0, childSize);
482
+ allChildren.forEach((_, childIndex) => {
483
+ if (nowIndex === 0 && directionRef.current === rightDirec && childIndex === total - 1) {
484
+ movedChildRef.current = childIndex;
485
+ newTransform[childIndex] = -1 * total * dis * rtlRatio;
486
+ }
487
+ else if (nowIndex === total - 1 &&
488
+ directionRef.current === leftDirec &&
489
+ childIndex === 0) {
490
+ movedChildRef.current = childIndex;
491
+ newTransform[childIndex] = total * dis * rtlRatio;
492
+ }
493
+ else if (nowIndex >= 0 && nowIndex < total) {
494
+ newTransform[childIndex] = 0;
495
+ }
496
+ });
497
+ setTransforms(newTransform);
498
+ }
499
+ function delayTimeout(callback, timeout) {
500
+ return setTimeout(callback, timeout);
501
+ }
502
+ function handleTouchEnd(e) {
503
+ if (!needTouchEvent) {
504
+ return;
505
+ }
506
+ if (onTouchEnd && onTouchEnd(e.nativeEvent, shownTotal, getShownIndex(indexRef.current))) {
507
+ return;
508
+ }
509
+ stopPropagation && e.stopPropagation();
510
+ if (bouncingRef.current) {
511
+ bouncingRef.current = false;
512
+ jumpTo(index, false);
513
+ return;
514
+ }
515
+ if (!touchStartedRef.current) {
516
+ return;
517
+ }
518
+ touchStartedRef.current = false;
519
+ if (!touchMovedRef.current) {
520
+ setPlayIntervalRef.current();
521
+ return;
522
+ }
523
+ touchMovedRef.current = false;
524
+ if (posAdjustingRef.current || touchStoppedRef.current) {
525
+ return;
526
+ }
527
+ const touchEndTime = new Date().getTime();
528
+ const dis = Math.abs(distance);
529
+ const speed = (dis / (touchEndTime - touchStartTimeRef.current)) * 1000;
530
+ const maxSlice = childSize * percentToChange;
531
+ const needJump = (dis > maxSlice && dis > distanceToChange) || speed > speedToChange;
532
+ const comparedDis = distance * rtlRatio;
533
+ if (comparedDis > 0 && needJump) {
534
+ jumpTo(index - 1, false);
535
+ }
536
+ else if (comparedDis < 0 && needJump) {
537
+ jumpTo(index + 1, false);
538
+ }
539
+ else {
540
+ jumpTo(index, false);
541
+ }
542
+ }
543
+ function getSlideTransitionStyle() {
544
+ return {
545
+ transitionProperty: posAdjusting ? 'transform' : 'none',
546
+ transitionDuration: posAdjusting ? `${dynamicAnimateDuration}ms` : '0ms',
547
+ };
548
+ }
549
+ function getInnerStyle() {
550
+ const transitionStyle = getStyleWithVendor(getSlideTransitionStyle());
551
+ const innerSize = childSize * total;
552
+ const dis = index * childSize * -1 * rtlRatio + distance + rtlRatio * leftOffset;
553
+ const min = childSize > 0 ? leftOffset : 0;
554
+ const max = allowEndBlank ? dis * rtlRatio : -1 * innerSize + wrapSize - rightOffset;
555
+ const minTransform = horizontalUseRtl ? -1 * max : min;
556
+ const maxTransform = horizontalUseRtl ? -1 * min : max;
557
+ const comparedDis = rtlRatio * distance;
558
+ const noLoopDis = bounceWhenNoLoop &&
559
+ ((index === 0 && comparedDis > 0) || (index === total - 1 && comparedDis < 0))
560
+ ? Math.min(minTransform + distance, Math.max(maxTransform + distance, dis))
561
+ : Math.min(minTransform, Math.max(maxTransform, dis));
562
+ // noLoop时需要在最后也露出spaceBetween的空白,所以当滑到最后一个时transform向左移动相应宽度
563
+ // @en When noLoop is used, the blank space of spaceBetween needs to be exposed at the end, so when sliding to the last one, the transform value moves to the left by the corresponding width
564
+ const translateDis = noLoop
565
+ ? noLoopDis - (total > 1 && index === total - 1 ? spaceBetween : 0) * rtlRatio
566
+ : dis;
567
+ const initTranslateDis = -1 * index * 100;
568
+ // bugfix: prop `style` did not match in ssr
569
+ const transStr = childSize > 0
570
+ ? `${translateDis}${translateDis ? 'px' : ''}`
571
+ : `${initTranslateDis}${initTranslateDis ? '%' : ''}`;
572
+ if (vertical) {
573
+ const translateStyle = getStyleWithVendor({
574
+ transform: `translateY(${transStr}) translateZ(0)`,
575
+ });
576
+ return {
577
+ ...transitionStyle,
578
+ ...translateStyle,
579
+ width: '100%',
580
+ };
581
+ }
582
+ const translateStyle = getStyleWithVendor({
583
+ transform: `translateX(${transStr}) translateZ(0)`,
584
+ });
585
+ return {
586
+ width: Math.max(0, innerSize) || 'auto',
587
+ height,
588
+ ...transitionStyle,
589
+ ...translateStyle,
590
+ };
591
+ }
592
+ function getCarouselStyle() {
593
+ if (vertical) {
594
+ return {
595
+ height: userSetBoxHeight,
596
+ ...(style || {}),
597
+ };
598
+ }
599
+ const heightStyle = currentItemHeight && currentItemHeight !== 'auto'
600
+ ? {
601
+ height: currentItemHeight,
602
+ }
603
+ : {};
604
+ return {
605
+ width: userSetBoxWidth,
606
+ ...heightStyle,
607
+ ...(style || {}),
608
+ };
609
+ }
610
+ // 当最前或最后的滑块通过transform手动被放置到最后或最前时,在展示层可以认为是第total个或第-1个模块
611
+ // @en When the front or last slider is manually placed to the rear or the front through transform, it can be considered as the total or -1 module in the display layer
612
+ function getShownChildIndex(curIndex) {
613
+ let childIndex = curIndex;
614
+ if (transforms[childIndex] * rtlRatio > 0) {
615
+ childIndex = total;
616
+ }
617
+ else if (transforms[childIndex] * rtlRatio < 0) {
618
+ childIndex = -1;
619
+ }
620
+ return childIndex;
621
+ }
622
+ // 当两侧有露出内容时,为了循环衔接上需要fake前后的dom来做视觉填充
623
+ // @en When there is exposed content on both sides, it is necessary to fake the front and rear dom to make visual filling in order to connect circularly.
624
+ function setCurrentFakeIndex() {
625
+ const newIndexes = fakeIndexes.slice();
626
+ if (childSize <= 0) {
627
+ if (index === 0) {
628
+ newIndexes[0] = { index: total - 1, side: 'left' };
629
+ }
630
+ if (index === total - 1) {
631
+ newIndexes[2] = { index: 0, side: 'right' };
632
+ }
633
+ setFakeIndexes(newIndexes);
634
+ return;
635
+ }
636
+ if ((index === 1 && direction === rightDirec) ||
637
+ (index === 0 && direction !== rightDirec)) {
638
+ newIndexes[0] = { index: total - 1, side: 'left' };
639
+ }
640
+ if ((index === 0 && direction === rightDirec) || index === -1) {
641
+ newIndexes[1] = { index: total - 2, side: 'left' };
642
+ }
643
+ if ((index === total - 2 && direction === leftDirec) ||
644
+ (index === total - 1 && direction !== leftDirec)) {
645
+ newIndexes[2] = { index: 0, side: 'right' };
646
+ }
647
+ if ((index === total - 1 && direction === leftDirec) || index === total) {
648
+ newIndexes[3] = { index: 1, side: 'right' };
649
+ }
650
+ setFakeIndexes(newIndexes);
651
+ }
652
+ function getItemTranslateStyle(childIndex, ratio) {
653
+ const dis = index - childIndex;
654
+ const prefix = dis > 0 ? 1 : -1;
655
+ const transPercent = 1 - inactiveValidScale;
656
+ const ratioWithRtl = ratio * rtlRatio;
657
+ let trans = 0;
658
+ if (Math.abs(dis) > 1) {
659
+ trans = (prefix * (Math.abs(dis) - 1) - ratioWithRtl) * transPercent * rtlRatio;
660
+ }
661
+ else if ((dis === -1 && ratioWithRtl > 0) || (dis === 1 && ratioWithRtl < 0)) {
662
+ trans = -1 * ratio * transPercent;
663
+ }
664
+ return `translate${vertical ? 'Y' : 'X'}(${trans * 100}%)`;
665
+ }
666
+ function getItemScaleStyle(childIndex, ratio) {
667
+ const originScale = inactiveValidScale;
668
+ // active滑块前后两侧的滑块,根据滑动距离等比放大
669
+ // @en The front and rear sides of the active slider, and zoom in proportionally according to the sliding distance
670
+ if ((childIndex === index - 1 && direction === rightDirec) ||
671
+ (childIndex === index + 1 && direction === leftDirec)) {
672
+ return originScale + (1 - originScale) * Math.abs(ratio);
673
+ }
674
+ // active的滑块,根据滑动距离等比缩小
675
+ // @en The active slider, zoom out proportionally according to the sliding distance
676
+ if (childIndex === index) {
677
+ return 1 - (1 - originScale) * Math.abs(ratio);
678
+ }
679
+ // 其他保持inactiveScale即可
680
+ // @en Others remain inactiveScale
681
+ return originScale;
682
+ }
683
+ function getItemOriginStyle(childIndex) {
684
+ let origin = 0.5;
685
+ const dis = childIndex - index;
686
+ if (dis === 0) {
687
+ // 当前active的卡片,随滑动方向切换origin
688
+ // @en The currently active card, switch origin with the sliding direction
689
+ origin =
690
+ direction === 'right' || (direction === '' && lastDirectionRef.current === 'left')
691
+ ? 0
692
+ : 1;
693
+ }
694
+ else if (dis <= -1) {
695
+ // 当前active之前的卡片,origin均靠最右
696
+ // @en The cards in front of the currently active card, the origin is on the far right
697
+ origin = horizontalUseRtl ? 0 : 1;
698
+ }
699
+ else if (dis >= 1) {
700
+ // 当前active之后的卡片,origin均靠最左
701
+ // @en The cards after the currently active card, the origin is on the far left
702
+ origin = horizontalUseRtl ? 1 : 0;
703
+ }
704
+ const originStr = `${origin * 100}%`;
705
+ return vertical ? `center ${originStr}` : `${originStr} center`;
706
+ }
707
+ function getItemInnerStyle(curIndex) {
708
+ const transitionStyle = getSlideTransitionStyle();
709
+ const childIndex = getShownChildIndex(curIndex);
710
+ const ratio = distance / childSize || 0;
711
+ // 有放大效果的item,随着distance变化而变化scale和transform-origin
712
+ // @en Item with magnification effect, scale and transform-origin change with distance
713
+ // transform效果与fake dom时item的transform需隔离,且scale后会影响item的padding展示
714
+ // @en The transform effect of the item needs to be isolated from the fake dom, and the padding display of the item will be affected after scale.
715
+ // 因此需要缩放时多包裹一层item-inner,单独处理缩放逻辑
716
+ // @en Therefore, need to wrap an additional layer of item-inner when scaling, and handle the scaling logic separately
717
+ const scale = getItemScaleStyle(childIndex, ratio);
718
+ const transformStyle = {
719
+ transform: `${getItemTranslateStyle(childIndex, ratio)} scale(${scale})`,
720
+ transformOrigin: getItemOriginStyle(childIndex),
721
+ };
722
+ return getStyleWithVendor({
723
+ ...transitionStyle,
724
+ ...transformStyle,
725
+ });
726
+ }
727
+ function getItemFakeStyle(childIndex) {
728
+ const styleMap = {
729
+ leftDirec: vertical ? 'top' : leftDirec,
730
+ rightDirec: vertical ? 'bottom' : rightDirec,
731
+ otherDirec: vertical ? 'left' : 'top',
732
+ trans: vertical ? 'Y' : 'X',
733
+ };
734
+ return {
735
+ position: 'absolute',
736
+ [styleMap.otherDirec]: 0,
737
+ ...(childIndex >= 0
738
+ ? {
739
+ [styleMap.leftDirec]: childSize > 0 ? '100%' : `${total * 100}%`,
740
+ transform: `translate${styleMap.trans}(${(childIndex - total) * rtlRatio * 100}%)`,
741
+ }
742
+ : {
743
+ [styleMap.rightDirec]: '100%',
744
+ transform: `translate${styleMap.trans}(${(childIndex + 1) * rtlRatio * 100}%)`,
745
+ }),
746
+ };
747
+ }
748
+ function getItemStyle(childIndex, isFake) {
749
+ const initialStartSpace = spaceBetween + leftOffset;
750
+ const initialEndSpace = spaceBetween + rightOffset;
751
+ const initalSize = vertical ? userSetBoxHeight : '100%';
752
+ const horizontalPaddingStart = horizontalUseRtl ? 'paddingRight' : 'paddingLeft';
753
+ const horizontalPaddingEnd = horizontalUseRtl ? 'paddingLeft' : 'paddingRight';
754
+ const styleMap = {
755
+ size: vertical ? 'height' : 'width',
756
+ paddingStart: vertical ? 'paddingTop' : horizontalPaddingStart,
757
+ paddingEnd: vertical ? 'paddingBottom' : horizontalPaddingEnd,
758
+ translate: vertical ? 'translateY' : 'translateX',
759
+ };
760
+ // bugfix: item 为半透明状态下 fakeItem 和普通 item 重叠露馅问题
761
+ // @en bugfix: Solve the problem of overlapping fakeItem and the normal item when item is translucent
762
+ const transformStyle = isFake
763
+ ? {
764
+ visibility: (childIndex === total && transforms[0] > 0) ||
765
+ (childIndex === -1 && transforms[total - 1] < 0)
766
+ ? 'hidden'
767
+ : 'initial',
768
+ }
769
+ : {
770
+ transform: `${styleMap.translate}(${transforms[childIndex] || 0}px)`,
771
+ };
772
+ // childSize <= 0 说明是未全部加载完成的首屏情况 做一下特殊处理
773
+ // @en childSize <= 0 indicates that the first screen is not fully loaded, so do some special treatment
774
+ const layoutStyle = childSize > 0
775
+ ? {
776
+ [styleMap.size]: childSize - spaceBetween,
777
+ [styleMap.paddingStart]: spaceBetween,
778
+ boxSizing: 'content-box',
779
+ }
780
+ : {
781
+ [styleMap.size]: initalSize,
782
+ [styleMap.paddingStart]: initialStartSpace,
783
+ [styleMap.paddingEnd]: initialEndSpace,
784
+ boxSizing: 'border-box',
785
+ transform: `${styleMap.translate}(${childIndex === index
786
+ ? 0
787
+ : (index - childIndex) * (spaceBetween + leftOffset + rightOffset)}px)`,
788
+ };
789
+ const fakeStyle = isFake ? getItemFakeStyle(childIndex) : {};
790
+ if (isFake && childSize < 0) {
791
+ delete fakeStyle.transform;
792
+ }
793
+ return getStyleWithVendor({
794
+ ...transformStyle,
795
+ ...layoutStyle,
796
+ ...fakeStyle,
797
+ });
798
+ }
799
+ function renderChild(child, childIndex, prefix) {
800
+ // 兼容线上逻辑,不需要切换放大效果的,不包裹item-inner
801
+ // @en No need to switch the magnification effect, do not wrap item-inner
802
+ return inactiveValidScale === 1 ? (child) : (React.createElement("div", { className: `${prefix}-item-inner`, style: getItemInnerStyle(childIndex) }, child));
803
+ }
804
+ function renderFakeItem(prefix, fakeIndex, side) {
805
+ if (!fakeItem || fakeIndex === void 0) {
806
+ return null;
807
+ }
808
+ const posIndex = side === 'left' ? fakeIndex - total : fakeIndex + total;
809
+ return (React.createElement("div", { key: `${fakeIndex}${posIndex}`, "data-fake-index": fakeIndex, "data-index": posIndex, className: cls(`${prefix}-item carousel-item fake-item fake-${side}`, { vertical }), style: getItemStyle(posIndex, true) }, renderChild(allChildren[fakeIndex], posIndex, prefix)));
810
+ }
811
+ function renderAllFakeItem(prefix) {
812
+ return fakeIndexes.map(fakeIndex => renderFakeItem(prefix, fakeIndex.index, fakeIndex.side));
813
+ }
814
+ function renderCarousel({ prefixCls }) {
815
+ const prefix = `${prefixCls}-carousel`;
816
+ return (React.createElement("div", { className: cls(`${prefix}-wrap`, className), style: wrapStyle, ref: domRef },
817
+ needRefreshDom ? (React.createElement("div", { key: "fake-carousel", className: `${prefix} wrap-placeholder`, ref: fakeWrapRef })) : null,
818
+ React.createElement("div", { key: "carousel", className: prefix, onTouchEnd: handleTouchEnd, onTouchCancel: handleTouchEnd, ref: wrapRef, style: getCarouselStyle() },
819
+ React.createElement("div", { className: cls(`${prefix}-inner ${cubic}`, { vertical }), style: getInnerStyle(), ref: innerRef },
820
+ allChildren.map((child, childIndex) => {
821
+ const inView = lazyloadCount !== void 0
822
+ ? childIndex >= index - lazyloadCount &&
823
+ childIndex <= index + lazyloadCount
824
+ : true;
825
+ return (React.createElement("div", { key: childIndex, className: cls(`${prefix}-item carousel-item normal-item`, {
826
+ active: childIndex === index,
827
+ vertical,
828
+ 'ssr-float': childSize <= 0 && childIndex !== index,
829
+ }), style: getItemStyle(childIndex), ref: childRef => {
830
+ itemsRef.current[childIndex] = childRef;
831
+ } }, inView || transforms[childIndex]
832
+ ? renderChild(child, childIndex, prefix)
833
+ : null));
834
+ }),
835
+ renderAllFakeItem(prefix)),
836
+ renderExtra?.(shownIndex)),
837
+ showIndicator && (total > 1 || !hideSingleIndicator) ? (React.createElement("div", { key: "carousel-indicator", className: cls(`${prefix}-indicator pos-${indicatorPos} ${prefix}-indicator-${vertical ? 'vertical' : 'horizontal'}`, { [`vertical ver-pos-${indicatorVerticalPos}`]: vertical }, {
838
+ inverse: indicatorInverse === void 0
839
+ ? indicatorOutside
840
+ : indicatorInverse,
841
+ }, { outside: indicatorOutside }) }, renderIndicator
842
+ ? renderIndicator(shownIndex, shownTotal, lastShownIndexRef.current)
843
+ : indicatorArr.map((_, i) => (React.createElement("i", { key: i, className: cls('indicator', `type-${indicatorType}`, indicatorClass, {
844
+ active: i === shownIndex,
845
+ }) }))))) : null));
846
+ }
847
+ return React.createElement(ContextLayout, null, renderCarousel);
848
+ });
849
+ export default Carousel;