taro-ui 3.3.0 → 3.3.2
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/LICENSE +21 -0
- package/lib/common/component.d.ts +10 -0
- package/lib/common/component.js +27 -28
- package/lib/common/component.js.map +1 -1
- package/lib/common/utils.d.ts +41 -0
- package/lib/common/utils.js +169 -192
- package/lib/common/utils.js.map +1 -1
- package/lib/components/accordion/index.d.ts +14 -0
- package/lib/components/accordion/index.js +111 -106
- package/lib/components/accordion/index.js.map +1 -1
- package/lib/components/action-sheet/body/index.d.ts +5 -0
- package/lib/components/action-sheet/body/index.js +11 -8
- package/lib/components/action-sheet/body/index.js.map +1 -1
- package/lib/components/action-sheet/body/item/index.d.ts +9 -0
- package/lib/components/action-sheet/body/item/index.js +21 -18
- package/lib/components/action-sheet/body/item/index.js.map +1 -1
- package/lib/components/action-sheet/footer/index.d.ts +9 -0
- package/lib/components/action-sheet/footer/index.js +24 -18
- package/lib/components/action-sheet/footer/index.js.map +1 -1
- package/lib/components/action-sheet/header/index.d.ts +5 -0
- package/lib/components/action-sheet/header/index.js +14 -8
- package/lib/components/action-sheet/header/index.js.map +1 -1
- package/lib/components/action-sheet/index.d.ts +14 -0
- package/lib/components/action-sheet/index.js +69 -64
- package/lib/components/action-sheet/index.js.map +1 -1
- package/lib/components/activity-indicator/index.d.ts +8 -0
- package/lib/components/activity-indicator/index.js +33 -29
- package/lib/components/activity-indicator/index.js.map +1 -1
- package/lib/components/avatar/index.d.ts +9 -0
- package/lib/components/avatar/index.js +58 -50
- package/lib/components/avatar/index.js.map +1 -1
- package/lib/components/badge/index.d.ts +10 -0
- package/lib/components/badge/index.js +44 -35
- package/lib/components/badge/index.js.map +1 -1
- package/lib/components/button/index.d.ts +15 -0
- package/lib/components/button/index.js +165 -113
- package/lib/components/button/index.js.map +1 -1
- package/lib/components/calendar/body/index.d.ts +26 -0
- package/lib/components/calendar/body/index.js +279 -183
- package/lib/components/calendar/body/index.js.map +1 -1
- package/lib/components/calendar/common/constant.d.ts +3 -0
- package/lib/components/calendar/common/constant.js +8 -3
- package/lib/components/calendar/common/constant.js.map +1 -1
- package/lib/components/calendar/common/helper.d.ts +4 -0
- package/lib/components/calendar/common/helper.js +77 -76
- package/lib/components/calendar/common/helper.js.map +1 -1
- package/lib/components/calendar/common/plugins.d.ts +11 -0
- package/lib/components/calendar/common/plugins.js +50 -66
- package/lib/components/calendar/common/plugins.js.map +1 -1
- package/lib/components/calendar/controller/index.d.ts +5 -0
- package/lib/components/calendar/controller/index.js +49 -28
- package/lib/components/calendar/controller/index.js.map +1 -1
- package/lib/components/calendar/index.d.ts +20 -0
- package/lib/components/calendar/index.js +233 -196
- package/lib/components/calendar/index.js.map +1 -1
- package/lib/components/calendar/ui/date-list/index.d.ts +12 -0
- package/lib/components/calendar/ui/date-list/index.js +50 -39
- package/lib/components/calendar/ui/date-list/index.js.map +1 -1
- package/lib/components/calendar/ui/day-list/index.d.ts +4 -0
- package/lib/components/calendar/ui/day-list/index.js +9 -14
- package/lib/components/calendar/ui/day-list/index.js.map +1 -1
- package/lib/components/card/index.d.ts +9 -0
- package/lib/components/card/index.js +73 -52
- package/lib/components/card/index.js.map +1 -1
- package/lib/components/checkbox/index.d.ts +9 -0
- package/lib/components/checkbox/index.js +52 -48
- package/lib/components/checkbox/index.js.map +1 -1
- package/lib/components/countdown/index.d.ts +20 -0
- package/lib/components/countdown/index.js +140 -125
- package/lib/components/countdown/index.js.map +1 -1
- package/lib/components/countdown/item/index.d.ts +9 -0
- package/lib/components/countdown/item/index.js +18 -18
- package/lib/components/countdown/item/index.js.map +1 -1
- package/lib/components/curtain/index.d.ts +10 -0
- package/lib/components/curtain/index.js +56 -39
- package/lib/components/curtain/index.js.map +1 -1
- package/lib/components/divider/index.d.ts +8 -0
- package/lib/components/divider/index.js +51 -34
- package/lib/components/divider/index.js.map +1 -1
- package/lib/components/drawer/index.d.ts +16 -0
- package/lib/components/drawer/index.js +106 -85
- package/lib/components/drawer/index.js.map +1 -1
- package/lib/components/fab/index.d.ts +9 -0
- package/lib/components/fab/index.js +22 -19
- package/lib/components/fab/index.js.map +1 -1
- package/lib/components/flex/index.d.ts +7 -0
- package/lib/components/flex/index.js +37 -34
- package/lib/components/flex/index.js.map +1 -1
- package/lib/components/flex/item/index.d.ts +7 -0
- package/lib/components/flex/item/index.js +30 -27
- package/lib/components/flex/item/index.js.map +1 -1
- package/lib/components/float-layout/index.d.ts +13 -0
- package/lib/components/float-layout/index.js +96 -68
- package/lib/components/float-layout/index.js.map +1 -1
- package/lib/components/form/index.d.ts +10 -0
- package/lib/components/form/index.js +37 -24
- package/lib/components/form/index.js.map +1 -1
- package/lib/components/grid/index.d.ts +9 -0
- package/lib/components/grid/index.js +92 -62
- package/lib/components/grid/index.js.map +1 -1
- package/lib/components/icon/index.d.ts +9 -0
- package/lib/components/icon/index.js +48 -31
- package/lib/components/icon/index.js.map +1 -1
- package/lib/components/image-picker/index.d.ts +11 -0
- package/lib/components/image-picker/index.js +152 -126
- package/lib/components/image-picker/index.js.map +1 -1
- package/lib/components/indexes/index.d.ts +29 -0
- package/lib/components/indexes/index.js +255 -198
- package/lib/components/indexes/index.js.map +1 -1
- package/lib/components/input/index.d.ts +17 -0
- package/lib/components/input/index.js +224 -160
- package/lib/components/input/index.js.map +1 -1
- package/lib/components/input-number/index.d.ts +13 -0
- package/lib/components/input-number/index.js +180 -152
- package/lib/components/input-number/index.js.map +1 -1
- package/lib/components/list/index.d.ts +8 -0
- package/lib/components/list/index.js +20 -13
- package/lib/components/list/index.js.map +1 -1
- package/lib/components/list/item/index.d.ts +11 -0
- package/lib/components/list/item/index.js +146 -99
- package/lib/components/list/item/index.js.map +1 -1
- package/lib/components/load-more/index.d.ts +9 -0
- package/lib/components/load-more/index.js +65 -41
- package/lib/components/load-more/index.js.map +1 -1
- package/lib/components/loading/index.d.ts +12 -0
- package/lib/components/loading/index.js +26 -26
- package/lib/components/loading/index.js.map +1 -1
- package/lib/components/message/index.d.ts +15 -0
- package/lib/components/message/index.js +72 -63
- package/lib/components/message/index.js.map +1 -1
- package/lib/components/modal/action/index.d.ts +8 -0
- package/lib/components/modal/action/index.js +20 -14
- package/lib/components/modal/action/index.js.map +1 -1
- package/lib/components/modal/content/index.d.ts +5 -0
- package/lib/components/modal/content/index.js +11 -8
- package/lib/components/modal/content/index.js.map +1 -1
- package/lib/components/modal/header/index.d.ts +5 -0
- package/lib/components/modal/header/index.js +11 -8
- package/lib/components/modal/header/index.js.map +1 -1
- package/lib/components/modal/index.d.ts +15 -0
- package/lib/components/modal/index.js +96 -87
- package/lib/components/modal/index.js.map +1 -1
- package/lib/components/nav-bar/index.d.ts +12 -0
- package/lib/components/nav-bar/index.js +210 -98
- package/lib/components/nav-bar/index.js.map +1 -1
- package/lib/components/noticebar/index.d.ts +16 -0
- package/lib/components/noticebar/index.js +177 -154
- package/lib/components/noticebar/index.js.map +1 -1
- package/lib/components/pagination/index.d.ts +12 -0
- package/lib/components/pagination/index.js +133 -102
- package/lib/components/pagination/index.js.map +1 -1
- package/lib/components/progress/index.d.ts +7 -0
- package/lib/components/progress/index.js +48 -40
- package/lib/components/progress/index.js.map +1 -1
- package/lib/components/radio/index.d.ts +9 -0
- package/lib/components/radio/index.js +48 -37
- package/lib/components/radio/index.js.map +1 -1
- package/lib/components/range/index.d.ts +22 -0
- package/lib/components/range/index.js +197 -142
- package/lib/components/range/index.js.map +1 -1
- package/lib/components/rate/index.d.ts +9 -0
- package/lib/components/rate/index.js +74 -48
- package/lib/components/rate/index.js.map +1 -1
- package/lib/components/search-bar/index.d.ts +16 -0
- package/lib/components/search-bar/index.js +167 -112
- package/lib/components/search-bar/index.js.map +1 -1
- package/lib/components/segmented-control/index.d.ts +9 -0
- package/lib/components/segmented-control/index.js +78 -53
- package/lib/components/segmented-control/index.js.map +1 -1
- package/lib/components/slider/index.d.ts +13 -0
- package/lib/components/slider/index.js +107 -69
- package/lib/components/slider/index.js.map +1 -1
- package/lib/components/steps/index.d.ts +9 -0
- package/lib/components/steps/index.js +61 -44
- package/lib/components/steps/index.js.map +1 -1
- package/lib/components/swipe-action/index.d.ts +27 -0
- package/lib/components/swipe-action/index.js +206 -157
- package/lib/components/swipe-action/index.js.map +1 -1
- package/lib/components/swipe-action/options/index.d.ts +5 -0
- package/lib/components/swipe-action/options/index.js +22 -8
- package/lib/components/swipe-action/options/index.js.map +1 -1
- package/lib/components/switch/index.d.ts +9 -0
- package/lib/components/switch/index.js +53 -42
- package/lib/components/switch/index.js.map +1 -1
- package/lib/components/tab-bar/index.d.ts +9 -0
- package/lib/components/tab-bar/index.js +164 -90
- package/lib/components/tab-bar/index.js.map +1 -1
- package/lib/components/tabs/index.d.ts +24 -0
- package/lib/components/tabs/index.js +203 -174
- package/lib/components/tabs/index.js.map +1 -1
- package/lib/components/tabs-pane/index.d.ts +8 -0
- package/lib/components/tabs-pane/index.js +37 -24
- package/lib/components/tabs-pane/index.js.map +1 -1
- package/lib/components/tag/index.d.ts +9 -0
- package/lib/components/tag/index.js +64 -44
- package/lib/components/tag/index.js.map +1 -1
- package/lib/components/textarea/index.d.ts +13 -0
- package/lib/components/textarea/index.js +132 -86
- package/lib/components/textarea/index.js.map +1 -1
- package/lib/components/timeline/index.d.ts +8 -0
- package/lib/components/timeline/index.js +70 -47
- package/lib/components/timeline/index.js.map +1 -1
- package/lib/components/toast/img.json +6 -3
- package/lib/components/toast/index.d.ts +16 -0
- package/lib/components/toast/index.js +111 -104
- package/lib/components/toast/index.js.map +1 -1
- package/lib/index.d.ts +53 -0
- package/lib/index.js +108 -54
- package/lib/index.js.map +1 -1
- package/{dist → lib}/style/components/curtain.scss +3 -3
- package/{dist → lib}/style/components/grid.scss +2 -2
- package/lib/style/components/index.scss +52 -0
- package/{dist → lib}/style/components/list.scss +2 -2
- package/{dist → lib}/style/components/range.scss +2 -2
- package/{dist → lib}/style/components/toast.scss +1 -1
- package/lib/style/index.css +11754 -0
- package/lib/style/index.css.map +1 -0
- package/lib/style/mixins/index.scss +18 -0
- package/{dist → lib}/style/mixins/libs/shade.scss +4 -2
- package/{dist → lib}/style/mixins/libs/tint.scss +4 -2
- package/{dist → lib}/style/variables/default.scss +1 -1
- package/package.json +45 -48
- package/rn/components/action-sheet/index.tsx +8 -14
- package/rn/components/calendar/ui/date-list/index.tsx +1 -1
- package/rn/components/drawer/index.tsx +15 -15
- package/rn/components/float-layout/index.tsx +3 -2
- package/rn/components/input/index.tsx +14 -7
- package/rn/components/input-number/index.tsx +19 -19
- package/rn/components/message/index.tsx +1 -1
- package/rn/components/swipe-action/index.rn.tsx +4 -2
- package/rn/components/swipe-action/index.tsx +6 -5
- package/rn/components/tab-bar/index.tsx +1 -1
- package/rn/components/tabs/index.tsx +14 -14
- package/rn/components/textarea/index.tsx +2 -2
- package/README.md +0 -85
- package/dist/index.esm.js +0 -8407
- package/dist/index.esm.js.map +0 -1
- package/dist/index.js +0 -8468
- package/dist/index.js.map +0 -1
- package/dist/style/components/accordion.rn.scss +0 -79
- package/dist/style/components/action-sheet.rn.scss +0 -80
- package/dist/style/components/activity-indicator.rn.scss +0 -30
- package/dist/style/components/article.rn.scss +0 -59
- package/dist/style/components/avatar.rn.scss +0 -46
- package/dist/style/components/badge.rn.scss +0 -52
- package/dist/style/components/button.rn.scss +0 -80
- package/dist/style/components/calendar.rn.scss +0 -182
- package/dist/style/components/card.rn.scss +0 -88
- package/dist/style/components/checkbox.rn.scss +0 -108
- package/dist/style/components/countdown.rn.scss +0 -82
- package/dist/style/components/curtain.rn.scss +0 -129
- package/dist/style/components/divider.rn.scss +0 -33
- package/dist/style/components/drawer.rn.scss +0 -72
- package/dist/style/components/fab.rn.scss +0 -38
- package/dist/style/components/flex.rn.scss +0 -159
- package/dist/style/components/float-layout.rn.scss +0 -119
- package/dist/style/components/form.rn.scss +0 -12
- package/dist/style/components/grid.rn.scss +0 -104
- package/dist/style/components/icon.rn.scss +0 -221
- package/dist/style/components/image-picker.rn.scss +0 -108
- package/dist/style/components/index.rn.scss +0 -51
- package/dist/style/components/index.scss +0 -52
- package/dist/style/components/indexes.rn.scss +0 -53
- package/dist/style/components/input-number.rn.scss +0 -82
- package/dist/style/components/input.rn.scss +0 -149
- package/dist/style/components/list.rn.scss +0 -107
- package/dist/style/components/load-more.rn.scss +0 -28
- package/dist/style/components/loading.rn.scss +0 -45
- package/dist/style/components/message.rn.scss +0 -57
- package/dist/style/components/modal.rn.scss +0 -136
- package/dist/style/components/nav-bar.rn.scss +0 -123
- package/dist/style/components/noticebar.rn.scss +0 -111
- package/dist/style/components/pagination.rn.scss +0 -43
- package/dist/style/components/progress.rn.scss +0 -105
- package/dist/style/components/radio.rn.scss +0 -94
- package/dist/style/components/range.rn.scss +0 -52
- package/dist/style/components/rate.rn.scss +0 -48
- package/dist/style/components/search-bar.rn.scss +0 -134
- package/dist/style/components/segmented-control.rn.scss +0 -44
- package/dist/style/components/slider.rn.scss +0 -33
- package/dist/style/components/steps.rn.scss +0 -131
- package/dist/style/components/swipe-action.rn.scss +0 -53
- package/dist/style/components/switch.rn.scss +0 -61
- package/dist/style/components/tab-bar.rn.scss +0 -74
- package/dist/style/components/tabs.rn.scss +0 -205
- package/dist/style/components/tag.rn.scss +0 -74
- package/dist/style/components/textarea.rn.scss +0 -57
- package/dist/style/components/timeline.rn.scss +0 -89
- package/dist/style/components/toast.rn.scss +0 -112
- package/dist/style/index.rn.scss +0 -14
- package/dist/style/mixins/index.rn.scss +0 -18
- package/dist/style/mixins/index.scss +0 -18
- package/dist/style/mixins/libs/absolute-center.rn.scss +0 -9
- package/dist/style/mixins/libs/active.rn.scss +0 -10
- package/dist/style/mixins/libs/alignhack.rn.scss +0 -11
- package/dist/style/mixins/libs/border.rn.scss +0 -48
- package/dist/style/mixins/libs/clearfix.rn.scss +0 -21
- package/dist/style/mixins/libs/disabled.rn.scss +0 -6
- package/dist/style/mixins/libs/flex.rn.scss +0 -49
- package/dist/style/mixins/libs/hairline.rn.scss +0 -209
- package/dist/style/mixins/libs/line.rn.scss +0 -14
- package/dist/style/mixins/libs/overlay.rn.scss +0 -11
- package/dist/style/mixins/libs/placeholder.rn.scss +0 -12
- package/dist/style/mixins/libs/shade.rn.scss +0 -23
- package/dist/style/mixins/libs/tint.rn.scss +0 -23
- package/dist/style/themes/purple.rn.scss +0 -44
- package/dist/style/themes/red.rn.scss +0 -45
- package/dist/style/variables/default.rn.scss +0 -461
- package/types/accordion.d.ts +0 -49
- package/types/action-sheet.d.ts +0 -55
- package/types/activity-indicator.d.ts +0 -33
- package/types/avatar.d.ts +0 -39
- package/types/badge.d.ts +0 -24
- package/types/base.d.ts +0 -26
- package/types/button.d.ts +0 -70
- package/types/calendar.d.ts +0 -225
- package/types/card.d.ts +0 -48
- package/types/checkbox.d.ts +0 -24
- package/types/countdown.d.ts +0 -95
- package/types/curtain.d.ts +0 -26
- package/types/divider.d.ts +0 -33
- package/types/drawer.d.ts +0 -48
- package/types/fab.d.ts +0 -21
- package/types/flex.d.ts +0 -27
- package/types/float-button.d.ts +0 -26
- package/types/float-layout.d.ts +0 -73
- package/types/form.d.ts +0 -26
- package/types/grid.d.ts +0 -51
- package/types/icon.d.ts +0 -12
- package/types/image-picker.d.ts +0 -73
- package/types/index.d.ts +0 -55
- package/types/indexes.d.ts +0 -76
- package/types/input-number.d.ts +0 -89
- package/types/input.d.ts +0 -162
- package/types/list.d.ts +0 -84
- package/types/load-more.d.ts +0 -43
- package/types/message.d.ts +0 -43
- package/types/modal.d.ts +0 -62
- package/types/nav-bar.d.ts +0 -65
- package/types/noticebar.d.ts +0 -65
- package/types/pagination.d.ts +0 -51
- package/types/progress.d.ts +0 -30
- package/types/radio.d.ts +0 -47
- package/types/range.d.ts +0 -63
- package/types/rate.d.ts +0 -34
- package/types/search-bar.d.ts +0 -105
- package/types/segmented-control.d.ts +0 -44
- package/types/slider.d.ts +0 -73
- package/types/steps.d.ts +0 -69
- package/types/swipe-action.d.ts +0 -86
- package/types/switch.d.ts +0 -38
- package/types/tab-bar.d.ts +0 -98
- package/types/tabs-pane.d.ts +0 -25
- package/types/tabs.d.ts +0 -62
- package/types/tag.d.ts +0 -48
- package/types/textarea.d.ts +0 -113
- package/types/timeline.d.ts +0 -46
- package/types/toast.d.ts +0 -53
- /package/{dist → lib}/style/components/accordion.scss +0 -0
- /package/{dist → lib}/style/components/action-sheet.scss +0 -0
- /package/{dist → lib}/style/components/activity-indicator.scss +0 -0
- /package/{dist → lib}/style/components/article.scss +0 -0
- /package/{dist → lib}/style/components/avatar.scss +0 -0
- /package/{dist → lib}/style/components/badge.scss +0 -0
- /package/{dist → lib}/style/components/button.scss +0 -0
- /package/{dist → lib}/style/components/calendar.scss +0 -0
- /package/{dist → lib}/style/components/card.scss +0 -0
- /package/{dist → lib}/style/components/checkbox.scss +0 -0
- /package/{dist → lib}/style/components/countdown.scss +0 -0
- /package/{dist → lib}/style/components/divider.scss +0 -0
- /package/{dist → lib}/style/components/drawer.scss +0 -0
- /package/{dist → lib}/style/components/fab.scss +0 -0
- /package/{dist → lib}/style/components/flex.scss +0 -0
- /package/{dist → lib}/style/components/float-layout.scss +0 -0
- /package/{dist → lib}/style/components/form.scss +0 -0
- /package/{dist → lib}/style/components/icon.scss +0 -0
- /package/{dist → lib}/style/components/image-picker.scss +0 -0
- /package/{dist → lib}/style/components/indexes.scss +0 -0
- /package/{dist → lib}/style/components/input-number.scss +0 -0
- /package/{dist → lib}/style/components/input.scss +0 -0
- /package/{dist → lib}/style/components/load-more.scss +0 -0
- /package/{dist → lib}/style/components/loading.scss +0 -0
- /package/{dist → lib}/style/components/message.scss +0 -0
- /package/{dist → lib}/style/components/modal.scss +0 -0
- /package/{dist → lib}/style/components/nav-bar.scss +0 -0
- /package/{dist → lib}/style/components/noticebar.scss +0 -0
- /package/{dist → lib}/style/components/pagination.scss +0 -0
- /package/{dist → lib}/style/components/progress.scss +0 -0
- /package/{dist → lib}/style/components/radio.scss +0 -0
- /package/{dist → lib}/style/components/rate.scss +0 -0
- /package/{dist → lib}/style/components/search-bar.scss +0 -0
- /package/{dist → lib}/style/components/segmented-control.scss +0 -0
- /package/{dist → lib}/style/components/slider.scss +0 -0
- /package/{dist → lib}/style/components/steps.scss +0 -0
- /package/{dist → lib}/style/components/swipe-action.scss +0 -0
- /package/{dist → lib}/style/components/switch.scss +0 -0
- /package/{dist → lib}/style/components/tab-bar.scss +0 -0
- /package/{dist → lib}/style/components/tabs.scss +0 -0
- /package/{dist → lib}/style/components/tag.scss +0 -0
- /package/{dist → lib}/style/components/textarea.scss +0 -0
- /package/{dist → lib}/style/components/timeline.scss +0 -0
- /package/{dist → lib}/style/index.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/absolute-center.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/active.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/alignhack.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/border.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/clearfix.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/disabled.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/flex.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/hairline.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/line.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/overlay.scss +0 -0
- /package/{dist → lib}/style/mixins/libs/placeholder.scss +0 -0
- /package/{dist → lib}/style/themes/purple.scss +0 -0
- /package/{dist → lib}/style/themes/red.scss +0 -0
|
@@ -1,207 +1,244 @@
|
|
|
1
|
-
import classnames from
|
|
2
|
-
import dayjs from
|
|
3
|
-
import React from
|
|
4
|
-
import { View } from
|
|
5
|
-
import AtCalendarBody from
|
|
6
|
-
import AtCalendarController from
|
|
1
|
+
import classnames from "classnames";
|
|
2
|
+
import dayjs from "dayjs";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { View } from "@tarojs/components";
|
|
5
|
+
import AtCalendarBody from "./body/index";
|
|
6
|
+
import AtCalendarController from "./controller/index";
|
|
7
7
|
const defaultProps = {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
8
|
+
validDates: [],
|
|
9
|
+
marks: [],
|
|
10
|
+
isSwiper: true,
|
|
11
|
+
hideArrow: false,
|
|
12
|
+
isVertical: false,
|
|
13
|
+
selectedDates: [],
|
|
14
|
+
isMultiSelect: false,
|
|
15
|
+
format: "YYYY-MM-DD",
|
|
16
|
+
currentDate: Date.now(),
|
|
17
|
+
monthFormat: "YYYY\u5E74MM\u6708"
|
|
18
18
|
};
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
19
|
+
class AtCalendar extends React.Component {
|
|
20
|
+
constructor(props) {
|
|
21
|
+
super(props);
|
|
22
|
+
this.getSingleSelectdState = (value) => {
|
|
23
|
+
const { generateDate } = this.state;
|
|
24
|
+
const stateValue = {
|
|
25
|
+
selectedDate: this.getSelectedDate(value.valueOf())
|
|
26
|
+
};
|
|
27
|
+
const dayjsGenerateDate = value.startOf("month");
|
|
28
|
+
const generateDateValue = dayjsGenerateDate.valueOf();
|
|
29
|
+
if (generateDateValue !== generateDate) {
|
|
30
|
+
this.triggerChangeDate(dayjsGenerateDate);
|
|
31
|
+
stateValue.generateDate = generateDateValue;
|
|
32
|
+
}
|
|
33
|
+
return stateValue;
|
|
34
|
+
};
|
|
35
|
+
this.getMultiSelectedState = (value) => {
|
|
36
|
+
const { selectedDate } = this.state;
|
|
37
|
+
const { end, start } = selectedDate;
|
|
38
|
+
const valueUnix = value.valueOf();
|
|
39
|
+
const state = {
|
|
40
|
+
selectedDate
|
|
41
|
+
};
|
|
42
|
+
if (end) {
|
|
43
|
+
state.selectedDate = this.getSelectedDate(valueUnix, 0);
|
|
44
|
+
} else {
|
|
45
|
+
state.selectedDate.end = Math.max(valueUnix, +start);
|
|
46
|
+
state.selectedDate.start = Math.min(valueUnix, +start);
|
|
47
|
+
}
|
|
48
|
+
return state;
|
|
49
|
+
};
|
|
50
|
+
this.getSelectedDate = (start, end) => {
|
|
51
|
+
const stateValue = {
|
|
52
|
+
start,
|
|
53
|
+
end: start
|
|
54
|
+
};
|
|
55
|
+
if (typeof end !== "undefined") {
|
|
56
|
+
stateValue.end = end;
|
|
57
|
+
}
|
|
58
|
+
return stateValue;
|
|
59
|
+
};
|
|
60
|
+
this.triggerChangeDate = (value) => {
|
|
61
|
+
const { format } = this.props;
|
|
62
|
+
if (typeof this.props.onMonthChange !== "function") return;
|
|
63
|
+
this.props.onMonthChange(value.format(format));
|
|
64
|
+
};
|
|
65
|
+
this.setMonth = (vectorCount) => {
|
|
66
|
+
const { format } = this.props;
|
|
67
|
+
const { generateDate } = this.state;
|
|
68
|
+
const _generateDate = dayjs(generateDate).add(vectorCount, "month");
|
|
69
|
+
this.setState({
|
|
70
|
+
generateDate: _generateDate.valueOf()
|
|
71
|
+
});
|
|
72
|
+
if (vectorCount && typeof this.props.onMonthChange === "function") {
|
|
73
|
+
this.props.onMonthChange(_generateDate.format(format));
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
this.handleClickPreMonth = (isMinMonth) => {
|
|
77
|
+
if (isMinMonth === true) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
this.setMonth(-1);
|
|
81
|
+
if (typeof this.props.onClickPreMonth === "function") {
|
|
82
|
+
this.props.onClickPreMonth();
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
this.handleClickNextMonth = (isMaxMonth) => {
|
|
86
|
+
if (isMaxMonth === true) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
this.setMonth(1);
|
|
90
|
+
if (typeof this.props.onClickNextMonth === "function") {
|
|
91
|
+
this.props.onClickNextMonth();
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
// picker 选择时间改变时触发
|
|
95
|
+
this.handleSelectDate = (e) => {
|
|
96
|
+
const { value } = e.detail;
|
|
97
|
+
const _generateDate = dayjs(value);
|
|
98
|
+
const _generateDateValue = _generateDate.valueOf();
|
|
99
|
+
if (this.state.generateDate === _generateDateValue) return;
|
|
100
|
+
this.triggerChangeDate(_generateDate);
|
|
101
|
+
this.setState({
|
|
102
|
+
generateDate: _generateDateValue
|
|
103
|
+
});
|
|
104
|
+
};
|
|
105
|
+
this.handleDayClick = (item) => {
|
|
106
|
+
const { isMultiSelect } = this.props;
|
|
107
|
+
const { isDisabled, value } = item;
|
|
108
|
+
if (isDisabled) return;
|
|
109
|
+
const dayjsDate = dayjs(value);
|
|
110
|
+
let stateValue = {};
|
|
111
|
+
if (isMultiSelect) {
|
|
112
|
+
stateValue = this.getMultiSelectedState(dayjsDate);
|
|
113
|
+
} else {
|
|
114
|
+
stateValue = this.getSingleSelectdState(dayjsDate);
|
|
115
|
+
}
|
|
116
|
+
this.setState(stateValue, () => {
|
|
117
|
+
this.handleSelectedDate();
|
|
118
|
+
});
|
|
119
|
+
if (typeof this.props.onDayClick === "function") {
|
|
120
|
+
this.props.onDayClick({ value: item.value });
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
this.handleSelectedDate = () => {
|
|
124
|
+
const selectDate = this.state.selectedDate;
|
|
125
|
+
if (typeof this.props.onSelectDate === "function") {
|
|
126
|
+
const info = {
|
|
127
|
+
start: dayjs(selectDate.start).format(this.props.format)
|
|
34
128
|
};
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
const { end, start } = selectedDate;
|
|
38
|
-
const valueUnix = value.valueOf();
|
|
39
|
-
const state = {
|
|
40
|
-
selectedDate
|
|
41
|
-
};
|
|
42
|
-
if (end) {
|
|
43
|
-
state.selectedDate = this.getSelectedDate(valueUnix, 0);
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
state.selectedDate.end = Math.max(valueUnix, +start);
|
|
47
|
-
state.selectedDate.start = Math.min(valueUnix, +start);
|
|
48
|
-
}
|
|
49
|
-
return state;
|
|
50
|
-
};
|
|
51
|
-
this.getSelectedDate = (start, end) => {
|
|
52
|
-
const stateValue = {
|
|
53
|
-
start,
|
|
54
|
-
end: start
|
|
55
|
-
};
|
|
56
|
-
if (typeof end !== 'undefined') {
|
|
57
|
-
stateValue.end = end;
|
|
58
|
-
}
|
|
59
|
-
return stateValue;
|
|
60
|
-
};
|
|
61
|
-
this.triggerChangeDate = (value) => {
|
|
62
|
-
const { format } = this.props;
|
|
63
|
-
if (typeof this.props.onMonthChange !== 'function')
|
|
64
|
-
return;
|
|
65
|
-
this.props.onMonthChange(value.format(format));
|
|
66
|
-
};
|
|
67
|
-
this.setMonth = (vectorCount) => {
|
|
68
|
-
const { format } = this.props;
|
|
69
|
-
const { generateDate } = this.state;
|
|
70
|
-
const _generateDate = dayjs(generateDate).add(vectorCount, 'month');
|
|
71
|
-
this.setState({
|
|
72
|
-
generateDate: _generateDate.valueOf()
|
|
73
|
-
});
|
|
74
|
-
if (vectorCount && typeof this.props.onMonthChange === 'function') {
|
|
75
|
-
this.props.onMonthChange(_generateDate.format(format));
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
this.handleClickPreMonth = (isMinMonth) => {
|
|
79
|
-
if (isMinMonth === true) {
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
this.setMonth(-1);
|
|
83
|
-
if (typeof this.props.onClickPreMonth === 'function') {
|
|
84
|
-
this.props.onClickPreMonth();
|
|
85
|
-
}
|
|
86
|
-
};
|
|
87
|
-
this.handleClickNextMonth = (isMaxMonth) => {
|
|
88
|
-
if (isMaxMonth === true) {
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
this.setMonth(1);
|
|
92
|
-
if (typeof this.props.onClickNextMonth === 'function') {
|
|
93
|
-
this.props.onClickNextMonth();
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
// picker 选择时间改变时触发
|
|
97
|
-
this.handleSelectDate = (e) => {
|
|
98
|
-
const { value } = e.detail;
|
|
99
|
-
const _generateDate = dayjs(value);
|
|
100
|
-
const _generateDateValue = _generateDate.valueOf();
|
|
101
|
-
if (this.state.generateDate === _generateDateValue)
|
|
102
|
-
return;
|
|
103
|
-
this.triggerChangeDate(_generateDate);
|
|
104
|
-
this.setState({
|
|
105
|
-
generateDate: _generateDateValue
|
|
106
|
-
});
|
|
107
|
-
};
|
|
108
|
-
this.handleDayClick = (item) => {
|
|
109
|
-
const { isMultiSelect } = this.props;
|
|
110
|
-
const { isDisabled, value } = item;
|
|
111
|
-
if (isDisabled)
|
|
112
|
-
return;
|
|
113
|
-
const dayjsDate = dayjs(value);
|
|
114
|
-
let stateValue = {};
|
|
115
|
-
if (isMultiSelect) {
|
|
116
|
-
stateValue = this.getMultiSelectedState(dayjsDate);
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
stateValue = this.getSingleSelectdState(dayjsDate);
|
|
120
|
-
}
|
|
121
|
-
this.setState(stateValue, () => {
|
|
122
|
-
this.handleSelectedDate();
|
|
123
|
-
});
|
|
124
|
-
if (typeof this.props.onDayClick === 'function') {
|
|
125
|
-
this.props.onDayClick({ value: item.value });
|
|
126
|
-
}
|
|
127
|
-
};
|
|
128
|
-
this.handleSelectedDate = () => {
|
|
129
|
-
const selectDate = this.state.selectedDate;
|
|
130
|
-
if (typeof this.props.onSelectDate === 'function') {
|
|
131
|
-
const info = {
|
|
132
|
-
start: dayjs(selectDate.start).format(this.props.format)
|
|
133
|
-
};
|
|
134
|
-
if (selectDate.end) {
|
|
135
|
-
info.end = dayjs(selectDate.end).format(this.props.format);
|
|
136
|
-
}
|
|
137
|
-
this.props.onSelectDate({
|
|
138
|
-
value: info
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
};
|
|
142
|
-
this.handleDayLongClick = (item) => {
|
|
143
|
-
if (typeof this.props.onDayLongClick === 'function') {
|
|
144
|
-
this.props.onDayLongClick({ value: item.value });
|
|
145
|
-
}
|
|
146
|
-
};
|
|
147
|
-
const { currentDate, isMultiSelect } = props;
|
|
148
|
-
this.state = this.getInitializeState(currentDate, isMultiSelect);
|
|
149
|
-
}
|
|
150
|
-
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
151
|
-
const { currentDate, isMultiSelect } = nextProps;
|
|
152
|
-
if (!currentDate || currentDate === this.props.currentDate)
|
|
153
|
-
return;
|
|
154
|
-
if (isMultiSelect && this.props.isMultiSelect) {
|
|
155
|
-
const { start, end } = currentDate;
|
|
156
|
-
const { start: preStart, end: preEnd } = this.props
|
|
157
|
-
.currentDate;
|
|
158
|
-
if (start === preStart && preEnd === end) {
|
|
159
|
-
return;
|
|
160
|
-
}
|
|
129
|
+
if (selectDate.end) {
|
|
130
|
+
info.end = dayjs(selectDate.end).format(this.props.format);
|
|
161
131
|
}
|
|
162
|
-
|
|
163
|
-
|
|
132
|
+
this.props.onSelectDate({
|
|
133
|
+
value: info
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
this.handleDayLongClick = (item) => {
|
|
138
|
+
if (typeof this.props.onDayLongClick === "function") {
|
|
139
|
+
this.props.onDayLongClick({ value: item.value });
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
const { currentDate, isMultiSelect } = props;
|
|
143
|
+
this.state = this.getInitializeState(currentDate, isMultiSelect);
|
|
144
|
+
}
|
|
145
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
146
|
+
const { currentDate, isMultiSelect } = nextProps;
|
|
147
|
+
if (!currentDate || currentDate === this.props.currentDate) return;
|
|
148
|
+
if (isMultiSelect && this.props.isMultiSelect) {
|
|
149
|
+
const { start, end } = currentDate;
|
|
150
|
+
const { start: preStart, end: preEnd } = this.props.currentDate;
|
|
151
|
+
if (start === preStart && preEnd === end) {
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
164
154
|
}
|
|
165
|
-
getInitializeState(
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
start = dayjsStart.startOf('day').valueOf();
|
|
184
|
-
generateDateValue = dayjsStart.startOf('month').valueOf();
|
|
185
|
-
end = cEnd ? dayjs(cEnd).startOf('day').valueOf() : start;
|
|
155
|
+
const stateValue = this.getInitializeState(
|
|
156
|
+
currentDate,
|
|
157
|
+
isMultiSelect
|
|
158
|
+
);
|
|
159
|
+
this.setState(stateValue);
|
|
160
|
+
}
|
|
161
|
+
getInitializeState(currentDate, isMultiSelect) {
|
|
162
|
+
let end;
|
|
163
|
+
let start;
|
|
164
|
+
let generateDateValue;
|
|
165
|
+
if (!currentDate) {
|
|
166
|
+
const dayjsStart = dayjs();
|
|
167
|
+
start = dayjsStart.startOf("day").valueOf();
|
|
168
|
+
generateDateValue = dayjsStart.startOf("month").valueOf();
|
|
169
|
+
return {
|
|
170
|
+
generateDate: generateDateValue,
|
|
171
|
+
selectedDate: {
|
|
172
|
+
start: ""
|
|
186
173
|
}
|
|
187
|
-
|
|
188
|
-
const dayjsStart = dayjs(currentDate);
|
|
189
|
-
start = dayjsStart.startOf('day').valueOf();
|
|
190
|
-
generateDateValue = dayjsStart.startOf('month').valueOf();
|
|
191
|
-
end = start;
|
|
192
|
-
}
|
|
193
|
-
return {
|
|
194
|
-
generateDate: generateDateValue,
|
|
195
|
-
selectedDate: this.getSelectedDate(start, end)
|
|
196
|
-
};
|
|
174
|
+
};
|
|
197
175
|
}
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
176
|
+
if (isMultiSelect) {
|
|
177
|
+
const { start: cStart, end: cEnd } = currentDate;
|
|
178
|
+
const dayjsStart = dayjs(cStart);
|
|
179
|
+
start = dayjsStart.startOf("day").valueOf();
|
|
180
|
+
generateDateValue = dayjsStart.startOf("month").valueOf();
|
|
181
|
+
end = cEnd ? dayjs(cEnd).startOf("day").valueOf() : start;
|
|
182
|
+
} else {
|
|
183
|
+
const dayjsStart = dayjs(currentDate);
|
|
184
|
+
start = dayjsStart.startOf("day").valueOf();
|
|
185
|
+
generateDateValue = dayjsStart.startOf("month").valueOf();
|
|
186
|
+
end = start;
|
|
204
187
|
}
|
|
188
|
+
return {
|
|
189
|
+
generateDate: generateDateValue,
|
|
190
|
+
selectedDate: this.getSelectedDate(start, end)
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
render() {
|
|
194
|
+
const { generateDate, selectedDate } = this.state;
|
|
195
|
+
const {
|
|
196
|
+
validDates,
|
|
197
|
+
marks,
|
|
198
|
+
format,
|
|
199
|
+
minDate,
|
|
200
|
+
maxDate,
|
|
201
|
+
isSwiper,
|
|
202
|
+
className,
|
|
203
|
+
hideArrow,
|
|
204
|
+
isVertical,
|
|
205
|
+
monthFormat,
|
|
206
|
+
selectedDates
|
|
207
|
+
} = this.props;
|
|
208
|
+
return /* @__PURE__ */ React.createElement(View, { className: classnames("at-calendar", className) }, /* @__PURE__ */ React.createElement(
|
|
209
|
+
AtCalendarController,
|
|
210
|
+
{
|
|
211
|
+
minDate,
|
|
212
|
+
maxDate,
|
|
213
|
+
hideArrow,
|
|
214
|
+
monthFormat,
|
|
215
|
+
generateDate,
|
|
216
|
+
onPreMonth: this.handleClickPreMonth,
|
|
217
|
+
onNextMonth: this.handleClickNextMonth,
|
|
218
|
+
onSelectDate: this.handleSelectDate
|
|
219
|
+
}
|
|
220
|
+
), /* @__PURE__ */ React.createElement(
|
|
221
|
+
AtCalendarBody,
|
|
222
|
+
{
|
|
223
|
+
validDates,
|
|
224
|
+
marks,
|
|
225
|
+
format,
|
|
226
|
+
minDate,
|
|
227
|
+
maxDate,
|
|
228
|
+
isSwiper,
|
|
229
|
+
isVertical,
|
|
230
|
+
selectedDate,
|
|
231
|
+
selectedDates,
|
|
232
|
+
generateDate,
|
|
233
|
+
onDayClick: this.handleDayClick,
|
|
234
|
+
onSwipeMonth: this.setMonth,
|
|
235
|
+
onLongClick: this.handleDayLongClick
|
|
236
|
+
}
|
|
237
|
+
));
|
|
238
|
+
}
|
|
205
239
|
}
|
|
206
240
|
AtCalendar.defaultProps = defaultProps;
|
|
241
|
+
export {
|
|
242
|
+
AtCalendar as default
|
|
243
|
+
};
|
|
207
244
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/calendar/index.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/calendar/index.tsx"],"sourcesContent":["import classnames from 'classnames'\nimport dayjs, { Dayjs } from 'dayjs'\nimport React from 'react'\nimport { View } from '@tarojs/components'\nimport { BaseEventOrig } from '@tarojs/components/types/common'\nimport {\n AtCalendarDefaultProps,\n AtCalendarProps,\n AtCalendarPropsWithDefaults,\n AtCalendarState,\n Calendar\n} from '../../../types/calendar'\nimport AtCalendarBody from './body/index'\nimport AtCalendarController from './controller/index'\n\nconst defaultProps: AtCalendarDefaultProps = {\n validDates: [],\n marks: [],\n isSwiper: true,\n hideArrow: false,\n isVertical: false,\n selectedDates: [],\n isMultiSelect: false,\n format: 'YYYY-MM-DD',\n currentDate: Date.now(),\n monthFormat: 'YYYY年MM月'\n}\n\nexport default class AtCalendar extends React.Component<\n AtCalendarProps,\n Readonly<AtCalendarState>\n> {\n static defaultProps: AtCalendarDefaultProps = defaultProps\n\n public constructor(props: AtCalendarProps) {\n super(props)\n\n const { currentDate, isMultiSelect } = props as AtCalendarPropsWithDefaults\n\n this.state = this.getInitializeState(currentDate, isMultiSelect)\n }\n\n public UNSAFE_componentWillReceiveProps(nextProps: AtCalendarProps): void {\n const { currentDate, isMultiSelect } = nextProps\n if (!currentDate || currentDate === this.props.currentDate) return\n\n if (isMultiSelect && this.props.isMultiSelect) {\n const { start, end } = currentDate as Calendar.SelectedDate\n const { start: preStart, end: preEnd } = this.props\n .currentDate as Calendar.SelectedDate\n\n if (start === preStart && preEnd === end) {\n return\n }\n }\n\n const stateValue: AtCalendarState = this.getInitializeState(\n currentDate,\n isMultiSelect\n )\n\n this.setState(stateValue)\n }\n\n private getSingleSelectdState = (value: Dayjs): Partial<AtCalendarState> => {\n const { generateDate } = this.state\n\n const stateValue: Partial<AtCalendarState> = {\n selectedDate: this.getSelectedDate(value.valueOf())\n }\n\n const dayjsGenerateDate: Dayjs = value.startOf('month')\n const generateDateValue: number = dayjsGenerateDate.valueOf()\n\n if (generateDateValue !== generateDate) {\n this.triggerChangeDate(dayjsGenerateDate)\n stateValue.generateDate = generateDateValue\n }\n\n return stateValue\n }\n\n private getMultiSelectedState = (\n value: Dayjs\n ): Pick<AtCalendarState, 'selectedDate'> => {\n const { selectedDate } = this.state\n const { end, start } = selectedDate\n\n const valueUnix: number = value.valueOf()\n const state: Pick<AtCalendarState, 'selectedDate'> = {\n selectedDate\n }\n\n if (end) {\n state.selectedDate = this.getSelectedDate(valueUnix, 0)\n } else {\n state.selectedDate.end = Math.max(valueUnix, +start)\n state.selectedDate.start = Math.min(valueUnix, +start)\n }\n\n return state\n }\n\n private getSelectedDate = (\n start: number,\n end?: number\n ): Calendar.SelectedDate => {\n const stateValue: Calendar.SelectedDate = {\n start,\n end: start\n }\n\n if (typeof end !== 'undefined') {\n stateValue.end = end\n }\n\n return stateValue\n }\n\n private getInitializeState(\n currentDate: Calendar.DateArg | Calendar.SelectedDate,\n isMultiSelect?: boolean\n ): AtCalendarState {\n let end: number\n let start: number\n let generateDateValue: number\n\n if (!currentDate) {\n const dayjsStart = dayjs()\n start = dayjsStart.startOf('day').valueOf()\n generateDateValue = dayjsStart.startOf('month').valueOf()\n return {\n generateDate: generateDateValue,\n selectedDate: {\n start: ''\n }\n }\n }\n\n if (isMultiSelect) {\n const { start: cStart, end: cEnd } = currentDate as Calendar.SelectedDate\n\n const dayjsStart = dayjs(cStart)\n\n start = dayjsStart.startOf('day').valueOf()\n generateDateValue = dayjsStart.startOf('month').valueOf()\n\n end = cEnd ? dayjs(cEnd).startOf('day').valueOf() : start\n } else {\n const dayjsStart = dayjs(currentDate as Calendar.DateArg)\n\n start = dayjsStart.startOf('day').valueOf()\n generateDateValue = dayjsStart.startOf('month').valueOf()\n\n end = start\n }\n\n return {\n generateDate: generateDateValue,\n selectedDate: this.getSelectedDate(start, end)\n }\n }\n\n private triggerChangeDate = (value: Dayjs): void => {\n const { format } = this.props\n\n if (typeof this.props.onMonthChange !== 'function') return\n\n this.props.onMonthChange(value.format(format))\n }\n\n private setMonth = (vectorCount: number): void => {\n const { format } = this.props\n const { generateDate } = this.state\n\n const _generateDate: Dayjs = dayjs(generateDate).add(vectorCount, 'month')\n this.setState({\n generateDate: _generateDate.valueOf()\n })\n\n if (vectorCount && typeof this.props.onMonthChange === 'function') {\n this.props.onMonthChange(_generateDate.format(format))\n }\n }\n\n private handleClickPreMonth = (isMinMonth?: boolean): void => {\n if (isMinMonth === true) {\n return\n }\n\n this.setMonth(-1)\n\n if (typeof this.props.onClickPreMonth === 'function') {\n this.props.onClickPreMonth()\n }\n }\n\n private handleClickNextMonth = (isMaxMonth?: boolean): void => {\n if (isMaxMonth === true) {\n return\n }\n\n this.setMonth(1)\n\n if (typeof this.props.onClickNextMonth === 'function') {\n this.props.onClickNextMonth()\n }\n }\n\n // picker 选择时间改变时触发\n private handleSelectDate = (e: BaseEventOrig<{ value: string }>): void => {\n const { value } = e.detail\n\n const _generateDate: Dayjs = dayjs(value)\n const _generateDateValue: number = _generateDate.valueOf()\n\n if (this.state.generateDate === _generateDateValue) return\n\n this.triggerChangeDate(_generateDate)\n this.setState({\n generateDate: _generateDateValue\n })\n }\n\n private handleDayClick = (item: Calendar.Item): void => {\n const { isMultiSelect } = this.props\n const { isDisabled, value } = item\n\n if (isDisabled) return\n\n const dayjsDate: Dayjs = dayjs(value)\n\n let stateValue: Partial<AtCalendarState> = {}\n\n if (isMultiSelect) {\n stateValue = this.getMultiSelectedState(dayjsDate)\n } else {\n stateValue = this.getSingleSelectdState(dayjsDate)\n }\n\n this.setState(stateValue as AtCalendarState, () => {\n this.handleSelectedDate()\n })\n\n if (typeof this.props.onDayClick === 'function') {\n this.props.onDayClick({ value: item.value })\n }\n }\n\n private handleSelectedDate = (): void => {\n const selectDate = this.state.selectedDate\n if (typeof this.props.onSelectDate === 'function') {\n const info: Calendar.SelectedDate = {\n start: dayjs(selectDate.start).format(this.props.format)\n }\n\n if (selectDate.end) {\n info.end = dayjs(selectDate.end).format(this.props.format)\n }\n\n this.props.onSelectDate({\n value: info\n })\n }\n }\n\n private handleDayLongClick = (item: Calendar.Item): void => {\n if (typeof this.props.onDayLongClick === 'function') {\n this.props.onDayLongClick({ value: item.value })\n }\n }\n\n public render(): JSX.Element {\n const { generateDate, selectedDate } = this.state\n const {\n validDates,\n marks,\n format,\n minDate,\n maxDate,\n isSwiper,\n className,\n hideArrow,\n isVertical,\n monthFormat,\n selectedDates\n } = this.props as AtCalendarPropsWithDefaults\n\n return (\n <View className={classnames('at-calendar', className)}>\n <AtCalendarController\n minDate={minDate}\n maxDate={maxDate}\n hideArrow={hideArrow}\n monthFormat={monthFormat}\n generateDate={generateDate}\n onPreMonth={this.handleClickPreMonth}\n onNextMonth={this.handleClickNextMonth}\n onSelectDate={this.handleSelectDate}\n />\n <AtCalendarBody\n validDates={validDates}\n marks={marks}\n format={format}\n minDate={minDate}\n maxDate={maxDate}\n isSwiper={isSwiper}\n isVertical={isVertical}\n selectedDate={selectedDate}\n selectedDates={selectedDates}\n generateDate={generateDate}\n onDayClick={this.handleDayClick}\n onSwipeMonth={this.setMonth}\n onLongClick={this.handleDayLongClick}\n />\n </View>\n )\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Calendar } from '../../../../../types/calendar';
|
|
3
|
+
export interface Props {
|
|
4
|
+
list: Calendar.List<Calendar.Item>;
|
|
5
|
+
onClick?: (item: Calendar.Item) => void;
|
|
6
|
+
onLongClick?: (item: Calendar.Item) => void;
|
|
7
|
+
}
|
|
8
|
+
export default class AtCalendarList extends React.Component<Props> {
|
|
9
|
+
private handleClick;
|
|
10
|
+
private handleLongClick;
|
|
11
|
+
render(): JSX.Element | null;
|
|
12
|
+
}
|
|
@@ -1,43 +1,54 @@
|
|
|
1
|
-
import classnames from
|
|
2
|
-
import React from
|
|
3
|
-
import { Text, View } from
|
|
4
|
-
import * as constant from
|
|
1
|
+
import classnames from "classnames";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { Text, View } from "@tarojs/components";
|
|
4
|
+
import * as constant from "../../common/constant";
|
|
5
5
|
const MAP = {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
[constant.TYPE_PRE_MONTH]: "pre",
|
|
7
|
+
[constant.TYPE_NOW_MONTH]: "now",
|
|
8
|
+
[constant.TYPE_NEXT_MONTH]: "next"
|
|
9
9
|
};
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
10
|
+
class AtCalendarList extends React.Component {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this.handleClick = (item) => {
|
|
14
|
+
if (typeof this.props.onClick === "function") {
|
|
15
|
+
this.props.onClick(item);
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
this.handleLongClick = (item) => {
|
|
19
|
+
if (typeof this.props.onLongClick === "function") {
|
|
20
|
+
this.props.onLongClick(item);
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
render() {
|
|
25
|
+
const { list } = this.props;
|
|
26
|
+
if (!list || list.length === 0) return null;
|
|
27
|
+
return /* @__PURE__ */ React.createElement(View, { className: "at-calendar__list flex" }, list.map((item) => /* @__PURE__ */ React.createElement(
|
|
28
|
+
View,
|
|
29
|
+
{
|
|
30
|
+
key: `list-item-${item.value}`,
|
|
31
|
+
onClick: this.handleClick.bind(this, item),
|
|
32
|
+
onLongPress: this.handleLongClick.bind(this, item),
|
|
33
|
+
className: classnames(
|
|
34
|
+
"flex__item",
|
|
35
|
+
`flex__item--${MAP[item.type]}`,
|
|
36
|
+
{
|
|
37
|
+
"flex__item--today": item.isToday,
|
|
38
|
+
"flex__item--active": item.isActive,
|
|
39
|
+
"flex__item--selected": item.isSelected,
|
|
40
|
+
"flex__item--selected-head": item.isSelectedHead,
|
|
41
|
+
"flex__item--selected-tail": item.isSelectedTail,
|
|
42
|
+
"flex__item--blur": item.isDisabled || item.type === constant.TYPE_PRE_MONTH || item.type === constant.TYPE_NEXT_MONTH
|
|
43
|
+
}
|
|
44
|
+
)
|
|
45
|
+
},
|
|
46
|
+
/* @__PURE__ */ React.createElement(View, { className: "flex__item-container" }, /* @__PURE__ */ React.createElement(View, { className: "container-text" }, item.text)),
|
|
47
|
+
/* @__PURE__ */ React.createElement(View, { className: "flex__item-extra extra" }, item.marks && item.marks.length > 0 ? /* @__PURE__ */ React.createElement(View, { className: "extra-marks" }, item.marks.map((mark, key) => /* @__PURE__ */ React.createElement(Text, { key, className: "mark" }, mark.value))) : null)
|
|
48
|
+
)));
|
|
49
|
+
}
|
|
42
50
|
}
|
|
51
|
+
export {
|
|
52
|
+
AtCalendarList as default
|
|
53
|
+
};
|
|
43
54
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../../../../../src/components/calendar/ui/date-list/index.tsx"],"sourcesContent":["import classnames from 'classnames'\nimport React from 'react'\nimport { Text, View } from '@tarojs/components'\nimport { Calendar } from '../../../../../types/calendar'\nimport * as constant from '../../common/constant'\n\nconst MAP: { [key: number]: string } = {\n [constant.TYPE_PRE_MONTH]: 'pre',\n [constant.TYPE_NOW_MONTH]: 'now',\n [constant.TYPE_NEXT_MONTH]: 'next'\n}\n\nexport interface Props {\n list: Calendar.List<Calendar.Item>\n\n onClick?: (item: Calendar.Item) => void\n\n onLongClick?: (item: Calendar.Item) => void\n}\n\nexport default class AtCalendarList extends React.Component<Props> {\n private handleClick = (item: Calendar.Item): void => {\n if (typeof this.props.onClick === 'function') {\n this.props.onClick(item)\n }\n }\n\n private handleLongClick = (item: Calendar.Item): void => {\n if (typeof this.props.onLongClick === 'function') {\n this.props.onLongClick(item)\n }\n }\n\n public render(): JSX.Element | null {\n const { list } = this.props\n if (!list || list.length === 0) return null\n\n return (\n <View className='at-calendar__list flex'>\n {list.map((item: Calendar.Item) => (\n <View\n key={`list-item-${item.value}`}\n onClick={this.handleClick.bind(this, item)}\n onLongPress={this.handleLongClick.bind(this, item)}\n className={classnames(\n 'flex__item',\n `flex__item--${MAP[item.type]}`,\n {\n 'flex__item--today': item.isToday,\n 'flex__item--active': item.isActive,\n 'flex__item--selected': item.isSelected,\n 'flex__item--selected-head': item.isSelectedHead,\n 'flex__item--selected-tail': item.isSelectedTail,\n 'flex__item--blur':\n item.isDisabled ||\n item.type === constant.TYPE_PRE_MONTH ||\n item.type === constant.TYPE_NEXT_MONTH\n }\n )}\n >\n <View className='flex__item-container'>\n <View className='container-text'>{item.text}</View>\n </View>\n <View className='flex__item-extra extra'>\n {item.marks && item.marks.length > 0 ? (\n <View className='extra-marks'>\n {item.marks.map((mark, key) => (\n <Text key={key} className='mark'>\n {mark.value}\n </Text>\n ))}\n </View>\n ) : null}\n </View>\n </View>\n ))}\n </View>\n )\n }\n}\n"],"mappings":"AAAA,OAAO,gBAAgB;AACvB,OAAO,WAAW;AAClB,SAAS,MAAM,YAAY;AAE3B,YAAY,cAAc;AAE1B,MAAM,MAAiC;AAAA,EACrC,CAAC,SAAS,cAAc,GAAG;AAAA,EAC3B,CAAC,SAAS,cAAc,GAAG;AAAA,EAC3B,CAAC,SAAS,eAAe,GAAG;AAC9B;AAUA,MAAO,uBAAqC,MAAM,UAAiB;AAAA,EAAnE;AAAA;AACE,SAAQ,cAAc,CAAC,SAA8B;AACnD,UAAI,OAAO,KAAK,MAAM,YAAY,YAAY;AAC5C,aAAK,MAAM,QAAQ,IAAI;AAAA,MACzB;AAAA,IACF;AAEA,SAAQ,kBAAkB,CAAC,SAA8B;AACvD,UAAI,OAAO,KAAK,MAAM,gBAAgB,YAAY;AAChD,aAAK,MAAM,YAAY,IAAI;AAAA,MAC7B;AAAA,IACF;AAAA;AAAA,EAEO,SAA6B;AAClC,UAAM,EAAE,KAAK,IAAI,KAAK;AACtB,QAAI,CAAC,QAAQ,KAAK,WAAW,EAAG,QAAO;AAEvC,WACE,oCAAC,QAAK,WAAU,4BACb,KAAK,IAAI,CAAC,SACT;AAAA,MAAC;AAAA;AAAA,QACC,KAAK,aAAa,KAAK,KAAK;AAAA,QAC5B,SAAS,KAAK,YAAY,KAAK,MAAM,IAAI;AAAA,QACzC,aAAa,KAAK,gBAAgB,KAAK,MAAM,IAAI;AAAA,QACjD,WAAW;AAAA,UACT;AAAA,UACA,eAAe,IAAI,KAAK,IAAI,CAAC;AAAA,UAC7B;AAAA,YACE,qBAAqB,KAAK;AAAA,YAC1B,sBAAsB,KAAK;AAAA,YAC3B,wBAAwB,KAAK;AAAA,YAC7B,6BAA6B,KAAK;AAAA,YAClC,6BAA6B,KAAK;AAAA,YAClC,oBACE,KAAK,cACL,KAAK,SAAS,SAAS,kBACvB,KAAK,SAAS,SAAS;AAAA,UAC3B;AAAA,QACF;AAAA;AAAA,MAEA,oCAAC,QAAK,WAAU,0BACd,oCAAC,QAAK,WAAU,oBAAkB,KAAK,IAAK,CAC9C;AAAA,MACA,oCAAC,QAAK,WAAU,4BACb,KAAK,SAAS,KAAK,MAAM,SAAS,IACjC,oCAAC,QAAK,WAAU,iBACb,KAAK,MAAM,IAAI,CAAC,MAAM,QACrB,oCAAC,QAAK,KAAU,WAAU,UACvB,KAAK,KACR,CACD,CACH,IACE,IACN;AAAA,IACF,CACD,CACH;AAAA,EAEJ;AACF;","names":[]}
|