taro-ui 3.3.1 → 3.3.3
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/dist/common/component.d.ts +10 -0
- package/dist/common/component.js +32 -0
- package/dist/common/component.js.map +1 -0
- package/dist/common/utils.d.ts +41 -0
- package/dist/common/utils.js +203 -0
- package/dist/common/utils.js.map +1 -0
- package/dist/components/accordion/index.d.ts +14 -0
- package/dist/components/accordion/index.js +121 -0
- package/dist/components/accordion/index.js.map +1 -0
- package/dist/components/action-sheet/body/index.d.ts +5 -0
- package/dist/components/action-sheet/body/index.js +13 -0
- package/dist/components/action-sheet/body/index.js.map +1 -0
- package/dist/components/action-sheet/body/item/index.d.ts +9 -0
- package/dist/components/action-sheet/body/item/index.js +25 -0
- package/dist/components/action-sheet/body/item/index.js.map +1 -0
- package/dist/components/action-sheet/footer/index.d.ts +9 -0
- package/dist/components/action-sheet/footer/index.js +28 -0
- package/dist/components/action-sheet/footer/index.js.map +1 -0
- package/dist/components/action-sheet/header/index.d.ts +5 -0
- package/dist/components/action-sheet/header/index.js +16 -0
- package/dist/components/action-sheet/header/index.js.map +1 -0
- package/dist/components/action-sheet/index.d.ts +14 -0
- package/dist/components/action-sheet/index.js +76 -0
- package/dist/components/action-sheet/index.js.map +1 -0
- package/dist/components/activity-indicator/index.d.ts +8 -0
- package/dist/components/activity-indicator/index.js +39 -0
- package/dist/components/activity-indicator/index.js.map +1 -0
- package/dist/components/avatar/index.d.ts +9 -0
- package/dist/components/avatar/index.js +68 -0
- package/dist/components/avatar/index.js.map +1 -0
- package/dist/components/badge/index.d.ts +10 -0
- package/dist/components/badge/index.js +51 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/button/index.d.ts +15 -0
- package/dist/components/button/index.js +177 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/calendar/body/index.d.ts +26 -0
- package/dist/components/calendar/body/index.js +289 -0
- package/dist/components/calendar/body/index.js.map +1 -0
- package/dist/components/calendar/common/constant.d.ts +3 -0
- package/dist/components/calendar/common/constant.js +9 -0
- package/dist/components/calendar/common/constant.js.map +1 -0
- package/dist/components/calendar/common/helper.d.ts +4 -0
- package/dist/components/calendar/common/helper.js +84 -0
- package/dist/components/calendar/common/helper.js.map +1 -0
- package/dist/components/calendar/common/plugins.d.ts +11 -0
- package/dist/components/calendar/common/plugins.js +55 -0
- package/dist/components/calendar/common/plugins.js.map +1 -0
- package/dist/components/calendar/controller/index.d.ts +5 -0
- package/dist/components/calendar/controller/index.js +51 -0
- package/dist/components/calendar/controller/index.js.map +1 -0
- package/dist/components/calendar/index.d.ts +20 -0
- package/dist/components/calendar/index.js +244 -0
- package/dist/components/calendar/index.js.map +1 -0
- package/dist/components/calendar/ui/date-list/index.d.ts +12 -0
- package/dist/components/calendar/ui/date-list/index.js +54 -0
- package/dist/components/calendar/ui/date-list/index.js.map +1 -0
- package/dist/components/calendar/ui/day-list/index.d.ts +4 -0
- package/dist/components/calendar/ui/day-list/index.js +11 -0
- package/dist/components/calendar/ui/day-list/index.js.map +1 -0
- package/dist/components/card/index.d.ts +9 -0
- package/dist/components/card/index.js +80 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/checkbox/index.d.ts +9 -0
- package/dist/components/checkbox/index.js +59 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/countdown/index.d.ts +20 -0
- package/dist/components/countdown/index.js +152 -0
- package/dist/components/countdown/index.js.map +1 -0
- package/dist/components/countdown/item/index.d.ts +9 -0
- package/dist/components/countdown/item/index.js +24 -0
- package/dist/components/countdown/item/index.js.map +1 -0
- package/dist/components/curtain/index.d.ts +10 -0
- package/dist/components/curtain/index.js +62 -0
- package/dist/components/curtain/index.js.map +1 -0
- package/dist/components/divider/index.d.ts +8 -0
- package/dist/components/divider/index.js +57 -0
- package/dist/components/divider/index.js.map +1 -0
- package/dist/components/drawer/index.d.ts +16 -0
- package/dist/components/drawer/index.js +114 -0
- package/dist/components/drawer/index.js.map +1 -0
- package/dist/components/fab/index.d.ts +9 -0
- package/dist/components/fab/index.js +29 -0
- package/dist/components/fab/index.js.map +1 -0
- package/dist/components/flex/index.d.ts +7 -0
- package/dist/components/flex/index.js +41 -0
- package/dist/components/flex/index.js.map +1 -0
- package/dist/components/flex/item/index.d.ts +7 -0
- package/dist/components/flex/item/index.js +34 -0
- package/dist/components/flex/item/index.js.map +1 -0
- package/dist/components/float-layout/index.d.ts +13 -0
- package/dist/components/float-layout/index.js +104 -0
- package/dist/components/float-layout/index.js.map +1 -0
- package/dist/components/form/index.d.ts +10 -0
- package/dist/components/form/index.js +43 -0
- package/dist/components/form/index.js.map +1 -0
- package/dist/components/grid/index.d.ts +9 -0
- package/dist/components/grid/index.js +101 -0
- package/dist/components/grid/index.js.map +1 -0
- package/dist/components/icon/index.d.ts +9 -0
- package/dist/components/icon/index.js +54 -0
- package/dist/components/icon/index.js.map +1 -0
- package/dist/components/image-picker/index.d.ts +11 -0
- package/dist/components/image-picker/index.js +164 -0
- package/dist/components/image-picker/index.js.map +1 -0
- package/dist/components/indexes/index.d.ts +29 -0
- package/dist/components/indexes/index.js +272 -0
- package/dist/components/indexes/index.js.map +1 -0
- package/dist/components/input/index.d.ts +17 -0
- package/dist/components/input/index.js +232 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/input-number/index.d.ts +13 -0
- package/dist/components/input-number/index.js +193 -0
- package/dist/components/input-number/index.js.map +1 -0
- package/dist/components/list/index.d.ts +8 -0
- package/dist/components/list/index.js +26 -0
- package/dist/components/list/index.js.map +1 -0
- package/dist/components/list/item/index.d.ts +11 -0
- package/dist/components/list/item/index.js +152 -0
- package/dist/components/list/item/index.js.map +1 -0
- package/dist/components/load-more/index.d.ts +9 -0
- package/dist/components/load-more/index.js +72 -0
- package/dist/components/load-more/index.js.map +1 -0
- package/dist/components/loading/index.d.ts +12 -0
- package/dist/components/loading/index.js +32 -0
- package/dist/components/loading/index.js.map +1 -0
- package/dist/components/message/index.d.ts +15 -0
- package/dist/components/message/index.js +78 -0
- package/dist/components/message/index.js.map +1 -0
- package/dist/components/modal/action/index.d.ts +8 -0
- package/dist/components/modal/action/index.js +26 -0
- package/dist/components/modal/action/index.js.map +1 -0
- package/dist/components/modal/content/index.d.ts +5 -0
- package/dist/components/modal/content/index.js +13 -0
- package/dist/components/modal/content/index.js.map +1 -0
- package/dist/components/modal/header/index.d.ts +5 -0
- package/dist/components/modal/header/index.js +13 -0
- package/dist/components/modal/header/index.js.map +1 -0
- package/dist/components/modal/index.d.ts +15 -0
- package/dist/components/modal/index.js +106 -0
- package/dist/components/modal/index.js.map +1 -0
- package/dist/components/nav-bar/index.d.ts +12 -0
- package/dist/components/nav-bar/index.js +217 -0
- package/dist/components/nav-bar/index.js.map +1 -0
- package/dist/components/noticebar/index.d.ts +16 -0
- package/dist/components/noticebar/index.js +186 -0
- package/dist/components/noticebar/index.js.map +1 -0
- package/dist/components/pagination/index.d.ts +12 -0
- package/dist/components/pagination/index.js +146 -0
- package/dist/components/pagination/index.js.map +1 -0
- package/dist/components/progress/index.d.ts +7 -0
- package/dist/components/progress/index.js +53 -0
- package/dist/components/progress/index.js.map +1 -0
- package/dist/components/radio/index.d.ts +9 -0
- package/dist/components/radio/index.js +54 -0
- package/dist/components/radio/index.js.map +1 -0
- package/dist/components/range/index.d.ts +22 -0
- package/dist/components/range/index.js +207 -0
- package/dist/components/range/index.js.map +1 -0
- package/dist/components/rate/index.d.ts +9 -0
- package/dist/components/rate/index.js +82 -0
- package/dist/components/rate/index.js.map +1 -0
- package/dist/components/search-bar/index.d.ts +16 -0
- package/dist/components/search-bar/index.js +176 -0
- package/dist/components/search-bar/index.js.map +1 -0
- package/dist/components/segmented-control/index.d.ts +9 -0
- package/dist/components/segmented-control/index.js +84 -0
- package/dist/components/segmented-control/index.js.map +1 -0
- package/dist/components/slider/index.d.ts +13 -0
- package/dist/components/slider/index.js +115 -0
- package/dist/components/slider/index.js.map +1 -0
- package/dist/components/steps/index.d.ts +9 -0
- package/dist/components/steps/index.js +67 -0
- package/dist/components/steps/index.js.map +1 -0
- package/dist/components/swipe-action/index.d.ts +27 -0
- package/dist/components/swipe-action/index.js +220 -0
- package/dist/components/swipe-action/index.js.map +1 -0
- package/dist/components/swipe-action/options/index.d.ts +5 -0
- package/dist/components/swipe-action/options/index.js +24 -0
- package/dist/components/swipe-action/options/index.js.map +1 -0
- package/dist/components/switch/index.d.ts +9 -0
- package/dist/components/switch/index.js +59 -0
- package/dist/components/switch/index.js.map +1 -0
- package/dist/components/tab-bar/index.d.ts +9 -0
- package/dist/components/tab-bar/index.js +170 -0
- package/dist/components/tab-bar/index.js.map +1 -0
- package/dist/components/tabs/index.d.ts +24 -0
- package/dist/components/tabs/index.js +219 -0
- package/dist/components/tabs/index.js.map +1 -0
- package/dist/components/tabs-pane/index.d.ts +8 -0
- package/dist/components/tabs-pane/index.js +43 -0
- package/dist/components/tabs-pane/index.js.map +1 -0
- package/dist/components/tag/index.d.ts +9 -0
- package/dist/components/tag/index.js +75 -0
- package/dist/components/tag/index.js.map +1 -0
- package/dist/components/textarea/index.d.ts +13 -0
- package/dist/components/textarea/index.js +141 -0
- package/dist/components/textarea/index.js.map +1 -0
- package/dist/components/timeline/index.d.ts +8 -0
- package/dist/components/timeline/index.js +76 -0
- package/dist/components/timeline/index.js.map +1 -0
- package/dist/components/toast/img.json +8 -0
- package/dist/components/toast/index.d.ts +16 -0
- package/dist/components/toast/index.js +124 -0
- package/dist/components/toast/index.js.map +1 -0
- package/{lib/index.js → dist/index.d.ts} +0 -2
- package/dist/index.esm.js +6020 -8272
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +6104 -8332
- package/dist/index.js.map +1 -1
- package/dist/style/components/grid.scss +2 -2
- package/dist/style/components/index.scss +48 -48
- package/dist/style/components/list.scss +2 -2
- package/dist/style/index.css +11754 -0
- package/dist/style/index.css.map +1 -0
- package/dist/style/mixins/index.scss +13 -13
- package/dist/style/mixins/libs/shade.scss +4 -2
- package/dist/style/mixins/libs/tint.scss +4 -2
- package/dist/style/variables/default.scss +1 -1
- package/package.json +56 -33
- 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/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/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/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/lib/common/component.js +0 -33
- package/lib/common/component.js.map +0 -1
- package/lib/common/utils.js +0 -226
- package/lib/common/utils.js.map +0 -1
- package/lib/components/accordion/index.js +0 -116
- package/lib/components/accordion/index.js.map +0 -1
- package/lib/components/action-sheet/body/index.js +0 -10
- package/lib/components/action-sheet/body/index.js.map +0 -1
- package/lib/components/action-sheet/body/item/index.js +0 -22
- package/lib/components/action-sheet/body/item/index.js.map +0 -1
- package/lib/components/action-sheet/footer/index.js +0 -22
- package/lib/components/action-sheet/footer/index.js.map +0 -1
- package/lib/components/action-sheet/header/index.js +0 -10
- package/lib/components/action-sheet/header/index.js.map +0 -1
- package/lib/components/action-sheet/index.js +0 -71
- package/lib/components/action-sheet/index.js.map +0 -1
- package/lib/components/activity-indicator/index.js +0 -35
- package/lib/components/activity-indicator/index.js.map +0 -1
- package/lib/components/avatar/index.js +0 -64
- package/lib/components/avatar/index.js.map +0 -1
- package/lib/components/badge/index.js +0 -42
- package/lib/components/badge/index.js.map +0 -1
- package/lib/components/button/index.js +0 -125
- package/lib/components/button/index.js.map +0 -1
- package/lib/components/calendar/body/index.js +0 -193
- package/lib/components/calendar/body/index.js.map +0 -1
- package/lib/components/calendar/common/constant.js +0 -4
- package/lib/components/calendar/common/constant.js.map +0 -1
- package/lib/components/calendar/common/helper.js +0 -83
- package/lib/components/calendar/common/helper.js.map +0 -1
- package/lib/components/calendar/common/plugins.js +0 -71
- package/lib/components/calendar/common/plugins.js.map +0 -1
- package/lib/components/calendar/controller/index.js +0 -30
- package/lib/components/calendar/controller/index.js.map +0 -1
- package/lib/components/calendar/index.js +0 -207
- package/lib/components/calendar/index.js.map +0 -1
- package/lib/components/calendar/ui/date-list/index.js +0 -43
- package/lib/components/calendar/ui/date-list/index.js.map +0 -1
- package/lib/components/calendar/ui/day-list/index.js +0 -16
- package/lib/components/calendar/ui/day-list/index.js.map +0 -1
- package/lib/components/card/index.js +0 -59
- package/lib/components/card/index.js.map +0 -1
- package/lib/components/checkbox/index.js +0 -55
- package/lib/components/checkbox/index.js.map +0 -1
- package/lib/components/countdown/index.js +0 -137
- package/lib/components/countdown/index.js.map +0 -1
- package/lib/components/countdown/item/index.js +0 -24
- package/lib/components/countdown/item/index.js.map +0 -1
- package/lib/components/curtain/index.js +0 -45
- package/lib/components/curtain/index.js.map +0 -1
- package/lib/components/divider/index.js +0 -40
- package/lib/components/divider/index.js.map +0 -1
- package/lib/components/drawer/index.js +0 -93
- package/lib/components/drawer/index.js.map +0 -1
- package/lib/components/fab/index.js +0 -26
- package/lib/components/fab/index.js.map +0 -1
- package/lib/components/flex/index.js +0 -38
- package/lib/components/flex/index.js.map +0 -1
- package/lib/components/flex/item/index.js +0 -31
- package/lib/components/flex/item/index.js.map +0 -1
- package/lib/components/float-layout/index.js +0 -76
- package/lib/components/float-layout/index.js.map +0 -1
- package/lib/components/form/index.js +0 -30
- package/lib/components/form/index.js.map +0 -1
- package/lib/components/grid/index.js +0 -71
- package/lib/components/grid/index.js.map +0 -1
- package/lib/components/icon/index.js +0 -37
- package/lib/components/icon/index.js.map +0 -1
- package/lib/components/image-picker/index.js +0 -138
- package/lib/components/image-picker/index.js.map +0 -1
- package/lib/components/indexes/index.js +0 -215
- package/lib/components/indexes/index.js.map +0 -1
- package/lib/components/input/index.js +0 -168
- package/lib/components/input/index.js.map +0 -1
- package/lib/components/input-number/index.js +0 -165
- package/lib/components/input-number/index.js.map +0 -1
- package/lib/components/list/index.js +0 -19
- package/lib/components/list/index.js.map +0 -1
- package/lib/components/list/item/index.js +0 -105
- package/lib/components/list/item/index.js.map +0 -1
- package/lib/components/load-more/index.js +0 -48
- package/lib/components/load-more/index.js.map +0 -1
- package/lib/components/loading/index.js +0 -32
- package/lib/components/loading/index.js.map +0 -1
- package/lib/components/message/index.js +0 -69
- package/lib/components/message/index.js.map +0 -1
- package/lib/components/modal/action/index.js +0 -20
- package/lib/components/modal/action/index.js.map +0 -1
- package/lib/components/modal/content/index.js +0 -10
- package/lib/components/modal/content/index.js.map +0 -1
- package/lib/components/modal/header/index.js +0 -10
- package/lib/components/modal/header/index.js.map +0 -1
- package/lib/components/modal/index.js +0 -97
- package/lib/components/modal/index.js.map +0 -1
- package/lib/components/nav-bar/index.js +0 -105
- package/lib/components/nav-bar/index.js.map +0 -1
- package/lib/components/noticebar/index.js +0 -163
- package/lib/components/noticebar/index.js.map +0 -1
- package/lib/components/pagination/index.js +0 -115
- package/lib/components/pagination/index.js.map +0 -1
- package/lib/components/progress/index.js +0 -45
- package/lib/components/progress/index.js.map +0 -1
- package/lib/components/radio/index.js +0 -43
- package/lib/components/radio/index.js.map +0 -1
- package/lib/components/range/index.js +0 -152
- package/lib/components/range/index.js.map +0 -1
- package/lib/components/rate/index.js +0 -56
- package/lib/components/rate/index.js.map +0 -1
- package/lib/components/search-bar/index.js +0 -121
- package/lib/components/search-bar/index.js.map +0 -1
- package/lib/components/segmented-control/index.js +0 -59
- package/lib/components/segmented-control/index.js.map +0 -1
- package/lib/components/slider/index.js +0 -77
- package/lib/components/slider/index.js.map +0 -1
- package/lib/components/steps/index.js +0 -50
- package/lib/components/steps/index.js.map +0 -1
- package/lib/components/swipe-action/index.js +0 -171
- package/lib/components/swipe-action/index.js.map +0 -1
- package/lib/components/swipe-action/options/index.js +0 -10
- package/lib/components/swipe-action/options/index.js.map +0 -1
- package/lib/components/switch/index.js +0 -48
- package/lib/components/switch/index.js.map +0 -1
- package/lib/components/tab-bar/index.js +0 -96
- package/lib/components/tab-bar/index.js.map +0 -1
- package/lib/components/tabs/index.js +0 -190
- package/lib/components/tabs/index.js.map +0 -1
- package/lib/components/tabs-pane/index.js +0 -30
- package/lib/components/tabs-pane/index.js.map +0 -1
- package/lib/components/tag/index.js +0 -55
- package/lib/components/tag/index.js.map +0 -1
- package/lib/components/textarea/index.js +0 -95
- package/lib/components/textarea/index.js.map +0 -1
- package/lib/components/timeline/index.js +0 -53
- package/lib/components/timeline/index.js.map +0 -1
- package/lib/components/toast/img.json +0 -5
- package/lib/components/toast/index.js +0 -117
- package/lib/components/toast/index.js.map +0 -1
- package/lib/index.js.map +0 -1
- 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
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import classNames from "classnames";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { Image, Text, View } from "@tarojs/components";
|
|
5
|
+
import { mergeStyle } from "../../common/utils";
|
|
6
|
+
import AtBadge from "../badge/index";
|
|
7
|
+
class AtTabBar extends React.Component {
|
|
8
|
+
// constructor () {
|
|
9
|
+
// super(...arguments)
|
|
10
|
+
// this.state = {
|
|
11
|
+
// isIPhoneX: false
|
|
12
|
+
// }
|
|
13
|
+
// }
|
|
14
|
+
// componentDidMount () {
|
|
15
|
+
// const curEnv = Taro.getEnv()
|
|
16
|
+
// if (
|
|
17
|
+
// curEnv === Taro.ENV_TYPE.WEAPP &&
|
|
18
|
+
// Taro.getSystemInfoSync().model.indexOf('iPhone X') >= 0
|
|
19
|
+
// ) {
|
|
20
|
+
// this.setState({ isIPhoneX: true })
|
|
21
|
+
// }
|
|
22
|
+
// }
|
|
23
|
+
handleClick(index, event) {
|
|
24
|
+
this.props.onClick(index, event);
|
|
25
|
+
}
|
|
26
|
+
render() {
|
|
27
|
+
const {
|
|
28
|
+
customStyle = "",
|
|
29
|
+
className,
|
|
30
|
+
fixed,
|
|
31
|
+
backgroundColor,
|
|
32
|
+
tabList,
|
|
33
|
+
current,
|
|
34
|
+
color,
|
|
35
|
+
iconSize,
|
|
36
|
+
fontSize,
|
|
37
|
+
selectedColor
|
|
38
|
+
} = this.props;
|
|
39
|
+
const defaultStyle = {
|
|
40
|
+
color: color || ""
|
|
41
|
+
};
|
|
42
|
+
const selectedStyle = {
|
|
43
|
+
color: selectedColor || ""
|
|
44
|
+
};
|
|
45
|
+
const titleStyle = {
|
|
46
|
+
fontSize: fontSize ? `${fontSize}px` : ""
|
|
47
|
+
};
|
|
48
|
+
const rootStyle = {
|
|
49
|
+
backgroundColor: backgroundColor || ""
|
|
50
|
+
};
|
|
51
|
+
const imgStyle = {
|
|
52
|
+
width: `${iconSize}px`,
|
|
53
|
+
height: `${iconSize}px`
|
|
54
|
+
};
|
|
55
|
+
return /* @__PURE__ */ React.createElement(
|
|
56
|
+
View,
|
|
57
|
+
{
|
|
58
|
+
className: classNames(
|
|
59
|
+
{
|
|
60
|
+
"at-tab-bar": true,
|
|
61
|
+
"at-tab-bar--fixed": fixed
|
|
62
|
+
// 'at-tab-bar--ipx': isIPhoneX
|
|
63
|
+
},
|
|
64
|
+
className
|
|
65
|
+
),
|
|
66
|
+
style: mergeStyle(rootStyle, customStyle)
|
|
67
|
+
},
|
|
68
|
+
tabList.map((item, i) => /* @__PURE__ */ React.createElement(
|
|
69
|
+
View,
|
|
70
|
+
{
|
|
71
|
+
className: classNames("at-tab-bar__item", {
|
|
72
|
+
"at-tab-bar__item--active": current === i
|
|
73
|
+
}),
|
|
74
|
+
style: current === i ? selectedStyle : defaultStyle,
|
|
75
|
+
key: i,
|
|
76
|
+
onClick: this.handleClick.bind(this, i)
|
|
77
|
+
},
|
|
78
|
+
item.iconType ? /* @__PURE__ */ React.createElement(
|
|
79
|
+
AtBadge,
|
|
80
|
+
{
|
|
81
|
+
dot: !!item.dot,
|
|
82
|
+
value: item.text,
|
|
83
|
+
maxValue: Number(item.max)
|
|
84
|
+
},
|
|
85
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-tab-bar__icon" }, /* @__PURE__ */ React.createElement(
|
|
86
|
+
Text,
|
|
87
|
+
{
|
|
88
|
+
className: classNames(
|
|
89
|
+
`${item.iconPrefixClass || "at-icon"}`,
|
|
90
|
+
{
|
|
91
|
+
[`${item.iconPrefixClass || "at-icon"}-${item.selectedIconType}`]: current === i && item.selectedIconType,
|
|
92
|
+
[`${item.iconPrefixClass || "at-icon"}-${item.iconType}`]: !(current === i && item.selectedIconType)
|
|
93
|
+
}
|
|
94
|
+
),
|
|
95
|
+
style: {
|
|
96
|
+
color: current === i ? selectedColor : color,
|
|
97
|
+
fontSize: iconSize ? `${iconSize}px` : ""
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
))
|
|
101
|
+
) : null,
|
|
102
|
+
item.image ? /* @__PURE__ */ React.createElement(
|
|
103
|
+
AtBadge,
|
|
104
|
+
{
|
|
105
|
+
dot: !!item.dot,
|
|
106
|
+
value: item.text,
|
|
107
|
+
maxValue: Number(item.max)
|
|
108
|
+
},
|
|
109
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-tab-bar__icon" }, /* @__PURE__ */ React.createElement(
|
|
110
|
+
Image,
|
|
111
|
+
{
|
|
112
|
+
className: classNames("at-tab-bar__inner-img", {
|
|
113
|
+
"at-tab-bar__inner-img--inactive": current !== i
|
|
114
|
+
}),
|
|
115
|
+
mode: "widthFix",
|
|
116
|
+
src: item.selectedImage || item.image,
|
|
117
|
+
style: imgStyle
|
|
118
|
+
}
|
|
119
|
+
), /* @__PURE__ */ React.createElement(
|
|
120
|
+
Image,
|
|
121
|
+
{
|
|
122
|
+
className: classNames("at-tab-bar__inner-img", {
|
|
123
|
+
"at-tab-bar__inner-img--inactive": current === i
|
|
124
|
+
}),
|
|
125
|
+
mode: "widthFix",
|
|
126
|
+
src: item.image,
|
|
127
|
+
style: imgStyle
|
|
128
|
+
}
|
|
129
|
+
))
|
|
130
|
+
) : null,
|
|
131
|
+
/* @__PURE__ */ React.createElement(View, null, /* @__PURE__ */ React.createElement(
|
|
132
|
+
AtBadge,
|
|
133
|
+
{
|
|
134
|
+
dot: item.iconType || item.image ? false : !!item.dot,
|
|
135
|
+
value: item.iconType || item.image ? "" : item.text,
|
|
136
|
+
maxValue: item.iconType || item.image ? 0 : Number(item.max)
|
|
137
|
+
},
|
|
138
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-tab-bar__title", style: titleStyle }, item.title)
|
|
139
|
+
))
|
|
140
|
+
))
|
|
141
|
+
);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
AtTabBar.defaultProps = {
|
|
145
|
+
customStyle: "",
|
|
146
|
+
className: "",
|
|
147
|
+
fixed: false,
|
|
148
|
+
current: 0,
|
|
149
|
+
tabList: [],
|
|
150
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
151
|
+
onClick: () => {
|
|
152
|
+
}
|
|
153
|
+
};
|
|
154
|
+
AtTabBar.propTypes = {
|
|
155
|
+
customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
|
|
156
|
+
className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),
|
|
157
|
+
fixed: PropTypes.bool,
|
|
158
|
+
backgroundColor: PropTypes.string,
|
|
159
|
+
current: PropTypes.number,
|
|
160
|
+
iconSize: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
|
161
|
+
fontSize: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
|
162
|
+
color: PropTypes.string,
|
|
163
|
+
selectedColor: PropTypes.string,
|
|
164
|
+
tabList: PropTypes.array,
|
|
165
|
+
onClick: PropTypes.func
|
|
166
|
+
};
|
|
167
|
+
export {
|
|
168
|
+
AtTabBar as default
|
|
169
|
+
};
|
|
170
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/tab-bar/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport PropTypes, { InferProps } from 'prop-types'\nimport React from 'react'\nimport { Image, Text, View } from '@tarojs/components'\nimport { CommonEvent } from '@tarojs/components/types/common'\nimport { AtTabBarProps, TabItem } from '../../../types/tab-bar'\nimport { mergeStyle } from '../../common/utils'\nimport AtBadge from '../badge/index'\n\nexport default class AtTabBar extends React.Component<AtTabBarProps> {\n public static defaultProps: AtTabBarProps\n public static propTypes: InferProps<AtTabBarProps>\n\n // constructor () {\n // super(...arguments)\n // this.state = {\n // isIPhoneX: false\n // }\n // }\n\n // componentDidMount () {\n // const curEnv = Taro.getEnv()\n\n // if (\n // curEnv === Taro.ENV_TYPE.WEAPP &&\n // Taro.getSystemInfoSync().model.indexOf('iPhone X') >= 0\n // ) {\n // this.setState({ isIPhoneX: true })\n // }\n // }\n\n private handleClick(index: number, event: CommonEvent): void {\n this.props.onClick(index, event)\n }\n\n public render(): JSX.Element {\n const {\n customStyle = '',\n className,\n fixed,\n backgroundColor,\n tabList,\n current,\n color,\n iconSize,\n fontSize,\n selectedColor\n } = this.props\n // const { isIPhoneX } = this.state\n const defaultStyle = {\n color: color || ''\n }\n const selectedStyle = {\n color: selectedColor || ''\n }\n const titleStyle = {\n fontSize: fontSize ? `${fontSize}px` : ''\n }\n const rootStyle = {\n backgroundColor: backgroundColor || ''\n }\n const imgStyle = {\n width: `${iconSize}px`,\n height: `${iconSize}px`\n }\n\n return (\n <View\n className={classNames(\n {\n 'at-tab-bar': true,\n 'at-tab-bar--fixed': fixed\n // 'at-tab-bar--ipx': isIPhoneX\n },\n className\n )}\n style={mergeStyle(rootStyle, customStyle)}\n >\n {tabList.map((item: TabItem, i: number) => (\n <View\n className={classNames('at-tab-bar__item', {\n 'at-tab-bar__item--active': current === i\n })}\n style={current === i ? selectedStyle : defaultStyle}\n key={i}\n onClick={this.handleClick.bind(this, i)}\n >\n {item.iconType ? (\n <AtBadge\n dot={!!item.dot}\n value={item.text}\n maxValue={Number(item.max)}\n >\n <View className='at-tab-bar__icon'>\n <Text\n className={classNames(\n `${item.iconPrefixClass || 'at-icon'}`,\n {\n [`${item.iconPrefixClass || 'at-icon'}-${\n item.selectedIconType\n }`]: current === i && item.selectedIconType,\n [`${item.iconPrefixClass || 'at-icon'}-${\n item.iconType\n }`]: !(current === i && item.selectedIconType)\n }\n )}\n style={{\n color: current === i ? selectedColor : color,\n fontSize: iconSize ? `${iconSize}px` : ''\n }}\n ></Text>\n </View>\n </AtBadge>\n ) : null}\n\n {item.image ? (\n <AtBadge\n dot={!!item.dot}\n value={item.text}\n maxValue={Number(item.max)}\n >\n <View className='at-tab-bar__icon'>\n <Image\n className={classNames('at-tab-bar__inner-img', {\n 'at-tab-bar__inner-img--inactive': current !== i\n })}\n mode='widthFix'\n src={item.selectedImage || item.image}\n style={imgStyle}\n ></Image>\n <Image\n className={classNames('at-tab-bar__inner-img', {\n 'at-tab-bar__inner-img--inactive': current === i\n })}\n mode='widthFix'\n src={item.image}\n style={imgStyle}\n ></Image>\n </View>\n </AtBadge>\n ) : null}\n\n <View>\n <AtBadge\n dot={item.iconType || item.image ? false : !!item.dot}\n value={item.iconType || item.image ? '' : item.text}\n maxValue={item.iconType || item.image ? 0 : Number(item.max)}\n >\n <View className='at-tab-bar__title' style={titleStyle}>\n {item.title}\n </View>\n </AtBadge>\n </View>\n </View>\n ))}\n </View>\n )\n }\n}\n\nAtTabBar.defaultProps = {\n customStyle: '',\n className: '',\n fixed: false,\n current: 0,\n tabList: [],\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n onClick: (): void => {}\n}\n\nAtTabBar.propTypes = {\n customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),\n fixed: PropTypes.bool,\n backgroundColor: PropTypes.string,\n current: PropTypes.number,\n iconSize: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n fontSize: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n color: PropTypes.string,\n selectedColor: PropTypes.string,\n tabList: PropTypes.array,\n onClick: PropTypes.func\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtTabsProps, AtTabsState } from '../../../types/tabs';
|
|
4
|
+
export default class AtTabs extends React.Component<AtTabsProps, AtTabsState> {
|
|
5
|
+
static defaultProps: AtTabsProps;
|
|
6
|
+
static propTypes: InferProps<AtTabsProps>;
|
|
7
|
+
private _tabId;
|
|
8
|
+
private _touchDot;
|
|
9
|
+
private _timer;
|
|
10
|
+
private _interval;
|
|
11
|
+
private _isMoving;
|
|
12
|
+
private tabHeaderRef;
|
|
13
|
+
constructor(props: AtTabsProps);
|
|
14
|
+
private updateState;
|
|
15
|
+
private handleClick;
|
|
16
|
+
private handleTouchStart;
|
|
17
|
+
private handleTouchMove;
|
|
18
|
+
private handleTouchEnd;
|
|
19
|
+
private getTabHeaderRef;
|
|
20
|
+
UNSAFE_componentWillReceiveProps(nextProps: AtTabsProps): void;
|
|
21
|
+
componentDidMount(): void;
|
|
22
|
+
componentWillUnmount(): void;
|
|
23
|
+
render(): JSX.Element;
|
|
24
|
+
}
|
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import classNames from "classnames";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { ScrollView, View } from "@tarojs/components";
|
|
5
|
+
import Taro from "@tarojs/taro";
|
|
6
|
+
import { isTest, mergeStyle, uuid } from "../../common/utils";
|
|
7
|
+
const ENV = Taro.getEnv();
|
|
8
|
+
const MIN_DISTANCE = 100;
|
|
9
|
+
const MAX_INTERVAL = 10;
|
|
10
|
+
class AtTabs extends React.Component {
|
|
11
|
+
constructor(props) {
|
|
12
|
+
super(props);
|
|
13
|
+
this.updateState = (idx) => {
|
|
14
|
+
if (this.props.scroll) {
|
|
15
|
+
switch (ENV) {
|
|
16
|
+
case Taro.ENV_TYPE.WEAPP:
|
|
17
|
+
case Taro.ENV_TYPE.ALIPAY:
|
|
18
|
+
case Taro.ENV_TYPE.SWAN: {
|
|
19
|
+
const index = Math.max(idx - 1, 0);
|
|
20
|
+
this.setState({
|
|
21
|
+
_scrollIntoView: `tab${this._tabId}${index}`
|
|
22
|
+
});
|
|
23
|
+
break;
|
|
24
|
+
}
|
|
25
|
+
case Taro.ENV_TYPE.WEB: {
|
|
26
|
+
const index = Math.max(idx - 1, 0);
|
|
27
|
+
const prevTabItem = this.tabHeaderRef.children[index];
|
|
28
|
+
prevTabItem && this.setState({
|
|
29
|
+
_scrollTop: prevTabItem.offsetTop,
|
|
30
|
+
_scrollLeft: prevTabItem.offsetLeft
|
|
31
|
+
});
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
default: {
|
|
35
|
+
console.warn("AtTab \u7EC4\u4EF6\u5728\u8BE5\u73AF\u5883\u8FD8\u672A\u9002\u914D");
|
|
36
|
+
break;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
this.state = {
|
|
42
|
+
_scrollLeft: 0,
|
|
43
|
+
_scrollTop: 0,
|
|
44
|
+
_scrollIntoView: ""
|
|
45
|
+
};
|
|
46
|
+
this._tabId = isTest() ? "tabs-AOTU2018" : uuid();
|
|
47
|
+
this._touchDot = 0;
|
|
48
|
+
this._timer = null;
|
|
49
|
+
this._interval = 0;
|
|
50
|
+
this._isMoving = false;
|
|
51
|
+
}
|
|
52
|
+
handleClick(index, event) {
|
|
53
|
+
this.props.onClick(index, event);
|
|
54
|
+
}
|
|
55
|
+
handleTouchStart(e) {
|
|
56
|
+
const { swipeable, tabDirection } = this.props;
|
|
57
|
+
if (!swipeable || tabDirection === "vertical") return;
|
|
58
|
+
this._touchDot = e.touches[0].pageX;
|
|
59
|
+
this._timer = setInterval(() => {
|
|
60
|
+
this._interval++;
|
|
61
|
+
}, 100);
|
|
62
|
+
}
|
|
63
|
+
handleTouchMove(e) {
|
|
64
|
+
const { swipeable, tabDirection, current, tabList } = this.props;
|
|
65
|
+
if (!swipeable || tabDirection === "vertical") return;
|
|
66
|
+
const touchMove = e.touches[0].pageX;
|
|
67
|
+
const moveDistance = touchMove - this._touchDot;
|
|
68
|
+
const maxIndex = tabList.length;
|
|
69
|
+
if (!this._isMoving && this._interval < MAX_INTERVAL && this._touchDot > 20) {
|
|
70
|
+
if (current + 1 < maxIndex && moveDistance <= -MIN_DISTANCE) {
|
|
71
|
+
this._isMoving = true;
|
|
72
|
+
this.handleClick(current + 1, e);
|
|
73
|
+
} else if (current - 1 >= 0 && moveDistance >= MIN_DISTANCE) {
|
|
74
|
+
this._isMoving = true;
|
|
75
|
+
this.handleClick(current - 1, e);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
handleTouchEnd() {
|
|
80
|
+
const { swipeable, tabDirection } = this.props;
|
|
81
|
+
if (!swipeable || tabDirection === "vertical") return;
|
|
82
|
+
this._timer && clearInterval(this._timer);
|
|
83
|
+
this._interval = 0;
|
|
84
|
+
this._isMoving = false;
|
|
85
|
+
}
|
|
86
|
+
getTabHeaderRef() {
|
|
87
|
+
if (ENV === Taro.ENV_TYPE.WEB) {
|
|
88
|
+
this.tabHeaderRef = document.getElementById(this._tabId);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
92
|
+
if (nextProps.scroll !== this.props.scroll) {
|
|
93
|
+
this.getTabHeaderRef();
|
|
94
|
+
}
|
|
95
|
+
if (nextProps.current !== this.props.current) {
|
|
96
|
+
this.updateState(nextProps.current);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
componentDidMount() {
|
|
100
|
+
this.getTabHeaderRef();
|
|
101
|
+
this.updateState(this.props.current);
|
|
102
|
+
}
|
|
103
|
+
componentWillUnmount() {
|
|
104
|
+
this.tabHeaderRef = null;
|
|
105
|
+
}
|
|
106
|
+
render() {
|
|
107
|
+
const {
|
|
108
|
+
customStyle = "",
|
|
109
|
+
className,
|
|
110
|
+
height,
|
|
111
|
+
tabDirection,
|
|
112
|
+
animated,
|
|
113
|
+
tabList,
|
|
114
|
+
scroll,
|
|
115
|
+
current
|
|
116
|
+
} = this.props;
|
|
117
|
+
const { _scrollLeft, _scrollTop, _scrollIntoView } = this.state;
|
|
118
|
+
const heightStyle = { height };
|
|
119
|
+
const underlineStyle = {
|
|
120
|
+
height: tabDirection === "vertical" ? `${tabList.length * 100}%` : "1PX",
|
|
121
|
+
width: tabDirection === "horizontal" ? `${tabList.length * 100}%` : "1PX"
|
|
122
|
+
};
|
|
123
|
+
const bodyStyle = {};
|
|
124
|
+
let transformStyle = `translate3d(0px, -${current * 100}%, 0px)`;
|
|
125
|
+
if (tabDirection === "horizontal") {
|
|
126
|
+
transformStyle = `translate3d(-${current * 100}%, 0px, 0px)`;
|
|
127
|
+
}
|
|
128
|
+
Object.assign(bodyStyle, {
|
|
129
|
+
transform: transformStyle
|
|
130
|
+
});
|
|
131
|
+
if (!animated) {
|
|
132
|
+
bodyStyle.transition = "unset";
|
|
133
|
+
}
|
|
134
|
+
const tabItems = tabList.map((item, idx) => {
|
|
135
|
+
const itemCls = classNames({
|
|
136
|
+
"at-tabs__item": true,
|
|
137
|
+
"at-tabs__item--active": current === idx
|
|
138
|
+
});
|
|
139
|
+
return /* @__PURE__ */ React.createElement(
|
|
140
|
+
View,
|
|
141
|
+
{
|
|
142
|
+
className: itemCls,
|
|
143
|
+
id: `tab${this._tabId}${idx}`,
|
|
144
|
+
key: `at-tabs-item-${idx}`,
|
|
145
|
+
onClick: this.handleClick.bind(this, idx)
|
|
146
|
+
},
|
|
147
|
+
item.title,
|
|
148
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-tabs__item-underline" })
|
|
149
|
+
);
|
|
150
|
+
});
|
|
151
|
+
const rootCls = classNames(
|
|
152
|
+
{
|
|
153
|
+
"at-tabs": true,
|
|
154
|
+
"at-tabs--scroll": scroll,
|
|
155
|
+
[`at-tabs--${tabDirection}`]: true,
|
|
156
|
+
[`at-tabs--${ENV}`]: true
|
|
157
|
+
},
|
|
158
|
+
className
|
|
159
|
+
);
|
|
160
|
+
const scrollX = tabDirection === "horizontal";
|
|
161
|
+
const scrollY = tabDirection === "vertical";
|
|
162
|
+
return /* @__PURE__ */ React.createElement(View, { className: rootCls, style: mergeStyle(heightStyle, customStyle) }, scroll ? /* @__PURE__ */ React.createElement(
|
|
163
|
+
ScrollView,
|
|
164
|
+
{
|
|
165
|
+
id: this._tabId,
|
|
166
|
+
className: "at-tabs__header",
|
|
167
|
+
style: heightStyle,
|
|
168
|
+
scrollX,
|
|
169
|
+
scrollY,
|
|
170
|
+
scrollWithAnimation: true,
|
|
171
|
+
scrollLeft: _scrollLeft,
|
|
172
|
+
scrollTop: _scrollTop,
|
|
173
|
+
scrollIntoView: _scrollIntoView
|
|
174
|
+
},
|
|
175
|
+
tabItems
|
|
176
|
+
) : /* @__PURE__ */ React.createElement(View, { id: this._tabId, className: "at-tabs__header" }, tabItems), /* @__PURE__ */ React.createElement(
|
|
177
|
+
View,
|
|
178
|
+
{
|
|
179
|
+
className: "at-tabs__body",
|
|
180
|
+
onTouchStart: this.handleTouchStart.bind(this),
|
|
181
|
+
onTouchEnd: this.handleTouchEnd.bind(this),
|
|
182
|
+
onTouchMove: this.handleTouchMove.bind(this),
|
|
183
|
+
style: mergeStyle(bodyStyle, heightStyle)
|
|
184
|
+
},
|
|
185
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-tabs__underline", style: underlineStyle }),
|
|
186
|
+
this.props.children
|
|
187
|
+
));
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
AtTabs.defaultProps = {
|
|
191
|
+
customStyle: "",
|
|
192
|
+
className: "",
|
|
193
|
+
tabDirection: "horizontal",
|
|
194
|
+
height: "",
|
|
195
|
+
current: 0,
|
|
196
|
+
swipeable: true,
|
|
197
|
+
scroll: false,
|
|
198
|
+
animated: true,
|
|
199
|
+
tabList: [],
|
|
200
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
201
|
+
onClick: () => {
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
AtTabs.propTypes = {
|
|
205
|
+
customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
|
|
206
|
+
className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),
|
|
207
|
+
height: PropTypes.string,
|
|
208
|
+
tabDirection: PropTypes.oneOf(["horizontal", "vertical"]),
|
|
209
|
+
current: PropTypes.number,
|
|
210
|
+
swipeable: PropTypes.bool,
|
|
211
|
+
scroll: PropTypes.bool,
|
|
212
|
+
animated: PropTypes.bool,
|
|
213
|
+
tabList: PropTypes.array,
|
|
214
|
+
onClick: PropTypes.func
|
|
215
|
+
};
|
|
216
|
+
export {
|
|
217
|
+
AtTabs as default
|
|
218
|
+
};
|
|
219
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/tabs/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport PropTypes, { InferProps } from 'prop-types'\nimport React from 'react'\nimport { ScrollView, View } from '@tarojs/components'\nimport { CommonEvent, ITouchEvent } from '@tarojs/components/types/common'\nimport Taro from '@tarojs/taro'\nimport { AtTabsProps, AtTabsState } from '../../../types/tabs'\nimport { isTest, mergeStyle, uuid } from '../../common/utils'\n\nconst ENV = Taro.getEnv()\nconst MIN_DISTANCE = 100\nconst MAX_INTERVAL = 10\n\nexport default class AtTabs extends React.Component<AtTabsProps, AtTabsState> {\n public static defaultProps: AtTabsProps\n public static propTypes: InferProps<AtTabsProps>\n\n private _tabId: string\n private _touchDot: number\n private _timer: ReturnType<typeof setInterval> | null\n private _interval: number\n private _isMoving: boolean\n private tabHeaderRef: any\n\n public constructor(props: AtTabsProps) {\n super(props)\n this.state = {\n _scrollLeft: 0,\n _scrollTop: 0,\n _scrollIntoView: ''\n }\n this._tabId = isTest() ? 'tabs-AOTU2018' : uuid()\n // 触摸时的原点\n this._touchDot = 0\n // 定时器\n this._timer = null\n // 滑动时间间隔\n this._interval = 0\n // 是否已经在滑动\n this._isMoving = false\n }\n\n private updateState = (idx: number): void => {\n if (this.props.scroll) {\n // 标签栏滚动\n switch (ENV) {\n case Taro.ENV_TYPE.WEAPP:\n case Taro.ENV_TYPE.ALIPAY:\n case Taro.ENV_TYPE.SWAN: {\n const index = Math.max(idx - 1, 0)\n this.setState({\n _scrollIntoView: `tab${this._tabId}${index}`\n })\n break\n }\n case Taro.ENV_TYPE.WEB: {\n const index = Math.max(idx - 1, 0)\n const prevTabItem = this.tabHeaderRef.children[index]\n prevTabItem &&\n this.setState({\n _scrollTop: prevTabItem.offsetTop,\n _scrollLeft: prevTabItem.offsetLeft\n })\n break\n }\n default: {\n console.warn('AtTab 组件在该环境还未适配')\n break\n }\n }\n }\n }\n\n private handleClick(index: number, event: CommonEvent): void {\n this.props.onClick(index, event)\n }\n\n private handleTouchStart(e: ITouchEvent): void {\n const { swipeable, tabDirection } = this.props\n if (!swipeable || tabDirection === 'vertical') return\n // 获取触摸时的原点\n this._touchDot = e.touches[0].pageX\n // 使用js计时器记录时间\n this._timer = setInterval(() => {\n this._interval++\n }, 100)\n }\n\n private handleTouchMove(e: ITouchEvent): void {\n const { swipeable, tabDirection, current, tabList } = this.props\n if (!swipeable || tabDirection === 'vertical') return\n\n const touchMove = e.touches[0].pageX\n const moveDistance = touchMove - this._touchDot\n const maxIndex = tabList.length\n\n if (\n !this._isMoving &&\n this._interval < MAX_INTERVAL &&\n this._touchDot > 20\n ) {\n // 向左滑动\n if (current + 1 < maxIndex && moveDistance <= -MIN_DISTANCE) {\n this._isMoving = true\n this.handleClick(current + 1, e)\n\n // 向右滑动\n } else if (current - 1 >= 0 && moveDistance >= MIN_DISTANCE) {\n this._isMoving = true\n this.handleClick(current - 1, e)\n }\n }\n }\n\n private handleTouchEnd(): void {\n const { swipeable, tabDirection } = this.props\n if (!swipeable || tabDirection === 'vertical') return\n\n this._timer && clearInterval(this._timer)\n this._interval = 0\n this._isMoving = false\n }\n\n private getTabHeaderRef(): void {\n if (ENV === Taro.ENV_TYPE.WEB) {\n this.tabHeaderRef = document.getElementById(this._tabId)\n }\n }\n\n public UNSAFE_componentWillReceiveProps(nextProps: AtTabsProps): void {\n if (nextProps.scroll !== this.props.scroll) {\n this.getTabHeaderRef()\n }\n if (nextProps.current !== this.props.current) {\n this.updateState(nextProps.current)\n }\n }\n\n public componentDidMount(): void {\n this.getTabHeaderRef()\n this.updateState(this.props.current)\n }\n\n public componentWillUnmount(): void {\n this.tabHeaderRef = null\n }\n\n public render(): JSX.Element {\n const {\n customStyle = '',\n className,\n height,\n tabDirection,\n animated,\n tabList,\n scroll,\n current\n } = this.props\n const { _scrollLeft, _scrollTop, _scrollIntoView } = this.state\n\n const heightStyle = { height }\n const underlineStyle = {\n height: tabDirection === 'vertical' ? `${tabList.length * 100}%` : '1PX',\n width: tabDirection === 'horizontal' ? `${tabList.length * 100}%` : '1PX'\n }\n const bodyStyle: React.CSSProperties = {}\n let transformStyle = `translate3d(0px, -${current * 100}%, 0px)`\n if (tabDirection === 'horizontal') {\n transformStyle = `translate3d(-${current * 100}%, 0px, 0px)`\n }\n Object.assign(bodyStyle, {\n transform: transformStyle\n })\n if (!animated) {\n bodyStyle.transition = 'unset'\n }\n\n const tabItems = tabList.map((item, idx) => {\n const itemCls = classNames({\n 'at-tabs__item': true,\n 'at-tabs__item--active': current === idx\n })\n\n return (\n <View\n className={itemCls}\n id={`tab${this._tabId}${idx}`}\n key={`at-tabs-item-${idx}`}\n onClick={this.handleClick.bind(this, idx)}\n >\n {item.title}\n <View className='at-tabs__item-underline'></View>\n </View>\n )\n })\n const rootCls = classNames(\n {\n 'at-tabs': true,\n 'at-tabs--scroll': scroll,\n [`at-tabs--${tabDirection}`]: true,\n [`at-tabs--${ENV}`]: true\n },\n className\n )\n const scrollX = tabDirection === 'horizontal'\n const scrollY = tabDirection === 'vertical'\n\n return (\n <View className={rootCls} style={mergeStyle(heightStyle, customStyle)}>\n {scroll ? (\n <ScrollView\n id={this._tabId}\n className='at-tabs__header'\n style={heightStyle}\n scrollX={scrollX}\n scrollY={scrollY}\n scrollWithAnimation\n scrollLeft={_scrollLeft}\n scrollTop={_scrollTop}\n scrollIntoView={_scrollIntoView}\n >\n {tabItems}\n </ScrollView>\n ) : (\n <View id={this._tabId} className='at-tabs__header'>\n {tabItems}\n </View>\n )}\n <View\n className='at-tabs__body'\n onTouchStart={this.handleTouchStart.bind(this)}\n onTouchEnd={this.handleTouchEnd.bind(this)}\n onTouchMove={this.handleTouchMove.bind(this)}\n style={mergeStyle(bodyStyle, heightStyle)}\n >\n <View className='at-tabs__underline' style={underlineStyle}></View>\n {this.props.children}\n </View>\n </View>\n )\n }\n}\n\nAtTabs.defaultProps = {\n customStyle: '',\n className: '',\n tabDirection: 'horizontal',\n height: '',\n current: 0,\n swipeable: true,\n scroll: false,\n animated: true,\n tabList: [],\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n onClick: (): void => {}\n}\n\nAtTabs.propTypes = {\n customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),\n height: PropTypes.string,\n tabDirection: PropTypes.oneOf(['horizontal', 'vertical']),\n current: PropTypes.number,\n swipeable: PropTypes.bool,\n scroll: PropTypes.bool,\n animated: PropTypes.bool,\n tabList: PropTypes.array,\n onClick: PropTypes.func\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtTabsPaneProps } from '../../../types/tabs-pane';
|
|
4
|
+
export default class AtTabsPane extends React.Component<AtTabsPaneProps> {
|
|
5
|
+
static defaultProps: AtTabsPaneProps;
|
|
6
|
+
static propTypes: InferProps<AtTabsPaneProps>;
|
|
7
|
+
render(): JSX.Element;
|
|
8
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import classNames from "classnames";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { View } from "@tarojs/components";
|
|
5
|
+
class AtTabsPane extends React.Component {
|
|
6
|
+
render() {
|
|
7
|
+
const { customStyle, className, tabDirection, index, current } = this.props;
|
|
8
|
+
return /* @__PURE__ */ React.createElement(
|
|
9
|
+
View,
|
|
10
|
+
{
|
|
11
|
+
className: classNames(
|
|
12
|
+
{
|
|
13
|
+
"at-tabs-pane": true,
|
|
14
|
+
"at-tabs-pane--vertical": tabDirection === "vertical",
|
|
15
|
+
"at-tabs-pane--active": index === current,
|
|
16
|
+
"at-tabs-pane--inactive": index !== current
|
|
17
|
+
},
|
|
18
|
+
className
|
|
19
|
+
),
|
|
20
|
+
style: customStyle
|
|
21
|
+
},
|
|
22
|
+
this.props.children
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
AtTabsPane.defaultProps = {
|
|
27
|
+
customStyle: "",
|
|
28
|
+
className: "",
|
|
29
|
+
tabDirection: "horizontal",
|
|
30
|
+
index: 0,
|
|
31
|
+
current: 0
|
|
32
|
+
};
|
|
33
|
+
AtTabsPane.propTypes = {
|
|
34
|
+
customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
|
|
35
|
+
className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),
|
|
36
|
+
tabDirection: PropTypes.oneOf(["horizontal", "vertical"]),
|
|
37
|
+
index: PropTypes.number,
|
|
38
|
+
current: PropTypes.number
|
|
39
|
+
};
|
|
40
|
+
export {
|
|
41
|
+
AtTabsPane as default
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/tabs-pane/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport PropTypes, { InferProps } from 'prop-types'\nimport React from 'react'\nimport { View } from '@tarojs/components'\nimport { AtTabsPaneProps } from '../../../types/tabs-pane'\n\nexport default class AtTabsPane extends React.Component<AtTabsPaneProps> {\n public static defaultProps: AtTabsPaneProps\n public static propTypes: InferProps<AtTabsPaneProps>\n\n public render(): JSX.Element {\n const { customStyle, className, tabDirection, index, current } = this.props\n\n return (\n <View\n className={classNames(\n {\n 'at-tabs-pane': true,\n 'at-tabs-pane--vertical': tabDirection === 'vertical',\n 'at-tabs-pane--active': index === current,\n 'at-tabs-pane--inactive': index !== current\n },\n className\n )}\n style={customStyle}\n >\n {this.props.children}\n </View>\n )\n }\n}\n\nAtTabsPane.defaultProps = {\n customStyle: '',\n className: '',\n tabDirection: 'horizontal',\n index: 0,\n current: 0\n}\n\nAtTabsPane.propTypes = {\n customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),\n tabDirection: PropTypes.oneOf(['horizontal', 'vertical']),\n index: PropTypes.number,\n current: PropTypes.number\n}\n"],"mappings":"AAAA,OAAO,gBAAgB;AACvB,OAAO,eAA+B;AACtC,OAAO,WAAW;AAClB,SAAS,YAAY;AAGrB,MAAO,mBAAiC,MAAM,UAA2B;AAAA,EAIhE,SAAsB;AAC3B,UAAM,EAAE,aAAa,WAAW,cAAc,OAAO,QAAQ,IAAI,KAAK;AAEtE,WACE;AAAA,MAAC;AAAA;AAAA,QACC,WAAW;AAAA,UACT;AAAA,YACE,gBAAgB;AAAA,YAChB,0BAA0B,iBAAiB;AAAA,YAC3C,wBAAwB,UAAU;AAAA,YAClC,0BAA0B,UAAU;AAAA,UACtC;AAAA,UACA;AAAA,QACF;AAAA,QACA,OAAO;AAAA;AAAA,MAEN,KAAK,MAAM;AAAA,IACd;AAAA,EAEJ;AACF;AAEA,WAAW,eAAe;AAAA,EACxB,aAAa;AAAA,EACb,WAAW;AAAA,EACX,cAAc;AAAA,EACd,OAAO;AAAA,EACP,SAAS;AACX;AAEA,WAAW,YAAY;AAAA,EACrB,aAAa,UAAU,UAAU,CAAC,UAAU,QAAQ,UAAU,MAAM,CAAC;AAAA,EACrE,WAAW,UAAU,UAAU,CAAC,UAAU,OAAO,UAAU,MAAM,CAAC;AAAA,EAClE,cAAc,UAAU,MAAM,CAAC,cAAc,UAAU,CAAC;AAAA,EACxD,OAAO,UAAU;AAAA,EACjB,SAAS,UAAU;AACrB;","names":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtTagProps } from '../../../types/tag';
|
|
4
|
+
export default class AtTag extends React.Component<AtTagProps> {
|
|
5
|
+
static defaultProps: AtTagProps;
|
|
6
|
+
static propTypes: InferProps<AtTagProps>;
|
|
7
|
+
private onClick;
|
|
8
|
+
render(): JSX.Element;
|
|
9
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import classNames from "classnames";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { View } from "@tarojs/components";
|
|
5
|
+
const SIZE_CLASS = {
|
|
6
|
+
normal: "normal",
|
|
7
|
+
small: "small"
|
|
8
|
+
};
|
|
9
|
+
const TYPE_CLASS = {
|
|
10
|
+
primary: "primary"
|
|
11
|
+
};
|
|
12
|
+
class AtTag extends React.Component {
|
|
13
|
+
onClick(event) {
|
|
14
|
+
const { name = "", active = false, disabled, onClick } = this.props;
|
|
15
|
+
if (!disabled) {
|
|
16
|
+
typeof onClick === "function" && onClick(
|
|
17
|
+
{
|
|
18
|
+
name,
|
|
19
|
+
active
|
|
20
|
+
},
|
|
21
|
+
event
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
render() {
|
|
26
|
+
const {
|
|
27
|
+
size = "normal",
|
|
28
|
+
type = "",
|
|
29
|
+
circle = false,
|
|
30
|
+
disabled = false,
|
|
31
|
+
active = false,
|
|
32
|
+
customStyle
|
|
33
|
+
} = this.props;
|
|
34
|
+
const rootClassName = ["at-tag"];
|
|
35
|
+
const classObject = {
|
|
36
|
+
[`at-tag--${SIZE_CLASS[size]}`]: SIZE_CLASS[size],
|
|
37
|
+
[`at-tag--${type}`]: TYPE_CLASS[type],
|
|
38
|
+
"at-tag--disabled": disabled,
|
|
39
|
+
"at-tag--active": active,
|
|
40
|
+
"at-tag--circle": circle
|
|
41
|
+
};
|
|
42
|
+
return /* @__PURE__ */ React.createElement(
|
|
43
|
+
View,
|
|
44
|
+
{
|
|
45
|
+
className: classNames(rootClassName, classObject, this.props.className),
|
|
46
|
+
style: customStyle,
|
|
47
|
+
onClick: this.onClick.bind(this)
|
|
48
|
+
},
|
|
49
|
+
this.props.children
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
AtTag.defaultProps = {
|
|
54
|
+
size: "normal",
|
|
55
|
+
type: "",
|
|
56
|
+
name: "",
|
|
57
|
+
circle: false,
|
|
58
|
+
active: false,
|
|
59
|
+
disabled: false,
|
|
60
|
+
customStyle: {}
|
|
61
|
+
};
|
|
62
|
+
AtTag.propTypes = {
|
|
63
|
+
size: PropTypes.oneOf(["normal", "small"]),
|
|
64
|
+
type: PropTypes.oneOf(["", "primary"]),
|
|
65
|
+
name: PropTypes.string,
|
|
66
|
+
circle: PropTypes.bool,
|
|
67
|
+
active: PropTypes.bool,
|
|
68
|
+
disabled: PropTypes.bool,
|
|
69
|
+
customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
|
|
70
|
+
onClick: PropTypes.func
|
|
71
|
+
};
|
|
72
|
+
export {
|
|
73
|
+
AtTag as default
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/tag/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport PropTypes, { InferProps } from 'prop-types'\nimport React from 'react'\nimport { View } from '@tarojs/components'\nimport { CommonEvent } from '@tarojs/components/types/common'\nimport { AtTagProps } from '../../../types/tag'\n\nconst SIZE_CLASS = {\n normal: 'normal',\n small: 'small'\n}\n\nconst TYPE_CLASS = {\n primary: 'primary'\n}\n\nexport default class AtTag extends React.Component<AtTagProps> {\n public static defaultProps: AtTagProps\n public static propTypes: InferProps<AtTagProps>\n\n private onClick(event: CommonEvent): void {\n const { name = '', active = false, disabled, onClick } = this.props\n if (!disabled) {\n typeof onClick === 'function' &&\n onClick(\n {\n name,\n active\n },\n event\n )\n }\n }\n\n public render(): JSX.Element {\n const {\n size = 'normal',\n type = '',\n circle = false,\n disabled = false,\n active = false,\n customStyle\n } = this.props\n const rootClassName = ['at-tag']\n\n const classObject = {\n [`at-tag--${SIZE_CLASS[size]}`]: SIZE_CLASS[size],\n [`at-tag--${type}`]: TYPE_CLASS[type],\n 'at-tag--disabled': disabled,\n 'at-tag--active': active,\n 'at-tag--circle': circle\n }\n\n return (\n <View\n className={classNames(rootClassName, classObject, this.props.className)}\n style={customStyle}\n onClick={this.onClick.bind(this)}\n >\n {this.props.children}\n </View>\n )\n }\n}\n\nAtTag.defaultProps = {\n size: 'normal',\n type: '',\n name: '',\n circle: false,\n active: false,\n disabled: false,\n customStyle: {}\n}\n\nAtTag.propTypes = {\n size: PropTypes.oneOf(['normal', 'small']),\n type: PropTypes.oneOf(['', 'primary']),\n name: PropTypes.string,\n circle: PropTypes.bool,\n active: PropTypes.bool,\n disabled: PropTypes.bool,\n customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n onClick: PropTypes.func\n}\n"],"mappings":"AAAA,OAAO,gBAAgB;AACvB,OAAO,eAA+B;AACtC,OAAO,WAAW;AAClB,SAAS,YAAY;AAIrB,MAAM,aAAa;AAAA,EACjB,QAAQ;AAAA,EACR,OAAO;AACT;AAEA,MAAM,aAAa;AAAA,EACjB,SAAS;AACX;AAEA,MAAO,cAA4B,MAAM,UAAsB;AAAA,EAIrD,QAAQ,OAA0B;AACxC,UAAM,EAAE,OAAO,IAAI,SAAS,OAAO,UAAU,QAAQ,IAAI,KAAK;AAC9D,QAAI,CAAC,UAAU;AACb,aAAO,YAAY,cACjB;AAAA,QACE;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,MACF;AAAA,IACJ;AAAA,EACF;AAAA,EAEO,SAAsB;AAC3B,UAAM;AAAA,MACJ,OAAO;AAAA,MACP,OAAO;AAAA,MACP,SAAS;AAAA,MACT,WAAW;AAAA,MACX,SAAS;AAAA,MACT;AAAA,IACF,IAAI,KAAK;AACT,UAAM,gBAAgB,CAAC,QAAQ;AAE/B,UAAM,cAAc;AAAA,MAClB,CAAC,WAAW,WAAW,IAAI,CAAC,EAAE,GAAG,WAAW,IAAI;AAAA,MAChD,CAAC,WAAW,IAAI,EAAE,GAAG,WAAW,IAAI;AAAA,MACpC,oBAAoB;AAAA,MACpB,kBAAkB;AAAA,MAClB,kBAAkB;AAAA,IACpB;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC,WAAW,WAAW,eAAe,aAAa,KAAK,MAAM,SAAS;AAAA,QACtE,OAAO;AAAA,QACP,SAAS,KAAK,QAAQ,KAAK,IAAI;AAAA;AAAA,MAE9B,KAAK,MAAM;AAAA,IACd;AAAA,EAEJ;AACF;AAEA,MAAM,eAAe;AAAA,EACnB,MAAM;AAAA,EACN,MAAM;AAAA,EACN,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,aAAa,CAAC;AAChB;AAEA,MAAM,YAAY;AAAA,EAChB,MAAM,UAAU,MAAM,CAAC,UAAU,OAAO,CAAC;AAAA,EACzC,MAAM,UAAU,MAAM,CAAC,IAAI,SAAS,CAAC;AAAA,EACrC,MAAM,UAAU;AAAA,EAChB,QAAQ,UAAU;AAAA,EAClB,QAAQ,UAAU;AAAA,EAClB,UAAU,UAAU;AAAA,EACpB,aAAa,UAAU,UAAU,CAAC,UAAU,QAAQ,UAAU,MAAM,CAAC;AAAA,EACrE,SAAS,UAAU;AACrB;","names":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtTextareaProps } from '../../../types/textarea';
|
|
4
|
+
export default class AtTextarea extends React.Component<AtTextareaProps> {
|
|
5
|
+
static defaultProps: AtTextareaProps;
|
|
6
|
+
static propTypes: InferProps<AtTextareaProps>;
|
|
7
|
+
private handleInput;
|
|
8
|
+
private handleFocus;
|
|
9
|
+
private handleBlur;
|
|
10
|
+
private handleConfirm;
|
|
11
|
+
private handleLinechange;
|
|
12
|
+
render(): JSX.Element;
|
|
13
|
+
}
|