cbvirtua 1.0.100 → 1.0.102
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/5111.zip +0 -0
- package/dist/action-sheet/index.d.ts +1 -0
- package/dist/action-sheet/index.js +75 -0
- package/dist/action-sheet/index.json +8 -0
- package/dist/action-sheet/index.wxml +70 -0
- package/dist/action-sheet/index.wxss +1 -0
- package/dist/area/index.d.ts +1 -0
- package/dist/area/index.js +220 -0
- package/dist/area/index.json +6 -0
- package/dist/area/index.wxml +20 -0
- package/dist/area/index.wxs +8 -0
- package/dist/area/index.wxss +1 -0
- package/dist/button/index.d.ts +1 -0
- package/dist/button/index.js +64 -0
- package/dist/button/index.json +7 -0
- package/dist/button/index.wxml +56 -0
- package/dist/button/index.wxs +39 -0
- package/dist/button/index.wxss +1 -0
- package/dist/calendar/calendar.wxml +70 -0
- package/dist/calendar/components/header/index.d.ts +1 -0
- package/dist/calendar/components/header/index.js +37 -0
- package/dist/calendar/components/header/index.json +3 -0
- package/dist/calendar/components/header/index.wxml +16 -0
- package/dist/calendar/components/header/index.wxss +1 -0
- package/dist/calendar/components/month/index.d.ts +6 -0
- package/dist/calendar/components/month/index.js +154 -0
- package/dist/calendar/components/month/index.json +3 -0
- package/dist/calendar/components/month/index.wxml +39 -0
- package/dist/calendar/components/month/index.wxs +71 -0
- package/dist/calendar/components/month/index.wxss +1 -0
- package/dist/calendar/index.d.ts +1 -0
- package/dist/calendar/index.js +360 -0
- package/dist/calendar/index.json +10 -0
- package/dist/calendar/index.wxml +27 -0
- package/dist/calendar/index.wxs +37 -0
- package/dist/calendar/index.wxss +1 -0
- package/dist/calendar/utils.d.ts +12 -0
- package/dist/calendar/utils.js +83 -0
- package/dist/calendar/utils.wxs +25 -0
- package/dist/card/index.d.ts +1 -0
- package/dist/card/index.js +49 -0
- package/dist/card/index.json +6 -0
- package/dist/card/index.wxml +56 -0
- package/dist/card/index.wxss +1 -0
- package/dist/cascader/index.d.ts +1 -0
- package/dist/cascader/index.js +214 -0
- package/dist/cascader/index.json +8 -0
- package/dist/cascader/index.wxml +55 -0
- package/dist/cascader/index.wxs +24 -0
- package/dist/cascader/index.wxss +1 -0
- package/dist/cell/index.d.ts +1 -0
- package/dist/cell/index.js +38 -0
- package/dist/cell/index.json +6 -0
- package/dist/cell/index.wxml +47 -0
- package/dist/cell/index.wxs +17 -0
- package/dist/cell/index.wxss +1 -0
- package/dist/cell-group/index.d.ts +1 -0
- package/dist/cell-group/index.js +11 -0
- package/dist/cell-group/index.json +3 -0
- package/dist/cell-group/index.wxml +11 -0
- package/dist/cell-group/index.wxss +1 -0
- package/dist/checkbox/index.d.ts +1 -0
- package/dist/checkbox/index.js +77 -0
- package/dist/checkbox/index.json +6 -0
- package/dist/checkbox/index.wxml +31 -0
- package/dist/checkbox/index.wxs +20 -0
- package/dist/checkbox/index.wxss +1 -0
- package/dist/checkbox-group/index.d.ts +1 -0
- package/dist/checkbox-group/index.js +36 -0
- package/dist/checkbox-group/index.json +3 -0
- package/dist/checkbox-group/index.wxml +5 -0
- package/dist/checkbox-group/index.wxss +1 -0
- package/dist/circle/canvas.d.ts +4 -0
- package/dist/circle/canvas.js +43 -0
- package/dist/circle/index.d.ts +1 -0
- package/dist/circle/index.js +197 -0
- package/dist/circle/index.json +3 -0
- package/dist/circle/index.wxml +9 -0
- package/dist/circle/index.wxss +1 -0
- package/dist/col/index.d.ts +1 -0
- package/dist/col/index.js +9 -0
- package/dist/col/index.json +3 -0
- package/dist/col/index.wxml +9 -0
- package/dist/col/index.wxs +18 -0
- package/dist/col/index.wxss +1 -0
- package/dist/collapse/index.d.ts +1 -0
- package/dist/collapse/index.js +46 -0
- package/dist/collapse/index.json +3 -0
- package/dist/collapse/index.wxml +3 -0
- package/dist/collapse/index.wxss +1 -0
- package/dist/collapse-item/animate.d.ts +2 -0
- package/dist/collapse-item/animate.js +39 -0
- package/dist/collapse-item/index.d.ts +1 -0
- package/dist/collapse-item/index.js +61 -0
- package/dist/collapse-item/index.json +6 -0
- package/dist/collapse-item/index.wxml +45 -0
- package/dist/collapse-item/index.wxss +1 -0
- package/dist/common/color.d.ts +7 -0
- package/dist/common/color.js +7 -0
- package/dist/common/component.d.ts +4 -0
- package/dist/common/component.js +46 -0
- package/dist/common/index.wxss +1 -0
- package/dist/common/relation.d.ts +15 -0
- package/dist/common/relation.js +56 -0
- package/dist/common/style/clearfix.wxss +1 -0
- package/dist/common/style/ellipsis.wxss +1 -0
- package/dist/common/style/hairline.wxss +1 -0
- package/dist/common/style/mixins/clearfix.wxss +0 -0
- package/dist/common/style/mixins/ellipsis.wxss +0 -0
- package/dist/common/style/mixins/hairline.wxss +0 -0
- package/dist/common/style/var.wxss +0 -0
- package/dist/common/utils.d.ts +21 -0
- package/dist/common/utils.js +86 -0
- package/dist/common/validator.d.ts +9 -0
- package/dist/common/validator.js +31 -0
- package/dist/common/version.d.ts +15 -0
- package/dist/common/version.js +59 -0
- package/dist/config-provider/index.d.ts +1 -0
- package/dist/config-provider/index.js +9 -0
- package/dist/config-provider/index.json +3 -0
- package/dist/config-provider/index.wxml +5 -0
- package/dist/config-provider/index.wxs +29 -0
- package/dist/count-down/index.d.ts +1 -0
- package/dist/count-down/index.js +100 -0
- package/dist/count-down/index.json +3 -0
- package/dist/count-down/index.wxml +4 -0
- package/dist/count-down/index.wxss +1 -0
- package/dist/count-down/utils.d.ts +10 -0
- package/dist/count-down/utils.js +57 -0
- package/dist/datetime-picker/index.d.ts +1 -0
- package/dist/datetime-picker/index.js +295 -0
- package/dist/datetime-picker/index.json +6 -0
- package/dist/datetime-picker/index.wxml +16 -0
- package/dist/datetime-picker/index.wxss +1 -0
- package/dist/definitions/index.d.ts +29 -0
- package/dist/definitions/index.js +1 -0
- package/dist/dialog/dialog.d.ts +55 -0
- package/dist/dialog/dialog.js +77 -0
- package/dist/dialog/index.d.ts +1 -0
- package/dist/dialog/index.js +132 -0
- package/dist/dialog/index.json +9 -0
- package/dist/dialog/index.wxml +126 -0
- package/dist/dialog/index.wxss +1 -0
- package/dist/divider/index.d.ts +1 -0
- package/dist/divider/index.js +12 -0
- package/dist/divider/index.json +4 -0
- package/dist/divider/index.wxml +9 -0
- package/dist/divider/index.wxs +18 -0
- package/dist/divider/index.wxss +1 -0
- package/dist/dropdown-item/index.d.ts +1 -0
- package/dist/dropdown-item/index.js +130 -0
- package/dist/dropdown-item/index.json +8 -0
- package/dist/dropdown-item/index.wxml +50 -0
- package/dist/dropdown-item/index.wxss +1 -0
- package/dist/dropdown-item/shared.d.ts +5 -0
- package/dist/dropdown-item/shared.js +1 -0
- package/dist/dropdown-menu/index.d.ts +1 -0
- package/dist/dropdown-menu/index.js +117 -0
- package/dist/dropdown-menu/index.json +3 -0
- package/dist/dropdown-menu/index.wxml +23 -0
- package/dist/dropdown-menu/index.wxs +16 -0
- package/dist/dropdown-menu/index.wxss +1 -0
- package/dist/empty/index.d.ts +1 -0
- package/dist/empty/index.js +10 -0
- package/dist/empty/index.json +4 -0
- package/dist/empty/index.wxml +22 -0
- package/dist/empty/index.wxs +15 -0
- package/dist/empty/index.wxss +1 -0
- package/dist/field/index.d.ts +1 -0
- package/dist/field/index.js +138 -0
- package/dist/field/index.json +7 -0
- package/dist/field/index.wxml +56 -0
- package/dist/field/index.wxs +18 -0
- package/dist/field/index.wxss +1 -0
- package/dist/field/input.wxml +31 -0
- package/dist/field/props.d.ts +4 -0
- package/dist/field/props.js +56 -0
- package/dist/field/textarea.wxml +32 -0
- package/dist/field/types.d.ts +8 -0
- package/dist/field/types.js +1 -0
- package/dist/goods-action/index.d.ts +1 -0
- package/dist/goods-action/index.js +15 -0
- package/dist/goods-action/index.json +3 -0
- package/dist/goods-action/index.wxml +5 -0
- package/dist/goods-action/index.wxss +1 -0
- package/dist/goods-action-button/index.d.ts +1 -0
- package/dist/goods-action-button/index.js +44 -0
- package/dist/goods-action-button/index.json +6 -0
- package/dist/goods-action-button/index.wxml +35 -0
- package/dist/goods-action-button/index.wxss +1 -0
- package/dist/goods-action-icon/index.d.ts +1 -0
- package/dist/goods-action-icon/index.js +27 -0
- package/dist/goods-action-icon/index.json +7 -0
- package/dist/goods-action-icon/index.wxml +41 -0
- package/dist/goods-action-icon/index.wxss +1 -0
- package/dist/grid/index.d.ts +1 -0
- package/dist/grid/index.js +55 -0
- package/dist/grid/index.json +3 -0
- package/dist/grid/index.wxml +8 -0
- package/dist/grid/index.wxs +13 -0
- package/dist/grid/index.wxss +1 -0
- package/dist/grid-item/index.d.ts +1 -0
- package/dist/grid-item/index.js +52 -0
- package/dist/grid-item/index.json +6 -0
- package/dist/grid-item/index.wxml +27 -0
- package/dist/grid-item/index.wxs +32 -0
- package/dist/grid-item/index.wxss +1 -0
- package/dist/icon/index.d.ts +1 -0
- package/dist/icon/index.js +21 -0
- package/dist/icon/index.json +6 -0
- package/dist/icon/index.wxml +20 -0
- package/dist/icon/index.wxs +43 -0
- package/dist/icon/index.wxss +1 -0
- package/dist/image/index.d.ts +1 -0
- package/dist/image/index.js +64 -0
- package/dist/image/index.json +7 -0
- package/dist/image/index.wxml +35 -0
- package/dist/image/index.wxs +32 -0
- package/dist/image/index.wxss +1 -0
- package/dist/index-anchor/index.d.ts +1 -0
- package/dist/index-anchor/index.js +25 -0
- package/dist/index-anchor/index.json +3 -0
- package/dist/index-anchor/index.wxml +14 -0
- package/dist/index-anchor/index.wxss +1 -0
- package/dist/index-bar/index.d.ts +1 -0
- package/dist/index-bar/index.js +246 -0
- package/dist/index-bar/index.json +3 -0
- package/dist/index-bar/index.wxml +22 -0
- package/dist/index-bar/index.wxss +1 -0
- package/dist/info/index.d.ts +1 -0
- package/dist/info/index.js +8 -0
- package/dist/info/index.json +3 -0
- package/dist/info/index.wxml +7 -0
- package/dist/info/index.wxss +1 -0
- package/dist/loading/index.d.ts +1 -0
- package/dist/loading/index.js +16 -0
- package/dist/loading/index.json +3 -0
- package/dist/loading/index.wxml +19 -0
- package/dist/loading/index.wxs +22 -0
- package/dist/loading/index.wxss +1 -0
- package/dist/mixins/basic.d.ts +1 -0
- package/dist/mixins/basic.js +26 -0
- package/dist/mixins/button.d.ts +1 -0
- package/dist/mixins/button.js +51 -0
- package/dist/mixins/link.d.ts +1 -0
- package/dist/mixins/link.js +23 -0
- package/dist/mixins/page-scroll.d.ts +6 -0
- package/dist/mixins/page-scroll.js +42 -0
- package/dist/mixins/touch.d.ts +1 -0
- package/dist/mixins/touch.js +37 -0
- package/dist/mixins/transition.d.ts +1 -0
- package/dist/mixins/transition.js +136 -0
- package/dist/nav-bar/index.d.ts +1 -0
- package/dist/nav-bar/index.js +65 -0
- package/dist/nav-bar/index.json +6 -0
- package/dist/nav-bar/index.wxml +42 -0
- package/dist/nav-bar/index.wxs +13 -0
- package/dist/nav-bar/index.wxss +1 -0
- package/dist/notice-bar/index.d.ts +1 -0
- package/dist/notice-bar/index.js +132 -0
- package/dist/notice-bar/index.json +6 -0
- package/dist/notice-bar/index.wxml +38 -0
- package/dist/notice-bar/index.wxs +15 -0
- package/dist/notice-bar/index.wxss +1 -0
- package/dist/notify/index.d.ts +1 -0
- package/dist/notify/index.js +65 -0
- package/dist/notify/index.json +6 -0
- package/dist/notify/index.wxml +21 -0
- package/dist/notify/index.wxs +22 -0
- package/dist/notify/index.wxss +1 -0
- package/dist/notify/notify.d.ts +22 -0
- package/dist/notify/notify.js +53 -0
- package/dist/overlay/index.d.ts +1 -0
- package/dist/overlay/index.js +30 -0
- package/dist/overlay/index.json +6 -0
- package/dist/overlay/index.wxml +7 -0
- package/dist/overlay/index.wxss +1 -0
- package/dist/overlay/overlay.wxml +10 -0
- package/dist/panel/index.d.ts +1 -0
- package/dist/panel/index.js +9 -0
- package/dist/panel/index.json +6 -0
- package/dist/panel/index.wxml +19 -0
- package/dist/panel/index.wxss +1 -0
- package/dist/picker/index.d.ts +1 -0
- package/dist/picker/index.js +136 -0
- package/dist/picker/index.json +7 -0
- package/dist/picker/index.wxml +37 -0
- package/dist/picker/index.wxs +42 -0
- package/dist/picker/index.wxss +1 -0
- package/dist/picker/shared.d.ts +21 -0
- package/dist/picker/shared.js +21 -0
- package/dist/picker/toolbar.wxml +23 -0
- package/dist/picker-column/index.d.ts +1 -0
- package/dist/picker-column/index.js +118 -0
- package/dist/picker-column/index.json +3 -0
- package/dist/picker-column/index.wxml +23 -0
- package/dist/picker-column/index.wxs +36 -0
- package/dist/picker-column/index.wxss +1 -0
- package/dist/popup/index.d.ts +1 -0
- package/dist/popup/index.js +97 -0
- package/dist/popup/index.json +7 -0
- package/dist/popup/index.wxml +21 -0
- package/dist/popup/index.wxs +18 -0
- package/dist/popup/index.wxss +1 -0
- package/dist/popup/popup.wxml +16 -0
- package/dist/progress/index.d.ts +1 -0
- package/dist/progress/index.js +51 -0
- package/dist/progress/index.json +3 -0
- package/dist/progress/index.wxml +20 -0
- package/dist/progress/index.wxs +36 -0
- package/dist/progress/index.wxss +1 -0
- package/dist/radio/index.d.ts +1 -0
- package/dist/radio/index.js +66 -0
- package/dist/radio/index.json +6 -0
- package/dist/radio/index.wxml +30 -0
- package/dist/radio/index.wxs +33 -0
- package/dist/radio/index.wxss +1 -0
- package/dist/radio-group/index.d.ts +1 -0
- package/dist/radio-group/index.js +22 -0
- package/dist/radio-group/index.json +3 -0
- package/dist/radio-group/index.wxml +5 -0
- package/dist/radio-group/index.wxss +1 -0
- package/dist/rate/index.d.ts +1 -0
- package/dist/rate/index.js +78 -0
- package/dist/rate/index.json +6 -0
- package/dist/rate/index.wxml +35 -0
- package/dist/rate/index.wxss +1 -0
- package/dist/row/index.d.ts +1 -0
- package/dist/row/index.js +23 -0
- package/dist/row/index.json +3 -0
- package/dist/row/index.wxml +5 -0
- package/dist/row/index.wxs +18 -0
- package/dist/row/index.wxss +1 -0
- package/dist/search/index.d.ts +1 -0
- package/dist/search/index.js +97 -0
- package/dist/search/index.json +6 -0
- package/dist/search/index.wxml +54 -0
- package/dist/search/index.wxss +1 -0
- package/dist/share-sheet/index.d.ts +1 -0
- package/dist/share-sheet/index.js +59 -0
- package/dist/share-sheet/index.json +7 -0
- package/dist/share-sheet/index.wxml +47 -0
- package/dist/share-sheet/index.wxs +12 -0
- package/dist/share-sheet/index.wxss +1 -0
- package/dist/share-sheet/options.d.ts +1 -0
- package/dist/share-sheet/options.js +14 -0
- package/dist/share-sheet/options.json +3 -0
- package/dist/share-sheet/options.wxml +20 -0
- package/dist/share-sheet/options.wxs +14 -0
- package/dist/share-sheet/options.wxss +1 -0
- package/dist/sidebar/index.d.ts +1 -0
- package/dist/sidebar/index.js +34 -0
- package/dist/sidebar/index.json +3 -0
- package/dist/sidebar/index.wxml +3 -0
- package/dist/sidebar/index.wxss +1 -0
- package/dist/sidebar-item/index.d.ts +1 -0
- package/dist/sidebar-item/index.js +29 -0
- package/dist/sidebar-item/index.json +6 -0
- package/dist/sidebar-item/index.wxml +18 -0
- package/dist/sidebar-item/index.wxss +1 -0
- package/dist/skeleton/index.d.ts +1 -0
- package/dist/skeleton/index.js +46 -0
- package/dist/skeleton/index.json +4 -0
- package/dist/skeleton/index.wxml +29 -0
- package/dist/skeleton/index.wxss +1 -0
- package/dist/slider/index.d.ts +1 -0
- package/dist/slider/index.js +207 -0
- package/dist/slider/index.json +3 -0
- package/dist/slider/index.wxml +68 -0
- package/dist/slider/index.wxs +14 -0
- package/dist/slider/index.wxss +1 -0
- package/dist/stepper/index.d.ts +1 -0
- package/dist/stepper/index.js +184 -0
- package/dist/stepper/index.json +3 -0
- package/dist/stepper/index.wxml +43 -0
- package/dist/stepper/index.wxs +22 -0
- package/dist/stepper/index.wxss +1 -0
- package/dist/steps/index.d.ts +1 -0
- package/dist/steps/index.js +33 -0
- package/dist/steps/index.json +6 -0
- package/dist/steps/index.wxml +54 -0
- package/dist/steps/index.wxss +1 -0
- package/dist/sticky/index.d.ts +1 -0
- package/dist/sticky/index.js +120 -0
- package/dist/sticky/index.json +3 -0
- package/dist/sticky/index.wxml +8 -0
- package/dist/sticky/index.wxs +25 -0
- package/dist/sticky/index.wxss +1 -0
- package/dist/submit-bar/index.d.ts +1 -0
- package/dist/submit-bar/index.js +56 -0
- package/dist/submit-bar/index.json +7 -0
- package/dist/submit-bar/index.wxml +44 -0
- package/dist/submit-bar/index.wxss +1 -0
- package/dist/swipe-cell/index.d.ts +1 -0
- package/dist/swipe-cell/index.js +133 -0
- package/dist/swipe-cell/index.json +3 -0
- package/dist/swipe-cell/index.wxml +20 -0
- package/dist/swipe-cell/index.wxss +1 -0
- package/dist/switch/index.d.ts +1 -0
- package/dist/switch/index.js +36 -0
- package/dist/switch/index.json +6 -0
- package/dist/switch/index.wxml +16 -0
- package/dist/switch/index.wxs +26 -0
- package/dist/switch/index.wxss +1 -0
- package/dist/tab/index.d.ts +1 -0
- package/dist/tab/index.js +56 -0
- package/dist/tab/index.json +3 -0
- package/dist/tab/index.wxml +8 -0
- package/dist/tab/index.wxss +1 -0
- package/dist/tabbar/index.d.ts +1 -0
- package/dist/tabbar/index.js +65 -0
- package/dist/tabbar/index.json +3 -0
- package/dist/tabbar/index.wxml +10 -0
- package/dist/tabbar/index.wxss +1 -0
- package/dist/tabbar-item/index.d.ts +1 -0
- package/dist/tabbar-item/index.js +68 -0
- package/dist/tabbar-item/index.json +7 -0
- package/dist/tabbar-item/index.wxml +28 -0
- package/dist/tabbar-item/index.wxss +1 -0
- package/dist/tabs/index.d.ts +1 -0
- package/dist/tabs/index.js +302 -0
- package/dist/tabs/index.json +7 -0
- package/dist/tabs/index.wxml +63 -0
- package/dist/tabs/index.wxs +83 -0
- package/dist/tabs/index.wxss +1 -0
- package/dist/tag/index.d.ts +1 -0
- package/dist/tag/index.js +21 -0
- package/dist/tag/index.json +6 -0
- package/dist/tag/index.wxml +15 -0
- package/dist/tag/index.wxs +13 -0
- package/dist/tag/index.wxss +1 -0
- package/dist/toast/index.d.ts +1 -0
- package/dist/toast/index.js +29 -0
- package/dist/toast/index.json +9 -0
- package/dist/toast/index.wxml +36 -0
- package/dist/toast/index.wxss +1 -0
- package/dist/toast/toast.d.ts +28 -0
- package/dist/toast/toast.js +68 -0
- package/dist/transition/index.d.ts +1 -0
- package/dist/transition/index.js +13 -0
- package/dist/transition/index.json +3 -0
- package/dist/transition/index.wxml +10 -0
- package/dist/transition/index.wxs +17 -0
- package/dist/transition/index.wxss +1 -0
- package/dist/tree-select/index.d.ts +1 -0
- package/dist/tree-select/index.js +68 -0
- package/dist/tree-select/index.json +8 -0
- package/dist/tree-select/index.wxml +41 -0
- package/dist/tree-select/index.wxs +12 -0
- package/dist/tree-select/index.wxss +1 -0
- package/dist/uploader/index.d.ts +1 -0
- package/dist/uploader/index.js +170 -0
- package/dist/uploader/index.json +7 -0
- package/dist/uploader/index.wxml +85 -0
- package/dist/uploader/index.wxs +17 -0
- package/dist/uploader/index.wxss +1 -0
- package/dist/uploader/shared.d.ts +61 -0
- package/dist/uploader/shared.js +65 -0
- package/dist/uploader/utils.d.ts +24 -0
- package/dist/uploader/utils.js +94 -0
- package/dist/wxs/add-unit.wxs +12 -0
- package/dist/wxs/array.wxs +5 -0
- package/dist/wxs/bem.wxs +39 -0
- package/dist/wxs/memoize.wxs +55 -0
- package/dist/wxs/object.wxs +13 -0
- package/dist/wxs/style.wxs +42 -0
- package/dist/wxs/utils.wxs +10 -0
- package/package.json +1 -1
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { VantComponent } from '../common/component';
|
|
2
|
+
import { transition } from '../mixins/transition';
|
|
3
|
+
VantComponent({
|
|
4
|
+
classes: [
|
|
5
|
+
'enter-class',
|
|
6
|
+
'enter-active-class',
|
|
7
|
+
'enter-to-class',
|
|
8
|
+
'leave-class',
|
|
9
|
+
'leave-active-class',
|
|
10
|
+
'leave-to-class',
|
|
11
|
+
'close-icon-class',
|
|
12
|
+
],
|
|
13
|
+
mixins: [transition(false)],
|
|
14
|
+
props: {
|
|
15
|
+
round: Boolean,
|
|
16
|
+
closeable: Boolean,
|
|
17
|
+
customStyle: String,
|
|
18
|
+
overlayStyle: String,
|
|
19
|
+
transition: {
|
|
20
|
+
type: String,
|
|
21
|
+
observer: 'observeClass',
|
|
22
|
+
},
|
|
23
|
+
zIndex: {
|
|
24
|
+
type: Number,
|
|
25
|
+
value: 100,
|
|
26
|
+
},
|
|
27
|
+
overlay: {
|
|
28
|
+
type: Boolean,
|
|
29
|
+
value: true,
|
|
30
|
+
},
|
|
31
|
+
closeIcon: {
|
|
32
|
+
type: String,
|
|
33
|
+
value: 'cross',
|
|
34
|
+
},
|
|
35
|
+
closeIconPosition: {
|
|
36
|
+
type: String,
|
|
37
|
+
value: 'top-right',
|
|
38
|
+
},
|
|
39
|
+
closeOnClickOverlay: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
value: true,
|
|
42
|
+
},
|
|
43
|
+
position: {
|
|
44
|
+
type: String,
|
|
45
|
+
value: 'center',
|
|
46
|
+
observer: 'observeClass',
|
|
47
|
+
},
|
|
48
|
+
safeAreaInsetBottom: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
value: true,
|
|
51
|
+
},
|
|
52
|
+
safeAreaInsetTop: {
|
|
53
|
+
type: Boolean,
|
|
54
|
+
value: false,
|
|
55
|
+
},
|
|
56
|
+
safeAreaTabBar: {
|
|
57
|
+
type: Boolean,
|
|
58
|
+
value: false,
|
|
59
|
+
},
|
|
60
|
+
lockScroll: {
|
|
61
|
+
type: Boolean,
|
|
62
|
+
value: true,
|
|
63
|
+
},
|
|
64
|
+
rootPortal: {
|
|
65
|
+
type: Boolean,
|
|
66
|
+
value: false,
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
created() {
|
|
70
|
+
this.observeClass();
|
|
71
|
+
},
|
|
72
|
+
methods: {
|
|
73
|
+
onClickCloseIcon() {
|
|
74
|
+
this.$emit('close');
|
|
75
|
+
},
|
|
76
|
+
onClickOverlay() {
|
|
77
|
+
this.$emit('click-overlay');
|
|
78
|
+
if (this.data.closeOnClickOverlay) {
|
|
79
|
+
this.$emit('close');
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
observeClass() {
|
|
83
|
+
const { transition, position, duration } = this.data;
|
|
84
|
+
const updateData = {
|
|
85
|
+
name: transition || position,
|
|
86
|
+
};
|
|
87
|
+
if (transition === 'none') {
|
|
88
|
+
updateData.duration = 0;
|
|
89
|
+
this.originDuration = duration;
|
|
90
|
+
}
|
|
91
|
+
else if (this.originDuration != null) {
|
|
92
|
+
updateData.duration = this.originDuration;
|
|
93
|
+
}
|
|
94
|
+
this.setData(updateData);
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
<wxs src="../wxs/utils.wxs" module="utils" />
|
|
2
|
+
<wxs src="./index.wxs" module="computed" />
|
|
3
|
+
|
|
4
|
+
<import src="./popup.wxml" />
|
|
5
|
+
|
|
6
|
+
<van-overlay
|
|
7
|
+
wx:if="{{ overlay }}"
|
|
8
|
+
show="{{ show }}"
|
|
9
|
+
z-index="{{ zIndex }}"
|
|
10
|
+
custom-style="{{ overlayStyle }}"
|
|
11
|
+
duration="{{ duration }}"
|
|
12
|
+
bind:click="onClickOverlay"
|
|
13
|
+
lock-scroll="{{ lockScroll }}"
|
|
14
|
+
root-portal="{{ rootPortal }}"
|
|
15
|
+
/>
|
|
16
|
+
|
|
17
|
+
<root-portal wx:if="{{ rootPortal }}">
|
|
18
|
+
<include src="./popup.wxml" />
|
|
19
|
+
</root-portal>
|
|
20
|
+
|
|
21
|
+
<include wx:else src="./popup.wxml" />
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
var style = require('../wxs/style.wxs');
|
|
3
|
+
|
|
4
|
+
function popupStyle(data) {
|
|
5
|
+
return style([
|
|
6
|
+
{
|
|
7
|
+
'z-index': data.zIndex,
|
|
8
|
+
'-webkit-transition-duration': data.currentDuration + 'ms',
|
|
9
|
+
'transition-duration': data.currentDuration + 'ms',
|
|
10
|
+
},
|
|
11
|
+
data.display ? null : 'display: none',
|
|
12
|
+
data.customStyle,
|
|
13
|
+
]);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
module.exports = {
|
|
17
|
+
popupStyle: popupStyle,
|
|
18
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import '../common/index.wxss';.van-popup{-webkit-overflow-scrolling:touch;animation:ease both;background-color:var(--popup-background-color,#fff);box-sizing:border-box;max-height:100%;overflow-y:auto;position:fixed;transition-timing-function:ease}.van-popup--center{left:50%;top:50%;transform:translate3d(-50%,-50%,0)}.van-popup--center.van-popup--round{border-radius:var(--popup-round-border-radius,16px)}.van-popup--top{left:0;top:0;width:100%}.van-popup--top.van-popup--round{border-radius:0 0 var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) var(--popup-round-border-radius,var(--popup-round-border-radius,16px))}.van-popup--right{right:0;top:50%;transform:translate3d(0,-50%,0)}.van-popup--right.van-popup--round{border-radius:var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) 0 0 var(--popup-round-border-radius,var(--popup-round-border-radius,16px))}.van-popup--bottom{bottom:0;left:0;width:100%}.van-popup--bottom.van-popup--round{border-radius:var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) 0 0}.van-popup--left{left:0;top:50%;transform:translate3d(0,-50%,0)}.van-popup--left.van-popup--round{border-radius:0 var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) var(--popup-round-border-radius,var(--popup-round-border-radius,16px)) 0}.van-popup--bottom.van-popup--safe{padding-bottom:env(safe-area-inset-bottom)}.van-popup--bottom.van-popup--safeTabBar,.van-popup--top.van-popup--safeTabBar{bottom:var(--tabbar-height,50px)}.van-popup--safeTop{padding-top:env(safe-area-inset-top)}.van-popup__close-icon{color:var(--popup-close-icon-color,#969799);font-size:var(--popup-close-icon-size,18px);position:absolute;z-index:var(--popup-close-icon-z-index,1)}.van-popup__close-icon--top-left{left:var(--popup-close-icon-margin,16px);top:var(--popup-close-icon-margin,16px)}.van-popup__close-icon--top-right{right:var(--popup-close-icon-margin,16px);top:var(--popup-close-icon-margin,16px)}.van-popup__close-icon--bottom-left{bottom:var(--popup-close-icon-margin,16px);left:var(--popup-close-icon-margin,16px)}.van-popup__close-icon--bottom-right{bottom:var(--popup-close-icon-margin,16px);right:var(--popup-close-icon-margin,16px)}.van-popup__close-icon:active{opacity:.6}.van-scale-enter-active,.van-scale-leave-active{transition-property:opacity,transform}.van-scale-enter,.van-scale-leave-to{opacity:0;transform:translate3d(-50%,-50%,0) scale(.7)}.van-fade-enter-active,.van-fade-leave-active{transition-property:opacity}.van-fade-enter,.van-fade-leave-to{opacity:0}.van-center-enter-active,.van-center-leave-active{transition-property:opacity}.van-center-enter,.van-center-leave-to{opacity:0}.van-bottom-enter-active,.van-bottom-leave-active,.van-left-enter-active,.van-left-leave-active,.van-right-enter-active,.van-right-leave-active,.van-top-enter-active,.van-top-leave-active{transition-property:transform}.van-bottom-enter,.van-bottom-leave-to{transform:translate3d(0,100%,0)}.van-top-enter,.van-top-leave-to{transform:translate3d(0,-100%,0)}.van-left-enter,.van-left-leave-to{transform:translate3d(-100%,-50%,0)}.van-right-enter,.van-right-leave-to{transform:translate3d(100%,-50%,0)}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
<wxs src="../wxs/utils.wxs" module="utils" />
|
|
2
|
+
<wxs src="./index.wxs" module="computed" />
|
|
3
|
+
<view
|
|
4
|
+
wx:if="{{ inited }}"
|
|
5
|
+
class="custom-class {{ classes }} {{ utils.bem('popup', [position, { round, safe: safeAreaInsetBottom, safeTop: safeAreaInsetTop, safeTabBar: safeAreaTabBar }]) }}"
|
|
6
|
+
style="{{ computed.popupStyle({ zIndex, currentDuration, display, customStyle }) }}"
|
|
7
|
+
bind:transitionend="onTransitionEnd"
|
|
8
|
+
>
|
|
9
|
+
<slot />
|
|
10
|
+
<van-icon
|
|
11
|
+
wx:if="{{ closeable }}"
|
|
12
|
+
name="{{ closeIcon }}"
|
|
13
|
+
class="close-icon-class van-popup__close-icon van-popup__close-icon--{{ closeIconPosition }}"
|
|
14
|
+
bind:tap="onClickCloseIcon"
|
|
15
|
+
/>
|
|
16
|
+
</view>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { VantComponent } from '../common/component';
|
|
2
|
+
import { BLUE } from '../common/color';
|
|
3
|
+
import { getRect } from '../common/utils';
|
|
4
|
+
VantComponent({
|
|
5
|
+
props: {
|
|
6
|
+
inactive: Boolean,
|
|
7
|
+
percentage: {
|
|
8
|
+
type: Number,
|
|
9
|
+
observer: 'setLeft',
|
|
10
|
+
},
|
|
11
|
+
pivotText: String,
|
|
12
|
+
pivotColor: String,
|
|
13
|
+
trackColor: String,
|
|
14
|
+
showPivot: {
|
|
15
|
+
type: Boolean,
|
|
16
|
+
value: true,
|
|
17
|
+
},
|
|
18
|
+
color: {
|
|
19
|
+
type: String,
|
|
20
|
+
value: BLUE,
|
|
21
|
+
},
|
|
22
|
+
textColor: {
|
|
23
|
+
type: String,
|
|
24
|
+
value: '#fff',
|
|
25
|
+
},
|
|
26
|
+
strokeWidth: {
|
|
27
|
+
type: null,
|
|
28
|
+
value: 4,
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
data: {
|
|
32
|
+
right: 0,
|
|
33
|
+
},
|
|
34
|
+
mounted() {
|
|
35
|
+
this.setLeft();
|
|
36
|
+
},
|
|
37
|
+
methods: {
|
|
38
|
+
setLeft() {
|
|
39
|
+
Promise.all([
|
|
40
|
+
getRect(this, '.van-progress'),
|
|
41
|
+
getRect(this, '.van-progress__pivot'),
|
|
42
|
+
]).then(([portion, pivot]) => {
|
|
43
|
+
if (portion && pivot) {
|
|
44
|
+
this.setData({
|
|
45
|
+
right: (pivot.width * (this.data.percentage - 100)) / 100,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
});
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
<wxs src="../wxs/utils.wxs" module="utils" />
|
|
2
|
+
<wxs src="./index.wxs" module="computed" />
|
|
3
|
+
|
|
4
|
+
<view
|
|
5
|
+
class="van-progress custom-class"
|
|
6
|
+
style="{{ computed.rootStyle({ strokeWidth, trackColor }) }}"
|
|
7
|
+
>
|
|
8
|
+
<view
|
|
9
|
+
class="van-progress__portion"
|
|
10
|
+
style="{{ computed.portionStyle({ percentage, inactive, color }) }}"
|
|
11
|
+
>
|
|
12
|
+
<view
|
|
13
|
+
wx:if="{{ showPivot && computed.pivotText(pivotText, percentage) }}"
|
|
14
|
+
style="{{ computed.pivotStyle({ textColor, pivotColor, inactive, color, right }) }}"
|
|
15
|
+
class="van-progress__pivot"
|
|
16
|
+
>
|
|
17
|
+
{{ computed.pivotText(pivotText, percentage) }}
|
|
18
|
+
</view>
|
|
19
|
+
</view>
|
|
20
|
+
</view>
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
var utils = require('../wxs/utils.wxs');
|
|
3
|
+
var style = require('../wxs/style.wxs');
|
|
4
|
+
|
|
5
|
+
function pivotText(pivotText, percentage) {
|
|
6
|
+
return pivotText || percentage + '%';
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
function rootStyle(data) {
|
|
10
|
+
return style({
|
|
11
|
+
'height': data.strokeWidth ? utils.addUnit(data.strokeWidth) : '',
|
|
12
|
+
'background': data.trackColor,
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function portionStyle(data) {
|
|
17
|
+
return style({
|
|
18
|
+
background: data.inactive ? '#cacaca' : data.color,
|
|
19
|
+
width: data.percentage ? data.percentage + '%' : '',
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function pivotStyle(data) {
|
|
24
|
+
return style({
|
|
25
|
+
color: data.textColor,
|
|
26
|
+
right: data.right + 'px',
|
|
27
|
+
background: data.pivotColor ? data.pivotColor : data.inactive ? '#cacaca' : data.color,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
module.exports = {
|
|
32
|
+
pivotText: pivotText,
|
|
33
|
+
rootStyle: rootStyle,
|
|
34
|
+
portionStyle: portionStyle,
|
|
35
|
+
pivotStyle: pivotStyle,
|
|
36
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import '../common/index.wxss';.van-progress{background:var(--progress-background-color,#ebedf0);border-radius:var(--progress-height,4px);height:var(--progress-height,4px);position:relative}.van-progress__portion{background:var(--progress-color,#1989fa);border-radius:inherit;height:100%;left:0;position:absolute}.van-progress__pivot{background-color:var(--progress-pivot-background-color,#1989fa);border-radius:1em;box-sizing:border-box;color:var(--progress-pivot-text-color,#fff);font-size:var(--progress-pivot-font-size,10px);line-height:var(--progress-pivot-line-height,1.6);min-width:3.6em;padding:var(--progress-pivot-padding,0 5px);position:absolute;text-align:center;top:50%;transform:translateY(-50%);word-break:keep-all}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { canIUseModel } from '../common/version';
|
|
2
|
+
import { VantComponent } from '../common/component';
|
|
3
|
+
import { useParent } from '../common/relation';
|
|
4
|
+
VantComponent({
|
|
5
|
+
field: true,
|
|
6
|
+
relation: useParent('radio-group', function () {
|
|
7
|
+
this.updateFromParent();
|
|
8
|
+
}),
|
|
9
|
+
classes: ['icon-class', 'label-class'],
|
|
10
|
+
props: {
|
|
11
|
+
name: null,
|
|
12
|
+
value: null,
|
|
13
|
+
disabled: Boolean,
|
|
14
|
+
useIconSlot: Boolean,
|
|
15
|
+
checkedColor: String,
|
|
16
|
+
labelPosition: {
|
|
17
|
+
type: String,
|
|
18
|
+
value: 'right',
|
|
19
|
+
},
|
|
20
|
+
labelDisabled: Boolean,
|
|
21
|
+
shape: {
|
|
22
|
+
type: String,
|
|
23
|
+
value: 'round',
|
|
24
|
+
},
|
|
25
|
+
iconSize: {
|
|
26
|
+
type: null,
|
|
27
|
+
value: 20,
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
data: {
|
|
31
|
+
direction: '',
|
|
32
|
+
parentDisabled: false,
|
|
33
|
+
},
|
|
34
|
+
methods: {
|
|
35
|
+
updateFromParent() {
|
|
36
|
+
if (!this.parent) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
const { value, disabled: parentDisabled, direction } = this.parent.data;
|
|
40
|
+
this.setData({
|
|
41
|
+
value,
|
|
42
|
+
direction,
|
|
43
|
+
parentDisabled,
|
|
44
|
+
});
|
|
45
|
+
},
|
|
46
|
+
emitChange(value) {
|
|
47
|
+
const instance = this.parent || this;
|
|
48
|
+
instance.$emit('input', value);
|
|
49
|
+
instance.$emit('change', value);
|
|
50
|
+
if (canIUseModel()) {
|
|
51
|
+
instance.setData({ value });
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
onChange() {
|
|
55
|
+
if (!this.data.disabled && !this.data.parentDisabled) {
|
|
56
|
+
this.emitChange(this.data.name);
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
onClickLabel() {
|
|
60
|
+
const { disabled, parentDisabled, labelDisabled, name } = this.data;
|
|
61
|
+
if (!(disabled || parentDisabled) && !labelDisabled) {
|
|
62
|
+
this.emitChange(name);
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
});
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
<wxs src="../wxs/utils.wxs" module="utils" />
|
|
2
|
+
<wxs src="./index.wxs" module="computed" />
|
|
3
|
+
|
|
4
|
+
<view class="{{ utils.bem('radio', [direction]) }} custom-class">
|
|
5
|
+
<view
|
|
6
|
+
wx:if="{{ labelPosition === 'left' }}"
|
|
7
|
+
class="{{ utils.bem('radio__label', [labelPosition, { disabled: disabled || parentDisabled }]) }} label-class"
|
|
8
|
+
bindtap="onClickLabel"
|
|
9
|
+
>
|
|
10
|
+
<slot />
|
|
11
|
+
</view>
|
|
12
|
+
<view class="van-radio__icon-wrap" style="font-size: {{ utils.addUnit(iconSize) }}" bindtap="onChange">
|
|
13
|
+
<slot wx:if="{{ useIconSlot }}" name="icon" />
|
|
14
|
+
<van-icon
|
|
15
|
+
wx:else
|
|
16
|
+
name="success"
|
|
17
|
+
class="{{ utils.bem('radio__icon', [shape, { disabled: disabled || parentDisabled, checked: value === name }]) }}"
|
|
18
|
+
style="{{ computed.iconStyle({ iconSize, checkedColor, disabled, parentDisabled, value, name }) }}"
|
|
19
|
+
custom-class="icon-class"
|
|
20
|
+
custom-style="{{ computed.iconCustomStyle({ iconSize }) }}"
|
|
21
|
+
/>
|
|
22
|
+
</view>
|
|
23
|
+
<view
|
|
24
|
+
wx:if="{{ labelPosition === 'right' }}"
|
|
25
|
+
class="label-class {{ utils.bem('radio__label', [labelPosition, { disabled: disabled || parentDisabled }]) }}"
|
|
26
|
+
bindtap="onClickLabel"
|
|
27
|
+
>
|
|
28
|
+
<slot />
|
|
29
|
+
</view>
|
|
30
|
+
</view>
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
var style = require('../wxs/style.wxs');
|
|
3
|
+
var addUnit = require('../wxs/add-unit.wxs');
|
|
4
|
+
|
|
5
|
+
function iconStyle(data) {
|
|
6
|
+
var styles = {
|
|
7
|
+
'font-size': addUnit(data.iconSize),
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
if (
|
|
11
|
+
data.checkedColor &&
|
|
12
|
+
!(data.disabled || data.parentDisabled) &&
|
|
13
|
+
data.value === data.name
|
|
14
|
+
) {
|
|
15
|
+
styles['border-color'] = data.checkedColor;
|
|
16
|
+
styles['background-color'] = data.checkedColor;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
return style(styles);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function iconCustomStyle(data) {
|
|
23
|
+
return style({
|
|
24
|
+
'line-height': addUnit(data.iconSize),
|
|
25
|
+
'font-size': '.8em',
|
|
26
|
+
display: 'block',
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
module.exports = {
|
|
31
|
+
iconStyle: iconStyle,
|
|
32
|
+
iconCustomStyle: iconCustomStyle,
|
|
33
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import '../common/index.wxss';.van-radio{align-items:center;display:flex;overflow:hidden;-webkit-user-select:none;user-select:none}.van-radio__icon-wrap{flex:none}.van-radio--horizontal{margin-right:var(--padding-sm,12px)}.van-radio__icon{align-items:center;border:1px solid var(--radio-border-color,#c8c9cc);box-sizing:border-box;color:transparent;display:flex;font-size:var(--radio-size,20px);height:1em;justify-content:center;text-align:center;transition-duration:var(--radio-transition-duration,.2s);transition-property:color,border-color,background-color;width:1em}.van-radio__icon--round{border-radius:100%}.van-radio__icon--checked{background-color:var(--radio-checked-icon-color,#1989fa);border-color:var(--radio-checked-icon-color,#1989fa);color:#fff}.van-radio__icon--disabled{background-color:var(--radio-disabled-background-color,#ebedf0);border-color:var(--radio-disabled-icon-color,#c8c9cc)}.van-radio__icon--disabled.van-radio__icon--checked{color:var(--radio-disabled-icon-color,#c8c9cc)}.van-radio__label{word-wrap:break-word;color:var(--radio-label-color,#323233);line-height:var(--radio-size,20px);padding-left:var(--radio-label-margin,10px)}.van-radio__label--left{float:left;margin:0 var(--radio-label-margin,10px) 0 0}.van-radio__label--disabled{color:var(--radio-disabled-label-color,#c8c9cc)}.van-radio__label:empty{margin:0}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { VantComponent } from '../common/component';
|
|
2
|
+
import { useChildren } from '../common/relation';
|
|
3
|
+
VantComponent({
|
|
4
|
+
field: true,
|
|
5
|
+
relation: useChildren('radio'),
|
|
6
|
+
props: {
|
|
7
|
+
value: {
|
|
8
|
+
type: null,
|
|
9
|
+
observer: 'updateChildren',
|
|
10
|
+
},
|
|
11
|
+
direction: String,
|
|
12
|
+
disabled: {
|
|
13
|
+
type: Boolean,
|
|
14
|
+
observer: 'updateChildren',
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
methods: {
|
|
18
|
+
updateChildren() {
|
|
19
|
+
this.children.forEach((child) => child.updateFromParent());
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import '../common/index.wxss';.van-radio-group--horizontal{display:flex;flex-wrap:wrap}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { getAllRect } from '../common/utils';
|
|
2
|
+
import { VantComponent } from '../common/component';
|
|
3
|
+
import { canIUseModel } from '../common/version';
|
|
4
|
+
VantComponent({
|
|
5
|
+
field: true,
|
|
6
|
+
classes: ['icon-class'],
|
|
7
|
+
props: {
|
|
8
|
+
value: {
|
|
9
|
+
type: Number,
|
|
10
|
+
observer(value) {
|
|
11
|
+
if (value !== this.data.innerValue) {
|
|
12
|
+
this.setData({ innerValue: value });
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
readonly: Boolean,
|
|
17
|
+
disabled: Boolean,
|
|
18
|
+
allowHalf: Boolean,
|
|
19
|
+
size: null,
|
|
20
|
+
icon: {
|
|
21
|
+
type: String,
|
|
22
|
+
value: 'star',
|
|
23
|
+
},
|
|
24
|
+
voidIcon: {
|
|
25
|
+
type: String,
|
|
26
|
+
value: 'star-o',
|
|
27
|
+
},
|
|
28
|
+
color: String,
|
|
29
|
+
voidColor: String,
|
|
30
|
+
disabledColor: String,
|
|
31
|
+
count: {
|
|
32
|
+
type: Number,
|
|
33
|
+
value: 5,
|
|
34
|
+
observer(value) {
|
|
35
|
+
this.setData({ innerCountArray: Array.from({ length: value }) });
|
|
36
|
+
},
|
|
37
|
+
},
|
|
38
|
+
gutter: null,
|
|
39
|
+
touchable: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
value: true,
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
data: {
|
|
45
|
+
innerValue: 0,
|
|
46
|
+
innerCountArray: Array.from({ length: 5 }),
|
|
47
|
+
},
|
|
48
|
+
methods: {
|
|
49
|
+
onSelect(event) {
|
|
50
|
+
const { data } = this;
|
|
51
|
+
const { score } = event.currentTarget.dataset;
|
|
52
|
+
if (!data.disabled && !data.readonly) {
|
|
53
|
+
this.setData({ innerValue: score + 1 });
|
|
54
|
+
if (canIUseModel()) {
|
|
55
|
+
this.setData({ value: score + 1 });
|
|
56
|
+
}
|
|
57
|
+
wx.nextTick(() => {
|
|
58
|
+
this.$emit('input', score + 1);
|
|
59
|
+
this.$emit('change', score + 1);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
onTouchMove(event) {
|
|
64
|
+
const { touchable } = this.data;
|
|
65
|
+
if (!touchable)
|
|
66
|
+
return;
|
|
67
|
+
const { clientX } = event.touches[0];
|
|
68
|
+
getAllRect(this, '.van-rate__icon').then((list) => {
|
|
69
|
+
const target = list
|
|
70
|
+
.sort((cur, next) => cur.dataset.score - next.dataset.score)
|
|
71
|
+
.find((item) => clientX >= item.left && clientX <= item.right);
|
|
72
|
+
if (target != null) {
|
|
73
|
+
this.onSelect(Object.assign(Object.assign({}, event), { currentTarget: target }));
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
});
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
<wxs src="../wxs/utils.wxs" module="utils" />
|
|
2
|
+
<wxs src="../wxs/style.wxs" module="style" />
|
|
3
|
+
|
|
4
|
+
<view
|
|
5
|
+
class="{{ utils.bem('rate') }} custom-class"
|
|
6
|
+
bind:touchmove="onTouchMove"
|
|
7
|
+
>
|
|
8
|
+
<view
|
|
9
|
+
class="{{ utils.bem('rate__item') }}"
|
|
10
|
+
wx:for="{{ innerCountArray }}"
|
|
11
|
+
wx:key="index"
|
|
12
|
+
style="{{ style({ paddingRight: index !== count - 1 ? utils.addUnit(gutter) : null }) }}"
|
|
13
|
+
>
|
|
14
|
+
<van-icon
|
|
15
|
+
name="{{ index + 1 <= innerValue ? icon : voidIcon }}"
|
|
16
|
+
class="{{ utils.bem('rate__icon', [{ disabled, full: index + 1 <= innerValue }])}}"
|
|
17
|
+
style="{{ style({ fontSize: utils.addUnit(size) }) }}"
|
|
18
|
+
custom-class="icon-class"
|
|
19
|
+
data-score="{{ index }}"
|
|
20
|
+
color="{{ disabled ? disabledColor : index + 1 <= innerValue ? color : voidColor }}"
|
|
21
|
+
bind:click="onSelect"
|
|
22
|
+
/>
|
|
23
|
+
|
|
24
|
+
<van-icon
|
|
25
|
+
wx:if="{{ allowHalf }}"
|
|
26
|
+
name="{{ index + 0.5 <= innerValue ? icon : voidIcon }}"
|
|
27
|
+
class="{{ utils.bem('rate__icon', ['half', { disabled, full: index + 0.5 <= innerValue }]) }}"
|
|
28
|
+
style="{{ style({ fontSize: utils.addUnit(size) }) }}"
|
|
29
|
+
custom-class="icon-class"
|
|
30
|
+
data-score="{{ index - 0.5 }}"
|
|
31
|
+
color="{{ disabled ? disabledColor : index + 0.5 <= innerValue ? color : voidColor }}"
|
|
32
|
+
bind:click="onSelect"
|
|
33
|
+
/>
|
|
34
|
+
</view>
|
|
35
|
+
</view>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
@import '../common/index.wxss';.van-rate{display:inline-flex;-webkit-user-select:none;user-select:none}.van-rate__item{padding:0 var(--rate-horizontal-padding,2px);position:relative}.van-rate__item:not(:last-child){padding-right:var(--rate-icon-gutter,4px)}.van-rate__icon{color:var(--rate-icon-void-color,#c8c9cc);display:block;font-size:var(--rate-icon-size,20px);height:100%}.van-rate__icon--half{left:var(--rate-horizontal-padding,2px);overflow:hidden;position:absolute;top:0;width:.5em}.van-rate__icon--full,.van-rate__icon--half{color:var(--rate-icon-full-color,#ee0a24)}.van-rate__icon--disabled{color:var(--rate-icon-disabled-color,#c8c9cc)}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { VantComponent } from '../common/component';
|
|
2
|
+
import { useChildren } from '../common/relation';
|
|
3
|
+
VantComponent({
|
|
4
|
+
relation: useChildren('col', function (target) {
|
|
5
|
+
const { gutter } = this.data;
|
|
6
|
+
if (gutter) {
|
|
7
|
+
target.setData({ gutter });
|
|
8
|
+
}
|
|
9
|
+
}),
|
|
10
|
+
props: {
|
|
11
|
+
gutter: {
|
|
12
|
+
type: Number,
|
|
13
|
+
observer: 'setGutter',
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
methods: {
|
|
17
|
+
setGutter() {
|
|
18
|
+
this.children.forEach((col) => {
|
|
19
|
+
col.setData(this.data);
|
|
20
|
+
});
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
});
|