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,29 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtIndexesProps, AtIndexesState } from '../../../types/indexes';
|
|
4
|
+
export default class AtIndexes extends React.Component<AtIndexesProps, AtIndexesState> {
|
|
5
|
+
static defaultProps: AtIndexesProps;
|
|
6
|
+
static propTypes: InferProps<AtIndexesProps>;
|
|
7
|
+
private menuHeight;
|
|
8
|
+
private startTop;
|
|
9
|
+
private itemHeight;
|
|
10
|
+
private currentIndex;
|
|
11
|
+
private listId;
|
|
12
|
+
private timeoutTimer;
|
|
13
|
+
private listRef;
|
|
14
|
+
private indexMap;
|
|
15
|
+
constructor(props: AtIndexesProps);
|
|
16
|
+
private handleClick;
|
|
17
|
+
private handleTouchMove;
|
|
18
|
+
private handleTouchEnd;
|
|
19
|
+
private jumpTarget;
|
|
20
|
+
private __jumpTarget;
|
|
21
|
+
private updateState;
|
|
22
|
+
private initData;
|
|
23
|
+
private handleScroll;
|
|
24
|
+
private getAnchorIndex;
|
|
25
|
+
UNSAFE_componentWillReceiveProps(nextProps: AtIndexesProps): void;
|
|
26
|
+
componentDidMount(): void;
|
|
27
|
+
UNSAFE_componentWillMount(): void;
|
|
28
|
+
render(): JSX.Element;
|
|
29
|
+
}
|
|
@@ -0,0 +1,272 @@
|
|
|
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 {
|
|
7
|
+
delayQuerySelector,
|
|
8
|
+
isTest,
|
|
9
|
+
pxTransform,
|
|
10
|
+
uuid
|
|
11
|
+
} from "../../common/utils";
|
|
12
|
+
import AtList from "../list/index";
|
|
13
|
+
import AtListItem from "../list/item/index";
|
|
14
|
+
import AtToast from "../toast/index";
|
|
15
|
+
const ENV = Taro.getEnv();
|
|
16
|
+
class AtIndexes extends React.Component {
|
|
17
|
+
constructor(props) {
|
|
18
|
+
super(props);
|
|
19
|
+
this.handleClick = (item) => {
|
|
20
|
+
this.props.onClick && this.props.onClick(item);
|
|
21
|
+
};
|
|
22
|
+
this.handleTouchMove = (event) => {
|
|
23
|
+
event.stopPropagation();
|
|
24
|
+
event.preventDefault();
|
|
25
|
+
const { list } = this.props;
|
|
26
|
+
const pageY = event.touches[0].pageY;
|
|
27
|
+
const index = Math.floor((pageY - this.startTop) / this.itemHeight);
|
|
28
|
+
if (index >= 0 && index <= list.length && this.currentIndex !== index) {
|
|
29
|
+
this.currentIndex = index;
|
|
30
|
+
const key = index > 0 ? list[index - 1].key : "top";
|
|
31
|
+
const touchView = `at-indexes__list-${key}`;
|
|
32
|
+
this.jumpTarget(touchView, index);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
this.handleTouchEnd = () => {
|
|
36
|
+
this.currentIndex = -1;
|
|
37
|
+
};
|
|
38
|
+
this.state = {
|
|
39
|
+
_scrollIntoView: "",
|
|
40
|
+
_scrollTop: 0,
|
|
41
|
+
_tipText: "",
|
|
42
|
+
_isShowToast: false,
|
|
43
|
+
isWEB: Taro.getEnv() === Taro.ENV_TYPE.WEB,
|
|
44
|
+
currentIndex: -1
|
|
45
|
+
};
|
|
46
|
+
this.menuHeight = 0;
|
|
47
|
+
this.startTop = 0;
|
|
48
|
+
this.itemHeight = 0;
|
|
49
|
+
this.currentIndex = -1;
|
|
50
|
+
this.listId = isTest() ? "indexes-list-AOTU2018" : `list-${uuid()}`;
|
|
51
|
+
this.indexMap = [];
|
|
52
|
+
}
|
|
53
|
+
jumpTarget(_scrollIntoView, idx) {
|
|
54
|
+
const { topKey = "Top", list } = this.props;
|
|
55
|
+
const _tipText = idx === 0 ? topKey : list[idx - 1].key;
|
|
56
|
+
if (ENV === Taro.ENV_TYPE.WEB) {
|
|
57
|
+
delayQuerySelector(".at-indexes", 0).then((rect) => {
|
|
58
|
+
const targetOffsetTop = this.listRef.children[idx].offsetTop;
|
|
59
|
+
const _scrollTop = targetOffsetTop - rect[0].top;
|
|
60
|
+
this.updateState({
|
|
61
|
+
_scrollTop,
|
|
62
|
+
_scrollIntoView,
|
|
63
|
+
_tipText
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
this.updateState({
|
|
69
|
+
_scrollIntoView,
|
|
70
|
+
_tipText
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
__jumpTarget(key) {
|
|
74
|
+
const { list } = this.props;
|
|
75
|
+
const index = list.findIndex((item) => item.key === key);
|
|
76
|
+
const targetView = `at-indexes__list-${key}`;
|
|
77
|
+
this.jumpTarget(targetView, index + 1);
|
|
78
|
+
}
|
|
79
|
+
updateState(state) {
|
|
80
|
+
const { isShowToast, isVibrate } = this.props;
|
|
81
|
+
const { _scrollIntoView, _tipText, _scrollTop } = state;
|
|
82
|
+
this.setState(
|
|
83
|
+
{
|
|
84
|
+
_scrollIntoView,
|
|
85
|
+
_tipText,
|
|
86
|
+
_scrollTop,
|
|
87
|
+
_isShowToast: isShowToast
|
|
88
|
+
},
|
|
89
|
+
/* eslint-enable @typescript-eslint/no-non-null-assertion */
|
|
90
|
+
() => {
|
|
91
|
+
clearTimeout(this.timeoutTimer);
|
|
92
|
+
this.timeoutTimer = setTimeout(() => {
|
|
93
|
+
this.setState({
|
|
94
|
+
_tipText: "",
|
|
95
|
+
_isShowToast: false
|
|
96
|
+
});
|
|
97
|
+
}, 3e3);
|
|
98
|
+
}
|
|
99
|
+
);
|
|
100
|
+
if (isVibrate) {
|
|
101
|
+
Taro.vibrateShort();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
async initData() {
|
|
105
|
+
var _a, _b, _c, _d;
|
|
106
|
+
delayQuerySelector(".at-indexes__menu").then((rect) => {
|
|
107
|
+
const len = this.props.list.length;
|
|
108
|
+
this.menuHeight = rect[0].height;
|
|
109
|
+
this.startTop = rect[0].top;
|
|
110
|
+
this.itemHeight = Math.floor(this.menuHeight / (len + 1));
|
|
111
|
+
});
|
|
112
|
+
const headerHeight = ((_b = (_a = await delayQuerySelector("#at-indexes__top")) == null ? void 0 : _a[0]) == null ? void 0 : _b.height) || 0;
|
|
113
|
+
const itemHeight = ((_c = await delayQuerySelector(".at-list__item")) == null ? void 0 : _c[0].height) || 0;
|
|
114
|
+
const titleHeight = ((_d = await delayQuerySelector(".at-indexes__list-title")) == null ? void 0 : _d[0].height) || 0;
|
|
115
|
+
this.indexMap = [];
|
|
116
|
+
this.props.list.forEach((dataList, i) => {
|
|
117
|
+
if (i === 0) {
|
|
118
|
+
this.indexMap.push({
|
|
119
|
+
key: dataList.key,
|
|
120
|
+
startHeight: headerHeight,
|
|
121
|
+
endHeight: dataList.items.length * itemHeight + headerHeight + titleHeight
|
|
122
|
+
});
|
|
123
|
+
} else {
|
|
124
|
+
const prev = this.indexMap[i - 1];
|
|
125
|
+
this.indexMap.push({
|
|
126
|
+
key: dataList.key,
|
|
127
|
+
startHeight: prev.endHeight,
|
|
128
|
+
endHeight: prev.endHeight + dataList.items.length * itemHeight + titleHeight
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
handleScroll(e) {
|
|
134
|
+
if (e && e.detail) {
|
|
135
|
+
const scrollTop = e.detail.scrollTop;
|
|
136
|
+
this.setState({
|
|
137
|
+
_scrollTop: scrollTop
|
|
138
|
+
});
|
|
139
|
+
this.getAnchorIndex(scrollTop);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
// 根据滚动高度,判断当前应该显示的索引值
|
|
143
|
+
getAnchorIndex(scrollTop) {
|
|
144
|
+
const index = this.indexMap.findIndex((item) => {
|
|
145
|
+
return scrollTop >= item.startHeight && scrollTop < item.endHeight;
|
|
146
|
+
});
|
|
147
|
+
this.setState({
|
|
148
|
+
currentIndex: index
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
UNSAFE_componentWillReceiveProps(nextProps) {
|
|
152
|
+
if (nextProps.list.length !== this.props.list.length) {
|
|
153
|
+
this.initData();
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
componentDidMount() {
|
|
157
|
+
if (ENV === Taro.ENV_TYPE.WEB) {
|
|
158
|
+
this.listRef = document.getElementById(this.listId);
|
|
159
|
+
}
|
|
160
|
+
this.initData();
|
|
161
|
+
}
|
|
162
|
+
UNSAFE_componentWillMount() {
|
|
163
|
+
this.props.onScrollIntoView && this.props.onScrollIntoView(this.__jumpTarget.bind(this));
|
|
164
|
+
}
|
|
165
|
+
render() {
|
|
166
|
+
const { className, customStyle, animation, topKey, list } = this.props;
|
|
167
|
+
const {
|
|
168
|
+
_scrollTop,
|
|
169
|
+
_scrollIntoView,
|
|
170
|
+
_tipText,
|
|
171
|
+
_isShowToast,
|
|
172
|
+
isWEB,
|
|
173
|
+
currentIndex
|
|
174
|
+
} = this.state;
|
|
175
|
+
const toastStyle = { minWidth: pxTransform(100) };
|
|
176
|
+
const rootCls = classNames("at-indexes", className);
|
|
177
|
+
const menuList = list.map((dataList, i) => {
|
|
178
|
+
const { key } = dataList;
|
|
179
|
+
const targetView = `at-indexes__list-${key}`;
|
|
180
|
+
return /* @__PURE__ */ React.createElement(
|
|
181
|
+
View,
|
|
182
|
+
{
|
|
183
|
+
className: classNames("at-indexes__menu-item", {
|
|
184
|
+
"at-indexes__menu-item--active": currentIndex === i
|
|
185
|
+
}),
|
|
186
|
+
key,
|
|
187
|
+
onClick: this.jumpTarget.bind(this, targetView, i + 1)
|
|
188
|
+
},
|
|
189
|
+
key
|
|
190
|
+
);
|
|
191
|
+
});
|
|
192
|
+
const indexesList = list.map((dataList) => /* @__PURE__ */ React.createElement(
|
|
193
|
+
View,
|
|
194
|
+
{
|
|
195
|
+
id: `at-indexes__list-${dataList.key}`,
|
|
196
|
+
className: "at-indexes__list",
|
|
197
|
+
key: dataList.key
|
|
198
|
+
},
|
|
199
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-indexes__list-title" }, dataList.title),
|
|
200
|
+
/* @__PURE__ */ React.createElement(AtList, null, dataList.items && dataList.items.map((item) => /* @__PURE__ */ React.createElement(
|
|
201
|
+
AtListItem,
|
|
202
|
+
{
|
|
203
|
+
key: item.name,
|
|
204
|
+
title: item.name,
|
|
205
|
+
onClick: this.handleClick.bind(this, item)
|
|
206
|
+
}
|
|
207
|
+
)))
|
|
208
|
+
));
|
|
209
|
+
return /* @__PURE__ */ React.createElement(View, { className: rootCls, style: customStyle }, /* @__PURE__ */ React.createElement(
|
|
210
|
+
AtToast,
|
|
211
|
+
{
|
|
212
|
+
customStyle: toastStyle,
|
|
213
|
+
isOpened: _isShowToast,
|
|
214
|
+
text: _tipText,
|
|
215
|
+
duration: 2e3
|
|
216
|
+
}
|
|
217
|
+
), /* @__PURE__ */ React.createElement(
|
|
218
|
+
View,
|
|
219
|
+
{
|
|
220
|
+
className: "at-indexes__menu",
|
|
221
|
+
onTouchMove: this.handleTouchMove,
|
|
222
|
+
onTouchEnd: this.handleTouchEnd
|
|
223
|
+
},
|
|
224
|
+
/* @__PURE__ */ React.createElement(
|
|
225
|
+
View,
|
|
226
|
+
{
|
|
227
|
+
className: "at-indexes__menu-item",
|
|
228
|
+
onClick: this.jumpTarget.bind(this, "at-indexes__top", 0)
|
|
229
|
+
},
|
|
230
|
+
topKey
|
|
231
|
+
),
|
|
232
|
+
menuList
|
|
233
|
+
), /* @__PURE__ */ React.createElement(
|
|
234
|
+
ScrollView,
|
|
235
|
+
{
|
|
236
|
+
className: "at-indexes__body",
|
|
237
|
+
id: this.listId,
|
|
238
|
+
scrollY: true,
|
|
239
|
+
scrollWithAnimation: animation,
|
|
240
|
+
scrollTop: isWEB ? _scrollTop : void 0,
|
|
241
|
+
scrollIntoView: !isWEB ? _scrollIntoView : "",
|
|
242
|
+
onScroll: this.handleScroll.bind(this)
|
|
243
|
+
},
|
|
244
|
+
/* @__PURE__ */ React.createElement(View, { className: "at-indexes__content", id: "at-indexes__top" }, this.props.children),
|
|
245
|
+
indexesList
|
|
246
|
+
));
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
AtIndexes.propTypes = {
|
|
250
|
+
customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),
|
|
251
|
+
className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),
|
|
252
|
+
animation: PropTypes.bool,
|
|
253
|
+
isVibrate: PropTypes.bool,
|
|
254
|
+
isShowToast: PropTypes.bool,
|
|
255
|
+
topKey: PropTypes.string,
|
|
256
|
+
list: PropTypes.array,
|
|
257
|
+
onClick: PropTypes.func,
|
|
258
|
+
onScrollIntoView: PropTypes.func
|
|
259
|
+
};
|
|
260
|
+
AtIndexes.defaultProps = {
|
|
261
|
+
customStyle: "",
|
|
262
|
+
className: "",
|
|
263
|
+
animation: false,
|
|
264
|
+
topKey: "Top",
|
|
265
|
+
isVibrate: true,
|
|
266
|
+
isShowToast: true,
|
|
267
|
+
list: []
|
|
268
|
+
};
|
|
269
|
+
export {
|
|
270
|
+
AtIndexes as default
|
|
271
|
+
};
|
|
272
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/indexes/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 { AtIndexesProps, AtIndexesState, Item } from '../../../types/indexes'\nimport {\n delayQuerySelector,\n isTest,\n pxTransform,\n uuid\n} from '../../common/utils'\nimport AtList from '../list/index'\nimport AtListItem from '../list/item/index'\nimport AtToast from '../toast/index'\n\nconst ENV = Taro.getEnv()\n\nexport default class AtIndexes extends React.Component<\n AtIndexesProps,\n AtIndexesState\n> {\n public static defaultProps: AtIndexesProps\n public static propTypes: InferProps<AtIndexesProps>\n\n private menuHeight: number\n private startTop: number\n private itemHeight: number\n private currentIndex: number\n private listId: string\n private timeoutTimer: NodeJS.Timeout | number | undefined\n private listRef: any\n private indexMap: { key: string; startHeight: number; endHeight: number }[]\n\n public constructor(props: AtIndexesProps) {\n super(props)\n this.state = {\n _scrollIntoView: '',\n _scrollTop: 0,\n _tipText: '',\n _isShowToast: false,\n isWEB: Taro.getEnv() === Taro.ENV_TYPE.WEB,\n currentIndex: -1\n }\n // 右侧导航高度\n this.menuHeight = 0\n // 右侧导航距离顶部高度\n this.startTop = 0\n // 右侧导航元素高度\n this.itemHeight = 0\n // 当前索引\n this.currentIndex = -1\n this.listId = isTest() ? 'indexes-list-AOTU2018' : `list-${uuid()}`\n this.indexMap = []\n }\n\n private handleClick = (item: Item): void => {\n this.props.onClick && this.props.onClick(item)\n }\n\n private handleTouchMove = (event: ITouchEvent): void => {\n event.stopPropagation()\n event.preventDefault()\n\n const { list } = this.props\n const pageY = event.touches[0].pageY\n const index = Math.floor((pageY - this.startTop) / this.itemHeight)\n\n if (index >= 0 && index <= list.length && this.currentIndex !== index) {\n this.currentIndex = index\n const key = index > 0 ? list[index - 1].key : 'top'\n const touchView = `at-indexes__list-${key}`\n this.jumpTarget(touchView, index)\n }\n }\n\n private handleTouchEnd = (): void => {\n this.currentIndex = -1\n }\n\n private jumpTarget(_scrollIntoView: string, idx: number): void {\n const { topKey = 'Top', list } = this.props\n const _tipText = idx === 0 ? topKey : list[idx - 1].key\n\n if (ENV === Taro.ENV_TYPE.WEB) {\n delayQuerySelector('.at-indexes', 0).then(rect => {\n const targetOffsetTop = this.listRef.children[idx].offsetTop\n const _scrollTop = targetOffsetTop - rect[0].top\n this.updateState({\n _scrollTop,\n _scrollIntoView,\n _tipText\n })\n })\n return\n }\n\n this.updateState({\n _scrollIntoView,\n _tipText\n })\n }\n\n private __jumpTarget(key: string): void {\n const { list } = this.props\n // const index = _findIndex(list, ['key', key])\n const index = list.findIndex(item => item.key === key)\n const targetView = `at-indexes__list-${key}`\n this.jumpTarget(targetView, index + 1)\n }\n\n private updateState(state: Partial<AtIndexesState>): void {\n const { isShowToast, isVibrate } = this.props\n const { _scrollIntoView, _tipText, _scrollTop } = state\n // TODO: Fix dirty hack\n /* eslint-disable @typescript-eslint/no-non-null-assertion */\n this.setState(\n {\n _scrollIntoView: _scrollIntoView!,\n _tipText: _tipText!,\n _scrollTop: _scrollTop!,\n _isShowToast: isShowToast!\n },\n /* eslint-enable @typescript-eslint/no-non-null-assertion */\n () => {\n clearTimeout(this.timeoutTimer as number)\n this.timeoutTimer = setTimeout(() => {\n this.setState({\n _tipText: '',\n _isShowToast: false\n })\n }, 3000)\n }\n )\n\n if (isVibrate) {\n Taro.vibrateShort()\n }\n }\n\n private async initData(): Promise<void> {\n delayQuerySelector('.at-indexes__menu').then(rect => {\n const len = this.props.list.length\n this.menuHeight = rect[0].height\n this.startTop = rect[0].top\n this.itemHeight = Math.floor(this.menuHeight / (len + 1))\n })\n\n const headerHeight =\n (await delayQuerySelector('#at-indexes__top'))?.[0]?.height || 0\n const itemHeight =\n (await delayQuerySelector('.at-list__item'))?.[0].height || 0\n const titleHeight =\n (await delayQuerySelector('.at-indexes__list-title'))?.[0].height || 0\n\n this.indexMap = []\n this.props.list.forEach((dataList, i) => {\n if (i === 0) {\n this.indexMap.push({\n key: dataList.key,\n startHeight: headerHeight,\n endHeight:\n dataList.items.length * itemHeight + headerHeight + titleHeight\n })\n } else {\n const prev = this.indexMap[i - 1]\n this.indexMap.push({\n key: dataList.key,\n startHeight: prev.endHeight,\n endHeight:\n prev.endHeight + dataList.items.length * itemHeight + titleHeight\n })\n }\n })\n }\n\n private handleScroll(e: CommonEvent): void {\n if (e && e.detail) {\n const scrollTop = e.detail.scrollTop\n\n this.setState({\n _scrollTop: scrollTop\n })\n\n this.getAnchorIndex(scrollTop)\n }\n }\n\n // 根据滚动高度,判断当前应该显示的索引值\n private getAnchorIndex(scrollTop: number) {\n const index = this.indexMap.findIndex(item => {\n return scrollTop >= item.startHeight && scrollTop < item.endHeight\n })\n\n this.setState({\n currentIndex: index\n })\n }\n\n public UNSAFE_componentWillReceiveProps(nextProps: AtIndexesProps): void {\n if (nextProps.list.length !== this.props.list.length) {\n this.initData()\n }\n }\n\n public componentDidMount(): void {\n if (ENV === Taro.ENV_TYPE.WEB) {\n this.listRef = document.getElementById(this.listId)\n }\n this.initData()\n }\n\n public UNSAFE_componentWillMount(): void {\n this.props.onScrollIntoView &&\n this.props.onScrollIntoView(this.__jumpTarget.bind(this))\n }\n\n public render(): JSX.Element {\n const { className, customStyle, animation, topKey, list } = this.props\n const {\n _scrollTop,\n _scrollIntoView,\n _tipText,\n _isShowToast,\n isWEB,\n currentIndex\n } = this.state\n\n const toastStyle = { minWidth: pxTransform(100) }\n const rootCls = classNames('at-indexes', className)\n\n const menuList = list.map((dataList, i) => {\n const { key } = dataList\n const targetView = `at-indexes__list-${key}`\n return (\n <View\n className={classNames('at-indexes__menu-item', {\n 'at-indexes__menu-item--active': currentIndex === i\n })}\n key={key}\n onClick={this.jumpTarget.bind(this, targetView, i + 1)}\n >\n {key}\n </View>\n )\n })\n\n const indexesList = list.map(dataList => (\n <View\n id={`at-indexes__list-${dataList.key}`}\n className='at-indexes__list'\n key={dataList.key}\n >\n <View className='at-indexes__list-title'>{dataList.title}</View>\n <AtList>\n {dataList.items &&\n dataList.items.map(item => (\n <AtListItem\n key={item.name}\n title={item.name}\n onClick={this.handleClick.bind(this, item)}\n />\n ))}\n </AtList>\n </View>\n ))\n\n return (\n <View className={rootCls} style={customStyle}>\n <AtToast\n customStyle={toastStyle}\n isOpened={_isShowToast}\n text={_tipText}\n duration={2000}\n />\n <View\n className='at-indexes__menu'\n onTouchMove={this.handleTouchMove}\n onTouchEnd={this.handleTouchEnd}\n >\n <View\n className='at-indexes__menu-item'\n onClick={this.jumpTarget.bind(this, 'at-indexes__top', 0)}\n >\n {topKey}\n </View>\n {menuList}\n </View>\n <ScrollView\n className='at-indexes__body'\n id={this.listId}\n scrollY\n scrollWithAnimation={animation}\n // eslint-disable-next-line no-undefined\n scrollTop={isWEB ? _scrollTop : undefined}\n scrollIntoView={!isWEB ? _scrollIntoView : ''}\n onScroll={this.handleScroll.bind(this)}\n >\n <View className='at-indexes__content' id='at-indexes__top'>\n {this.props.children}\n </View>\n {indexesList}\n </ScrollView>\n </View>\n )\n }\n}\n\nAtIndexes.propTypes = {\n customStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.string]),\n className: PropTypes.oneOfType([PropTypes.array, PropTypes.string]),\n animation: PropTypes.bool,\n isVibrate: PropTypes.bool,\n isShowToast: PropTypes.bool,\n topKey: PropTypes.string,\n list: PropTypes.array,\n onClick: PropTypes.func,\n onScrollIntoView: PropTypes.func\n}\n\nAtIndexes.defaultProps = {\n customStyle: '',\n className: '',\n animation: false,\n topKey: 'Top',\n isVibrate: true,\n isShowToast: true,\n list: []\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtInputProps } from '../../../types/input';
|
|
4
|
+
export default class AtInput extends React.Component<AtInputProps> {
|
|
5
|
+
static defaultProps: AtInputProps;
|
|
6
|
+
static propTypes: InferProps<AtInputProps>;
|
|
7
|
+
private inputClearing;
|
|
8
|
+
private handleInput;
|
|
9
|
+
private handleFocus;
|
|
10
|
+
private handleBlur;
|
|
11
|
+
private handleConfirm;
|
|
12
|
+
private handleClick;
|
|
13
|
+
private handleClearValue;
|
|
14
|
+
private handleKeyboardHeightChange;
|
|
15
|
+
private handleErrorClick;
|
|
16
|
+
render(): JSX.Element;
|
|
17
|
+
}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import classNames from "classnames";
|
|
2
|
+
import PropTypes from "prop-types";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { Input, Label, Text, View } from "@tarojs/components";
|
|
5
|
+
function getInputProps(props) {
|
|
6
|
+
const actualProps = {
|
|
7
|
+
type: props.type,
|
|
8
|
+
maxLength: props.maxLength || props.maxlength,
|
|
9
|
+
disabled: props.disabled,
|
|
10
|
+
password: false
|
|
11
|
+
};
|
|
12
|
+
switch (actualProps.type) {
|
|
13
|
+
case "phone":
|
|
14
|
+
actualProps.type = "number";
|
|
15
|
+
actualProps.maxLength = 11;
|
|
16
|
+
break;
|
|
17
|
+
case "password":
|
|
18
|
+
actualProps.type = "text";
|
|
19
|
+
actualProps.password = true;
|
|
20
|
+
break;
|
|
21
|
+
default:
|
|
22
|
+
break;
|
|
23
|
+
}
|
|
24
|
+
if (!props.disabled && !props.editable) {
|
|
25
|
+
actualProps.disabled = true;
|
|
26
|
+
}
|
|
27
|
+
return actualProps;
|
|
28
|
+
}
|
|
29
|
+
class AtInput extends React.Component {
|
|
30
|
+
constructor() {
|
|
31
|
+
super(...arguments);
|
|
32
|
+
// TODO: 有待考证是否为合理方式处理 #840
|
|
33
|
+
this.inputClearing = false;
|
|
34
|
+
this.handleInput = (event) => {
|
|
35
|
+
var _a, _b;
|
|
36
|
+
return (_b = (_a = this.props).onChange) == null ? void 0 : _b.call(_a, event.detail.value, event);
|
|
37
|
+
};
|
|
38
|
+
this.handleFocus = (event) => {
|
|
39
|
+
if (typeof this.props.onFocus === "function") {
|
|
40
|
+
this.props.onFocus(event.detail.value, event);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
this.handleBlur = (event) => {
|
|
44
|
+
var _a, _b;
|
|
45
|
+
if (typeof this.props.onBlur === "function") {
|
|
46
|
+
this.props.onBlur(event.detail.value, event);
|
|
47
|
+
}
|
|
48
|
+
if (event.type === "blur" && !this.inputClearing) {
|
|
49
|
+
(_b = (_a = this.props).onChange) == null ? void 0 : _b.call(
|
|
50
|
+
_a,
|
|
51
|
+
event.detail.value,
|
|
52
|
+
event
|
|
53
|
+
);
|
|
54
|
+
}
|
|
55
|
+
this.inputClearing = false;
|
|
56
|
+
};
|
|
57
|
+
this.handleConfirm = (event) => {
|
|
58
|
+
if (typeof this.props.onConfirm === "function") {
|
|
59
|
+
this.props.onConfirm(event.detail.value, event);
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
this.handleClick = (event) => {
|
|
63
|
+
if (!this.props.editable && typeof this.props.onClick === "function") {
|
|
64
|
+
this.props.onClick(event);
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
this.handleClearValue = (event) => {
|
|
68
|
+
var _a, _b;
|
|
69
|
+
this.inputClearing = true;
|
|
70
|
+
(_b = (_a = this.props).onChange) == null ? void 0 : _b.call(_a, "", event);
|
|
71
|
+
};
|
|
72
|
+
this.handleKeyboardHeightChange = (event) => {
|
|
73
|
+
if (typeof this.props.onKeyboardHeightChange === "function") {
|
|
74
|
+
this.props.onKeyboardHeightChange(event);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
this.handleErrorClick = (event) => {
|
|
78
|
+
if (typeof this.props.onErrorClick === "function") {
|
|
79
|
+
this.props.onErrorClick(event);
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
render() {
|
|
84
|
+
const {
|
|
85
|
+
className,
|
|
86
|
+
customStyle,
|
|
87
|
+
name,
|
|
88
|
+
cursorSpacing,
|
|
89
|
+
confirmType,
|
|
90
|
+
cursor,
|
|
91
|
+
selectionStart,
|
|
92
|
+
selectionEnd,
|
|
93
|
+
adjustPosition,
|
|
94
|
+
border,
|
|
95
|
+
title,
|
|
96
|
+
error,
|
|
97
|
+
clear,
|
|
98
|
+
placeholder,
|
|
99
|
+
placeholderStyle,
|
|
100
|
+
placeholderClass,
|
|
101
|
+
autoFocus = false,
|
|
102
|
+
focus = false,
|
|
103
|
+
value,
|
|
104
|
+
required
|
|
105
|
+
} = this.props;
|
|
106
|
+
const { type, maxLength, disabled, password } = getInputProps(this.props);
|
|
107
|
+
const rootCls = classNames(
|
|
108
|
+
"at-input",
|
|
109
|
+
{
|
|
110
|
+
"at-input--without-border": !border
|
|
111
|
+
},
|
|
112
|
+
className
|
|
113
|
+
);
|
|
114
|
+
const containerCls = classNames("at-input__container", {
|
|
115
|
+
"at-input--error": error,
|
|
116
|
+
"at-input--disabled": disabled
|
|
117
|
+
});
|
|
118
|
+
const overlayCls = classNames("at-input__overlay", {
|
|
119
|
+
"at-input__overlay--hidden": !disabled
|
|
120
|
+
});
|
|
121
|
+
const placeholderCls = classNames("placeholder", placeholderClass);
|
|
122
|
+
return /* @__PURE__ */ React.createElement(View, { className: rootCls, style: customStyle }, /* @__PURE__ */ React.createElement(View, { className: containerCls }, /* @__PURE__ */ React.createElement(View, { className: overlayCls, onClick: this.handleClick }), title && /* @__PURE__ */ React.createElement(
|
|
123
|
+
Label,
|
|
124
|
+
{
|
|
125
|
+
className: `at-input__title ${required && "at-input__title--required"}`,
|
|
126
|
+
for: name
|
|
127
|
+
},
|
|
128
|
+
title
|
|
129
|
+
), /* @__PURE__ */ React.createElement(
|
|
130
|
+
Input,
|
|
131
|
+
{
|
|
132
|
+
className: "at-input__input",
|
|
133
|
+
id: name,
|
|
134
|
+
name,
|
|
135
|
+
type,
|
|
136
|
+
disabled,
|
|
137
|
+
password,
|
|
138
|
+
placeholderStyle,
|
|
139
|
+
placeholderClass: placeholderCls,
|
|
140
|
+
placeholder,
|
|
141
|
+
cursorSpacing,
|
|
142
|
+
maxlength: maxLength,
|
|
143
|
+
autoFocus,
|
|
144
|
+
focus,
|
|
145
|
+
value,
|
|
146
|
+
confirmType,
|
|
147
|
+
cursor,
|
|
148
|
+
selectionStart,
|
|
149
|
+
selectionEnd,
|
|
150
|
+
adjustPosition,
|
|
151
|
+
onInput: this.handleInput,
|
|
152
|
+
onFocus: this.handleFocus,
|
|
153
|
+
onBlur: this.handleBlur,
|
|
154
|
+
onConfirm: this.handleConfirm,
|
|
155
|
+
onKeyboardHeightChange: this.handleKeyboardHeightChange
|
|
156
|
+
}
|
|
157
|
+
), clear && value && /* @__PURE__ */ React.createElement(View, { className: "at-input__icon", onTouchEnd: this.handleClearValue }, /* @__PURE__ */ React.createElement(Text, { className: "at-icon at-icon-close-circle at-input__icon-close" })), error && /* @__PURE__ */ React.createElement(
|
|
158
|
+
View,
|
|
159
|
+
{
|
|
160
|
+
className: "at-input__icon",
|
|
161
|
+
onTouchStart: this.handleErrorClick
|
|
162
|
+
},
|
|
163
|
+
/* @__PURE__ */ React.createElement(Text, { className: "at-icon at-icon-alert-circle at-input__icon-alert" })
|
|
164
|
+
), /* @__PURE__ */ React.createElement(View, { className: "at-input__children" }, this.props.children)));
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
AtInput.defaultProps = {
|
|
168
|
+
className: "",
|
|
169
|
+
customStyle: "",
|
|
170
|
+
value: "",
|
|
171
|
+
name: "",
|
|
172
|
+
placeholder: "",
|
|
173
|
+
placeholderStyle: "",
|
|
174
|
+
placeholderClass: "",
|
|
175
|
+
title: "",
|
|
176
|
+
cursorSpacing: 50,
|
|
177
|
+
confirmType: "done",
|
|
178
|
+
selectionStart: -1,
|
|
179
|
+
selectionEnd: -1,
|
|
180
|
+
adjustPosition: true,
|
|
181
|
+
maxlength: 140,
|
|
182
|
+
maxLength: 140,
|
|
183
|
+
type: "text",
|
|
184
|
+
disabled: false,
|
|
185
|
+
border: true,
|
|
186
|
+
editable: true,
|
|
187
|
+
error: false,
|
|
188
|
+
clear: false,
|
|
189
|
+
autoFocus: false,
|
|
190
|
+
focus: false,
|
|
191
|
+
required: false,
|
|
192
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
193
|
+
onChange: () => {
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
AtInput.propTypes = {
|
|
197
|
+
className: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),
|
|
198
|
+
customStyle: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
|
|
199
|
+
value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
200
|
+
name: PropTypes.string,
|
|
201
|
+
placeholder: PropTypes.string,
|
|
202
|
+
placeholderStyle: PropTypes.string,
|
|
203
|
+
placeholderClass: PropTypes.string,
|
|
204
|
+
title: PropTypes.string,
|
|
205
|
+
confirmType: PropTypes.string,
|
|
206
|
+
cursor: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
207
|
+
selectionStart: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
208
|
+
selectionEnd: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
209
|
+
adjustPosition: PropTypes.bool,
|
|
210
|
+
cursorSpacing: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
211
|
+
maxlength: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
212
|
+
maxLength: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
213
|
+
type: PropTypes.string,
|
|
214
|
+
disabled: PropTypes.bool,
|
|
215
|
+
border: PropTypes.bool,
|
|
216
|
+
editable: PropTypes.bool,
|
|
217
|
+
error: PropTypes.bool,
|
|
218
|
+
clear: PropTypes.bool,
|
|
219
|
+
autoFocus: PropTypes.bool,
|
|
220
|
+
focus: PropTypes.bool,
|
|
221
|
+
onChange: PropTypes.func,
|
|
222
|
+
onFocus: PropTypes.func,
|
|
223
|
+
onBlur: PropTypes.func,
|
|
224
|
+
onConfirm: PropTypes.func,
|
|
225
|
+
onErrorClick: PropTypes.func,
|
|
226
|
+
onClick: PropTypes.func,
|
|
227
|
+
required: PropTypes.bool
|
|
228
|
+
};
|
|
229
|
+
export {
|
|
230
|
+
AtInput as default
|
|
231
|
+
};
|
|
232
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/input/index.tsx"],"sourcesContent":["import classNames from 'classnames'\nimport PropTypes, { InferProps } from 'prop-types'\nimport React from 'react'\nimport { Input, Label, Text, View } from '@tarojs/components'\nimport { BaseEventOrig, ITouchEvent } from '@tarojs/components/types/common'\nimport { InputProps } from '@tarojs/components/types/Input'\nimport {\n AtInputProps,\n BlurEventDetail,\n ConfirmEventDetail,\n FocusEventDetail,\n InputEventDetail,\n KeyboardHeightEventDetail\n} from '../../../types/input'\n\ntype PickAtInputProps = Pick<\n AtInputProps,\n 'maxLength' | 'maxlength' | 'disabled' | 'password'\n>\ntype GetInputPropsReturn = PickAtInputProps & Pick<InputProps, 'type'>\n\nfunction getInputProps(props: AtInputProps): GetInputPropsReturn {\n const actualProps = {\n type: props.type,\n maxLength: props.maxLength || props.maxlength,\n disabled: props.disabled,\n password: false\n }\n\n switch (actualProps.type) {\n case 'phone':\n actualProps.type = 'number'\n actualProps.maxLength = 11\n break\n case 'password':\n actualProps.type = 'text'\n actualProps.password = true\n break\n default:\n break\n }\n if (!props.disabled && !props.editable) {\n actualProps.disabled = true\n }\n return actualProps as GetInputPropsReturn\n}\n\nexport default class AtInput extends React.Component<AtInputProps> {\n public static defaultProps: AtInputProps\n public static propTypes: InferProps<AtInputProps>\n // TODO: 有待考证是否为合理方式处理 #840\n private inputClearing = false\n\n private handleInput = (event: BaseEventOrig<InputEventDetail>): void =>\n this.props.onChange?.(event.detail.value, event)\n\n private handleFocus = (event: BaseEventOrig<FocusEventDetail>): void => {\n if (typeof this.props.onFocus === 'function') {\n this.props.onFocus(event.detail.value, event)\n }\n }\n\n private handleBlur = (event: BaseEventOrig<BlurEventDetail>): void => {\n if (typeof this.props.onBlur === 'function') {\n this.props.onBlur(event.detail.value, event)\n }\n if (event.type === 'blur' && !this.inputClearing) {\n // fix # 583 AtInput 不触发 onChange 的问题\n this.props.onChange?.(\n event.detail.value,\n event as BaseEventOrig<InputEventDetail>\n )\n }\n // 还原状态\n this.inputClearing = false\n }\n\n private handleConfirm = (event: BaseEventOrig<ConfirmEventDetail>): void => {\n if (typeof this.props.onConfirm === 'function') {\n this.props.onConfirm(event.detail.value, event)\n }\n }\n\n private handleClick = (event: ITouchEvent): void => {\n if (!this.props.editable && typeof this.props.onClick === 'function') {\n this.props.onClick(event)\n }\n }\n\n private handleClearValue = (event: ITouchEvent): void => {\n this.inputClearing = true\n this.props.onChange?.('', event)\n }\n\n private handleKeyboardHeightChange = (\n event: BaseEventOrig<KeyboardHeightEventDetail>\n ): void => {\n if (typeof this.props.onKeyboardHeightChange === 'function') {\n this.props.onKeyboardHeightChange(event)\n }\n }\n\n private handleErrorClick = (event: ITouchEvent): void => {\n if (typeof this.props.onErrorClick === 'function') {\n this.props.onErrorClick(event)\n }\n }\n\n public render(): JSX.Element {\n const {\n className,\n customStyle,\n name,\n cursorSpacing,\n confirmType,\n cursor,\n selectionStart,\n selectionEnd,\n adjustPosition,\n border,\n title,\n error,\n clear,\n placeholder,\n placeholderStyle,\n placeholderClass,\n autoFocus = false,\n focus = false,\n value,\n required\n } = this.props\n const { type, maxLength, disabled, password } = getInputProps(this.props)\n\n const rootCls = classNames(\n 'at-input',\n {\n 'at-input--without-border': !border\n },\n className\n )\n const containerCls = classNames('at-input__container', {\n 'at-input--error': error,\n 'at-input--disabled': disabled\n })\n // TODO: overlayCls 是否需要移除\n const overlayCls = classNames('at-input__overlay', {\n 'at-input__overlay--hidden': !disabled\n })\n const placeholderCls = classNames('placeholder', placeholderClass)\n\n return (\n <View className={rootCls} style={customStyle}>\n <View className={containerCls}>\n <View className={overlayCls} onClick={this.handleClick}></View>\n {title && (\n <Label\n className={`at-input__title ${\n required && 'at-input__title--required'\n }`}\n for={name}\n >\n {title}\n </Label>\n )}\n <Input\n className='at-input__input'\n id={name}\n name={name}\n type={type}\n disabled={disabled}\n password={password}\n placeholderStyle={placeholderStyle}\n placeholderClass={placeholderCls}\n placeholder={placeholder}\n cursorSpacing={cursorSpacing}\n maxlength={maxLength}\n autoFocus={autoFocus}\n // TODO: 临时解决方案,等 Taro 更新后还原到 focus={focus}\n focus={focus}\n value={value}\n confirmType={confirmType}\n cursor={cursor}\n selectionStart={selectionStart}\n selectionEnd={selectionEnd}\n adjustPosition={adjustPosition}\n onInput={this.handleInput}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n onConfirm={this.handleConfirm}\n onKeyboardHeightChange={this.handleKeyboardHeightChange}\n />\n {clear && value && (\n <View className='at-input__icon' onTouchEnd={this.handleClearValue}>\n <Text className='at-icon at-icon-close-circle at-input__icon-close'></Text>\n </View>\n )}\n {error && (\n <View\n className='at-input__icon'\n onTouchStart={this.handleErrorClick}\n >\n <Text className='at-icon at-icon-alert-circle at-input__icon-alert'></Text>\n </View>\n )}\n <View className='at-input__children'>{this.props.children}</View>\n </View>\n </View>\n )\n }\n}\n\nAtInput.defaultProps = {\n className: '',\n customStyle: '',\n value: '',\n name: '',\n placeholder: '',\n placeholderStyle: '',\n placeholderClass: '',\n title: '',\n cursorSpacing: 50,\n confirmType: 'done',\n selectionStart: -1,\n selectionEnd: -1,\n adjustPosition: true,\n maxlength: 140,\n maxLength: 140,\n type: 'text',\n disabled: false,\n border: true,\n editable: true,\n error: false,\n clear: false,\n autoFocus: false,\n focus: false,\n required: false,\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n onChange: (): void => {}\n}\n\nAtInput.propTypes = {\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n customStyle: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n name: PropTypes.string,\n placeholder: PropTypes.string,\n placeholderStyle: PropTypes.string,\n placeholderClass: PropTypes.string,\n title: PropTypes.string,\n confirmType: PropTypes.string,\n cursor: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n selectionStart: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n selectionEnd: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n adjustPosition: PropTypes.bool,\n cursorSpacing: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxlength: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxLength: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n type: PropTypes.string,\n disabled: PropTypes.bool,\n border: PropTypes.bool,\n editable: PropTypes.bool,\n error: PropTypes.bool,\n clear: PropTypes.bool,\n autoFocus: PropTypes.bool,\n focus: PropTypes.bool,\n onChange: PropTypes.func,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n onConfirm: PropTypes.func,\n onErrorClick: PropTypes.func,\n onClick: PropTypes.func,\n required: PropTypes.bool\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { InferProps } from 'prop-types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { AtInputNumberProps } from '../../../types/input-number';
|
|
4
|
+
export default class AtInputNumber extends React.Component<AtInputNumberProps> {
|
|
5
|
+
static defaultProps: AtInputNumberProps;
|
|
6
|
+
static propTypes: InferProps<AtInputNumberProps>;
|
|
7
|
+
private handleClick;
|
|
8
|
+
private handleValue;
|
|
9
|
+
private handleInput;
|
|
10
|
+
private handleBlur;
|
|
11
|
+
private handleError;
|
|
12
|
+
render(): JSX.Element;
|
|
13
|
+
}
|