@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.
- package/CHANGELOG.md +29 -0
- package/LICENSE +21 -0
- package/README.en-US.md +2 -2
- package/README.md +2 -2
- package/cjs/_helpers/index.d.ts +1 -0
- package/cjs/_helpers/index.js +9 -0
- package/cjs/_helpers/react-dom.js +18 -10
- package/cjs/avatar/index.js +3 -1
- package/cjs/avatar/type.d.ts +6 -0
- package/cjs/carousel/index.js +18 -1
- package/cjs/steps/index.d.ts +1 -1
- package/cjs/steps/index.js +6 -1
- package/cjs/steps/style/css/index.css +42 -4
- package/cjs/steps/style/index.less +58 -6
- package/cjs/steps/type.d.ts +5 -0
- package/dist/index.js +146 -97
- package/dist/index.min.js +4 -4
- package/dist/style.css +27 -4
- package/dist/style.min.css +1 -1
- package/esm/_helpers/index.d.ts +1 -0
- package/esm/_helpers/index.js +1 -0
- package/esm/_helpers/react-dom.js +15 -11
- package/esm/avatar/index.js +3 -1
- package/esm/avatar/type.d.ts +6 -0
- package/esm/carousel/index.js +18 -1
- package/esm/steps/index.d.ts +1 -1
- package/esm/steps/index.js +7 -2
- package/esm/steps/style/css/index.css +42 -4
- package/esm/steps/style/index.less +58 -6
- package/esm/steps/type.d.ts +5 -0
- package/esnext/_helpers/hooks.d.ts +290 -0
- package/esnext/_helpers/hooks.js +660 -0
- package/esnext/_helpers/index.d.ts +93 -0
- package/esnext/_helpers/index.js +110 -0
- package/esnext/_helpers/react-dom.d.ts +13 -0
- package/esnext/_helpers/react-dom.js +51 -0
- package/esnext/_helpers/render.d.ts +17 -0
- package/esnext/_helpers/render.js +38 -0
- package/esnext/_helpers/type.d.ts +30 -0
- package/esnext/_helpers/type.js +1 -0
- package/esnext/action-sheet/index.d.ts +106 -0
- package/esnext/action-sheet/index.js +53 -0
- package/esnext/action-sheet/methods.d.ts +10 -0
- package/esnext/action-sheet/methods.js +4 -0
- package/esnext/action-sheet/style/css/index.css +741 -0
- package/esnext/action-sheet/style/css/index.d.ts +3 -0
- package/esnext/action-sheet/style/css/index.js +3 -0
- package/esnext/action-sheet/style/index.d.ts +3 -0
- package/esnext/action-sheet/style/index.js +3 -0
- package/esnext/action-sheet/style/index.less +119 -0
- package/esnext/avatar/group.d.ts +9 -0
- package/esnext/avatar/group.js +35 -0
- package/esnext/avatar/index.d.ts +17 -0
- package/esnext/avatar/index.js +87 -0
- package/esnext/avatar/style/css/index.css +792 -0
- package/esnext/avatar/style/css/index.d.ts +3 -0
- package/esnext/avatar/style/css/index.js +3 -0
- package/esnext/avatar/style/index.d.ts +3 -0
- package/esnext/avatar/style/index.js +3 -0
- package/esnext/avatar/style/index.less +201 -0
- package/esnext/avatar/type.d.ts +132 -0
- package/esnext/avatar/type.js +1 -0
- package/esnext/badge/index.d.ts +80 -0
- package/esnext/badge/index.js +29 -0
- package/esnext/badge/style/css/index.css +640 -0
- package/esnext/badge/style/css/index.d.ts +2 -0
- package/esnext/badge/style/css/index.js +2 -0
- package/esnext/badge/style/index.d.ts +2 -0
- package/esnext/badge/style/index.js +2 -0
- package/esnext/badge/style/index.less +109 -0
- package/esnext/button/hooks.d.ts +8 -0
- package/esnext/button/hooks.js +45 -0
- package/esnext/button/index.d.ts +141 -0
- package/esnext/button/index.js +61 -0
- package/esnext/button/style/css/index.css +816 -0
- package/esnext/button/style/css/index.d.ts +3 -0
- package/esnext/button/style/css/index.js +3 -0
- package/esnext/button/style/index.d.ts +3 -0
- package/esnext/button/style/index.js +3 -0
- package/esnext/button/style/index.less +242 -0
- package/esnext/carousel/index.d.ts +383 -0
- package/esnext/carousel/index.js +849 -0
- package/esnext/carousel/style/css/index.css +748 -0
- package/esnext/carousel/style/css/index.d.ts +2 -0
- package/esnext/carousel/style/css/index.js +2 -0
- package/esnext/carousel/style/index.d.ts +2 -0
- package/esnext/carousel/style/index.js +2 -0
- package/esnext/carousel/style/index.less +263 -0
- package/esnext/cell/arrow.d.ts +2 -0
- package/esnext/cell/arrow.js +5 -0
- package/esnext/cell/cell.d.ts +3 -0
- package/esnext/cell/cell.js +24 -0
- package/esnext/cell/group.d.ts +7 -0
- package/esnext/cell/group.js +26 -0
- package/esnext/cell/index.d.ts +14 -0
- package/esnext/cell/index.js +16 -0
- package/esnext/cell/style/css/index.css +1008 -0
- package/esnext/cell/style/css/index.d.ts +2 -0
- package/esnext/cell/style/css/index.js +2 -0
- package/esnext/cell/style/index.d.ts +2 -0
- package/esnext/cell/style/index.js +2 -0
- package/esnext/cell/style/index.less +214 -0
- package/esnext/cell/type.d.ts +125 -0
- package/esnext/cell/type.js +1 -0
- package/esnext/checkbox/checkbox.d.ts +3 -0
- package/esnext/checkbox/checkbox.js +106 -0
- package/esnext/checkbox/group.d.ts +4 -0
- package/esnext/checkbox/group.js +54 -0
- package/esnext/checkbox/hooks/index.d.ts +1 -0
- package/esnext/checkbox/hooks/index.js +1 -0
- package/esnext/checkbox/hooks/useMergeProps.d.ts +3 -0
- package/esnext/checkbox/hooks/useMergeProps.js +20 -0
- package/esnext/checkbox/index.d.ts +19 -0
- package/esnext/checkbox/index.js +22 -0
- package/esnext/checkbox/style/css/index.css +613 -0
- package/esnext/checkbox/style/css/index.d.ts +2 -0
- package/esnext/checkbox/style/css/index.js +2 -0
- package/esnext/checkbox/style/index.d.ts +2 -0
- package/esnext/checkbox/style/index.js +2 -0
- package/esnext/checkbox/style/index.less +119 -0
- package/esnext/checkbox/type.d.ts +162 -0
- package/esnext/checkbox/type.js +27 -0
- package/esnext/circle-progress/index.d.ts +141 -0
- package/esnext/circle-progress/index.js +75 -0
- package/esnext/circle-progress/style/css/index.css +582 -0
- package/esnext/circle-progress/style/css/index.d.ts +2 -0
- package/esnext/circle-progress/style/css/index.js +2 -0
- package/esnext/circle-progress/style/index.d.ts +2 -0
- package/esnext/circle-progress/style/index.js +2 -0
- package/esnext/circle-progress/style/index.less +101 -0
- package/esnext/collapse/collapse.d.ts +3 -0
- package/esnext/collapse/collapse.js +111 -0
- package/esnext/collapse/group.d.ts +21 -0
- package/esnext/collapse/group.js +80 -0
- package/esnext/collapse/index.d.ts +23 -0
- package/esnext/collapse/index.js +14 -0
- package/esnext/collapse/style/css/index.css +662 -0
- package/esnext/collapse/style/css/index.d.ts +2 -0
- package/esnext/collapse/style/css/index.js +2 -0
- package/esnext/collapse/style/index.d.ts +2 -0
- package/esnext/collapse/style/index.js +2 -0
- package/esnext/collapse/style/index.less +106 -0
- package/esnext/collapse/type.d.ts +139 -0
- package/esnext/collapse/type.js +1 -0
- package/esnext/collapse/utils.d.ts +8 -0
- package/esnext/collapse/utils.js +16 -0
- package/esnext/context-provider/index.d.ts +74 -0
- package/esnext/context-provider/index.js +99 -0
- package/esnext/context-provider/style/css/index.css +0 -0
- package/esnext/context-provider/style/css/index.d.ts +2 -0
- package/esnext/context-provider/style/css/index.js +2 -0
- package/esnext/context-provider/style/index.d.ts +2 -0
- package/esnext/context-provider/style/index.js +2 -0
- package/esnext/context-provider/style/index.less +1 -0
- package/esnext/count-down/hooks.d.ts +10 -0
- package/esnext/count-down/hooks.js +107 -0
- package/esnext/count-down/index.d.ts +13 -0
- package/esnext/count-down/index.js +37 -0
- package/esnext/count-down/singleton.d.ts +15 -0
- package/esnext/count-down/singleton.js +52 -0
- package/esnext/count-down/style/css/index.css +534 -0
- package/esnext/count-down/style/css/index.d.ts +2 -0
- package/esnext/count-down/style/css/index.js +2 -0
- package/esnext/count-down/style/index.d.ts +2 -0
- package/esnext/count-down/style/index.js +2 -0
- package/esnext/count-down/style/index.less +37 -0
- package/esnext/count-down/type.d.ts +112 -0
- package/esnext/count-down/type.js +1 -0
- package/esnext/count-down/util.d.ts +8 -0
- package/esnext/count-down/util.js +106 -0
- package/esnext/date-picker/helper.d.ts +5 -0
- package/esnext/date-picker/helper.js +38 -0
- package/esnext/date-picker/index.d.ts +24 -0
- package/esnext/date-picker/index.js +217 -0
- package/esnext/date-picker/style/css/index.css +526 -0
- package/esnext/date-picker/style/css/index.d.ts +3 -0
- package/esnext/date-picker/style/css/index.js +3 -0
- package/esnext/date-picker/style/index.d.ts +3 -0
- package/esnext/date-picker/style/index.js +3 -0
- package/esnext/date-picker/style/index.less +30 -0
- package/esnext/date-picker/type.d.ts +114 -0
- package/esnext/date-picker/type.js +1 -0
- package/esnext/dialog/index.d.ts +213 -0
- package/esnext/dialog/index.js +87 -0
- package/esnext/dialog/methods.d.ts +20 -0
- package/esnext/dialog/methods.js +42 -0
- package/esnext/dialog/style/css/index.css +1111 -0
- package/esnext/dialog/style/css/index.d.ts +3 -0
- package/esnext/dialog/style/css/index.js +3 -0
- package/esnext/dialog/style/index.d.ts +3 -0
- package/esnext/dialog/style/index.js +3 -0
- package/esnext/dialog/style/index.less +376 -0
- package/esnext/divider/index.d.ts +49 -0
- package/esnext/divider/index.js +32 -0
- package/esnext/divider/style/css/index.css +609 -0
- package/esnext/divider/style/css/index.d.ts +2 -0
- package/esnext/divider/style/css/index.js +2 -0
- package/esnext/divider/style/index.d.ts +2 -0
- package/esnext/divider/style/index.js +2 -0
- package/esnext/divider/style/index.less +101 -0
- package/esnext/dropdown/dropdown.d.ts +3 -0
- package/esnext/dropdown/dropdown.js +196 -0
- package/esnext/dropdown/index.d.ts +14 -0
- package/esnext/dropdown/index.js +16 -0
- package/esnext/dropdown/options.d.ts +4 -0
- package/esnext/dropdown/options.js +61 -0
- package/esnext/dropdown/style/css/index.css +653 -0
- package/esnext/dropdown/style/css/index.d.ts +2 -0
- package/esnext/dropdown/style/css/index.js +2 -0
- package/esnext/dropdown/style/index.d.ts +2 -0
- package/esnext/dropdown/style/index.js +2 -0
- package/esnext/dropdown/style/index.less +177 -0
- package/esnext/dropdown/type.d.ts +269 -0
- package/esnext/dropdown/type.js +1 -0
- package/esnext/dropdown-menu/dropdown-menu.d.ts +4 -0
- package/esnext/dropdown-menu/dropdown-menu.js +161 -0
- package/esnext/dropdown-menu/helper.d.ts +34 -0
- package/esnext/dropdown-menu/helper.js +88 -0
- package/esnext/dropdown-menu/index.d.ts +12 -0
- package/esnext/dropdown-menu/index.js +13 -0
- package/esnext/dropdown-menu/style/css/index.css +705 -0
- package/esnext/dropdown-menu/style/css/index.d.ts +3 -0
- package/esnext/dropdown-menu/style/css/index.js +3 -0
- package/esnext/dropdown-menu/style/index.d.ts +3 -0
- package/esnext/dropdown-menu/style/index.js +3 -0
- package/esnext/dropdown-menu/style/index.less +122 -0
- package/esnext/dropdown-menu/type.d.ts +168 -0
- package/esnext/dropdown-menu/type.js +1 -0
- package/esnext/ellipsis/components/js-ellipsis.d.ts +6 -0
- package/esnext/ellipsis/components/js-ellipsis.js +178 -0
- package/esnext/ellipsis/components/native-ellipsis.d.ts +5 -0
- package/esnext/ellipsis/components/native-ellipsis.js +15 -0
- package/esnext/ellipsis/index.d.ts +13 -0
- package/esnext/ellipsis/index.js +31 -0
- package/esnext/ellipsis/style/css/index.css +556 -0
- package/esnext/ellipsis/style/css/index.d.ts +2 -0
- package/esnext/ellipsis/style/css/index.js +2 -0
- package/esnext/ellipsis/style/index.d.ts +2 -0
- package/esnext/ellipsis/style/index.js +2 -0
- package/esnext/ellipsis/style/index.less +63 -0
- package/esnext/ellipsis/type.d.ts +107 -0
- package/esnext/ellipsis/type.js +1 -0
- package/esnext/ellipsis/utils/dom.d.ts +2 -0
- package/esnext/ellipsis/utils/dom.js +35 -0
- package/esnext/ellipsis/utils/is.d.ts +3 -0
- package/esnext/ellipsis/utils/is.js +3 -0
- package/esnext/form/form-item-context.d.ts +3 -0
- package/esnext/form/form-item-context.js +6 -0
- package/esnext/form/form-item.d.ts +4 -0
- package/esnext/form/form-item.js +218 -0
- package/esnext/form/index.d.ts +16 -0
- package/esnext/form/index.js +50 -0
- package/esnext/form/linked-container.d.ts +8 -0
- package/esnext/form/linked-container.js +29 -0
- package/esnext/form/style/css/index.css +670 -0
- package/esnext/form/style/css/index.d.ts +2 -0
- package/esnext/form/style/css/index.js +2 -0
- package/esnext/form/style/index.d.ts +2 -0
- package/esnext/form/style/index.js +2 -0
- package/esnext/form/style/index.less +172 -0
- package/esnext/form/type.d.ts +373 -0
- package/esnext/form/type.js +26 -0
- package/esnext/form/useForm.d.ts +18 -0
- package/esnext/form/useForm.js +203 -0
- package/esnext/form/utils.d.ts +7 -0
- package/esnext/form/utils.js +21 -0
- package/esnext/grid/index.d.ts +112 -0
- package/esnext/grid/index.js +79 -0
- package/esnext/grid/style/css/index.css +661 -0
- package/esnext/grid/style/css/index.d.ts +2 -0
- package/esnext/grid/style/css/index.js +2 -0
- package/esnext/grid/style/index.d.ts +2 -0
- package/esnext/grid/style/index.js +2 -0
- package/esnext/grid/style/index.less +157 -0
- package/esnext/icon/IconAdd/index.d.ts +7 -0
- package/esnext/icon/IconAdd/index.js +7 -0
- package/esnext/icon/IconArrowBack/index.d.ts +7 -0
- package/esnext/icon/IconArrowBack/index.js +7 -0
- package/esnext/icon/IconArrowDown/index.d.ts +7 -0
- package/esnext/icon/IconArrowDown/index.js +7 -0
- package/esnext/icon/IconArrowIn/index.d.ts +7 -0
- package/esnext/icon/IconArrowIn/index.js +7 -0
- package/esnext/icon/IconArrowUp/index.d.ts +7 -0
- package/esnext/icon/IconArrowUp/index.js +7 -0
- package/esnext/icon/IconCheck/index.d.ts +7 -0
- package/esnext/icon/IconCheck/index.js +7 -0
- package/esnext/icon/IconCheckBold/index.d.ts +7 -0
- package/esnext/icon/IconCheckBold/index.js +8 -0
- package/esnext/icon/IconCircleChecked/index.d.ts +7 -0
- package/esnext/icon/IconCircleChecked/index.js +7 -0
- package/esnext/icon/IconCircleDisabled/index.d.ts +7 -0
- package/esnext/icon/IconCircleDisabled/index.js +7 -0
- package/esnext/icon/IconCircleUnchecked/index.d.ts +7 -0
- package/esnext/icon/IconCircleUnchecked/index.js +7 -0
- package/esnext/icon/IconClear/index.d.ts +7 -0
- package/esnext/icon/IconClear/index.js +7 -0
- package/esnext/icon/IconClose/index.d.ts +7 -0
- package/esnext/icon/IconClose/index.js +7 -0
- package/esnext/icon/IconCloseBold/index.d.ts +7 -0
- package/esnext/icon/IconCloseBold/index.js +8 -0
- package/esnext/icon/IconDelete/index.d.ts +7 -0
- package/esnext/icon/IconDelete/index.js +7 -0
- package/esnext/icon/IconDownload/index.d.ts +7 -0
- package/esnext/icon/IconDownload/index.js +7 -0
- package/esnext/icon/IconEdit/index.d.ts +7 -0
- package/esnext/icon/IconEdit/index.js +7 -0
- package/esnext/icon/IconErrorCircle/index.d.ts +7 -0
- package/esnext/icon/IconErrorCircle/index.js +8 -0
- package/esnext/icon/IconEyeInvisible/index.d.ts +7 -0
- package/esnext/icon/IconEyeInvisible/index.js +7 -0
- package/esnext/icon/IconEyeVisible/index.d.ts +7 -0
- package/esnext/icon/IconEyeVisible/index.js +7 -0
- package/esnext/icon/IconEyelashInvisible/index.d.ts +7 -0
- package/esnext/icon/IconEyelashInvisible/index.js +7 -0
- package/esnext/icon/IconFile/index.d.ts +7 -0
- package/esnext/icon/IconFile/index.js +7 -0
- package/esnext/icon/IconGift/index.d.ts +7 -0
- package/esnext/icon/IconGift/index.js +8 -0
- package/esnext/icon/IconHeart/index.d.ts +7 -0
- package/esnext/icon/IconHeart/index.js +8 -0
- package/esnext/icon/IconHome/index.d.ts +7 -0
- package/esnext/icon/IconHome/index.js +7 -0
- package/esnext/icon/IconKeyboard/index.d.ts +7 -0
- package/esnext/icon/IconKeyboard/index.js +8 -0
- package/esnext/icon/IconKeyboardDelete/index.d.ts +7 -0
- package/esnext/icon/IconKeyboardDelete/index.js +8 -0
- package/esnext/icon/IconLikeCircle/index.d.ts +7 -0
- package/esnext/icon/IconLikeCircle/index.js +7 -0
- package/esnext/icon/IconMinus/index.d.ts +7 -0
- package/esnext/icon/IconMinus/index.js +8 -0
- package/esnext/icon/IconMore/index.d.ts +7 -0
- package/esnext/icon/IconMore/index.js +7 -0
- package/esnext/icon/IconNotice/index.d.ts +7 -0
- package/esnext/icon/IconNotice/index.js +8 -0
- package/esnext/icon/IconNoticeOff/index.d.ts +7 -0
- package/esnext/icon/IconNoticeOff/index.js +8 -0
- package/esnext/icon/IconPicture/index.d.ts +7 -0
- package/esnext/icon/IconPicture/index.js +7 -0
- package/esnext/icon/IconPlay/index.d.ts +7 -0
- package/esnext/icon/IconPlay/index.js +8 -0
- package/esnext/icon/IconQuestionCircle/index.d.ts +7 -0
- package/esnext/icon/IconQuestionCircle/index.js +7 -0
- package/esnext/icon/IconRefresh/index.d.ts +7 -0
- package/esnext/icon/IconRefresh/index.js +7 -0
- package/esnext/icon/IconSad/index.d.ts +7 -0
- package/esnext/icon/IconSad/index.js +7 -0
- package/esnext/icon/IconScan/index.d.ts +7 -0
- package/esnext/icon/IconScan/index.js +7 -0
- package/esnext/icon/IconSearch/index.d.ts +7 -0
- package/esnext/icon/IconSearch/index.js +7 -0
- package/esnext/icon/IconSetting/index.d.ts +7 -0
- package/esnext/icon/IconSetting/index.js +8 -0
- package/esnext/icon/IconShop/index.d.ts +7 -0
- package/esnext/icon/IconShop/index.js +8 -0
- package/esnext/icon/IconShopping/index.d.ts +7 -0
- package/esnext/icon/IconShopping/index.js +8 -0
- package/esnext/icon/IconSmileFill/index.d.ts +7 -0
- package/esnext/icon/IconSmileFill/index.js +7 -0
- package/esnext/icon/IconSound/index.d.ts +7 -0
- package/esnext/icon/IconSound/index.js +8 -0
- package/esnext/icon/IconSquareChecked/index.d.ts +7 -0
- package/esnext/icon/IconSquareChecked/index.js +7 -0
- package/esnext/icon/IconSquareDisabled/index.d.ts +7 -0
- package/esnext/icon/IconSquareDisabled/index.js +7 -0
- package/esnext/icon/IconSquareUnchecked/index.d.ts +7 -0
- package/esnext/icon/IconSquareUnchecked/index.js +7 -0
- package/esnext/icon/IconStar/index.d.ts +7 -0
- package/esnext/icon/IconStar/index.js +7 -0
- package/esnext/icon/IconStarFill/index.d.ts +7 -0
- package/esnext/icon/IconStarFill/index.js +8 -0
- package/esnext/icon/IconStarHalf/index.d.ts +7 -0
- package/esnext/icon/IconStarHalf/index.js +7 -0
- package/esnext/icon/IconSubway/index.d.ts +7 -0
- package/esnext/icon/IconSubway/index.js +8 -0
- package/esnext/icon/IconSuccessCircle/index.d.ts +7 -0
- package/esnext/icon/IconSuccessCircle/index.js +8 -0
- package/esnext/icon/IconTriDown/index.d.ts +7 -0
- package/esnext/icon/IconTriDown/index.js +8 -0
- package/esnext/icon/IconTriUp/index.d.ts +7 -0
- package/esnext/icon/IconTriUp/index.js +8 -0
- package/esnext/icon/IconUpload/index.d.ts +7 -0
- package/esnext/icon/IconUpload/index.js +7 -0
- package/esnext/icon/IconUser/index.d.ts +7 -0
- package/esnext/icon/IconUser/index.js +7 -0
- package/esnext/icon/IconUserFill/index.d.ts +7 -0
- package/esnext/icon/IconUserFill/index.js +7 -0
- package/esnext/icon/IconWarnCircle/index.d.ts +7 -0
- package/esnext/icon/IconWarnCircle/index.js +8 -0
- package/esnext/icon/IconWarnCircleFill/index.d.ts +7 -0
- package/esnext/icon/IconWarnCircleFill/index.js +8 -0
- package/esnext/icon/index.d.ts +59 -0
- package/esnext/icon/index.js +59 -0
- package/esnext/icon/type.d.ts +10 -0
- package/esnext/icon/type.js +1 -0
- package/esnext/image/index.d.ts +186 -0
- package/esnext/image/index.js +223 -0
- package/esnext/image/style/css/index.css +734 -0
- package/esnext/image/style/css/index.d.ts +3 -0
- package/esnext/image/style/css/index.js +3 -0
- package/esnext/image/style/index.d.ts +3 -0
- package/esnext/image/style/index.js +3 -0
- package/esnext/image/style/index.less +198 -0
- package/esnext/image-picker/add-icon.d.ts +2 -0
- package/esnext/image-picker/add-icon.js +5 -0
- package/esnext/image-picker/index.d.ts +16 -0
- package/esnext/image-picker/index.js +77 -0
- package/esnext/image-picker/style/css/index.css +688 -0
- package/esnext/image-picker/style/css/index.d.ts +4 -0
- package/esnext/image-picker/style/css/index.js +4 -0
- package/esnext/image-picker/style/index.d.ts +4 -0
- package/esnext/image-picker/style/index.js +4 -0
- package/esnext/image-picker/style/index.less +170 -0
- package/esnext/image-picker/type.d.ts +115 -0
- package/esnext/image-picker/type.js +1 -0
- package/esnext/image-preview/index.d.ts +296 -0
- package/esnext/image-preview/index.js +794 -0
- package/esnext/image-preview/methods.d.ts +13 -0
- package/esnext/image-preview/methods.js +46 -0
- package/esnext/image-preview/style/css/index.css +664 -0
- package/esnext/image-preview/style/css/index.d.ts +5 -0
- package/esnext/image-preview/style/css/index.js +5 -0
- package/esnext/image-preview/style/index.d.ts +5 -0
- package/esnext/image-preview/style/index.js +5 -0
- package/esnext/image-preview/style/index.less +140 -0
- package/esnext/index-bar/context.d.ts +3 -0
- package/esnext/index-bar/context.js +6 -0
- package/esnext/index-bar/group.d.ts +3 -0
- package/esnext/index-bar/group.js +33 -0
- package/esnext/index-bar/index.d.ts +15 -0
- package/esnext/index-bar/index.js +151 -0
- package/esnext/index-bar/side-bar.d.ts +3 -0
- package/esnext/index-bar/side-bar.js +44 -0
- package/esnext/index-bar/style/css/index.css +767 -0
- package/esnext/index-bar/style/css/index.d.ts +3 -0
- package/esnext/index-bar/style/css/index.js +3 -0
- package/esnext/index-bar/style/index.d.ts +3 -0
- package/esnext/index-bar/style/index.js +3 -0
- package/esnext/index-bar/style/index.less +189 -0
- package/esnext/index-bar/type.d.ts +195 -0
- package/esnext/index-bar/type.js +1 -0
- package/esnext/index-bar/utils.d.ts +6 -0
- package/esnext/index-bar/utils.js +44 -0
- package/esnext/index.d.ts +59 -0
- package/esnext/index.js +59 -0
- package/esnext/input/hooks.d.ts +14 -0
- package/esnext/input/hooks.js +174 -0
- package/esnext/input/index.d.ts +60 -0
- package/esnext/input/index.js +28 -0
- package/esnext/input/props.d.ts +182 -0
- package/esnext/input/props.js +1 -0
- package/esnext/input/style/css/index.css +759 -0
- package/esnext/input/style/css/index.d.ts +2 -0
- package/esnext/input/style/css/index.js +2 -0
- package/esnext/input/style/index.d.ts +2 -0
- package/esnext/input/style/index.js +2 -0
- package/esnext/input/style/index.less +195 -0
- package/esnext/keyboard/index.d.ts +13 -0
- package/esnext/keyboard/index.js +159 -0
- package/esnext/keyboard/style/css/index.css +633 -0
- package/esnext/keyboard/style/css/index.d.ts +3 -0
- package/esnext/keyboard/style/css/index.js +3 -0
- package/esnext/keyboard/style/index.d.ts +3 -0
- package/esnext/keyboard/style/index.js +3 -0
- package/esnext/keyboard/style/index.less +131 -0
- package/esnext/keyboard/type.d.ts +102 -0
- package/esnext/keyboard/type.js +1 -0
- package/esnext/load-more/index.d.ts +158 -0
- package/esnext/load-more/index.js +150 -0
- package/esnext/load-more/style/css/index.css +534 -0
- package/esnext/load-more/style/css/index.d.ts +2 -0
- package/esnext/load-more/style/css/index.js +2 -0
- package/esnext/load-more/style/index.d.ts +2 -0
- package/esnext/load-more/style/index.js +2 -0
- package/esnext/load-more/style/index.less +37 -0
- package/esnext/loading/index.d.ts +76 -0
- package/esnext/loading/index.js +123 -0
- package/esnext/loading/style/css/index.css +648 -0
- package/esnext/loading/style/css/index.d.ts +2 -0
- package/esnext/loading/style/css/index.js +2 -0
- package/esnext/loading/style/index.d.ts +2 -0
- package/esnext/loading/style/index.js +2 -0
- package/esnext/loading/style/index.less +147 -0
- package/esnext/masking/index.d.ts +225 -0
- package/esnext/masking/index.js +114 -0
- package/esnext/masking/methods.d.ts +23 -0
- package/esnext/masking/methods.js +56 -0
- package/esnext/masking/style/css/index.css +552 -0
- package/esnext/masking/style/css/index.d.ts +3 -0
- package/esnext/masking/style/css/index.js +3 -0
- package/esnext/masking/style/index.d.ts +3 -0
- package/esnext/masking/style/index.js +3 -0
- package/esnext/masking/style/index.less +55 -0
- package/esnext/nav-bar/back-icon.d.ts +5 -0
- package/esnext/nav-bar/back-icon.js +9 -0
- package/esnext/nav-bar/index.d.ts +135 -0
- package/esnext/nav-bar/index.js +96 -0
- package/esnext/nav-bar/style/css/index.css +706 -0
- package/esnext/nav-bar/style/css/index.d.ts +2 -0
- package/esnext/nav-bar/style/css/index.js +2 -0
- package/esnext/nav-bar/style/index.d.ts +2 -0
- package/esnext/nav-bar/style/index.js +2 -0
- package/esnext/nav-bar/style/index.less +150 -0
- package/esnext/notice-bar/index.d.ts +107 -0
- package/esnext/notice-bar/index.js +126 -0
- package/esnext/notice-bar/style/css/index.css +685 -0
- package/esnext/notice-bar/style/css/index.d.ts +2 -0
- package/esnext/notice-bar/style/css/index.js +2 -0
- package/esnext/notice-bar/style/index.d.ts +2 -0
- package/esnext/notice-bar/style/index.js +2 -0
- package/esnext/notice-bar/style/index.less +160 -0
- package/esnext/notify/index.d.ts +97 -0
- package/esnext/notify/index.js +123 -0
- package/esnext/notify/methods.d.ts +14 -0
- package/esnext/notify/methods.js +63 -0
- package/esnext/notify/style/css/index.css +591 -0
- package/esnext/notify/style/css/index.d.ts +2 -0
- package/esnext/notify/style/css/index.js +2 -0
- package/esnext/notify/style/index.d.ts +2 -0
- package/esnext/notify/style/index.js +2 -0
- package/esnext/notify/style/index.less +90 -0
- package/esnext/notify/type.d.ts +70 -0
- package/esnext/notify/type.js +1 -0
- package/esnext/pagination/arrow.d.ts +2 -0
- package/esnext/pagination/arrow.js +5 -0
- package/esnext/pagination/index.d.ts +124 -0
- package/esnext/pagination/index.js +104 -0
- package/esnext/pagination/style/css/index.css +708 -0
- package/esnext/pagination/style/css/index.d.ts +2 -0
- package/esnext/pagination/style/css/index.js +2 -0
- package/esnext/pagination/style/index.d.ts +2 -0
- package/esnext/pagination/style/index.js +2 -0
- package/esnext/pagination/style/index.less +176 -0
- package/esnext/picker/index.d.ts +50 -0
- package/esnext/picker/index.js +93 -0
- package/esnext/picker/style/css/index.css +592 -0
- package/esnext/picker/style/css/index.d.ts +4 -0
- package/esnext/picker/style/css/index.js +4 -0
- package/esnext/picker/style/index.d.ts +4 -0
- package/esnext/picker/style/index.js +4 -0
- package/esnext/picker/style/index.less +95 -0
- package/esnext/picker/type.d.ts +131 -0
- package/esnext/picker/type.js +1 -0
- package/esnext/picker-view/components/cascader.d.ts +25 -0
- package/esnext/picker-view/components/cascader.js +54 -0
- package/esnext/picker-view/components/multi-picker.d.ts +11 -0
- package/esnext/picker-view/components/multi-picker.js +32 -0
- package/esnext/picker-view/components/picker-cell.d.ts +28 -0
- package/esnext/picker-view/components/picker-cell.js +284 -0
- package/esnext/picker-view/index.d.ts +62 -0
- package/esnext/picker-view/index.js +135 -0
- package/esnext/picker-view/style/css/index.css +750 -0
- package/esnext/picker-view/style/css/index.d.ts +2 -0
- package/esnext/picker-view/style/css/index.js +2 -0
- package/esnext/picker-view/style/index.d.ts +2 -0
- package/esnext/picker-view/style/index.js +2 -0
- package/esnext/picker-view/style/index.less +125 -0
- package/esnext/picker-view/type.d.ts +89 -0
- package/esnext/picker-view/type.js +1 -0
- package/esnext/popover/hooks/index.d.ts +2 -0
- package/esnext/popover/hooks/index.js +2 -0
- package/esnext/popover/hooks/useEvent.d.ts +8 -0
- package/esnext/popover/hooks/useEvent.js +148 -0
- package/esnext/popover/hooks/usePosition.d.ts +18 -0
- package/esnext/popover/hooks/usePosition.js +419 -0
- package/esnext/popover/index.d.ts +14 -0
- package/esnext/popover/index.js +20 -0
- package/esnext/popover/menu.d.ts +3 -0
- package/esnext/popover/menu.js +80 -0
- package/esnext/popover/popover-inner.d.ts +3 -0
- package/esnext/popover/popover-inner.js +79 -0
- package/esnext/popover/popover.d.ts +3 -0
- package/esnext/popover/popover.js +132 -0
- package/esnext/popover/style/css/index.css +993 -0
- package/esnext/popover/style/css/index.d.ts +3 -0
- package/esnext/popover/style/css/index.js +3 -0
- package/esnext/popover/style/css/menu.css +673 -0
- package/esnext/popover/style/index.d.ts +3 -0
- package/esnext/popover/style/index.js +3 -0
- package/esnext/popover/style/index.less +353 -0
- package/esnext/popover/style/menu.less +163 -0
- package/esnext/popover/type.d.ts +447 -0
- package/esnext/popover/type.js +1 -0
- package/esnext/popup/index.d.ts +86 -0
- package/esnext/popup/index.js +39 -0
- package/esnext/popup/methods.d.ts +10 -0
- package/esnext/popup/methods.js +4 -0
- package/esnext/popup/style/css/index.css +638 -0
- package/esnext/popup/style/css/index.d.ts +3 -0
- package/esnext/popup/style/css/index.js +3 -0
- package/esnext/popup/style/index.d.ts +3 -0
- package/esnext/popup/style/index.js +3 -0
- package/esnext/popup/style/index.less +114 -0
- package/esnext/popup-swiper/index.d.ts +93 -0
- package/esnext/popup-swiper/index.js +192 -0
- package/esnext/popup-swiper/methods.d.ts +10 -0
- package/esnext/popup-swiper/methods.js +4 -0
- package/esnext/popup-swiper/style/css/index.css +531 -0
- package/esnext/popup-swiper/style/css/index.d.ts +3 -0
- package/esnext/popup-swiper/style/css/index.js +3 -0
- package/esnext/popup-swiper/style/index.d.ts +3 -0
- package/esnext/popup-swiper/style/index.js +3 -0
- package/esnext/popup-swiper/style/index.less +35 -0
- package/esnext/portal/index.d.ts +23 -0
- package/esnext/portal/index.js +18 -0
- package/esnext/portal/style/css/index.css +0 -0
- package/esnext/portal/style/css/index.d.ts +2 -0
- package/esnext/portal/style/css/index.js +2 -0
- package/esnext/portal/style/index.d.ts +2 -0
- package/esnext/portal/style/index.js +2 -0
- package/esnext/portal/style/index.less +1 -0
- package/esnext/progress/index.d.ts +126 -0
- package/esnext/progress/index.js +66 -0
- package/esnext/progress/style/css/index.css +692 -0
- package/esnext/progress/style/css/index.d.ts +2 -0
- package/esnext/progress/style/css/index.js +2 -0
- package/esnext/progress/style/index.d.ts +2 -0
- package/esnext/progress/style/index.js +2 -0
- package/esnext/progress/style/index.less +205 -0
- package/esnext/pull-refresh/android-pull-refresh.d.ts +3 -0
- package/esnext/pull-refresh/android-pull-refresh.js +168 -0
- package/esnext/pull-refresh/hooks.d.ts +30 -0
- package/esnext/pull-refresh/hooks.js +73 -0
- package/esnext/pull-refresh/index.d.ts +28 -0
- package/esnext/pull-refresh/index.js +21 -0
- package/esnext/pull-refresh/ios-pull-refresh.d.ts +3 -0
- package/esnext/pull-refresh/ios-pull-refresh.js +137 -0
- package/esnext/pull-refresh/model.d.ts +111 -0
- package/esnext/pull-refresh/model.js +8 -0
- package/esnext/pull-refresh/style/css/index.css +650 -0
- package/esnext/pull-refresh/style/css/index.d.ts +3 -0
- package/esnext/pull-refresh/style/css/index.js +3 -0
- package/esnext/pull-refresh/style/index.d.ts +3 -0
- package/esnext/pull-refresh/style/index.js +3 -0
- package/esnext/pull-refresh/style/index.less +131 -0
- package/esnext/radio/group.d.ts +5 -0
- package/esnext/radio/group.js +50 -0
- package/esnext/radio/index.d.ts +19 -0
- package/esnext/radio/index.js +22 -0
- package/esnext/radio/radio.d.ts +5 -0
- package/esnext/radio/radio.js +13 -0
- package/esnext/radio/style/css/index.css +604 -0
- package/esnext/radio/style/css/index.d.ts +2 -0
- package/esnext/radio/style/css/index.js +2 -0
- package/esnext/radio/style/index.d.ts +2 -0
- package/esnext/radio/style/index.js +2 -0
- package/esnext/radio/style/index.less +114 -0
- package/esnext/radio/type.d.ts +31 -0
- package/esnext/radio/type.js +1 -0
- package/esnext/rate/index.d.ts +109 -0
- package/esnext/rate/index.js +87 -0
- package/esnext/rate/style/css/index.css +595 -0
- package/esnext/rate/style/css/index.d.ts +2 -0
- package/esnext/rate/style/css/index.js +2 -0
- package/esnext/rate/style/index.d.ts +2 -0
- package/esnext/rate/style/index.js +2 -0
- package/esnext/rate/style/index.less +106 -0
- package/esnext/search-bar/association.d.ts +3 -0
- package/esnext/search-bar/association.js +51 -0
- package/esnext/search-bar/cancel-button.d.ts +10 -0
- package/esnext/search-bar/cancel-button.js +18 -0
- package/esnext/search-bar/highlight.d.ts +12 -0
- package/esnext/search-bar/highlight.js +46 -0
- package/esnext/search-bar/index.d.ts +13 -0
- package/esnext/search-bar/index.js +109 -0
- package/esnext/search-bar/style/css/index.css +765 -0
- package/esnext/search-bar/style/css/index.d.ts +2 -0
- package/esnext/search-bar/style/css/index.js +2 -0
- package/esnext/search-bar/style/index.d.ts +2 -0
- package/esnext/search-bar/style/index.js +2 -0
- package/esnext/search-bar/style/index.less +198 -0
- package/esnext/search-bar/type.d.ts +163 -0
- package/esnext/search-bar/type.js +1 -0
- package/esnext/show-monitor/index.d.ts +115 -0
- package/esnext/show-monitor/index.js +416 -0
- package/esnext/show-monitor/style/css/index.css +0 -0
- package/esnext/show-monitor/style/css/index.d.ts +2 -0
- package/esnext/show-monitor/style/css/index.js +2 -0
- package/esnext/show-monitor/style/index.d.ts +2 -0
- package/esnext/show-monitor/style/index.js +2 -0
- package/esnext/show-monitor/style/index.less +1 -0
- package/esnext/skeleton/elements.d.ts +7 -0
- package/esnext/skeleton/elements.js +117 -0
- package/esnext/skeleton/index.d.ts +19 -0
- package/esnext/skeleton/index.js +50 -0
- package/esnext/skeleton/skeleton-context.d.ts +3 -0
- package/esnext/skeleton/skeleton-context.js +5 -0
- package/esnext/skeleton/style/css/index.css +712 -0
- package/esnext/skeleton/style/css/index.d.ts +3 -0
- package/esnext/skeleton/style/css/index.js +3 -0
- package/esnext/skeleton/style/index.d.ts +3 -0
- package/esnext/skeleton/style/index.js +3 -0
- package/esnext/skeleton/style/index.less +182 -0
- package/esnext/skeleton/type.d.ts +105 -0
- package/esnext/skeleton/type.js +1 -0
- package/esnext/slider/hooks/index.d.ts +12 -0
- package/esnext/slider/hooks/index.js +33 -0
- package/esnext/slider/hooks/useSliderEvents.d.ts +17 -0
- package/esnext/slider/hooks/useSliderEvents.js +128 -0
- package/esnext/slider/hooks/useSliderIcon.d.ts +7 -0
- package/esnext/slider/hooks/useSliderIcon.js +41 -0
- package/esnext/slider/hooks/useSliderInit.d.ts +14 -0
- package/esnext/slider/hooks/useSliderInit.js +146 -0
- package/esnext/slider/hooks/useSliderStyle.d.ts +13 -0
- package/esnext/slider/hooks/useSliderStyle.js +39 -0
- package/esnext/slider/index.d.ts +163 -0
- package/esnext/slider/index.js +120 -0
- package/esnext/slider/marks.d.ts +11 -0
- package/esnext/slider/marks.js +17 -0
- package/esnext/slider/popover.d.ts +6 -0
- package/esnext/slider/popover.js +13 -0
- package/esnext/slider/style/css/index.css +863 -0
- package/esnext/slider/style/css/index.d.ts +3 -0
- package/esnext/slider/style/css/index.js +3 -0
- package/esnext/slider/style/index.d.ts +3 -0
- package/esnext/slider/style/index.js +3 -0
- package/esnext/slider/style/index.less +366 -0
- package/esnext/slider/thumb.d.ts +9 -0
- package/esnext/slider/thumb.js +21 -0
- package/esnext/stepper/hooks/useButtonClick.d.ts +11 -0
- package/esnext/stepper/hooks/useButtonClick.js +46 -0
- package/esnext/stepper/hooks/useInputEvent.d.ts +10 -0
- package/esnext/stepper/hooks/useInputEvent.js +41 -0
- package/esnext/stepper/hooks/useValue.d.ts +7 -0
- package/esnext/stepper/hooks/useValue.js +33 -0
- package/esnext/stepper/index.d.ts +16 -0
- package/esnext/stepper/index.js +81 -0
- package/esnext/stepper/style/css/index.css +636 -0
- package/esnext/stepper/style/css/index.d.ts +2 -0
- package/esnext/stepper/style/css/index.js +2 -0
- package/esnext/stepper/style/index.d.ts +2 -0
- package/esnext/stepper/style/index.js +2 -0
- package/esnext/stepper/style/index.less +161 -0
- package/esnext/stepper/type.d.ts +159 -0
- package/esnext/stepper/type.js +1 -0
- package/esnext/steps/index.d.ts +19 -0
- package/esnext/steps/index.js +53 -0
- package/esnext/steps/step.d.ts +4 -0
- package/esnext/steps/step.js +43 -0
- package/esnext/steps/style/css/index.css +915 -0
- package/esnext/steps/style/css/index.d.ts +2 -0
- package/esnext/steps/style/css/index.js +2 -0
- package/esnext/steps/style/index.d.ts +2 -0
- package/esnext/steps/style/index.js +2 -0
- package/esnext/steps/style/index.less +459 -0
- package/esnext/steps/type.d.ts +115 -0
- package/esnext/steps/type.js +1 -0
- package/esnext/sticky/index.d.ts +141 -0
- package/esnext/sticky/index.js +165 -0
- package/esnext/sticky/style/css/index.css +526 -0
- package/esnext/sticky/style/css/index.d.ts +2 -0
- package/esnext/sticky/style/css/index.js +2 -0
- package/esnext/sticky/style/index.d.ts +2 -0
- package/esnext/sticky/style/index.js +2 -0
- package/esnext/sticky/style/index.less +30 -0
- package/esnext/style.d.ts +60 -0
- package/esnext/style.js +60 -0
- package/esnext/swipe-action/index.d.ts +13 -0
- package/esnext/swipe-action/index.js +220 -0
- package/esnext/swipe-action/item.d.ts +11 -0
- package/esnext/swipe-action/item.js +20 -0
- package/esnext/swipe-action/style/css/index.css +620 -0
- package/esnext/swipe-action/style/css/index.d.ts +2 -0
- package/esnext/swipe-action/style/css/index.js +2 -0
- package/esnext/swipe-action/style/index.d.ts +2 -0
- package/esnext/swipe-action/style/index.js +2 -0
- package/esnext/swipe-action/style/index.less +132 -0
- package/esnext/swipe-action/type.d.ts +123 -0
- package/esnext/swipe-action/type.js +1 -0
- package/esnext/swipe-load/index.d.ts +13 -0
- package/esnext/swipe-load/index.js +255 -0
- package/esnext/swipe-load/style/css/index.css +561 -0
- package/esnext/swipe-load/style/css/index.d.ts +2 -0
- package/esnext/swipe-load/style/css/index.js +2 -0
- package/esnext/swipe-load/style/index.d.ts +2 -0
- package/esnext/swipe-load/style/index.js +2 -0
- package/esnext/swipe-load/style/index.less +66 -0
- package/esnext/swipe-load/type.d.ts +152 -0
- package/esnext/swipe-load/type.js +1 -0
- package/esnext/switch/index.d.ts +105 -0
- package/esnext/switch/index.js +83 -0
- package/esnext/switch/style/css/index.css +765 -0
- package/esnext/switch/style/css/index.d.ts +2 -0
- package/esnext/switch/style/css/index.js +2 -0
- package/esnext/switch/style/index.d.ts +2 -0
- package/esnext/switch/style/index.js +2 -0
- package/esnext/switch/style/index.less +217 -0
- package/esnext/tab-bar/index.d.ts +14 -0
- package/esnext/tab-bar/index.js +16 -0
- package/esnext/tab-bar/item.d.ts +3 -0
- package/esnext/tab-bar/item.js +31 -0
- package/esnext/tab-bar/style/css/index.css +617 -0
- package/esnext/tab-bar/style/css/index.d.ts +2 -0
- package/esnext/tab-bar/style/css/index.js +2 -0
- package/esnext/tab-bar/style/index.d.ts +2 -0
- package/esnext/tab-bar/style/index.js +2 -0
- package/esnext/tab-bar/style/index.less +96 -0
- package/esnext/tab-bar/tab-bar.d.ts +11 -0
- package/esnext/tab-bar/tab-bar.js +40 -0
- package/esnext/tab-bar/type.d.ts +95 -0
- package/esnext/tab-bar/type.js +1 -0
- package/esnext/tabs/index.d.ts +13 -0
- package/esnext/tabs/index.js +340 -0
- package/esnext/tabs/style/css/index.css +1162 -0
- package/esnext/tabs/style/css/index.d.ts +2 -0
- package/esnext/tabs/style/css/index.js +2 -0
- package/esnext/tabs/style/index.d.ts +2 -0
- package/esnext/tabs/style/index.js +2 -0
- package/esnext/tabs/style/index.less +559 -0
- package/esnext/tabs/tab-cell-underline.d.ts +4 -0
- package/esnext/tabs/tab-cell-underline.js +237 -0
- package/esnext/tabs/tab-cell.d.ts +4 -0
- package/esnext/tabs/tab-cell.js +258 -0
- package/esnext/tabs/tab-pane.d.ts +4 -0
- package/esnext/tabs/tab-pane.js +241 -0
- package/esnext/tabs/type.d.ts +629 -0
- package/esnext/tabs/type.js +1 -0
- package/esnext/tag/index.d.ts +14 -0
- package/esnext/tag/index.js +20 -0
- package/esnext/tag/list.d.ts +3 -0
- package/esnext/tag/list.js +47 -0
- package/esnext/tag/style/css/index.css +738 -0
- package/esnext/tag/style/css/index.d.ts +2 -0
- package/esnext/tag/style/css/index.js +2 -0
- package/esnext/tag/style/index.d.ts +2 -0
- package/esnext/tag/style/index.js +2 -0
- package/esnext/tag/style/index.less +188 -0
- package/esnext/tag/tag.d.ts +3 -0
- package/esnext/tag/tag.js +32 -0
- package/esnext/tag/type.d.ts +159 -0
- package/esnext/tag/type.js +1 -0
- package/esnext/textarea/index.d.ts +96 -0
- package/esnext/textarea/index.js +88 -0
- package/esnext/textarea/style/css/index.css +572 -0
- package/esnext/textarea/style/css/index.d.ts +3 -0
- package/esnext/textarea/style/css/index.js +3 -0
- package/esnext/textarea/style/index.d.ts +3 -0
- package/esnext/textarea/style/index.js +3 -0
- package/esnext/textarea/style/index.less +84 -0
- package/esnext/toast/index.d.ts +257 -0
- package/esnext/toast/index.js +142 -0
- package/esnext/toast/methods.d.ts +16 -0
- package/esnext/toast/methods.js +61 -0
- package/esnext/toast/style/css/index.css +658 -0
- package/esnext/toast/style/css/index.d.ts +4 -0
- package/esnext/toast/style/css/index.js +4 -0
- package/esnext/toast/style/index.d.ts +4 -0
- package/esnext/toast/style/index.js +4 -0
- package/esnext/toast/style/index.less +130 -0
- package/esnext/transition/index.d.ts +49 -0
- package/esnext/transition/index.js +15 -0
- package/esnext/transition/style/css/index.css +549 -0
- package/esnext/transition/style/css/index.d.ts +2 -0
- package/esnext/transition/style/css/index.js +2 -0
- package/esnext/transition/style/index.d.ts +2 -0
- package/esnext/transition/style/index.js +2 -0
- package/esnext/transition/style/index.less +53 -0
- package/esnext/uploader/index.d.ts +16 -0
- package/esnext/uploader/index.js +75 -0
- package/esnext/uploader/style/css/index.css +666 -0
- package/esnext/uploader/style/css/index.d.ts +4 -0
- package/esnext/uploader/style/css/index.js +4 -0
- package/esnext/uploader/style/index.d.ts +4 -0
- package/esnext/uploader/style/index.js +4 -0
- package/esnext/uploader/style/index.less +161 -0
- package/esnext/uploader/type.d.ts +108 -0
- package/esnext/uploader/type.js +1 -0
- package/esnext/uploader/upload/index.d.ts +2 -0
- package/esnext/uploader/upload/index.js +2 -0
- package/esnext/uploader/upload/type.d.ts +107 -0
- package/esnext/uploader/upload/type.js +1 -0
- package/esnext/uploader/upload/upload.d.ts +20 -0
- package/esnext/uploader/upload/upload.js +123 -0
- package/esnext-tsconfig.json +23 -0
- package/package.json +3 -3
- package/umd/_helpers/index.d.ts +1 -0
- package/umd/_helpers/index.js +10 -4
- package/umd/_helpers/react-dom.js +21 -14
- package/umd/avatar/index.js +3 -1
- package/umd/avatar/type.d.ts +6 -0
- package/umd/carousel/index.js +18 -1
- package/umd/steps/index.d.ts +1 -1
- package/umd/steps/index.js +6 -1
- package/umd/steps/style/css/index.css +42 -4
- package/umd/steps/style/index.less +58 -6
- package/umd/steps/type.d.ts +5 -0
@@ -0,0 +1,416 @@
|
|
1
|
+
import React, { useRef, forwardRef, useImperativeHandle, useEffect, useCallback, useMemo, } from 'react';
|
2
|
+
import lodashThrottle from 'lodash.throttle';
|
3
|
+
import { scrollParent, checkOverflowVisible, checkNormalVisible, nextTick, cls, } from '@arco-design/mobile-utils';
|
4
|
+
import { ContextLayout } from '../context-provider';
|
5
|
+
const LISTEN_FLAG = 'data-show-listened';
|
6
|
+
/**
|
7
|
+
* 父 dom 节点集合
|
8
|
+
* @en Parent dom node collection
|
9
|
+
*/
|
10
|
+
const wrapperNodeList = [];
|
11
|
+
/**
|
12
|
+
* 同一父节点下监听队列
|
13
|
+
* @en Listening queue under the same parent node
|
14
|
+
*/
|
15
|
+
const listeners = {};
|
16
|
+
const onOnceEmittedListeners = {};
|
17
|
+
/**
|
18
|
+
* Intersection Observer 同一 root 节点下的监听队列
|
19
|
+
* @en Intersection Observer Listening queue under the same root node
|
20
|
+
*/
|
21
|
+
const ioListeners = [];
|
22
|
+
/**
|
23
|
+
* Intersection Observer 监听 visible 状态队列
|
24
|
+
* @en Intersection Observer listens to the visible status queue
|
25
|
+
*/
|
26
|
+
const ioVisibleList = [];
|
27
|
+
let throttlingVisibleChange;
|
28
|
+
/**
|
29
|
+
* 通过滚动事件监测 children 是否进入视口或离开视口。
|
30
|
+
* @en Use scroll events to monitor whether children enter or leave the viewport.
|
31
|
+
* @type 其他
|
32
|
+
* @type_en Others
|
33
|
+
* @name 滚动视口监听
|
34
|
+
* @name_en ShowMonitor
|
35
|
+
*/
|
36
|
+
const ShowMonitor = forwardRef((props, ref) => {
|
37
|
+
const { className, style, getScrollContainer, throttle = 300, listenResize = true, listenScroll = true, overflow = false, offset = 0, threshold = 0, once = false, children = null, disabled = false, onVisibleChange, onClick, } = props;
|
38
|
+
const domRef = useRef(null);
|
39
|
+
/**
|
40
|
+
* 滚动容器父级元素
|
41
|
+
* @en Scroll container parent element
|
42
|
+
*/
|
43
|
+
const scrollPort = useRef(null);
|
44
|
+
/**
|
45
|
+
* 局部滚动元素父节点
|
46
|
+
* @en Parent node of the local scroll element
|
47
|
+
*/
|
48
|
+
const domRefParent = useRef(null);
|
49
|
+
/**
|
50
|
+
* 保存当前节点信息,类似于 class component 中 this
|
51
|
+
* @en Save current node information, similar to this in class component
|
52
|
+
*/
|
53
|
+
const listener = useRef(null);
|
54
|
+
/**
|
55
|
+
* Intersection Observer 实例化对象
|
56
|
+
* @en Instantiated object of Intersection Observer
|
57
|
+
*/
|
58
|
+
const io = useRef(null);
|
59
|
+
/**
|
60
|
+
* 父容器唯一 key(wrapperNodeList index)
|
61
|
+
* @en The unique key of the parent container (wrapperNodeList index)
|
62
|
+
*/
|
63
|
+
const wrapperKey = useRef(-1);
|
64
|
+
const isChildrenExist = useRef(Boolean(children));
|
65
|
+
const isSupportNativeApi = useMemo(() => typeof IntersectionObserver === 'function', []); // 是否支持 Intersection Observer
|
66
|
+
useImperativeHandle(ref, () => ({
|
67
|
+
dom: domRef.current,
|
68
|
+
/**
|
69
|
+
* 提供检查元素是否可见的api
|
70
|
+
* @en Provides an api to check whether the element is visible
|
71
|
+
*/
|
72
|
+
checkVisible: () => checkVisible({
|
73
|
+
node: domRef.current,
|
74
|
+
overflow,
|
75
|
+
onVisibleChange,
|
76
|
+
offset,
|
77
|
+
threshold,
|
78
|
+
}, true),
|
79
|
+
/**
|
80
|
+
* 重置元素初始可见态为false,并重新对元素可见度发起检测,优先级低于disabled(通常用在对ShowMonitor内部元素变化时发起的重新监听)
|
81
|
+
* @en Reset the initial visible state of the element to false, and re-detect the visibility of the element, the priority is lower than 'disabled'(Usually used to re-listen when elements inside ShowMonitor change)
|
82
|
+
*/
|
83
|
+
flushVisibleStatus() {
|
84
|
+
if (isSupportNativeApi) {
|
85
|
+
disabled ? ioUnobserve() : ioObserve();
|
86
|
+
}
|
87
|
+
else if (listener.current) {
|
88
|
+
const key = wrapperKey.current;
|
89
|
+
if (once && onOnceEmittedListeners?.[key]) {
|
90
|
+
onOnceEmittedListeners[key] = onOnceEmittedListeners[key].filter(emitListener => emitListener !== listener.current);
|
91
|
+
}
|
92
|
+
if (!disabled &&
|
93
|
+
!listeners[key].find(_listener => _listener === listener.current)) {
|
94
|
+
listeners[key].push(listener.current);
|
95
|
+
}
|
96
|
+
!disabled && checkVisible(listener.current);
|
97
|
+
}
|
98
|
+
},
|
99
|
+
}));
|
100
|
+
function checkVisible(component, ignoreCheckPreVisibleStatus = false) {
|
101
|
+
const { node, overflow: compOverflow, once: compOnce, onVisibleChange: onCompVisibleChange, isVisible: preVisible, } = component;
|
102
|
+
if (!(node instanceof HTMLElement)) {
|
103
|
+
return;
|
104
|
+
}
|
105
|
+
const parent = scrollParent(node);
|
106
|
+
/**
|
107
|
+
* 当前元素为非 document 元素,即为局部滚动
|
108
|
+
* @en If the current element is a non-document element, it's local scrolling
|
109
|
+
*/
|
110
|
+
const isOverflow = compOverflow &&
|
111
|
+
[node.ownerDocument, document, document.documentElement].indexOf(parent) === -1;
|
112
|
+
/**
|
113
|
+
* 检查元素是否可见
|
114
|
+
* @en Check if element is visible
|
115
|
+
*/
|
116
|
+
const curVisible = isOverflow
|
117
|
+
? checkOverflowVisible(component, parent)
|
118
|
+
: checkNormalVisible(component);
|
119
|
+
/**
|
120
|
+
* 忽略前后可见状态判断
|
121
|
+
* @en Ignore the visible state judgment before and after
|
122
|
+
*/
|
123
|
+
if (ignoreCheckPreVisibleStatus) {
|
124
|
+
return curVisible;
|
125
|
+
}
|
126
|
+
/**
|
127
|
+
* 当前元素 visible 对比之前发生改变,触发回调函数
|
128
|
+
* @en The current element visible is changed before the comparison, and the callback function is triggered
|
129
|
+
*/
|
130
|
+
curVisible !== preVisible &&
|
131
|
+
handleCheckChildrenExist() &&
|
132
|
+
onCompVisibleChange(curVisible, node);
|
133
|
+
component.isVisible = curVisible;
|
134
|
+
const key = wrapperKey.current;
|
135
|
+
/**
|
136
|
+
* 监听一次后加入 pendingList 队列,随后被 listeners 过滤掉
|
137
|
+
* @en After listening once, it is added to the pendingList queue, and then filtered out by listeners
|
138
|
+
*/
|
139
|
+
if (!onOnceEmittedListeners[key]) {
|
140
|
+
onOnceEmittedListeners[key] = [];
|
141
|
+
}
|
142
|
+
/**
|
143
|
+
* 当前元素不可见 -> 可见,且 once, 触发回调函数
|
144
|
+
* @en The current element is invisible -> visible, and once, triggers the callback function
|
145
|
+
*/
|
146
|
+
curVisible && !preVisible && compOnce && onOnceEmittedListeners[key].push(component);
|
147
|
+
}
|
148
|
+
const checkVisibleHandler = useCallback(() => {
|
149
|
+
const key = wrapperKey.current;
|
150
|
+
const curListeners = listeners[key] || [];
|
151
|
+
curListeners.forEach(listen => checkVisible(listen));
|
152
|
+
listeners[key] = curListeners.filter(item => onOnceEmittedListeners[key].indexOf(item) === -1);
|
153
|
+
onOnceEmittedListeners[key] = [];
|
154
|
+
}, []);
|
155
|
+
function handleCheckChildrenExist(target) {
|
156
|
+
const dom = target || domRef.current;
|
157
|
+
return isChildrenExist.current && dom?.children.length;
|
158
|
+
}
|
159
|
+
function handleObserverStatusChange(entries) {
|
160
|
+
entries.forEach(entry => {
|
161
|
+
const { isIntersecting, target } = entry;
|
162
|
+
const visibleItem = ioVisibleList.find(item => item.node === target);
|
163
|
+
if (visibleItem) {
|
164
|
+
const { isVisible: curVisible, onVisibleChange: onCompVisibleChange, once: onceEmit, } = visibleItem;
|
165
|
+
/**
|
166
|
+
* 当前元素 visible 对比之前发生改变,触发回调函数
|
167
|
+
* @en Callback when the visible status of current element changes before the comparison
|
168
|
+
*/
|
169
|
+
isIntersecting !== curVisible &&
|
170
|
+
handleCheckChildrenExist(target) &&
|
171
|
+
onCompVisibleChange(isIntersecting, target);
|
172
|
+
/**
|
173
|
+
* 当前元素状态由不可见变为可见,且只触发一次
|
174
|
+
* @en The current element is invisible -> visible, and once, triggers the callback
|
175
|
+
*/
|
176
|
+
isIntersecting &&
|
177
|
+
!curVisible &&
|
178
|
+
onceEmit &&
|
179
|
+
target &&
|
180
|
+
ioUnobserve(target);
|
181
|
+
visibleItem.isVisible = isIntersecting;
|
182
|
+
}
|
183
|
+
});
|
184
|
+
}
|
185
|
+
/**
|
186
|
+
* 获取 io 单例
|
187
|
+
* @en Get the io singleton
|
188
|
+
*/
|
189
|
+
function getIOSingleton(ioOptions) {
|
190
|
+
const { root, rootMargin, threshold: ioThreshold } = ioOptions;
|
191
|
+
const ioKey = JSON.stringify({ rootMargin, threshold: ioThreshold });
|
192
|
+
const _ioListener = ioListeners.find(ioListener => ioListener.root === root && ioListener.key === ioKey);
|
193
|
+
if (!_ioListener) {
|
194
|
+
ioListeners.push({
|
195
|
+
root,
|
196
|
+
key: ioKey,
|
197
|
+
listener: (io.current = new IntersectionObserver(handleObserverStatusChange, ioOptions)),
|
198
|
+
});
|
199
|
+
}
|
200
|
+
else {
|
201
|
+
io.current = _ioListener.listener;
|
202
|
+
}
|
203
|
+
}
|
204
|
+
function ioObserve() {
|
205
|
+
if (domRef.current && io.current) {
|
206
|
+
const curIdx = ioVisibleList.findIndex(ioVisibleItem => ioVisibleItem.node === domRef.current);
|
207
|
+
if (curIdx !== -1) {
|
208
|
+
ioVisibleList[curIdx].isVisible = false;
|
209
|
+
}
|
210
|
+
else {
|
211
|
+
ioVisibleList.push({
|
212
|
+
node: domRef.current,
|
213
|
+
isVisible: false,
|
214
|
+
once,
|
215
|
+
onVisibleChange,
|
216
|
+
});
|
217
|
+
}
|
218
|
+
io.current.observe(domRef.current);
|
219
|
+
}
|
220
|
+
}
|
221
|
+
function ioUnobserve(target) {
|
222
|
+
const targetNode = target || domRef.current;
|
223
|
+
if (io.current && targetNode) {
|
224
|
+
const curIdx = ioVisibleList.findIndex(ioVisibleItem => ioVisibleItem.node === targetNode);
|
225
|
+
if (curIdx !== -1) {
|
226
|
+
ioVisibleList.splice(curIdx, 1);
|
227
|
+
}
|
228
|
+
io.current.unobserve(targetNode);
|
229
|
+
}
|
230
|
+
}
|
231
|
+
/**
|
232
|
+
* 非首次下disabled变化时,重新监听元素
|
233
|
+
* @en Re-listen to the element when it is not the first time that the disabled status changes,
|
234
|
+
*/
|
235
|
+
useEffect(() => {
|
236
|
+
if (isSupportNativeApi) {
|
237
|
+
// 非首次 render 下
|
238
|
+
// @en Not for the first time
|
239
|
+
disabled ? ioUnobserve() : ioObserve();
|
240
|
+
}
|
241
|
+
else {
|
242
|
+
// 非首次 render 下
|
243
|
+
// @en Not for the first time
|
244
|
+
if (wrapperKey.current !== -1 && listener.current && listeners[wrapperKey.current]) {
|
245
|
+
// 禁用监听,找到对应listener并删除
|
246
|
+
// @en Disable listening, find the corresponding listener and delete it
|
247
|
+
if (disabled) {
|
248
|
+
const isExist = listeners[wrapperKey.current].findIndex(item => item.node === domRef.current);
|
249
|
+
if (isExist !== -1) {
|
250
|
+
listeners[wrapperKey.current].splice(0, 1);
|
251
|
+
}
|
252
|
+
}
|
253
|
+
else {
|
254
|
+
// 开启监听
|
255
|
+
// @en Start to listen
|
256
|
+
listeners[wrapperKey.current].push(listener.current);
|
257
|
+
}
|
258
|
+
}
|
259
|
+
}
|
260
|
+
}, [disabled]);
|
261
|
+
useEffect(() => {
|
262
|
+
isChildrenExist.current = Boolean(children);
|
263
|
+
}, [children]);
|
264
|
+
useEffect(() => {
|
265
|
+
scrollPort.current = getScrollContainer ? getScrollContainer() : window;
|
266
|
+
if (!scrollPort.current)
|
267
|
+
return;
|
268
|
+
const wrapperNodeIndex = wrapperNodeList.indexOf(scrollPort.current);
|
269
|
+
if (wrapperNodeIndex === -1) {
|
270
|
+
// 当前滚动视口元素不在 wrapperNodeList 中, 入队列
|
271
|
+
// @en The current scroll viewport element is not in the wrapperNodeList, push it into the list
|
272
|
+
wrapperNodeList.push(scrollPort.current);
|
273
|
+
wrapperKey.current = wrapperNodeList.length - 1;
|
274
|
+
}
|
275
|
+
else {
|
276
|
+
// 取当前 index 作为 key
|
277
|
+
// @en Take the current index as the key
|
278
|
+
wrapperKey.current = wrapperNodeIndex;
|
279
|
+
}
|
280
|
+
const curWrapperKey = wrapperKey.current;
|
281
|
+
if (isSupportNativeApi) {
|
282
|
+
if (domRef.current) {
|
283
|
+
domRefParent.current = scrollParent(domRef.current);
|
284
|
+
const parent = domRefParent.current;
|
285
|
+
const isHTMLElement = [domRef.current.ownerDocument, document, document.documentElement].indexOf(parent) === -1;
|
286
|
+
const overflowRoot = isHTMLElement ? parent : null;
|
287
|
+
const root = (overflow
|
288
|
+
? overflowRoot
|
289
|
+
: scrollPort.current === window
|
290
|
+
? null
|
291
|
+
: scrollPort.current);
|
292
|
+
let rootMargin = '';
|
293
|
+
if (Array.isArray(offset)) {
|
294
|
+
if (offset.length === 2) {
|
295
|
+
rootMargin = `${offset[0]}px 0px ${offset[1]}px`;
|
296
|
+
}
|
297
|
+
else {
|
298
|
+
offset.forEach((val, index) => {
|
299
|
+
const space = index === 0 ? '' : ' ';
|
300
|
+
rootMargin += `${space}${val}px`;
|
301
|
+
});
|
302
|
+
}
|
303
|
+
}
|
304
|
+
else {
|
305
|
+
rootMargin = `${offset}px`;
|
306
|
+
}
|
307
|
+
getIOSingleton({
|
308
|
+
root,
|
309
|
+
rootMargin,
|
310
|
+
threshold,
|
311
|
+
});
|
312
|
+
!disabled && ioObserve();
|
313
|
+
}
|
314
|
+
}
|
315
|
+
else {
|
316
|
+
// 节流后回调函数
|
317
|
+
// @en Callback after throttling
|
318
|
+
throttlingVisibleChange = checkVisibleHandler;
|
319
|
+
throttle &&
|
320
|
+
(throttlingVisibleChange = lodashThrottle(throttlingVisibleChange, throttle));
|
321
|
+
if (overflow) {
|
322
|
+
if (domRef.current) {
|
323
|
+
domRefParent.current = scrollParent(domRef.current);
|
324
|
+
const parent = domRefParent.current;
|
325
|
+
if (parent &&
|
326
|
+
parent instanceof HTMLElement &&
|
327
|
+
typeof parent.getAttribute === 'function') {
|
328
|
+
const listenerCount = 1 + Number(parent.getAttribute(LISTEN_FLAG));
|
329
|
+
if (!listeners[curWrapperKey]) {
|
330
|
+
listeners[curWrapperKey] = [];
|
331
|
+
}
|
332
|
+
if (listenerCount === 1) {
|
333
|
+
// listener 数量为1时监听事件(列表中插入 ShowMonitor 时做判断)
|
334
|
+
// @en Listen when the number of listeners is 1 (judging when ShowMonitor is inserted into the list)
|
335
|
+
parent.addEventListener('scroll', throttlingVisibleChange);
|
336
|
+
}
|
337
|
+
parent.setAttribute(LISTEN_FLAG, String(listenerCount));
|
338
|
+
}
|
339
|
+
}
|
340
|
+
}
|
341
|
+
else if (!listeners[curWrapperKey] ||
|
342
|
+
listeners[curWrapperKey].length === 0 ||
|
343
|
+
// 相同curWrapperKey内全部为overflow场景,需要单独注册scroll事件
|
344
|
+
// @en It need to register the scroll event separately when all values in the same curWrapperKey are overflow
|
345
|
+
(listeners[curWrapperKey] && listeners[curWrapperKey].every(it => it.overflow))) {
|
346
|
+
if (!listeners[curWrapperKey]) {
|
347
|
+
listeners[curWrapperKey] = [];
|
348
|
+
}
|
349
|
+
listenScroll &&
|
350
|
+
scrollPort.current.addEventListener('scroll', throttlingVisibleChange);
|
351
|
+
listenResize &&
|
352
|
+
scrollPort.current.addEventListener('resize', throttlingVisibleChange);
|
353
|
+
}
|
354
|
+
listener.current = {
|
355
|
+
node: domRef.current,
|
356
|
+
isVisible: false,
|
357
|
+
overflow,
|
358
|
+
once,
|
359
|
+
offset,
|
360
|
+
threshold,
|
361
|
+
onVisibleChange,
|
362
|
+
};
|
363
|
+
// 将当前 listener 存入 listeners
|
364
|
+
!disabled && listeners[curWrapperKey].push(listener.current);
|
365
|
+
nextTick(() => {
|
366
|
+
!disabled && checkVisible(listener.current);
|
367
|
+
});
|
368
|
+
}
|
369
|
+
}, []);
|
370
|
+
useEffect(() => {
|
371
|
+
return () => {
|
372
|
+
if (isSupportNativeApi) {
|
373
|
+
ioUnobserve();
|
374
|
+
}
|
375
|
+
else {
|
376
|
+
if (overflow) {
|
377
|
+
const parent = domRefParent.current;
|
378
|
+
if (parent &&
|
379
|
+
parent instanceof HTMLElement &&
|
380
|
+
typeof parent.getAttribute === 'function') {
|
381
|
+
const listenerCount = Number(parent.getAttribute(LISTEN_FLAG) || 0) - 1;
|
382
|
+
if (listenerCount === 0) {
|
383
|
+
// 如果监听队列中无节点,解绑事件
|
384
|
+
// @en If there is no node in the listening queue, unbind the event
|
385
|
+
parent.removeEventListener('scroll', throttlingVisibleChange);
|
386
|
+
}
|
387
|
+
else {
|
388
|
+
// 如果监听队列中有元素节点,将 dataset 减1
|
389
|
+
// @en If there are element nodes in the listening queue, decrement dataset by 1
|
390
|
+
parent.setAttribute(LISTEN_FLAG, String(listenerCount));
|
391
|
+
}
|
392
|
+
}
|
393
|
+
}
|
394
|
+
const key = wrapperKey.current;
|
395
|
+
const curListeners = listeners[key];
|
396
|
+
if (curListeners) {
|
397
|
+
// 不在监听队列中,移除
|
398
|
+
// @en Not in the listening queue, remove it
|
399
|
+
const index = curListeners.indexOf(listener.current);
|
400
|
+
index !== -1 && curListeners.splice(index, 1);
|
401
|
+
// 监听队列为空,解绑 scroll、resize 事件
|
402
|
+
// @en When the listening queue is empty, unbind scroll and resize events
|
403
|
+
if (curListeners.length === 0) {
|
404
|
+
delete listeners[key];
|
405
|
+
if (scrollPort.current) {
|
406
|
+
scrollPort.current.removeEventListener('scroll', throttlingVisibleChange);
|
407
|
+
scrollPort.current.removeEventListener('resize', throttlingVisibleChange);
|
408
|
+
}
|
409
|
+
}
|
410
|
+
}
|
411
|
+
}
|
412
|
+
};
|
413
|
+
}, []);
|
414
|
+
return (React.createElement(ContextLayout, null, ({ prefixCls }) => (React.createElement("div", { className: cls(`${prefixCls}-show-monitor`, className), style: style, ref: domRef, onClick: onClick }, children))));
|
415
|
+
});
|
416
|
+
export default ShowMonitor;
|
File without changes
|
@@ -0,0 +1 @@
|
|
1
|
+
// 这里啥也没有,但是为了兼容 babel-plugin-import的统一引用,还是需要创建下文件
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { SkeletonAvatarProps, SkeletonGridProps, SkeletonNodeProps, SkeletonParagraphProps, SkeletonRef, SkeletonTitleProps } from './type';
|
3
|
+
export declare const SkeletonNode: React.ForwardRefExoticComponent<SkeletonNodeProps & React.RefAttributes<SkeletonRef>>;
|
4
|
+
export declare const SkeletonTitle: React.ForwardRefExoticComponent<SkeletonTitleProps & React.RefAttributes<SkeletonRef>>;
|
5
|
+
export declare const SkeletonParagraph: React.ForwardRefExoticComponent<SkeletonParagraphProps & React.RefAttributes<SkeletonRef>>;
|
6
|
+
export declare const SkeletonAvatar: React.ForwardRefExoticComponent<SkeletonAvatarProps & React.RefAttributes<SkeletonRef>>;
|
7
|
+
export declare const SkeletonGrid: React.ForwardRefExoticComponent<SkeletonGridProps & React.RefAttributes<SkeletonRef>>;
|
@@ -0,0 +1,117 @@
|
|
1
|
+
import React, { forwardRef, useContext, useEffect, useImperativeHandle, useRef, useState, } from 'react';
|
2
|
+
import { cls, isArray, nextTick } from '@arco-design/mobile-utils';
|
3
|
+
import { useListenResize } from '../_helpers';
|
4
|
+
import { GlobalContext } from '../context-provider';
|
5
|
+
import { SkeletonContext } from './skeleton-context';
|
6
|
+
const calcOffset = (dom, useRtl) => {
|
7
|
+
if (!dom) {
|
8
|
+
return 0;
|
9
|
+
}
|
10
|
+
if (useRtl) {
|
11
|
+
return dom.offsetLeft - dom.offsetTop;
|
12
|
+
}
|
13
|
+
return dom.offsetLeft + dom.offsetTop;
|
14
|
+
};
|
15
|
+
function useOffset(dom, useRtl) {
|
16
|
+
const [offset, setOffset] = useState();
|
17
|
+
const calcLayout = () => {
|
18
|
+
const isList = Array.isArray(dom);
|
19
|
+
if (!(isList ? dom.length > 0 : dom?.current)) {
|
20
|
+
return;
|
21
|
+
}
|
22
|
+
setOffset(isList
|
23
|
+
? dom.map(item => calcOffset(item, useRtl))
|
24
|
+
: calcOffset(dom.current, useRtl));
|
25
|
+
};
|
26
|
+
useEffect(() => {
|
27
|
+
nextTick(() => {
|
28
|
+
calcLayout();
|
29
|
+
});
|
30
|
+
}, [dom, useRtl]);
|
31
|
+
useListenResize(calcLayout);
|
32
|
+
return offset;
|
33
|
+
}
|
34
|
+
export const SkeletonNode = forwardRef((props, ref) => {
|
35
|
+
const { className = '', style, children } = props;
|
36
|
+
const { useRtl, prefixCls } = useContext(GlobalContext);
|
37
|
+
const { backgroundColor, showAnimation, animation } = useContext(SkeletonContext);
|
38
|
+
const domRef = useRef(null);
|
39
|
+
const isGradientAnimation = showAnimation && animation === 'gradient';
|
40
|
+
const offset = useOffset(isGradientAnimation ? domRef : undefined, useRtl);
|
41
|
+
useImperativeHandle(ref, () => ({
|
42
|
+
dom: domRef.current,
|
43
|
+
}));
|
44
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-node`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`, className), style: { backgroundColor, ...style }, ref: domRef },
|
45
|
+
children,
|
46
|
+
isGradientAnimation && offset !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: { left: 0 - offset } }))));
|
47
|
+
});
|
48
|
+
export const SkeletonTitle = forwardRef((props, ref) => {
|
49
|
+
const { className = '', style, width = '40%' } = props;
|
50
|
+
const { useRtl, prefixCls } = useContext(GlobalContext);
|
51
|
+
const { backgroundColor, showAnimation, animation } = useContext(SkeletonContext);
|
52
|
+
const domRef = useRef(null);
|
53
|
+
const isGradientAnimation = showAnimation && animation === 'gradient';
|
54
|
+
const offset = useOffset(isGradientAnimation ? domRef : undefined, useRtl);
|
55
|
+
useImperativeHandle(ref, () => ({
|
56
|
+
dom: domRef.current,
|
57
|
+
}));
|
58
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-title`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`, className), style: { width, backgroundColor, ...style }, ref: domRef }, isGradientAnimation && offset !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: { left: 0 - offset } }))));
|
59
|
+
});
|
60
|
+
export const SkeletonParagraph = forwardRef((props, ref) => {
|
61
|
+
const { className = '', style, rows = 3, width = '60%' } = props;
|
62
|
+
const { useRtl, prefixCls } = useContext(GlobalContext);
|
63
|
+
const { backgroundColor, showAnimation, animation } = useContext(SkeletonContext);
|
64
|
+
const domRef = useRef(null);
|
65
|
+
const lineDomRefs = useRef([]);
|
66
|
+
const isGradientAnimation = showAnimation && animation === 'gradient';
|
67
|
+
const offsets = useOffset(isGradientAnimation ? lineDomRefs.current : undefined, useRtl);
|
68
|
+
useImperativeHandle(ref, () => ({
|
69
|
+
dom: domRef.current,
|
70
|
+
}));
|
71
|
+
const getWidth = (idx) => {
|
72
|
+
if (isArray(width)) {
|
73
|
+
return width[idx];
|
74
|
+
}
|
75
|
+
if (rows - 1 === idx) {
|
76
|
+
return width;
|
77
|
+
}
|
78
|
+
return undefined;
|
79
|
+
};
|
80
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton-paragraph`, className), style: style, ref: domRef }, Array.from(new Array(rows)).map((_, idx) => (React.createElement("div", { key: idx, className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-paragraph-line`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`), style: {
|
81
|
+
width: getWidth(idx),
|
82
|
+
backgroundColor,
|
83
|
+
}, ref: el => el && (lineDomRefs.current[idx] = el) }, isGradientAnimation && offsets !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: { left: 0 - (offsets[idx] || 0) } })))))));
|
84
|
+
});
|
85
|
+
export const SkeletonAvatar = forwardRef((props, ref) => {
|
86
|
+
const { className = '', style } = props;
|
87
|
+
const { useRtl, prefixCls } = useContext(GlobalContext);
|
88
|
+
const { backgroundColor, showAnimation, animation } = useContext(SkeletonContext);
|
89
|
+
const domRef = useRef(null);
|
90
|
+
const isGradientAnimation = showAnimation && animation === 'gradient';
|
91
|
+
const offset = useOffset(isGradientAnimation ? domRef : undefined, useRtl);
|
92
|
+
useImperativeHandle(ref, () => ({
|
93
|
+
dom: domRef.current,
|
94
|
+
}));
|
95
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-avatar`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`, className), style: { backgroundColor, ...style }, ref: domRef }, isGradientAnimation && offset !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: { left: 0 - offset } }))));
|
96
|
+
});
|
97
|
+
export const SkeletonGrid = forwardRef((props, ref) => {
|
98
|
+
const { className = '', style, columns = 4 } = props;
|
99
|
+
const { useRtl, prefixCls } = useContext(GlobalContext);
|
100
|
+
const { backgroundColor, showAnimation, animation } = useContext(SkeletonContext);
|
101
|
+
const domRef = useRef(null);
|
102
|
+
const iconDomRefs = useRef([]);
|
103
|
+
const textDomRefs = useRef([]);
|
104
|
+
const isGradientAnimation = showAnimation && animation === 'gradient';
|
105
|
+
const iconOffsets = useOffset(isGradientAnimation ? iconDomRefs.current : undefined, useRtl);
|
106
|
+
const textOffsets = useOffset(isGradientAnimation ? textDomRefs.current : undefined, useRtl);
|
107
|
+
useImperativeHandle(ref, () => ({
|
108
|
+
dom: domRef.current,
|
109
|
+
}));
|
110
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton-grid`, className), style: style, ref: domRef }, Array.from(new Array(columns)).map((_, idx) => (React.createElement("div", { key: idx, className: cls(`${prefixCls}-skeleton-grid-item`) },
|
111
|
+
React.createElement("div", { className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-grid-icon`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`), style: { backgroundColor }, ref: el => el && (iconDomRefs.current[idx] = el) }, isGradientAnimation && iconOffsets !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: {
|
112
|
+
left: 0 - (iconOffsets?.[idx] || 0),
|
113
|
+
} }))),
|
114
|
+
React.createElement("div", { className: cls(`${prefixCls}-skeleton-item`, `${prefixCls}-skeleton-grid-text`, showAnimation && `${prefixCls}-skeleton-animation-${animation}`), style: { backgroundColor }, ref: el => el && (textDomRefs.current[idx] = el) }, isGradientAnimation && textOffsets !== undefined && (React.createElement("div", { className: `${prefixCls}-skeleton-animation-item`, style: {
|
115
|
+
left: 0 - (textOffsets?.[idx] || 0),
|
116
|
+
} }))))))));
|
117
|
+
});
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { SkeletonProps, SkeletonRef } from './type';
|
3
|
+
export * from './type';
|
4
|
+
declare const _default: React.ForwardRefExoticComponent<SkeletonProps & React.RefAttributes<SkeletonRef>> & {
|
5
|
+
Node: React.ForwardRefExoticComponent<import("./type").SkeletonNodeProps & React.RefAttributes<SkeletonRef>>;
|
6
|
+
Title: React.ForwardRefExoticComponent<import("./type").SkeletonTitleProps & React.RefAttributes<SkeletonRef>>;
|
7
|
+
Paragraph: React.ForwardRefExoticComponent<import("./type").SkeletonParagraphProps & React.RefAttributes<SkeletonRef>>;
|
8
|
+
Avatar: React.ForwardRefExoticComponent<import("./type").SkeletonAvatarProps & React.RefAttributes<SkeletonRef>>;
|
9
|
+
Grid: React.ForwardRefExoticComponent<import("./type").SkeletonGridProps & React.RefAttributes<SkeletonRef>>;
|
10
|
+
};
|
11
|
+
/**
|
12
|
+
* 在内容加载过程中展示一组占位图形。
|
13
|
+
* @en Display a set of placeholder graphics during content loading
|
14
|
+
* @type 信息展示
|
15
|
+
* @type_en Data Display
|
16
|
+
* @name 骨架屏
|
17
|
+
* @name_en Skeleton
|
18
|
+
*/
|
19
|
+
export default _default;
|
@@ -0,0 +1,50 @@
|
|
1
|
+
import React, { useRef, forwardRef, useImperativeHandle, useContext } from 'react';
|
2
|
+
import { cls, componentWrapper } from '@arco-design/mobile-utils';
|
3
|
+
import { GlobalContext } from '../context-provider';
|
4
|
+
import { SkeletonAvatar as Avatar, SkeletonGrid as Grid, SkeletonNode as Node, SkeletonParagraph as Paragraph, SkeletonTitle as Title, } from './elements';
|
5
|
+
import { SkeletonContext } from './skeleton-context';
|
6
|
+
export * from './type';
|
7
|
+
function getComponentProps(prop) {
|
8
|
+
if (prop && typeof prop === 'object') {
|
9
|
+
return prop;
|
10
|
+
}
|
11
|
+
return {};
|
12
|
+
}
|
13
|
+
const Skeleton = forwardRef((props, ref) => {
|
14
|
+
const { className = '', style, children, title = true, paragraph = true, avatar = false, grid, showAnimation = true, animation = 'gradient', animationGradientColor, backgroundColor, } = props;
|
15
|
+
const domRef = useRef(null);
|
16
|
+
const { prefixCls } = useContext(GlobalContext);
|
17
|
+
useImperativeHandle(ref, () => ({
|
18
|
+
dom: domRef.current,
|
19
|
+
}));
|
20
|
+
const isGrid = !!grid;
|
21
|
+
const hasTitle = !!title;
|
22
|
+
const hasParagraph = !!paragraph;
|
23
|
+
const hasAvatar = !!avatar;
|
24
|
+
const content = isGrid ? (React.createElement(Grid, Object.assign({}, getComponentProps(grid)))) : (React.createElement(React.Fragment, null,
|
25
|
+
hasAvatar && React.createElement(Avatar, Object.assign({}, getComponentProps(avatar))),
|
26
|
+
(hasTitle || hasParagraph) && (React.createElement("div", { className: `${prefixCls}-skeleton-content` },
|
27
|
+
hasTitle && React.createElement(Title, Object.assign({}, getComponentProps(title))),
|
28
|
+
hasParagraph && React.createElement(Paragraph, Object.assign({}, getComponentProps(paragraph)))))));
|
29
|
+
return (React.createElement("div", { className: cls(`${prefixCls}-skeleton`, {
|
30
|
+
[`${prefixCls}-skeleton-with-avatar`]: hasAvatar,
|
31
|
+
}, className), style: { color: animationGradientColor, ...style }, ref: domRef },
|
32
|
+
React.createElement(SkeletonContext.Provider, { value: { showAnimation, animation, backgroundColor } },
|
33
|
+
content,
|
34
|
+
children)));
|
35
|
+
});
|
36
|
+
/**
|
37
|
+
* 在内容加载过程中展示一组占位图形。
|
38
|
+
* @en Display a set of placeholder graphics during content loading
|
39
|
+
* @type 信息展示
|
40
|
+
* @type_en Data Display
|
41
|
+
* @name 骨架屏
|
42
|
+
* @name_en Skeleton
|
43
|
+
*/
|
44
|
+
export default componentWrapper(Skeleton, {
|
45
|
+
Node,
|
46
|
+
Title,
|
47
|
+
Paragraph,
|
48
|
+
Avatar,
|
49
|
+
Grid,
|
50
|
+
});
|