vant 3.2.6 → 3.3.1
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/es/action-bar/ActionBar.d.ts +8 -0
- package/es/action-bar/ActionBar.js +8 -6
- package/es/action-bar/index.css +1 -1
- package/es/action-bar/index.d.ts +1 -0
- package/es/action-bar/var.less +1 -1
- package/es/action-bar-button/ActionBarButton.d.ts +14 -1
- package/es/action-bar-button/ActionBarButton.js +13 -11
- package/es/action-bar-button/index.d.ts +1 -0
- package/es/action-bar-icon/ActionBarIcon.d.ts +15 -0
- package/es/action-bar-icon/ActionBarIcon.js +14 -12
- package/es/action-bar-icon/index.css +1 -1
- package/es/action-bar-icon/index.d.ts +1 -0
- package/es/action-bar-icon/var.less +1 -1
- package/es/action-sheet/ActionSheet.d.ts +57 -0
- package/es/action-sheet/ActionSheet.js +23 -20
- package/es/action-sheet/index.css +1 -1
- package/es/action-sheet/index.d.ts +1 -1
- package/es/action-sheet/index.less +0 -5
- package/es/action-sheet/var.less +4 -5
- package/es/address-edit/AddressEdit.d.ts +2 -2
- package/es/address-edit/AddressEdit.js +161 -186
- package/es/address-edit/AddressEditDetail.d.ts +10 -9
- package/es/address-edit/AddressEditDetail.js +10 -9
- package/es/address-list/AddressList.d.ts +20 -0
- package/es/address-list/AddressList.js +16 -13
- package/es/address-list/AddressListItem.js +6 -4
- package/es/address-list/index.css +1 -1
- package/es/address-list/index.d.ts +1 -0
- package/es/address-list/index.less +2 -2
- package/es/address-list/var.less +2 -2
- package/es/area/Area.d.ts +2 -2
- package/es/area/Area.js +20 -9
- package/es/area/index.d.ts +1 -2
- package/es/badge/Badge.d.ts +18 -2
- package/es/badge/Badge.js +17 -14
- package/es/badge/index.css +1 -1
- package/es/badge/index.d.ts +2 -1
- package/es/badge/index.less +1 -1
- package/es/button/Button.d.ts +43 -5
- package/es/button/Button.js +31 -28
- package/es/button/index.css +1 -1
- package/es/button/index.d.ts +18 -17
- package/es/button/types.d.ts +5 -0
- package/es/button/types.js +1 -0
- package/es/button/var.less +1 -1
- package/es/calendar/Calendar.d.ts +2 -2
- package/es/calendar/Calendar.js +32 -10
- package/es/calendar/CalendarDay.js +5 -4
- package/es/calendar/CalendarHeader.js +7 -7
- package/es/calendar/CalendarMonth.d.ts +2 -2
- package/es/calendar/CalendarMonth.js +7 -6
- package/es/calendar/index.css +1 -1
- package/es/calendar/index.d.ts +1 -2
- package/es/calendar/types.d.ts +1 -1
- package/es/calendar/utils.d.ts +1 -1
- package/es/calendar/var.less +2 -2
- package/es/card/Card.d.ts +18 -0
- package/es/card/Card.js +20 -17
- package/es/card/index.css +1 -1
- package/es/card/index.d.ts +1 -0
- package/es/card/var.less +3 -3
- package/es/cascader/Cascader.d.ts +2 -2
- package/es/cascader/Cascader.js +33 -15
- package/es/cascader/index.css +1 -1
- package/es/cascader/index.d.ts +1 -2
- package/es/cascader/index.less +0 -5
- package/es/cascader/var.less +2 -3
- package/es/cell/Cell.d.ts +35 -5
- package/es/cell/Cell.js +8 -13
- package/es/cell/index.css +1 -1
- package/es/cell/index.d.ts +3 -3
- package/es/cell/var.less +3 -3
- package/es/cell-group/CellGroup.d.ts +10 -0
- package/es/cell-group/CellGroup.js +12 -9
- package/es/cell-group/index.css +1 -1
- package/es/cell-group/index.d.ts +1 -0
- package/es/cell-group/var.less +2 -2
- package/es/checkbox/Checkbox.d.ts +2 -2
- package/es/checkbox/Checkbox.js +12 -7
- package/es/checkbox/Checker.js +6 -5
- package/es/checkbox/index.css +1 -1
- package/es/checkbox/index.d.ts +1 -2
- package/es/checkbox/types.d.ts +2 -6
- package/es/checkbox/var.less +1 -1
- package/es/checkbox-group/CheckboxGroup.d.ts +2 -2
- package/es/checkbox-group/CheckboxGroup.js +12 -7
- package/es/checkbox-group/index.d.ts +1 -2
- package/es/circle/Circle.d.ts +37 -1
- package/es/circle/Circle.js +20 -18
- package/es/circle/index.d.ts +1 -1
- package/es/col/Col.d.ts +13 -0
- package/es/col/Col.js +10 -8
- package/es/col/index.d.ts +1 -0
- package/es/collapse/Collapse.d.ts +13 -1
- package/es/collapse/Collapse.js +14 -12
- package/es/collapse/index.d.ts +1 -0
- package/es/collapse-item/CollapseItem.d.ts +5 -5
- package/es/collapse-item/CollapseItem.js +13 -8
- package/es/collapse-item/index.css +1 -1
- package/es/collapse-item/index.d.ts +3 -4
- package/es/collapse-item/var.less +3 -3
- package/es/composables/use-id.d.ts +1 -0
- package/es/composables/use-id.js +14 -0
- package/es/composables/use-route.d.ts +1 -1
- package/es/composables/use-route.js +4 -4
- package/es/config-provider/ConfigProvider.d.ts +11 -2
- package/es/config-provider/ConfigProvider.js +10 -8
- package/es/config-provider/index.d.ts +2 -1
- package/es/contact-card/ContactCard.d.ts +15 -0
- package/es/contact-card/ContactCard.js +13 -10
- package/es/contact-card/index.css +1 -1
- package/es/contact-card/index.d.ts +1 -1
- package/es/contact-card/index.less +2 -2
- package/es/contact-edit/ContactEdit.d.ts +17 -1
- package/es/contact-edit/ContactEdit.js +20 -18
- package/es/contact-edit/index.d.ts +1 -1
- package/es/contact-list/ContactList.d.ts +8 -1
- package/es/contact-list/ContactList.js +12 -9
- package/es/contact-list/index.css +1 -1
- package/es/contact-list/index.d.ts +1 -1
- package/es/contact-list/index.less +1 -1
- package/es/count-down/CountDown.d.ts +2 -2
- package/es/count-down/CountDown.js +8 -6
- package/es/count-down/index.d.ts +1 -2
- package/es/coupon/Coupon.js +2 -11
- package/es/coupon/index.css +1 -1
- package/es/coupon/index.less +2 -1
- package/es/coupon/utils.d.ts +3 -0
- package/es/coupon/utils.js +7 -0
- package/es/coupon/var.less +3 -2
- package/es/coupon-cell/CouponCell.d.ts +25 -0
- package/es/coupon-cell/CouponCell.js +17 -12
- package/es/coupon-cell/index.d.ts +1 -0
- package/es/coupon-list/CouponList.d.ts +55 -0
- package/es/coupon-list/CouponList.js +66 -48
- package/es/coupon-list/index.css +1 -1
- package/es/coupon-list/index.d.ts +1 -0
- package/es/coupon-list/index.less +3 -8
- package/es/coupon-list/var.less +1 -1
- package/es/datetime-picker/DatePicker.js +13 -10
- package/es/datetime-picker/DatetimePicker.d.ts +2 -2
- package/es/datetime-picker/DatetimePicker.js +10 -9
- package/es/datetime-picker/TimePicker.js +13 -10
- package/es/datetime-picker/utils.d.ts +1 -1
- package/es/datetime-picker/utils.js +3 -3
- package/es/dialog/Dialog.d.ts +55 -1
- package/es/dialog/Dialog.js +27 -25
- package/es/dialog/index.css +1 -1
- package/es/dialog/index.d.ts +1 -0
- package/es/dialog/var.less +1 -1
- package/es/divider/Divider.d.ts +13 -0
- package/es/divider/Divider.js +10 -8
- package/es/divider/index.css +1 -1
- package/es/divider/index.d.ts +1 -1
- package/es/divider/var.less +1 -1
- package/es/dropdown-item/DropdownItem.d.ts +2 -2
- package/es/dropdown-item/DropdownItem.js +23 -9
- package/es/dropdown-item/types.d.ts +2 -6
- package/es/dropdown-menu/DropdownMenu.d.ts +2 -2
- package/es/dropdown-menu/DropdownMenu.js +17 -10
- package/es/dropdown-menu/index.css +1 -1
- package/es/dropdown-menu/index.less +0 -8
- package/es/dropdown-menu/types.d.ts +1 -0
- package/es/dropdown-menu/var.less +2 -2
- package/es/empty/Empty.d.ts +10 -0
- package/es/empty/Empty.js +11 -8
- package/es/empty/Network.js +22 -34
- package/es/empty/index.css +1 -1
- package/es/empty/index.d.ts +1 -0
- package/es/empty/var.less +1 -1
- package/es/field/Field.d.ts +6 -6
- package/es/field/Field.js +60 -39
- package/es/field/index.css +1 -1
- package/es/field/index.d.ts +4 -4
- package/es/field/types.d.ts +7 -6
- package/es/field/utils.d.ts +2 -2
- package/es/field/utils.js +9 -6
- package/es/field/var.less +3 -3
- package/es/form/Form.d.ts +2 -2
- package/es/form/Form.js +9 -8
- package/es/grid/Grid.d.ts +3 -2
- package/es/grid/Grid.js +6 -5
- package/es/grid/index.d.ts +1 -1
- package/es/grid-item/GridItem.d.ts +14 -0
- package/es/grid-item/GridItem.js +14 -12
- package/es/grid-item/index.css +1 -1
- package/es/grid-item/index.d.ts +1 -0
- package/es/grid-item/var.less +1 -1
- package/es/icon/Icon.d.ts +14 -0
- package/es/icon/Icon.js +14 -12
- package/es/icon/index.d.ts +1 -0
- package/es/image/Image.d.ts +31 -2
- package/es/image/Image.js +36 -35
- package/es/image/index.css +1 -1
- package/es/image/index.d.ts +2 -2
- package/es/image/var.less +1 -1
- package/es/image-preview/ImagePreview.d.ts +2 -2
- package/es/image-preview/ImagePreview.js +11 -11
- package/es/image-preview/ImagePreviewItem.js +4 -3
- package/es/image-preview/function-call.js +5 -1
- package/es/image-preview/index.css +1 -1
- package/es/image-preview/index.less +0 -5
- package/es/image-preview/var.less +0 -1
- package/es/index-anchor/IndexAnchor.d.ts +5 -0
- package/es/index-anchor/IndexAnchor.js +8 -6
- package/es/index-anchor/index.css +1 -1
- package/es/index-anchor/index.d.ts +1 -0
- package/es/index-anchor/var.less +1 -1
- package/es/index-bar/IndexBar.d.ts +2 -2
- package/es/index-bar/IndexBar.js +7 -6
- package/es/index.d.ts +1 -1
- package/es/index.js +1 -1
- package/es/lazyload/index.d.ts +1 -1
- package/es/lazyload/index.js +1 -1
- package/es/lazyload/vue-lazyload/index.d.ts +55 -0
- package/es/lazyload/vue-lazyload/index.js +46 -0
- package/es/lazyload/vue-lazyload/lazy-component.js +53 -0
- package/es/lazyload/vue-lazyload/lazy-container.js +98 -0
- package/es/lazyload/vue-lazyload/lazy-image.js +115 -0
- package/es/lazyload/vue-lazyload/lazy.js +507 -0
- package/es/lazyload/vue-lazyload/listener.js +241 -0
- package/es/lazyload/vue-lazyload/util.js +183 -0
- package/es/list/List.d.ts +2 -2
- package/es/list/List.js +10 -7
- package/es/list/index.css +1 -1
- package/es/list/var.less +1 -1
- package/es/loading/Loading.d.ts +13 -0
- package/es/loading/Loading.js +13 -11
- package/es/loading/index.css +1 -1
- package/es/loading/index.d.ts +1 -1
- package/es/loading/var.less +1 -1
- package/es/locale/index.js +5 -1
- package/es/nav-bar/NavBar.d.ts +16 -0
- package/es/nav-bar/NavBar.js +20 -18
- package/es/nav-bar/index.css +1 -1
- package/es/nav-bar/index.d.ts +1 -0
- package/es/nav-bar/index.less +0 -4
- package/es/nav-bar/var.less +1 -1
- package/es/notice-bar/NoticeBar.d.ts +2 -2
- package/es/notice-bar/NoticeBar.js +7 -6
- package/es/notify/Notify.d.ts +38 -0
- package/es/notify/Notify.js +15 -12
- package/es/notify/index.d.ts +1 -0
- package/es/number-keyboard/NumberKeyboard.d.ts +48 -1
- package/es/number-keyboard/NumberKeyboard.js +30 -28
- package/es/number-keyboard/NumberKeyboardKey.js +9 -8
- package/es/number-keyboard/index.css +1 -1
- package/es/number-keyboard/index.d.ts +1 -1
- package/es/number-keyboard/index.less +0 -4
- package/es/number-keyboard/var.less +1 -1
- package/es/overlay/Overlay.d.ts +13 -1
- package/es/overlay/Overlay.js +13 -11
- package/es/overlay/index.d.ts +1 -0
- package/es/pagination/Pagination.d.ts +31 -0
- package/es/pagination/Pagination.js +84 -64
- package/es/pagination/index.css +1 -1
- package/es/pagination/index.d.ts +1 -1
- package/es/pagination/index.less +32 -31
- package/es/pagination/var.less +1 -1
- package/es/password-input/PasswordInput.d.ts +21 -1
- package/es/password-input/PasswordInput.js +15 -12
- package/es/password-input/index.css +1 -1
- package/es/password-input/index.d.ts +2 -1
- package/es/password-input/var.less +3 -3
- package/es/picker/Picker.d.ts +40 -1
- package/es/picker/Picker.js +20 -17
- package/es/picker/PickerColumn.js +5 -4
- package/es/picker/index.css +1 -1
- package/es/picker/index.less +2 -10
- package/es/picker/var.less +9 -3
- package/es/popover/Popover.d.ts +50 -11
- package/es/popover/Popover.js +35 -30
- package/es/popover/index.css +1 -1
- package/es/popover/index.d.ts +17 -16
- package/es/popover/types.d.ts +11 -0
- package/es/popover/types.js +1 -0
- package/es/popover/var.less +3 -3
- package/es/popup/Popup.d.ts +48 -3
- package/es/popup/Popup.js +23 -24
- package/es/popup/index.css +1 -1
- package/es/popup/index.d.ts +2 -3
- package/es/popup/index.less +0 -5
- package/es/popup/var.less +1 -2
- package/es/progress/Progress.d.ts +2 -2
- package/es/progress/Progress.js +4 -4
- package/es/pull-refresh/PullRefresh.d.ts +23 -0
- package/es/pull-refresh/PullRefresh.js +18 -16
- package/es/pull-refresh/index.css +1 -1
- package/es/pull-refresh/index.d.ts +1 -0
- package/es/pull-refresh/var.less +1 -1
- package/es/radio/Radio.d.ts +3 -1
- package/es/radio/Radio.js +5 -4
- package/es/radio/index.css +1 -1
- package/es/radio/index.d.ts +1 -2
- package/es/radio/var.less +1 -1
- package/es/radio-group/RadioGroup.d.ts +3 -2
- package/es/radio-group/RadioGroup.js +7 -6
- package/es/radio-group/index.d.ts +1 -2
- package/es/rate/Rate.d.ts +33 -0
- package/es/rate/Rate.js +26 -22
- package/es/rate/index.d.ts +1 -0
- package/es/row/Row.d.ts +18 -1
- package/es/row/Row.js +12 -10
- package/es/row/index.d.ts +1 -1
- package/es/search/Search.d.ts +2 -2
- package/es/search/Search.js +16 -9
- package/es/search/index.css +1 -1
- package/es/search/var.less +1 -1
- package/es/share-sheet/ShareSheet.d.ts +48 -0
- package/es/share-sheet/ShareSheet.js +20 -17
- package/es/share-sheet/index.css +1 -1
- package/es/share-sheet/index.d.ts +1 -1
- package/es/share-sheet/index.less +0 -4
- package/es/share-sheet/var.less +3 -3
- package/es/sidebar/Sidebar.d.ts +8 -1
- package/es/sidebar/Sidebar.js +10 -7
- package/es/sidebar/index.d.ts +1 -0
- package/es/sidebar-item/SidebarItem.d.ts +12 -0
- package/es/sidebar-item/SidebarItem.js +16 -11
- package/es/sidebar-item/index.css +1 -1
- package/es/sidebar-item/index.d.ts +1 -0
- package/es/sidebar-item/var.less +2 -2
- package/es/skeleton/Skeleton.d.ts +29 -1
- package/es/skeleton/Skeleton.js +21 -18
- package/es/skeleton/index.d.ts +5 -6
- package/es/slider/Slider.d.ts +31 -3
- package/es/slider/Slider.js +29 -25
- package/es/slider/index.d.ts +3 -2
- package/es/step/Step.js +4 -3
- package/es/step/index.css +1 -1
- package/es/step/index.less +1 -1
- package/es/step/var.less +1 -1
- package/es/stepper/Stepper.d.ts +53 -1
- package/es/stepper/Stepper.js +49 -39
- package/es/stepper/index.css +1 -1
- package/es/stepper/index.d.ts +3 -4
- package/es/stepper/index.less +3 -18
- package/es/stepper/var.less +1 -2
- package/es/steps/Steps.d.ts +3 -2
- package/es/steps/Steps.js +7 -6
- package/es/steps/index.css +1 -1
- package/es/steps/index.d.ts +5 -6
- package/es/steps/var.less +1 -1
- package/es/sticky/Sticky.d.ts +18 -1
- package/es/sticky/Sticky.js +13 -11
- package/es/sticky/index.d.ts +1 -1
- package/es/style/base.css +1 -1
- package/es/style/base.less +4 -0
- package/es/style/css-variables.css +1 -1
- package/es/style/css-variables.less +3 -1
- package/es/style/mixins/hairline.less +3 -3
- package/es/style/var.less +5 -3
- package/es/submit-bar/SubmitBar.d.ts +33 -3
- package/es/submit-bar/SubmitBar.js +23 -20
- package/es/submit-bar/index.css +1 -1
- package/es/submit-bar/index.d.ts +3 -2
- package/es/submit-bar/var.less +3 -3
- package/es/swipe/Swipe.d.ts +2 -2
- package/es/swipe/Swipe.js +32 -18
- package/es/swipe/types.d.ts +1 -3
- package/es/swipe-cell/SwipeCell.d.ts +2 -2
- package/es/swipe-cell/SwipeCell.js +12 -7
- package/es/swipe-item/SwipeItem.js +4 -3
- package/es/switch/Switch.d.ts +18 -0
- package/es/switch/Switch.js +23 -19
- package/es/switch/index.css +1 -1
- package/es/switch/index.d.ts +1 -0
- package/es/switch/index.less +2 -0
- package/es/switch/var.less +1 -1
- package/es/tab/Tab.d.ts +19 -1
- package/es/tab/Tab.js +33 -18
- package/es/tab/index.css +1 -1
- package/es/tab/index.d.ts +1 -0
- package/es/tab/index.less +1 -1
- package/es/tabbar/Tabbar.d.ts +4 -3
- package/es/tabbar/Tabbar.js +17 -16
- package/es/tabbar/index.css +1 -1
- package/es/tabbar/index.d.ts +1 -0
- package/es/tabbar/var.less +1 -1
- package/es/tabbar-item/TabbarItem.d.ts +13 -0
- package/es/tabbar-item/TabbarItem.js +25 -16
- package/es/tabbar-item/index.css +1 -1
- package/es/tabbar-item/index.d.ts +1 -0
- package/es/tabbar-item/var.less +1 -1
- package/es/tabs/Tabs.d.ts +2 -2
- package/es/tabs/Tabs.js +30 -18
- package/es/tabs/TabsContent.js +5 -4
- package/es/tabs/TabsTitle.d.ts +6 -0
- package/es/tabs/TabsTitle.js +7 -1
- package/es/tabs/index.css +1 -1
- package/es/tabs/types.d.ts +1 -0
- package/es/tabs/var.less +2 -2
- package/es/tag/Tag.d.ts +23 -3
- package/es/tag/Tag.js +18 -15
- package/es/tag/index.css +1 -1
- package/es/tag/index.d.ts +3 -2
- package/es/tag/var.less +1 -1
- package/es/toast/Toast.d.ts +33 -1
- package/es/toast/Toast.js +26 -24
- package/es/toast/function-call.js +10 -2
- package/es/toast/index.d.ts +1 -0
- package/es/tree-select/TreeSelect.d.ts +28 -1
- package/es/tree-select/TreeSelect.js +18 -15
- package/es/tree-select/index.css +1 -1
- package/es/tree-select/index.d.ts +1 -1
- package/es/tree-select/var.less +1 -1
- package/es/uploader/Uploader.d.ts +2 -2
- package/es/uploader/Uploader.js +17 -10
- package/es/uploader/UploaderPreviewItem.js +10 -5
- package/es/uploader/index.css +1 -1
- package/es/uploader/utils.d.ts +2 -2
- package/es/uploader/utils.js +2 -2
- package/es/uploader/var.less +1 -1
- package/es/utils/constant.d.ts +1 -0
- package/es/utils/constant.js +1 -0
- package/es/utils/create.d.ts +2 -2
- package/es/utils/create.js +6 -1
- package/es/utils/deep-assign.d.ts +1 -1
- package/es/utils/deep-assign.js +1 -1
- package/es/utils/deep-clone.js +2 -2
- package/es/utils/dom.d.ts +1 -1
- package/es/utils/dom.js +6 -7
- package/es/utils/format.js +20 -7
- package/es/utils/interceptor.d.ts +2 -2
- package/es/utils/interceptor.js +7 -5
- package/es/vue-tsx-shim.d.ts +1 -0
- package/lib/action-bar/ActionBar.d.ts +8 -0
- package/lib/action-bar/ActionBar.js +8 -6
- package/lib/action-bar/index.css +1 -1
- package/lib/action-bar/index.d.ts +1 -0
- package/lib/action-bar/var.less +1 -1
- package/lib/action-bar-button/ActionBarButton.d.ts +14 -1
- package/lib/action-bar-button/ActionBarButton.js +13 -11
- package/lib/action-bar-button/index.d.ts +1 -0
- package/lib/action-bar-icon/ActionBarIcon.d.ts +15 -0
- package/lib/action-bar-icon/ActionBarIcon.js +15 -13
- package/lib/action-bar-icon/index.css +1 -1
- package/lib/action-bar-icon/index.d.ts +1 -0
- package/lib/action-bar-icon/var.less +1 -1
- package/lib/action-sheet/ActionSheet.d.ts +57 -0
- package/lib/action-sheet/ActionSheet.js +22 -19
- package/lib/action-sheet/index.css +1 -1
- package/lib/action-sheet/index.d.ts +1 -1
- package/lib/action-sheet/index.less +0 -5
- package/lib/action-sheet/var.less +4 -5
- package/lib/address-edit/AddressEdit.d.ts +2 -2
- package/lib/address-edit/AddressEdit.js +162 -186
- package/lib/address-edit/AddressEditDetail.d.ts +10 -9
- package/lib/address-edit/AddressEditDetail.js +10 -9
- package/lib/address-list/AddressList.d.ts +20 -0
- package/lib/address-list/AddressList.js +16 -13
- package/lib/address-list/AddressListItem.js +6 -4
- package/lib/address-list/index.css +1 -1
- package/lib/address-list/index.d.ts +1 -0
- package/lib/address-list/index.less +2 -2
- package/lib/address-list/var.less +2 -2
- package/lib/area/Area.d.ts +2 -2
- package/lib/area/Area.js +19 -8
- package/lib/area/index.d.ts +1 -2
- package/lib/badge/Badge.d.ts +18 -2
- package/lib/badge/Badge.js +16 -13
- package/lib/badge/index.css +1 -1
- package/lib/badge/index.d.ts +2 -1
- package/lib/badge/index.less +1 -1
- package/lib/button/Button.d.ts +43 -5
- package/lib/button/Button.js +28 -26
- package/lib/button/index.css +1 -1
- package/lib/button/index.d.ts +18 -17
- package/lib/button/types.d.ts +5 -0
- package/lib/button/types.js +3 -0
- package/lib/button/var.less +1 -1
- package/lib/calendar/Calendar.d.ts +2 -2
- package/lib/calendar/Calendar.js +32 -10
- package/lib/calendar/CalendarDay.js +5 -4
- package/lib/calendar/CalendarHeader.js +7 -7
- package/lib/calendar/CalendarMonth.d.ts +2 -2
- package/lib/calendar/CalendarMonth.js +7 -6
- package/lib/calendar/index.css +1 -1
- package/lib/calendar/index.d.ts +1 -2
- package/lib/calendar/types.d.ts +1 -1
- package/lib/calendar/utils.d.ts +1 -1
- package/lib/calendar/var.less +2 -2
- package/lib/card/Card.d.ts +18 -0
- package/lib/card/Card.js +20 -17
- package/lib/card/index.css +1 -1
- package/lib/card/index.d.ts +1 -0
- package/lib/card/var.less +3 -3
- package/lib/cascader/Cascader.d.ts +2 -2
- package/lib/cascader/Cascader.js +32 -14
- package/lib/cascader/index.css +1 -1
- package/lib/cascader/index.d.ts +1 -2
- package/lib/cascader/index.less +0 -5
- package/lib/cascader/var.less +2 -3
- package/lib/cell/Cell.d.ts +35 -5
- package/lib/cell/Cell.js +10 -15
- package/lib/cell/index.css +1 -1
- package/lib/cell/index.d.ts +3 -3
- package/lib/cell/var.less +3 -3
- package/lib/cell-group/CellGroup.d.ts +10 -0
- package/lib/cell-group/CellGroup.js +13 -10
- package/lib/cell-group/index.css +1 -1
- package/lib/cell-group/index.d.ts +1 -0
- package/lib/cell-group/var.less +2 -2
- package/lib/checkbox/Checkbox.d.ts +2 -2
- package/lib/checkbox/Checkbox.js +12 -7
- package/lib/checkbox/Checker.js +6 -5
- package/lib/checkbox/index.css +1 -1
- package/lib/checkbox/index.d.ts +1 -2
- package/lib/checkbox/types.d.ts +2 -6
- package/lib/checkbox/var.less +1 -1
- package/lib/checkbox-group/CheckboxGroup.d.ts +2 -2
- package/lib/checkbox-group/CheckboxGroup.js +12 -7
- package/lib/checkbox-group/index.d.ts +1 -2
- package/lib/circle/Circle.d.ts +37 -1
- package/lib/circle/Circle.js +21 -18
- package/lib/circle/index.d.ts +1 -1
- package/lib/col/Col.d.ts +13 -0
- package/lib/col/Col.js +10 -8
- package/lib/col/index.d.ts +1 -0
- package/lib/collapse/Collapse.d.ts +13 -1
- package/lib/collapse/Collapse.js +14 -12
- package/lib/collapse/index.d.ts +1 -0
- package/lib/collapse-item/CollapseItem.d.ts +5 -5
- package/lib/collapse-item/CollapseItem.js +12 -7
- package/lib/collapse-item/index.css +1 -1
- package/lib/collapse-item/index.d.ts +3 -4
- package/lib/collapse-item/var.less +3 -3
- package/lib/composables/use-id.d.ts +1 -0
- package/lib/composables/use-id.js +21 -0
- package/lib/composables/use-route.d.ts +1 -1
- package/lib/composables/use-route.js +4 -4
- package/lib/config-provider/ConfigProvider.d.ts +11 -2
- package/lib/config-provider/ConfigProvider.js +11 -9
- package/lib/config-provider/index.d.ts +2 -1
- package/lib/contact-card/ContactCard.d.ts +15 -0
- package/lib/contact-card/ContactCard.js +13 -10
- package/lib/contact-card/index.css +1 -1
- package/lib/contact-card/index.d.ts +1 -1
- package/lib/contact-card/index.less +2 -2
- package/lib/contact-edit/ContactEdit.d.ts +17 -1
- package/lib/contact-edit/ContactEdit.js +20 -18
- package/lib/contact-edit/index.d.ts +1 -1
- package/lib/contact-list/ContactList.d.ts +8 -1
- package/lib/contact-list/ContactList.js +12 -9
- package/lib/contact-list/index.css +1 -1
- package/lib/contact-list/index.d.ts +1 -1
- package/lib/contact-list/index.less +1 -1
- package/lib/count-down/CountDown.d.ts +2 -2
- package/lib/count-down/CountDown.js +8 -6
- package/lib/count-down/index.d.ts +1 -2
- package/lib/coupon/Coupon.js +6 -13
- package/lib/coupon/index.css +1 -1
- package/lib/coupon/index.less +2 -1
- package/lib/coupon/utils.d.ts +3 -0
- package/lib/coupon/utils.js +20 -0
- package/lib/coupon/var.less +3 -2
- package/lib/coupon-cell/CouponCell.d.ts +25 -0
- package/lib/coupon-cell/CouponCell.js +16 -11
- package/lib/coupon-cell/index.d.ts +1 -0
- package/lib/coupon-list/CouponList.d.ts +55 -0
- package/lib/coupon-list/CouponList.js +65 -46
- package/lib/coupon-list/index.css +1 -1
- package/lib/coupon-list/index.d.ts +1 -0
- package/lib/coupon-list/index.less +3 -8
- package/lib/coupon-list/var.less +1 -1
- package/lib/datetime-picker/DatePicker.js +12 -9
- package/lib/datetime-picker/DatetimePicker.d.ts +2 -2
- package/lib/datetime-picker/DatetimePicker.js +10 -9
- package/lib/datetime-picker/TimePicker.js +12 -9
- package/lib/datetime-picker/utils.d.ts +1 -1
- package/lib/datetime-picker/utils.js +4 -4
- package/lib/dialog/Dialog.d.ts +55 -1
- package/lib/dialog/Dialog.js +27 -25
- package/lib/dialog/index.css +1 -1
- package/lib/dialog/index.d.ts +1 -0
- package/lib/dialog/var.less +1 -1
- package/lib/divider/Divider.d.ts +13 -0
- package/lib/divider/Divider.js +11 -9
- package/lib/divider/index.css +1 -1
- package/lib/divider/index.d.ts +1 -1
- package/lib/divider/var.less +1 -1
- package/lib/dropdown-item/DropdownItem.d.ts +2 -2
- package/lib/dropdown-item/DropdownItem.js +23 -9
- package/lib/dropdown-item/types.d.ts +2 -6
- package/lib/dropdown-menu/DropdownMenu.d.ts +2 -2
- package/lib/dropdown-menu/DropdownMenu.js +17 -9
- package/lib/dropdown-menu/index.css +1 -1
- package/lib/dropdown-menu/index.less +0 -8
- package/lib/dropdown-menu/types.d.ts +1 -0
- package/lib/dropdown-menu/var.less +2 -2
- package/lib/empty/Empty.d.ts +10 -0
- package/lib/empty/Empty.js +12 -9
- package/lib/empty/Network.js +22 -34
- package/lib/empty/index.css +1 -1
- package/lib/empty/index.d.ts +1 -0
- package/lib/empty/var.less +1 -1
- package/lib/field/Field.d.ts +6 -6
- package/lib/field/Field.js +60 -38
- package/lib/field/index.css +1 -1
- package/lib/field/index.d.ts +4 -4
- package/lib/field/types.d.ts +7 -6
- package/lib/field/utils.d.ts +2 -2
- package/lib/field/utils.js +8 -5
- package/lib/field/var.less +3 -3
- package/lib/form/Form.d.ts +2 -2
- package/lib/form/Form.js +8 -7
- package/lib/grid/Grid.d.ts +3 -2
- package/lib/grid/Grid.js +6 -5
- package/lib/grid/index.d.ts +1 -1
- package/lib/grid-item/GridItem.d.ts +14 -0
- package/lib/grid-item/GridItem.js +14 -12
- package/lib/grid-item/index.css +1 -1
- package/lib/grid-item/index.d.ts +1 -0
- package/lib/grid-item/var.less +1 -1
- package/lib/icon/Icon.d.ts +14 -0
- package/lib/icon/Icon.js +15 -12
- package/lib/icon/index.d.ts +1 -0
- package/lib/image/Image.d.ts +31 -2
- package/lib/image/Image.js +36 -35
- package/lib/image/index.css +1 -1
- package/lib/image/index.d.ts +2 -2
- package/lib/image/var.less +1 -1
- package/lib/image-preview/ImagePreview.d.ts +2 -2
- package/lib/image-preview/ImagePreview.js +9 -9
- package/lib/image-preview/ImagePreviewItem.js +4 -3
- package/lib/image-preview/function-call.js +5 -1
- package/lib/image-preview/index.css +1 -1
- package/lib/image-preview/index.less +0 -5
- package/lib/image-preview/var.less +0 -1
- package/lib/index-anchor/IndexAnchor.d.ts +5 -0
- package/lib/index-anchor/IndexAnchor.js +8 -6
- package/lib/index-anchor/index.css +1 -1
- package/lib/index-anchor/index.d.ts +1 -0
- package/lib/index-anchor/var.less +1 -1
- package/lib/index-bar/IndexBar.d.ts +2 -2
- package/lib/index-bar/IndexBar.js +7 -6
- package/lib/index.css +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/lazyload/index.d.ts +1 -1
- package/lib/lazyload/index.js +3 -3
- package/lib/lazyload/vue-lazyload/index.d.ts +55 -0
- package/lib/lazyload/vue-lazyload/index.js +58 -0
- package/lib/lazyload/vue-lazyload/lazy-component.js +62 -0
- package/lib/lazyload/vue-lazyload/lazy-container.js +106 -0
- package/lib/lazyload/vue-lazyload/lazy-image.js +125 -0
- package/lib/lazyload/vue-lazyload/lazy.js +520 -0
- package/lib/lazyload/vue-lazyload/listener.js +251 -0
- package/lib/lazyload/vue-lazyload/util.js +213 -0
- package/lib/list/List.d.ts +2 -2
- package/lib/list/List.js +10 -7
- package/lib/list/index.css +1 -1
- package/lib/list/var.less +1 -1
- package/lib/loading/Loading.d.ts +13 -0
- package/lib/loading/Loading.js +13 -11
- package/lib/loading/index.css +1 -1
- package/lib/loading/index.d.ts +1 -1
- package/lib/loading/var.less +1 -1
- package/lib/locale/index.js +5 -1
- package/lib/nav-bar/NavBar.d.ts +16 -0
- package/lib/nav-bar/NavBar.js +19 -17
- package/lib/nav-bar/index.css +1 -1
- package/lib/nav-bar/index.d.ts +1 -0
- package/lib/nav-bar/index.less +0 -4
- package/lib/nav-bar/var.less +1 -1
- package/lib/notice-bar/NoticeBar.d.ts +2 -2
- package/lib/notice-bar/NoticeBar.js +7 -6
- package/lib/notify/Notify.d.ts +38 -0
- package/lib/notify/Notify.js +15 -12
- package/lib/notify/index.d.ts +1 -0
- package/lib/number-keyboard/NumberKeyboard.d.ts +48 -1
- package/lib/number-keyboard/NumberKeyboard.js +29 -27
- package/lib/number-keyboard/NumberKeyboardKey.js +8 -7
- package/lib/number-keyboard/index.css +1 -1
- package/lib/number-keyboard/index.d.ts +1 -1
- package/lib/number-keyboard/index.less +0 -4
- package/lib/number-keyboard/var.less +1 -1
- package/lib/overlay/Overlay.d.ts +13 -1
- package/lib/overlay/Overlay.js +14 -12
- package/lib/overlay/index.d.ts +1 -0
- package/lib/pagination/Pagination.d.ts +31 -0
- package/lib/pagination/Pagination.js +83 -62
- package/lib/pagination/index.css +1 -1
- package/lib/pagination/index.d.ts +1 -1
- package/lib/pagination/index.less +32 -31
- package/lib/pagination/var.less +1 -1
- package/lib/password-input/PasswordInput.d.ts +21 -1
- package/lib/password-input/PasswordInput.js +15 -12
- package/lib/password-input/index.css +1 -1
- package/lib/password-input/index.d.ts +2 -1
- package/lib/password-input/var.less +3 -3
- package/lib/picker/Picker.d.ts +40 -1
- package/lib/picker/Picker.js +21 -18
- package/lib/picker/PickerColumn.js +5 -4
- package/lib/picker/index.css +1 -1
- package/lib/picker/index.less +2 -10
- package/lib/picker/var.less +9 -3
- package/lib/popover/Popover.d.ts +50 -11
- package/lib/popover/Popover.js +33 -29
- package/lib/popover/index.css +1 -1
- package/lib/popover/index.d.ts +17 -16
- package/lib/popover/types.d.ts +11 -0
- package/lib/popover/types.js +3 -0
- package/lib/popover/var.less +3 -3
- package/lib/popup/Popup.d.ts +48 -3
- package/lib/popup/Popup.js +22 -23
- package/lib/popup/index.css +1 -1
- package/lib/popup/index.d.ts +2 -3
- package/lib/popup/index.less +0 -5
- package/lib/popup/var.less +1 -2
- package/lib/progress/Progress.d.ts +2 -2
- package/lib/progress/Progress.js +4 -4
- package/lib/pull-refresh/PullRefresh.d.ts +23 -0
- package/lib/pull-refresh/PullRefresh.js +18 -16
- package/lib/pull-refresh/index.css +1 -1
- package/lib/pull-refresh/index.d.ts +1 -0
- package/lib/pull-refresh/var.less +1 -1
- package/lib/radio/Radio.d.ts +3 -1
- package/lib/radio/Radio.js +5 -4
- package/lib/radio/index.css +1 -1
- package/lib/radio/index.d.ts +1 -2
- package/lib/radio/var.less +1 -1
- package/lib/radio-group/RadioGroup.d.ts +3 -2
- package/lib/radio-group/RadioGroup.js +7 -6
- package/lib/radio-group/index.d.ts +1 -2
- package/lib/rate/Rate.d.ts +33 -0
- package/lib/rate/Rate.js +27 -22
- package/lib/rate/index.d.ts +1 -0
- package/lib/row/Row.d.ts +18 -1
- package/lib/row/Row.js +12 -10
- package/lib/row/index.d.ts +1 -1
- package/lib/search/Search.d.ts +2 -2
- package/lib/search/Search.js +17 -9
- package/lib/search/index.css +1 -1
- package/lib/search/var.less +1 -1
- package/lib/share-sheet/ShareSheet.d.ts +48 -0
- package/lib/share-sheet/ShareSheet.js +19 -16
- package/lib/share-sheet/index.css +1 -1
- package/lib/share-sheet/index.d.ts +1 -1
- package/lib/share-sheet/index.less +0 -4
- package/lib/share-sheet/var.less +3 -3
- package/lib/sidebar/Sidebar.d.ts +8 -1
- package/lib/sidebar/Sidebar.js +10 -7
- package/lib/sidebar/index.d.ts +1 -0
- package/lib/sidebar-item/SidebarItem.d.ts +12 -0
- package/lib/sidebar-item/SidebarItem.js +16 -11
- package/lib/sidebar-item/index.css +1 -1
- package/lib/sidebar-item/index.d.ts +1 -0
- package/lib/sidebar-item/var.less +2 -2
- package/lib/skeleton/Skeleton.d.ts +29 -1
- package/lib/skeleton/Skeleton.js +22 -19
- package/lib/skeleton/index.d.ts +5 -6
- package/lib/slider/Slider.d.ts +31 -3
- package/lib/slider/Slider.js +29 -25
- package/lib/slider/index.d.ts +3 -2
- package/lib/step/Step.js +4 -3
- package/lib/step/index.css +1 -1
- package/lib/step/index.less +1 -1
- package/lib/step/var.less +1 -1
- package/lib/stepper/Stepper.d.ts +53 -1
- package/lib/stepper/Stepper.js +48 -37
- package/lib/stepper/index.css +1 -1
- package/lib/stepper/index.d.ts +3 -4
- package/lib/stepper/index.less +3 -18
- package/lib/stepper/var.less +1 -2
- package/lib/steps/Steps.d.ts +3 -2
- package/lib/steps/Steps.js +7 -6
- package/lib/steps/index.css +1 -1
- package/lib/steps/index.d.ts +5 -6
- package/lib/steps/var.less +1 -1
- package/lib/sticky/Sticky.d.ts +18 -1
- package/lib/sticky/Sticky.js +13 -11
- package/lib/sticky/index.d.ts +1 -1
- package/lib/style/base.css +1 -1
- package/lib/style/base.less +4 -0
- package/lib/style/css-variables.css +1 -1
- package/lib/style/css-variables.less +3 -1
- package/lib/style/mixins/hairline.less +3 -3
- package/lib/style/var.less +5 -3
- package/lib/submit-bar/SubmitBar.d.ts +33 -3
- package/lib/submit-bar/SubmitBar.js +23 -20
- package/lib/submit-bar/index.css +1 -1
- package/lib/submit-bar/index.d.ts +3 -2
- package/lib/submit-bar/var.less +3 -3
- package/lib/swipe/Swipe.d.ts +2 -2
- package/lib/swipe/Swipe.js +30 -16
- package/lib/swipe/types.d.ts +1 -3
- package/lib/swipe-cell/SwipeCell.d.ts +2 -2
- package/lib/swipe-cell/SwipeCell.js +12 -7
- package/lib/swipe-item/SwipeItem.js +4 -3
- package/lib/switch/Switch.d.ts +18 -0
- package/lib/switch/Switch.js +23 -19
- package/lib/switch/index.css +1 -1
- package/lib/switch/index.d.ts +1 -0
- package/lib/switch/index.less +2 -0
- package/lib/switch/var.less +1 -1
- package/lib/tab/Tab.d.ts +19 -1
- package/lib/tab/Tab.js +35 -18
- package/lib/tab/index.css +1 -1
- package/lib/tab/index.d.ts +1 -0
- package/lib/tab/index.less +1 -1
- package/lib/tabbar/Tabbar.d.ts +4 -3
- package/lib/tabbar/Tabbar.js +17 -16
- package/lib/tabbar/index.css +1 -1
- package/lib/tabbar/index.d.ts +1 -0
- package/lib/tabbar/var.less +1 -1
- package/lib/tabbar-item/TabbarItem.d.ts +13 -0
- package/lib/tabbar-item/TabbarItem.js +24 -15
- package/lib/tabbar-item/index.css +1 -1
- package/lib/tabbar-item/index.d.ts +1 -0
- package/lib/tabbar-item/var.less +1 -1
- package/lib/tabs/Tabs.d.ts +2 -2
- package/lib/tabs/Tabs.js +29 -16
- package/lib/tabs/TabsContent.js +5 -4
- package/lib/tabs/TabsTitle.d.ts +6 -0
- package/lib/tabs/TabsTitle.js +7 -1
- package/lib/tabs/index.css +1 -1
- package/lib/tabs/types.d.ts +1 -0
- package/lib/tabs/var.less +2 -2
- package/lib/tag/Tag.d.ts +23 -3
- package/lib/tag/Tag.js +18 -15
- package/lib/tag/index.css +1 -1
- package/lib/tag/index.d.ts +3 -2
- package/lib/tag/var.less +1 -1
- package/lib/toast/Toast.d.ts +33 -1
- package/lib/toast/Toast.js +26 -24
- package/lib/toast/function-call.js +10 -2
- package/lib/toast/index.d.ts +1 -0
- package/lib/tree-select/TreeSelect.d.ts +28 -1
- package/lib/tree-select/TreeSelect.js +18 -15
- package/lib/tree-select/index.css +1 -1
- package/lib/tree-select/index.d.ts +1 -1
- package/lib/tree-select/var.less +1 -1
- package/lib/uploader/Uploader.d.ts +2 -2
- package/lib/uploader/Uploader.js +17 -10
- package/lib/uploader/UploaderPreviewItem.js +9 -4
- package/lib/uploader/index.css +1 -1
- package/lib/uploader/utils.d.ts +2 -2
- package/lib/uploader/utils.js +3 -2
- package/lib/uploader/var.less +1 -1
- package/lib/utils/constant.d.ts +1 -0
- package/lib/utils/constant.js +3 -1
- package/lib/utils/create.d.ts +2 -2
- package/lib/utils/create.js +6 -1
- package/lib/utils/deep-assign.d.ts +1 -1
- package/lib/utils/deep-assign.js +1 -1
- package/lib/utils/deep-clone.js +1 -1
- package/lib/utils/dom.d.ts +1 -1
- package/lib/utils/dom.js +9 -9
- package/lib/utils/format.js +21 -7
- package/lib/utils/interceptor.d.ts +2 -2
- package/lib/utils/interceptor.js +7 -5
- package/lib/vant.es.js +3584 -3234
- package/lib/vant.es.min.js +3584 -3234
- package/lib/vant.js +3583 -3233
- package/lib/vant.min.js +1 -1
- package/lib/vue-tsx-shim.d.ts +1 -0
- package/package.json +10 -7
- package/vetur/attributes.json +92 -92
- package/vetur/tags.json +26 -26
- package/vetur/web-types.json +358 -350
- package/es/composables/use-link-field.d.ts +0 -0
- package/es/composables/use-link-field.js +0 -0
- package/lib/composables/use-link-field.d.ts +0 -0
- package/lib/composables/use-link-field.js +0 -1
package/es/image/Image.js
CHANGED
@@ -5,30 +5,32 @@ import { isDef, addUnit, inBrowser, truthProp, numericProp, makeStringProp, crea
|
|
5
5
|
|
6
6
|
import { Icon } from '../icon';
|
7
7
|
var [name, bem] = createNamespace('image');
|
8
|
+
var imageProps = {
|
9
|
+
src: String,
|
10
|
+
alt: String,
|
11
|
+
fit: String,
|
12
|
+
round: Boolean,
|
13
|
+
width: numericProp,
|
14
|
+
height: numericProp,
|
15
|
+
radius: numericProp,
|
16
|
+
lazyLoad: Boolean,
|
17
|
+
iconSize: numericProp,
|
18
|
+
showError: truthProp,
|
19
|
+
errorIcon: makeStringProp('photo-fail'),
|
20
|
+
iconPrefix: String,
|
21
|
+
showLoading: truthProp,
|
22
|
+
loadingIcon: makeStringProp('photo')
|
23
|
+
};
|
8
24
|
export default defineComponent({
|
9
25
|
name,
|
10
|
-
props:
|
11
|
-
src: String,
|
12
|
-
alt: String,
|
13
|
-
fit: String,
|
14
|
-
round: Boolean,
|
15
|
-
width: numericProp,
|
16
|
-
height: numericProp,
|
17
|
-
radius: numericProp,
|
18
|
-
lazyLoad: Boolean,
|
19
|
-
iconSize: numericProp,
|
20
|
-
showError: truthProp,
|
21
|
-
errorIcon: makeStringProp('photo-fail'),
|
22
|
-
iconPrefix: String,
|
23
|
-
showLoading: truthProp,
|
24
|
-
loadingIcon: makeStringProp('photo')
|
25
|
-
},
|
26
|
+
props: imageProps,
|
26
27
|
emits: ['load', 'error'],
|
27
28
|
|
28
|
-
setup(props, {
|
29
|
-
|
30
|
-
|
31
|
-
|
29
|
+
setup(props, _ref) {
|
30
|
+
var {
|
31
|
+
emit,
|
32
|
+
slots
|
33
|
+
} = _ref;
|
32
34
|
var error = ref(false);
|
33
35
|
var loading = ref(true);
|
34
36
|
var imageRef = ref();
|
@@ -36,15 +38,10 @@ export default defineComponent({
|
|
36
38
|
$Lazyload
|
37
39
|
} = getCurrentInstance().proxy;
|
38
40
|
var style = computed(() => {
|
39
|
-
var style = {
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
}
|
44
|
-
|
45
|
-
if (isDef(props.height)) {
|
46
|
-
style.height = addUnit(props.height);
|
47
|
-
}
|
41
|
+
var style = {
|
42
|
+
width: addUnit(props.width),
|
43
|
+
height: addUnit(props.height)
|
44
|
+
};
|
48
45
|
|
49
46
|
if (isDef(props.radius)) {
|
50
47
|
style.overflow = 'hidden';
|
@@ -122,17 +119,21 @@ export default defineComponent({
|
|
122
119
|
}, attrs), null);
|
123
120
|
};
|
124
121
|
|
125
|
-
var onLazyLoaded =
|
126
|
-
|
127
|
-
|
122
|
+
var onLazyLoaded = _ref2 => {
|
123
|
+
var {
|
124
|
+
el
|
125
|
+
} = _ref2;
|
126
|
+
|
128
127
|
if (el === imageRef.value && loading.value) {
|
129
128
|
onLoad();
|
130
129
|
}
|
131
130
|
};
|
132
131
|
|
133
|
-
var onLazyLoadError =
|
134
|
-
|
135
|
-
|
132
|
+
var onLazyLoadError = _ref3 => {
|
133
|
+
var {
|
134
|
+
el
|
135
|
+
} = _ref3;
|
136
|
+
|
136
137
|
if (el === imageRef.value && !error.value) {
|
137
138
|
onError();
|
138
139
|
}
|
package/es/image/index.css
CHANGED
@@ -1 +1 @@
|
|
1
|
-
:root{--van-image-placeholder-text-color:var(--van-
|
1
|
+
:root{--van-image-placeholder-text-color:var(--van-text-color-2);--van-image-placeholder-font-size:var(--van-font-size-md);--van-image-placeholder-background-color:var(--van-background-color);--van-image-loading-icon-size:32px;--van-image-loading-icon-color:var(--van-gray-4);--van-image-error-icon-size:32px;--van-image-error-icon-color:var(--van-gray-4)}.van-image{position:relative;display:inline-block}.van-image--round{overflow:hidden;border-radius:var(--van-border-radius-max)}.van-image--round .van-image__img{border-radius:inherit}.van-image__error,.van-image__img,.van-image__loading{display:block;width:100%;height:100%}.van-image__error,.van-image__loading{position:absolute;top:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--van-image-placeholder-text-color);font-size:var(--van-image-placeholder-font-size);background:var(--van-image-placeholder-background-color)}.van-image__loading-icon{color:var(--van-image-loading-icon-color);font-size:var(--van-image-loading-icon-size)}.van-image__error-icon{color:var(--van-image-error-icon-color);font-size:var(--van-image-error-icon-size)}
|
package/es/image/index.d.ts
CHANGED
@@ -54,8 +54,8 @@ export declare const Image: import("../utils").WithInstall<import("vue").DefineC
|
|
54
54
|
alt?: string | undefined;
|
55
55
|
src?: string | undefined;
|
56
56
|
iconSize?: string | number | undefined;
|
57
|
-
radius?: string | number | undefined;
|
58
57
|
fit?: import("./Image").ImageFit | undefined;
|
58
|
+
radius?: string | number | undefined;
|
59
59
|
}> & {
|
60
60
|
onLoad?: ((...args: any[]) => any) | undefined;
|
61
61
|
onError?: ((...args: any[]) => any) | undefined;
|
@@ -68,4 +68,4 @@ export declare const Image: import("../utils").WithInstall<import("vue").DefineC
|
|
68
68
|
loadingIcon: string;
|
69
69
|
}>>;
|
70
70
|
export default Image;
|
71
|
-
export type { ImageFit } from './Image';
|
71
|
+
export type { ImageFit, ImageProps } from './Image';
|
package/es/image/var.less
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
@import '../style/var.less';
|
2
2
|
|
3
|
-
@image-placeholder-text-color: var(--van-
|
3
|
+
@image-placeholder-text-color: var(--van-text-color-2);
|
4
4
|
@image-placeholder-font-size: var(--van-font-size-md);
|
5
5
|
@image-placeholder-background-color: var(--van-background-color);
|
6
6
|
@image-loading-icon-size: 32px;
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { PropType, CSSProperties, ExtractPropTypes } from 'vue';
|
2
2
|
import { Interceptor } from '../utils';
|
3
3
|
import { PopupCloseIconPosition } from '../popup';
|
4
|
-
declare const
|
4
|
+
declare const imagePreviewProps: {
|
5
5
|
show: BooleanConstructor;
|
6
6
|
loop: {
|
7
7
|
type: BooleanConstructor;
|
@@ -54,7 +54,7 @@ declare const props: {
|
|
54
54
|
default: PopupCloseIconPosition;
|
55
55
|
};
|
56
56
|
};
|
57
|
-
export declare type ImagePreviewProps = ExtractPropTypes<typeof
|
57
|
+
export declare type ImagePreviewProps = ExtractPropTypes<typeof imagePreviewProps>;
|
58
58
|
declare const _default: import("vue").DefineComponent<{
|
59
59
|
show: BooleanConstructor;
|
60
60
|
loop: {
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import { mergeProps as _mergeProps, createVNode as _createVNode } from "vue";
|
2
2
|
import { ref, watch, nextTick, reactive, onMounted, defineComponent } from 'vue'; // Utils
|
3
3
|
|
4
|
-
import { pick, truthProp, unknownProp, makeArrayProp, makeStringProp, makeNumericProp, callInterceptor, createNamespace } from '../utils'; // Composables
|
4
|
+
import { pick, truthProp, unknownProp, windowWidth, windowHeight, makeArrayProp, makeStringProp, makeNumericProp, callInterceptor, createNamespace, HAPTICS_FEEDBACK } from '../utils'; // Composables
|
5
5
|
|
6
|
-
import { useRect
|
6
|
+
import { useRect } from '@vant/use';
|
7
7
|
import { useExpose } from '../composables/use-expose'; // Components
|
8
8
|
|
9
9
|
import { Icon } from '../icon';
|
@@ -13,7 +13,7 @@ import ImagePreviewItem from './ImagePreviewItem'; // Types
|
|
13
13
|
|
14
14
|
var [name, bem] = createNamespace('image-preview');
|
15
15
|
var popupProps = ['show', 'transition', 'overlayStyle', 'closeOnPopstate'];
|
16
|
-
var
|
16
|
+
var imagePreviewProps = {
|
17
17
|
show: Boolean,
|
18
18
|
loop: truthProp,
|
19
19
|
images: makeArrayProp(),
|
@@ -35,15 +35,15 @@ var props = {
|
|
35
35
|
};
|
36
36
|
export default defineComponent({
|
37
37
|
name,
|
38
|
-
props,
|
38
|
+
props: imagePreviewProps,
|
39
39
|
emits: ['scale', 'close', 'closed', 'change', 'update:show'],
|
40
40
|
|
41
|
-
setup(props, {
|
42
|
-
|
43
|
-
|
44
|
-
|
41
|
+
setup(props, _ref) {
|
42
|
+
var {
|
43
|
+
emit,
|
44
|
+
slots
|
45
|
+
} = _ref;
|
45
46
|
var swipeRef = ref();
|
46
|
-
var windowSize = useWindowSize();
|
47
47
|
var state = reactive({
|
48
48
|
active: 0,
|
49
49
|
rootWidth: 0,
|
@@ -124,7 +124,7 @@ export default defineComponent({
|
|
124
124
|
return _createVNode(Icon, {
|
125
125
|
"role": "button",
|
126
126
|
"name": props.closeIcon,
|
127
|
-
"class": bem('close-icon', props.closeIconPosition),
|
127
|
+
"class": [bem('close-icon', props.closeIconPosition), HAPTICS_FEEDBACK],
|
128
128
|
"onClick": emitClose
|
129
129
|
}, null);
|
130
130
|
}
|
@@ -142,7 +142,7 @@ export default defineComponent({
|
|
142
142
|
swipeTo
|
143
143
|
});
|
144
144
|
onMounted(resize);
|
145
|
-
watch([
|
145
|
+
watch([windowWidth, windowHeight], resize);
|
146
146
|
watch(() => props.startPosition, value => setActive(+value));
|
147
147
|
watch(() => props.show, value => {
|
148
148
|
var {
|
@@ -49,7 +49,11 @@ function initInstance() {
|
|
49
49
|
}));
|
50
50
|
}
|
51
51
|
|
52
|
-
var ImagePreview = (options, startPosition
|
52
|
+
var ImagePreview = function (options, startPosition) {
|
53
|
+
if (startPosition === void 0) {
|
54
|
+
startPosition = 0;
|
55
|
+
}
|
56
|
+
|
53
57
|
/* istanbul ignore if */
|
54
58
|
if (!inBrowser) {
|
55
59
|
return;
|
@@ -1 +1 @@
|
|
1
|
-
:root{--van-image-preview-index-text-color:var(--van-white);--van-image-preview-index-font-size:var(--van-font-size-md);--van-image-preview-index-line-height:var(--van-line-height-md);--van-image-preview-index-text-shadow:0 1px 1px var(--van-gray-8);--van-image-preview-overlay-background-color:rgba(0, 0, 0, 0.9);--van-image-preview-close-icon-size:22px;--van-image-preview-close-icon-color:var(--van-gray-5);--van-image-preview-close-icon-
|
1
|
+
:root{--van-image-preview-index-text-color:var(--van-white);--van-image-preview-index-font-size:var(--van-font-size-md);--van-image-preview-index-line-height:var(--van-line-height-md);--van-image-preview-index-text-shadow:0 1px 1px var(--van-gray-8);--van-image-preview-overlay-background-color:rgba(0, 0, 0, 0.9);--van-image-preview-close-icon-size:22px;--van-image-preview-close-icon-color:var(--van-gray-5);--van-image-preview-close-icon-margin:var(--van-padding-md);--van-image-preview-close-icon-z-index:1}.van-image-preview{position:fixed;top:0;left:0;width:100%;height:100%;background-color:transparent;transform:none}.van-image-preview__swipe{height:100%}.van-image-preview__swipe-item{display:flex;align-items:center;justify-content:center;overflow:hidden}.van-image-preview__cover{position:absolute;top:0;left:0}.van-image-preview__image{width:100%;transition-property:transform}.van-image-preview__image--vertical{width:auto;height:100%}.van-image-preview__image img{-webkit-user-drag:none}.van-image-preview__image .van-image__error{top:30%;height:40%}.van-image-preview__image .van-image__error-icon{font-size:36px}.van-image-preview__image .van-image__loading{background-color:transparent}.van-image-preview__index{position:absolute;top:var(--van-padding-md);left:50%;color:var(--van-image-preview-index-text-color);font-size:var(--van-image-preview-index-font-size);line-height:var(--van-image-preview-index-line-height);text-shadow:var(--van-image-preview-index-text-shadow);transform:translate(-50%,0)}.van-image-preview__overlay{background:var(--van-image-preview-overlay-background-color)}.van-image-preview__close-icon{position:absolute;z-index:var(--van-image-preview-close-icon-z-index);color:var(--van-image-preview-close-icon-color);font-size:var(--van-image-preview-close-icon-size);cursor:pointer}.van-image-preview__close-icon--top-left{top:var(--van-image-preview-close-icon-margin);left:var(--van-image-preview-close-icon-margin)}.van-image-preview__close-icon--top-right{top:var(--van-image-preview-close-icon-margin);right:var(--van-image-preview-close-icon-margin)}.van-image-preview__close-icon--bottom-left{bottom:var(--van-image-preview-close-icon-margin);left:var(--van-image-preview-close-icon-margin)}.van-image-preview__close-icon--bottom-right{right:var(--van-image-preview-close-icon-margin);bottom:var(--van-image-preview-close-icon-margin)}
|
@@ -8,7 +8,6 @@
|
|
8
8
|
--van-image-preview-overlay-background-color: @image-preview-overlay-background-color;
|
9
9
|
--van-image-preview-close-icon-size: @image-preview-close-icon-size;
|
10
10
|
--van-image-preview-close-icon-color: @image-preview-close-icon-color;
|
11
|
-
--van-image-preview-close-icon-active-color: @image-preview-close-icon-active-color;
|
12
11
|
--van-image-preview-close-icon-margin: @image-preview-close-icon-margin;
|
13
12
|
--van-image-preview-close-icon-z-index: @image-preview-close-icon-z-index;
|
14
13
|
}
|
@@ -91,10 +90,6 @@
|
|
91
90
|
font-size: var(--van-image-preview-close-icon-size);
|
92
91
|
cursor: pointer;
|
93
92
|
|
94
|
-
&:active {
|
95
|
-
color: var(--van-image-preview-close-icon-active-color);
|
96
|
-
}
|
97
|
-
|
98
93
|
&--top-left {
|
99
94
|
top: var(--van-image-preview-close-icon-margin);
|
100
95
|
left: var(--van-image-preview-close-icon-margin);
|
@@ -7,6 +7,5 @@
|
|
7
7
|
@image-preview-overlay-background-color: rgba(0, 0, 0, 0.9);
|
8
8
|
@image-preview-close-icon-size: 22px;
|
9
9
|
@image-preview-close-icon-color: var(--van-gray-5);
|
10
|
-
@image-preview-close-icon-active-color: var(--van-gray-6);
|
11
10
|
@image-preview-close-icon-margin: var(--van-padding-md);
|
12
11
|
@image-preview-close-icon-z-index: 1;
|
@@ -1,3 +1,8 @@
|
|
1
|
+
import { ExtractPropTypes } from 'vue';
|
2
|
+
declare const indexAnchorProps: {
|
3
|
+
index: (NumberConstructor | StringConstructor)[];
|
4
|
+
};
|
5
|
+
export declare type IndexAnchorProps = ExtractPropTypes<typeof indexAnchorProps>;
|
1
6
|
declare const _default: import("vue").DefineComponent<{
|
2
7
|
index: (NumberConstructor | StringConstructor)[];
|
3
8
|
}, (() => JSX.Element) | undefined, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, Record<string, any>, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("@vue/runtime-core").ComponentCustomProps, Readonly<{
|
@@ -8,15 +8,17 @@ import { getScrollTop, getRootScrollTop } from '../utils/dom'; // Composables
|
|
8
8
|
import { useRect, useParent } from '@vant/use';
|
9
9
|
import { useExpose } from '../composables/use-expose';
|
10
10
|
var [name, bem] = createNamespace('index-anchor');
|
11
|
+
var indexAnchorProps = {
|
12
|
+
index: numericProp
|
13
|
+
};
|
11
14
|
export default defineComponent({
|
12
15
|
name,
|
13
|
-
props:
|
14
|
-
index: numericProp
|
15
|
-
},
|
16
|
+
props: indexAnchorProps,
|
16
17
|
|
17
|
-
setup(props, {
|
18
|
-
|
19
|
-
|
18
|
+
setup(props, _ref) {
|
19
|
+
var {
|
20
|
+
slots
|
21
|
+
} = _ref;
|
20
22
|
var state = reactive({
|
21
23
|
top: 0,
|
22
24
|
left: null,
|
@@ -1 +1 @@
|
|
1
|
-
:root{--van-index-anchor-z-index:1;--van-index-anchor-padding:0 var(--van-padding-md);--van-index-anchor-text-color:var(--van-text-color);--van-index-anchor-font-weight:var(--van-font-weight-bold);--van-index-anchor-font-size:var(--van-font-size-md);--van-index-anchor-line-height:32px;--van-index-anchor-background-color:transparent;--van-index-anchor-sticky-text-color:var(--van-danger-color);--van-index-anchor-sticky-background-color:var(--van-
|
1
|
+
:root{--van-index-anchor-z-index:1;--van-index-anchor-padding:0 var(--van-padding-md);--van-index-anchor-text-color:var(--van-text-color);--van-index-anchor-font-weight:var(--van-font-weight-bold);--van-index-anchor-font-size:var(--van-font-size-md);--van-index-anchor-line-height:32px;--van-index-anchor-background-color:transparent;--van-index-anchor-sticky-text-color:var(--van-danger-color);--van-index-anchor-sticky-background-color:var(--van-background-color-light)}.van-index-anchor{z-index:var(--van-index-anchor-z-index);box-sizing:border-box;padding:var(--van-index-anchor-padding);color:var(--van-index-anchor-text-color);font-weight:var(--van-index-anchor-font-weight);font-size:var(--van-index-anchor-font-size);line-height:var(--van-index-anchor-line-height);background:var(--van-index-anchor-background-color)}.van-index-anchor--sticky{position:fixed;top:0;right:0;left:0;color:var(--van-index-anchor-sticky-text-color);background:var(--van-index-anchor-sticky-background-color)}
|
package/es/index-anchor/var.less
CHANGED
@@ -8,4 +8,4 @@
|
|
8
8
|
@index-anchor-line-height: 32px;
|
9
9
|
@index-anchor-background-color: transparent;
|
10
10
|
@index-anchor-sticky-text-color: var(--van-danger-color);
|
11
|
-
@index-anchor-sticky-background-color: var(--van-
|
11
|
+
@index-anchor-sticky-background-color: var(--van-background-color-light);
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { PropType, InjectionKey, ExtractPropTypes } from 'vue';
|
2
2
|
import { IndexBarProvide } from './types';
|
3
3
|
declare function genAlphabet(): string[];
|
4
|
-
declare const
|
4
|
+
declare const indexBarProps: {
|
5
5
|
sticky: {
|
6
6
|
type: BooleanConstructor;
|
7
7
|
default: true;
|
@@ -18,7 +18,7 @@ declare const props: {
|
|
18
18
|
default: typeof genAlphabet;
|
19
19
|
};
|
20
20
|
};
|
21
|
-
export declare type IndexBarProps = ExtractPropTypes<typeof
|
21
|
+
export declare type IndexBarProps = ExtractPropTypes<typeof indexBarProps>;
|
22
22
|
export declare const INDEX_BAR_KEY: InjectionKey<IndexBarProvide>;
|
23
23
|
declare const _default: import("vue").DefineComponent<{
|
24
24
|
sticky: {
|
package/es/index-bar/IndexBar.js
CHANGED
@@ -14,7 +14,7 @@ function genAlphabet() {
|
|
14
14
|
}
|
15
15
|
|
16
16
|
var [name, bem] = createNamespace('index-bar');
|
17
|
-
var
|
17
|
+
var indexBarProps = {
|
18
18
|
sticky: truthProp,
|
19
19
|
zIndex: numericProp,
|
20
20
|
teleport: [String, Object],
|
@@ -28,13 +28,14 @@ var props = {
|
|
28
28
|
export var INDEX_BAR_KEY = Symbol(name);
|
29
29
|
export default defineComponent({
|
30
30
|
name,
|
31
|
-
props,
|
31
|
+
props: indexBarProps,
|
32
32
|
emits: ['select', 'change'],
|
33
33
|
|
34
|
-
setup(props, {
|
35
|
-
|
36
|
-
|
37
|
-
|
34
|
+
setup(props, _ref) {
|
35
|
+
var {
|
36
|
+
emit,
|
37
|
+
slots
|
38
|
+
} = _ref;
|
38
39
|
var root = ref();
|
39
40
|
var activeAnchor = ref('');
|
40
41
|
var touch = useTouch();
|
package/es/index.d.ts
CHANGED
package/es/index.js
CHANGED
@@ -84,7 +84,7 @@ import { Tag } from './tag';
|
|
84
84
|
import { Toast } from './toast';
|
85
85
|
import { TreeSelect } from './tree-select';
|
86
86
|
import { Uploader } from './uploader';
|
87
|
-
var version = '3.
|
87
|
+
var version = '3.3.1';
|
88
88
|
|
89
89
|
function install(app) {
|
90
90
|
var components = [ActionBar, ActionBarButton, ActionBarIcon, ActionSheet, AddressEdit, AddressList, Area, Badge, Button, Calendar, Card, Cascader, Cell, CellGroup, Checkbox, CheckboxGroup, Circle, Col, Collapse, CollapseItem, ConfigProvider, ContactCard, ContactEdit, ContactList, CountDown, Coupon, CouponCell, CouponList, DatetimePicker, Dialog, Divider, DropdownItem, DropdownMenu, Empty, Field, Form, Grid, GridItem, Icon, Image, ImagePreview, IndexAnchor, IndexBar, List, Loading, Locale, NavBar, NoticeBar, Notify, NumberKeyboard, Overlay, Pagination, PasswordInput, Picker, Popover, Popup, Progress, PullRefresh, Radio, RadioGroup, Rate, Row, Search, ShareSheet, Sidebar, SidebarItem, Skeleton, Slider, Step, Stepper, Steps, Sticky, SubmitBar, Swipe, SwipeCell, SwipeItem, Switch, Tab, Tabbar, TabbarItem, Tabs, Tag, Toast, TreeSelect, Uploader];
|
package/es/lazyload/index.d.ts
CHANGED
package/es/lazyload/index.js
CHANGED
@@ -0,0 +1,55 @@
|
|
1
|
+
import type { App } from 'vue';
|
2
|
+
|
3
|
+
declare type ListenEvent =
|
4
|
+
| 'scroll'
|
5
|
+
| 'wheel'
|
6
|
+
| 'mousewheel'
|
7
|
+
| 'resize'
|
8
|
+
| 'animationend'
|
9
|
+
| 'transitionend'
|
10
|
+
| 'touchmove';
|
11
|
+
|
12
|
+
// eslint-disable-next-line
|
13
|
+
declare type Callback = (listener: any, options: LazyloadOptions) => void;
|
14
|
+
|
15
|
+
declare type Filter = {
|
16
|
+
webp?: Callback;
|
17
|
+
progressive?: Callback;
|
18
|
+
};
|
19
|
+
|
20
|
+
declare type Adapter = {
|
21
|
+
error?: Callback;
|
22
|
+
loaded?: Callback;
|
23
|
+
loading?: Callback;
|
24
|
+
};
|
25
|
+
|
26
|
+
export declare type LazyloadOptions = {
|
27
|
+
error?: string;
|
28
|
+
filter?: Filter;
|
29
|
+
silent?: boolean;
|
30
|
+
adapter?: Adapter;
|
31
|
+
loading?: string;
|
32
|
+
attempt?: number;
|
33
|
+
preLoad?: number;
|
34
|
+
observer?: boolean;
|
35
|
+
lazyImage?: boolean;
|
36
|
+
throttleWait?: number;
|
37
|
+
listenEvents?: ListenEvent[];
|
38
|
+
dispatchEvent?: boolean;
|
39
|
+
lazyComponent?: boolean;
|
40
|
+
observerOptions?: IntersectionObserverInit;
|
41
|
+
};
|
42
|
+
|
43
|
+
export declare const Lazyload: {
|
44
|
+
install(app: App, options?: LazyloadOptions): void;
|
45
|
+
};
|
46
|
+
|
47
|
+
declare module '@vue/runtime-core' {
|
48
|
+
interface ComponentCustomProperties {
|
49
|
+
$Lazyload: {
|
50
|
+
$on: (event: string, handler: Callback) => void;
|
51
|
+
$off: (event: string, handler?: Callback) => void;
|
52
|
+
$once: (event: string, handler: Callback) => void;
|
53
|
+
};
|
54
|
+
}
|
55
|
+
}
|
@@ -0,0 +1,46 @@
|
|
1
|
+
/**
|
2
|
+
* This is a fork of [vue-lazyload](https://github.com/hilongjw/vue-lazyload) with Vue 3 support.
|
3
|
+
*/
|
4
|
+
import Lazy from './lazy';
|
5
|
+
import LazyComponent from './lazy-component';
|
6
|
+
import LazyContainer from './lazy-container';
|
7
|
+
import LazyImage from './lazy-image';
|
8
|
+
export var Lazyload = {
|
9
|
+
/*
|
10
|
+
* install function
|
11
|
+
* @param {App} app
|
12
|
+
* @param {object} options lazyload options
|
13
|
+
*/
|
14
|
+
install(app, options) {
|
15
|
+
if (options === void 0) {
|
16
|
+
options = {};
|
17
|
+
}
|
18
|
+
|
19
|
+
var LazyClass = Lazy();
|
20
|
+
var lazy = new LazyClass(options);
|
21
|
+
var lazyContainer = new LazyContainer({
|
22
|
+
lazy
|
23
|
+
});
|
24
|
+
app.config.globalProperties.$Lazyload = lazy;
|
25
|
+
|
26
|
+
if (options.lazyComponent) {
|
27
|
+
app.component('LazyComponent', LazyComponent(lazy));
|
28
|
+
}
|
29
|
+
|
30
|
+
if (options.lazyImage) {
|
31
|
+
app.component('LazyImage', LazyImage(lazy));
|
32
|
+
}
|
33
|
+
|
34
|
+
app.directive('lazy', {
|
35
|
+
beforeMount: lazy.add.bind(lazy),
|
36
|
+
updated: lazy.update.bind(lazy),
|
37
|
+
unmounted: lazy.remove.bind(lazy)
|
38
|
+
});
|
39
|
+
app.directive('lazy-container', {
|
40
|
+
beforeMount: lazyContainer.bind.bind(lazyContainer),
|
41
|
+
updated: lazyContainer.update.bind(lazyContainer),
|
42
|
+
unmounted: lazyContainer.unbind.bind(lazyContainer)
|
43
|
+
});
|
44
|
+
}
|
45
|
+
|
46
|
+
};
|
@@ -0,0 +1,53 @@
|
|
1
|
+
import { h } from 'vue';
|
2
|
+
import { inBrowser, useRect } from '@vant/use';
|
3
|
+
export default (lazy => ({
|
4
|
+
props: {
|
5
|
+
tag: {
|
6
|
+
type: String,
|
7
|
+
default: 'div'
|
8
|
+
}
|
9
|
+
},
|
10
|
+
emits: ['show'],
|
11
|
+
|
12
|
+
render() {
|
13
|
+
return h(this.tag, this.show && this.$slots.default ? this.$slots.default() : null);
|
14
|
+
},
|
15
|
+
|
16
|
+
data() {
|
17
|
+
return {
|
18
|
+
el: null,
|
19
|
+
state: {
|
20
|
+
loaded: false
|
21
|
+
},
|
22
|
+
show: false
|
23
|
+
};
|
24
|
+
},
|
25
|
+
|
26
|
+
mounted() {
|
27
|
+
this.el = this.$el;
|
28
|
+
lazy.addLazyBox(this);
|
29
|
+
lazy.lazyLoadHandler();
|
30
|
+
},
|
31
|
+
|
32
|
+
beforeUnmount() {
|
33
|
+
lazy.removeComponent(this);
|
34
|
+
},
|
35
|
+
|
36
|
+
methods: {
|
37
|
+
checkInView() {
|
38
|
+
var rect = useRect(this.$el);
|
39
|
+
return inBrowser && rect.top < window.innerHeight * lazy.options.preLoad && rect.bottom > 0 && rect.left < window.innerWidth * lazy.options.preLoad && rect.right > 0;
|
40
|
+
},
|
41
|
+
|
42
|
+
load() {
|
43
|
+
this.show = true;
|
44
|
+
this.state.loaded = true;
|
45
|
+
this.$emit('show', this);
|
46
|
+
},
|
47
|
+
|
48
|
+
destroy() {
|
49
|
+
return this.$destroy;
|
50
|
+
}
|
51
|
+
|
52
|
+
}
|
53
|
+
}));
|
@@ -0,0 +1,98 @@
|
|
1
|
+
/* eslint-disable max-classes-per-file */
|
2
|
+
|
3
|
+
/* eslint-disable prefer-object-spread */
|
4
|
+
import { remove } from './util';
|
5
|
+
var defaultOptions = {
|
6
|
+
selector: 'img'
|
7
|
+
};
|
8
|
+
|
9
|
+
class LazyContainer {
|
10
|
+
constructor(_ref) {
|
11
|
+
var {
|
12
|
+
el,
|
13
|
+
binding,
|
14
|
+
vnode,
|
15
|
+
lazy
|
16
|
+
} = _ref;
|
17
|
+
this.el = null;
|
18
|
+
this.vnode = vnode;
|
19
|
+
this.binding = binding;
|
20
|
+
this.options = {};
|
21
|
+
this.lazy = lazy;
|
22
|
+
this.queue = [];
|
23
|
+
this.update({
|
24
|
+
el,
|
25
|
+
binding
|
26
|
+
});
|
27
|
+
}
|
28
|
+
|
29
|
+
update(_ref2) {
|
30
|
+
var {
|
31
|
+
el,
|
32
|
+
binding
|
33
|
+
} = _ref2;
|
34
|
+
this.el = el;
|
35
|
+
this.options = Object.assign({}, defaultOptions, binding.value);
|
36
|
+
var imgs = this.getImgs();
|
37
|
+
imgs.forEach(el => {
|
38
|
+
this.lazy.add(el, Object.assign({}, this.binding, {
|
39
|
+
value: {
|
40
|
+
src: 'dataset' in el ? el.dataset.src : el.getAttribute('data-src'),
|
41
|
+
error: ('dataset' in el ? el.dataset.error : el.getAttribute('data-error')) || this.options.error,
|
42
|
+
loading: ('dataset' in el ? el.dataset.loading : el.getAttribute('data-loading')) || this.options.loading
|
43
|
+
}
|
44
|
+
}), this.vnode);
|
45
|
+
});
|
46
|
+
}
|
47
|
+
|
48
|
+
getImgs() {
|
49
|
+
return Array.from(this.el.querySelectorAll(this.options.selector));
|
50
|
+
}
|
51
|
+
|
52
|
+
clear() {
|
53
|
+
var imgs = this.getImgs();
|
54
|
+
imgs.forEach(el => this.lazy.remove(el));
|
55
|
+
this.vnode = null;
|
56
|
+
this.binding = null;
|
57
|
+
this.lazy = null;
|
58
|
+
}
|
59
|
+
|
60
|
+
}
|
61
|
+
|
62
|
+
export default class LazyContainerManager {
|
63
|
+
constructor(_ref3) {
|
64
|
+
var {
|
65
|
+
lazy
|
66
|
+
} = _ref3;
|
67
|
+
this.lazy = lazy;
|
68
|
+
this.queue = [];
|
69
|
+
}
|
70
|
+
|
71
|
+
bind(el, binding, vnode) {
|
72
|
+
var container = new LazyContainer({
|
73
|
+
el,
|
74
|
+
binding,
|
75
|
+
vnode,
|
76
|
+
lazy: this.lazy
|
77
|
+
});
|
78
|
+
this.queue.push(container);
|
79
|
+
}
|
80
|
+
|
81
|
+
update(el, binding, vnode) {
|
82
|
+
var container = this.queue.find(item => item.el === el);
|
83
|
+
if (!container) return;
|
84
|
+
container.update({
|
85
|
+
el,
|
86
|
+
binding,
|
87
|
+
vnode
|
88
|
+
});
|
89
|
+
}
|
90
|
+
|
91
|
+
unbind(el) {
|
92
|
+
var container = this.queue.find(item => item.el === el);
|
93
|
+
if (!container) return;
|
94
|
+
container.clear();
|
95
|
+
remove(this.queue, container);
|
96
|
+
}
|
97
|
+
|
98
|
+
}
|