tntd 2.7.3 → 2.7.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +72 -0
- package/es/actions/index.js +12 -0
- package/es/actions/index.js.map +1 -0
- package/es/actions/index.less +70 -0
- package/es/check-card/group.js +149 -0
- package/es/check-card/group.js.map +1 -0
- package/es/check-card/index.js +120 -0
- package/es/check-card/index.js.map +1 -0
- package/es/check-card/index.less +179 -0
- package/es/color-picker/ColorPicker.js +1 -1
- package/es/color-picker/ColorPicker.js.map +1 -1
- package/es/color-picker/index.less +1 -1
- package/es/ellipsis/index.js +13 -3
- package/es/ellipsis/index.js.map +1 -1
- package/es/ellipsis/index.less +2 -2
- package/es/handle/handle.js +102 -0
- package/es/handle/handle.js.map +1 -0
- package/es/handle/index.js +20 -9
- package/es/handle/index.js.map +1 -1
- package/es/handle/index.less +1 -1
- package/es/index.js +7 -0
- package/es/index.js.map +1 -1
- package/es/index.less +5 -0
- package/es/locale/en_US.js +3 -1
- package/es/locale/en_US.js.map +1 -1
- package/es/locale/zh_CN.js +3 -1
- package/es/locale/zh_CN.js.map +1 -1
- package/es/mention/index.js +4 -0
- package/es/mention/index.js.map +1 -0
- package/es/page/Box.js +1 -1
- package/es/page/Box.js.map +1 -1
- package/es/page/index.js +1 -1
- package/es/page/index.js.map +1 -1
- package/es/page/index.less +5 -5
- package/es/prev-locale.js +1 -1
- package/es/prev-locale.js.map +1 -1
- package/es/query-form/Field/SelectInput.js +2 -2
- package/es/query-form/Field/SelectInput.js.map +1 -1
- package/es/query-form/Field/index.js +2 -1
- package/es/query-form/Field/index.js.map +1 -1
- package/es/query-list-scene/QueryForm.js +2 -2
- package/es/query-list-scene/QueryForm.js.map +1 -1
- package/es/segmented/index.js +50 -0
- package/es/segmented/index.js.map +1 -0
- package/es/segmented/index.less +138 -0
- package/es/table/constants.js +53 -0
- package/es/table/constants.js.map +1 -1
- package/es/table/context.js.map +1 -1
- package/es/table/hooks/use-column-setting.js.map +1 -1
- package/es/table/table.js +119 -6
- package/es/table/table.js.map +1 -1
- package/es/table/table.less +3 -1
- package/es/table/total-shower.js +6 -0
- package/es/table/total-shower.js.map +1 -0
- package/es/title/index.js +5 -5
- package/es/title/index.js.map +1 -1
- package/es/title/index.less +10 -10
- package/es/tntd-form/Form.js +1 -1
- package/es/tntd-form/Form.js.map +1 -1
- package/es/tntd-form/TntdForm/components/Item.js +42 -30
- package/es/tntd-form/TntdForm/components/ItemComp.js +167 -158
- package/es/tntd-form/TntdForm/components/List.js +89 -78
- package/es/tntd-form/TntdForm/index.js +38 -33
- package/es/tntd-form/TntdForm/interface.js +1 -2
- package/es/tntd-form/TntdForm/store.js +1 -2
- package/es/tntd-form/TntdForm/utils.js +158 -168
- package/es/tntd-modal/index.js +54 -21
- package/es/tntd-modal/index.js.map +1 -1
- package/es/tntd-modal/index.less +83 -63
- package/es/utils/index.js +1 -0
- package/es/utils/index.js.map +1 -1
- package/es/utils/simple-template.js +11 -0
- package/es/utils/simple-template.js.map +1 -0
- package/es/water-mark/index.js +99 -0
- package/es/water-mark/index.js.map +1 -0
- package/lib/actions/index.d.ts +15 -0
- package/lib/actions/index.d.ts.map +1 -0
- package/lib/actions/index.js +17 -0
- package/lib/actions/index.js.map +1 -0
- package/lib/actions/index.less +70 -0
- package/lib/check-card/group.d.ts +130 -0
- package/lib/check-card/group.d.ts.map +1 -0
- package/lib/check-card/group.js +179 -0
- package/lib/check-card/group.js.map +1 -0
- package/lib/check-card/index.d.ts +136 -0
- package/lib/check-card/index.d.ts.map +1 -0
- package/lib/check-card/index.js +148 -0
- package/lib/check-card/index.js.map +1 -0
- package/lib/check-card/index.less +179 -0
- package/lib/color-picker/ColorPicker.js +1 -1
- package/lib/color-picker/ColorPicker.js.map +1 -1
- package/lib/color-picker/index.less +1 -1
- package/lib/ellipsis/index.d.ts.map +1 -1
- package/lib/ellipsis/index.js +13 -3
- package/lib/ellipsis/index.js.map +1 -1
- package/lib/ellipsis/index.less +2 -2
- package/lib/handle/handle.d.ts +3 -0
- package/lib/handle/handle.d.ts.map +1 -0
- package/lib/handle/handle.js +130 -0
- package/lib/handle/handle.js.map +1 -0
- package/lib/handle/index.d.ts.map +1 -1
- package/lib/handle/index.js +20 -9
- package/lib/handle/index.js.map +1 -1
- package/lib/handle/index.less +1 -1
- package/lib/index.d.ts +7 -0
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +11 -1
- package/lib/index.js.map +1 -1
- package/lib/index.less +5 -0
- package/lib/locale/default.d.ts +1 -0
- package/lib/locale/default.d.ts.map +1 -1
- package/lib/locale/en_US.d.ts +1 -0
- package/lib/locale/en_US.d.ts.map +1 -1
- package/lib/locale/en_US.js +3 -1
- package/lib/locale/en_US.js.map +1 -1
- package/lib/locale/zh_CN.d.ts +1 -0
- package/lib/locale/zh_CN.d.ts.map +1 -1
- package/lib/locale/zh_CN.js +3 -1
- package/lib/locale/zh_CN.js.map +1 -1
- package/lib/mention/index.js +25 -0
- package/lib/page/Box.js +1 -1
- package/lib/page/Box.js.map +1 -1
- package/lib/page/index.js +1 -1
- package/lib/page/index.js.map +1 -1
- package/lib/page/index.less +5 -5
- package/lib/prev-locale.js +1 -1
- package/lib/prev-locale.js.map +1 -1
- package/lib/query-form/Field/SelectInput.d.ts.map +1 -1
- package/lib/query-form/Field/SelectInput.js +2 -2
- package/lib/query-form/Field/SelectInput.js.map +1 -1
- package/lib/query-form/Field/index.d.ts.map +1 -1
- package/lib/query-form/Field/index.js +2 -1
- package/lib/query-form/Field/index.js.map +1 -1
- package/lib/query-list-scene/QueryForm.d.ts +1 -1
- package/lib/query-list-scene/QueryForm.d.ts.map +1 -1
- package/lib/query-list-scene/QueryForm.js +2 -2
- package/lib/query-list-scene/QueryForm.js.map +1 -1
- package/lib/segmented/index.d.ts +23 -0
- package/lib/segmented/index.d.ts.map +1 -0
- package/lib/segmented/index.js +78 -0
- package/lib/segmented/index.js.map +1 -0
- package/lib/segmented/index.less +138 -0
- package/lib/table/constants.d.ts +2 -0
- package/lib/table/constants.d.ts.map +1 -1
- package/lib/table/constants.js +54 -1
- package/lib/table/constants.js.map +1 -1
- package/lib/table/context.d.ts +1 -0
- package/lib/table/context.d.ts.map +1 -1
- package/lib/table/context.js.map +1 -1
- package/lib/table/hooks/use-column-setting.d.ts +4 -1
- package/lib/table/hooks/use-column-setting.d.ts.map +1 -1
- package/lib/table/hooks/use-column-setting.js.map +1 -1
- package/lib/table/table.d.ts +2 -1
- package/lib/table/table.d.ts.map +1 -1
- package/lib/table/table.js +119 -6
- package/lib/table/table.js.map +1 -1
- package/lib/table/table.less +3 -1
- package/lib/table/total-shower.d.ts +9 -0
- package/lib/table/total-shower.d.ts.map +1 -0
- package/lib/table/total-shower.js +13 -0
- package/lib/table/total-shower.js.map +1 -0
- package/lib/title/index.d.ts +11 -1
- package/lib/title/index.d.ts.map +1 -1
- package/lib/title/index.js +5 -5
- package/lib/title/index.js.map +1 -1
- package/lib/title/index.less +10 -10
- package/lib/tntd-form/Form.js +1 -1
- package/lib/tntd-form/Form.js.map +1 -1
- package/lib/tntd-form/TntdForm/components/Item.js +55 -61
- package/lib/tntd-form/TntdForm/components/ItemComp.js +203 -190
- package/lib/tntd-form/TntdForm/components/List.js +118 -111
- package/lib/tntd-form/TntdForm/index.js +61 -67
- package/lib/tntd-form/TntdForm/interface.js +4 -2
- package/lib/tntd-form/TntdForm/store.js +8 -7
- package/lib/tntd-form/TntdForm/utils.js +182 -184
- package/lib/tntd-modal/index.d.ts +15 -2
- package/lib/tntd-modal/index.d.ts.map +1 -1
- package/lib/tntd-modal/index.js +58 -23
- package/lib/tntd-modal/index.js.map +1 -1
- package/lib/tntd-modal/index.less +83 -63
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/index.d.ts.map +1 -1
- package/lib/utils/index.js +1 -0
- package/lib/utils/index.js.map +1 -1
- package/lib/utils/simple-template.d.ts +9 -0
- package/lib/utils/simple-template.d.ts.map +1 -0
- package/lib/utils/simple-template.js +15 -0
- package/lib/utils/simple-template.js.map +1 -0
- package/lib/water-mark/index.d.ts +49 -0
- package/lib/water-mark/index.d.ts.map +1 -0
- package/lib/water-mark/index.js +129 -0
- package/lib/water-mark/index.js.map +1 -0
- package/package.json +21 -3
- package/es/_util/colors.js +0 -3
- package/es/_util/colors.js.map +0 -1
- package/es/_util/easings.js +0 -9
- package/es/_util/easings.js.map +0 -1
- package/es/_util/getDataOrAriaProps.js +0 -8
- package/es/_util/getDataOrAriaProps.js.map +0 -1
- package/es/_util/getScroll.js +0 -14
- package/es/_util/getScroll.js.map +0 -1
- package/es/_util/interopDefault.js +0 -5
- package/es/_util/interopDefault.js.map +0 -1
- package/es/_util/isNumeric.js +0 -4
- package/es/_util/isNumeric.js.map +0 -1
- package/es/_util/motion.js +0 -22
- package/es/_util/motion.js.map +0 -1
- package/es/_util/openAnimation.js +0 -51
- package/es/_util/openAnimation.js.map +0 -1
- package/es/_util/raf.js +0 -25
- package/es/_util/raf.js.map +0 -1
- package/es/_util/reactNode.js +0 -6
- package/es/_util/reactNode.js.map +0 -1
- package/es/_util/ref.js +0 -15
- package/es/_util/ref.js.map +0 -1
- package/es/_util/responsiveObserve.js +0 -82
- package/es/_util/responsiveObserve.js.map +0 -1
- package/es/_util/scrollTo.js +0 -29
- package/es/_util/scrollTo.js.map +0 -1
- package/es/_util/styleChecker.js +0 -12
- package/es/_util/styleChecker.js.map +0 -1
- package/es/_util/throttleByAnimationFrame.js +0 -40
- package/es/_util/throttleByAnimationFrame.js.map +0 -1
- package/es/_util/transButton.js +0 -103
- package/es/_util/transButton.js.map +0 -1
- package/es/_util/triggerEvent.js +0 -8
- package/es/_util/triggerEvent.js.map +0 -1
- package/es/_util/type.js +0 -3
- package/es/_util/type.js.map +0 -1
- package/es/_util/warning.js +0 -5
- package/es/_util/warning.js.map +0 -1
- package/es/_util/wave.js +0 -228
- package/es/_util/wave.js.map +0 -1
- package/es/config-provider/context.js +0 -41
- package/es/config-provider/context.js.map +0 -1
- package/es/tntd-form/__tests__/demo-extend.test.js +0 -3
- package/es/tntd-form/__tests__/demo-extend.test.js.map +0 -1
- package/es/tntd-form/__tests__/demo.test.js +0 -3
- package/es/tntd-form/__tests__/demo.test.js.map +0 -1
- package/es/tntd-form/__tests__/image.test.js +0 -5
- package/es/tntd-form/__tests__/image.test.js.map +0 -1
- package/es/tntd-form/__tests__/index.test.js +0 -957
- package/es/tntd-form/__tests__/index.test.js.map +0 -1
- package/es/tntd-form/__tests__/list-noStyle.test.js +0 -41
- package/es/tntd-form/__tests__/list-noStyle.test.js.map +0 -1
- package/es/tntd-form/__tests__/list.test.js +0 -164
- package/es/tntd-form/__tests__/list.test.js.map +0 -1
- package/es/tntd-form/__tests__/ref.test.js +0 -45
- package/es/tntd-form/__tests__/ref.test.js.map +0 -1
- package/es/tntd-form/__tests__/type.test.js +0 -74
- package/es/tntd-form/__tests__/type.test.js.map +0 -1
- package/lib/_util/colors.d.ts +0 -3
- package/lib/_util/colors.d.ts.map +0 -1
- package/lib/_util/colors.js +0 -7
- package/lib/_util/colors.js.map +0 -1
- package/lib/_util/easings.d.ts +0 -2
- package/lib/_util/easings.d.ts.map +0 -1
- package/lib/_util/easings.js +0 -14
- package/lib/_util/easings.js.map +0 -1
- package/lib/_util/getDataOrAriaProps.d.ts +0 -2
- package/lib/_util/getDataOrAriaProps.d.ts.map +0 -1
- package/lib/_util/getDataOrAriaProps.js +0 -13
- package/lib/_util/getDataOrAriaProps.js.map +0 -1
- package/lib/_util/getScroll.d.ts +0 -2
- package/lib/_util/getScroll.d.ts.map +0 -1
- package/lib/_util/getScroll.js +0 -18
- package/lib/_util/getScroll.js.map +0 -1
- package/lib/_util/interopDefault.d.ts +0 -2
- package/lib/_util/interopDefault.d.ts.map +0 -1
- package/lib/_util/interopDefault.js +0 -9
- package/lib/_util/interopDefault.js.map +0 -1
- package/lib/_util/isNumeric.d.ts +0 -3
- package/lib/_util/isNumeric.d.ts.map +0 -1
- package/lib/_util/isNumeric.js +0 -7
- package/lib/_util/isNumeric.js.map +0 -1
- package/lib/_util/motion.d.ts +0 -24
- package/lib/_util/motion.d.ts.map +0 -1
- package/lib/_util/motion.js +0 -17
- package/lib/_util/motion.js.map +0 -1
- package/lib/_util/openAnimation.d.ts +0 -7
- package/lib/_util/openAnimation.d.ts.map +0 -1
- package/lib/_util/openAnimation.js +0 -58
- package/lib/_util/openAnimation.js.map +0 -1
- package/lib/_util/raf.d.ts +0 -10
- package/lib/_util/raf.d.ts.map +0 -1
- package/lib/_util/raf.js +0 -34
- package/lib/_util/raf.js.map +0 -1
- package/lib/_util/reactNode.d.ts +0 -3
- package/lib/_util/reactNode.d.ts.map +0 -1
- package/lib/_util/reactNode.js +0 -31
- package/lib/_util/reactNode.js.map +0 -1
- package/lib/_util/ref.d.ts +0 -4
- package/lib/_util/ref.d.ts.map +0 -1
- package/lib/_util/ref.js +0 -22
- package/lib/_util/ref.js.map +0 -1
- package/lib/_util/responsiveObserve.d.ts +0 -14
- package/lib/_util/responsiveObserve.d.ts.map +0 -1
- package/lib/_util/responsiveObserve.js +0 -83
- package/lib/_util/responsiveObserve.js.map +0 -1
- package/lib/_util/scrollTo.d.ts +0 -11
- package/lib/_util/scrollTo.d.ts.map +0 -1
- package/lib/_util/scrollTo.js +0 -34
- package/lib/_util/scrollTo.js.map +0 -1
- package/lib/_util/styleChecker.d.ts +0 -4
- package/lib/_util/styleChecker.d.ts.map +0 -1
- package/lib/_util/styleChecker.js +0 -14
- package/lib/_util/styleChecker.js.map +0 -1
- package/lib/_util/throttleByAnimationFrame.d.ts +0 -6
- package/lib/_util/throttleByAnimationFrame.d.ts.map +0 -1
- package/lib/_util/throttleByAnimationFrame.js +0 -49
- package/lib/_util/throttleByAnimationFrame.js.map +0 -1
- package/lib/_util/transButton.d.ts +0 -21
- package/lib/_util/transButton.d.ts.map +0 -1
- package/lib/_util/transButton.js +0 -112
- package/lib/_util/transButton.js.map +0 -1
- package/lib/_util/triggerEvent.d.ts +0 -2
- package/lib/_util/triggerEvent.d.ts.map +0 -1
- package/lib/_util/triggerEvent.js +0 -12
- package/lib/_util/triggerEvent.js.map +0 -1
- package/lib/_util/type.d.ts +0 -4
- package/lib/_util/type.d.ts.map +0 -1
- package/lib/_util/type.js +0 -9
- package/lib/_util/type.js.map +0 -1
- package/lib/_util/warning.d.ts +0 -5
- package/lib/_util/warning.d.ts.map +0 -1
- package/lib/_util/warning.js +0 -28
- package/lib/_util/warning.js.map +0 -1
- package/lib/_util/wave.d.ts +0 -26
- package/lib/_util/wave.d.ts.map +0 -1
- package/lib/_util/wave.js +0 -249
- package/lib/_util/wave.js.map +0 -1
- package/lib/config-provider/context.d.ts +0 -61
- package/lib/config-provider/context.d.ts.map +0 -1
- package/lib/config-provider/context.js +0 -64
- package/lib/config-provider/context.js.map +0 -1
- package/lib/tntd-form/TntdForm/components/Item.d.ts +0 -5
- package/lib/tntd-form/TntdForm/components/Item.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/components/Item.js.map +0 -1
- package/lib/tntd-form/TntdForm/components/ItemComp.d.ts +0 -5
- package/lib/tntd-form/TntdForm/components/ItemComp.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/components/ItemComp.js.map +0 -1
- package/lib/tntd-form/TntdForm/components/List.d.ts +0 -5
- package/lib/tntd-form/TntdForm/components/List.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/components/List.js.map +0 -1
- package/lib/tntd-form/TntdForm/index.d.ts +0 -10
- package/lib/tntd-form/TntdForm/index.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/index.js.map +0 -1
- package/lib/tntd-form/TntdForm/interface.d.ts +0 -93
- package/lib/tntd-form/TntdForm/interface.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/interface.js.map +0 -1
- package/lib/tntd-form/TntdForm/store.d.ts +0 -4
- package/lib/tntd-form/TntdForm/store.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/store.js.map +0 -1
- package/lib/tntd-form/TntdForm/utils.d.ts +0 -48
- package/lib/tntd-form/TntdForm/utils.d.ts.map +0 -1
- package/lib/tntd-form/TntdForm/utils.js.map +0 -1
- package/lib/tntd-form/__tests__/demo-extend.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/demo-extend.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/demo-extend.test.js +0 -5
- package/lib/tntd-form/__tests__/demo-extend.test.js.map +0 -1
- package/lib/tntd-form/__tests__/demo.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/demo.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/demo.test.js +0 -8
- package/lib/tntd-form/__tests__/demo.test.js.map +0 -1
- package/lib/tntd-form/__tests__/image.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/image.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/image.test.js +0 -7
- package/lib/tntd-form/__tests__/image.test.js.map +0 -1
- package/lib/tntd-form/__tests__/index.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/index.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/index.test.js +0 -981
- package/lib/tntd-form/__tests__/index.test.js.map +0 -1
- package/lib/tntd-form/__tests__/list-noStyle.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/list-noStyle.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/list-noStyle.test.js +0 -46
- package/lib/tntd-form/__tests__/list-noStyle.test.js.map +0 -1
- package/lib/tntd-form/__tests__/list.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/list.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/list.test.js +0 -169
- package/lib/tntd-form/__tests__/list.test.js.map +0 -1
- package/lib/tntd-form/__tests__/ref.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/ref.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/ref.test.js +0 -50
- package/lib/tntd-form/__tests__/ref.test.js.map +0 -1
- package/lib/tntd-form/__tests__/type.test.d.ts +0 -2
- package/lib/tntd-form/__tests__/type.test.d.ts.map +0 -1
- package/lib/tntd-form/__tests__/type.test.js +0 -98
- package/lib/tntd-form/__tests__/type.test.js.map +0 -1
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
The MIT License (MIT)
|
|
2
|
+
|
|
3
|
+
Copyright (c) rookie
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
# 组件介绍
|
|
2
|
+
tntd是基于 TNT Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
## 如何从 `tntd v1.0` 迁移到 `tntd v2.0`
|
|
6
|
+
|
|
7
|
+
### 安装 `tntd` 最新版本
|
|
8
|
+
|
|
9
|
+
```
|
|
10
|
+
npm install tntd
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
### 更改配置
|
|
14
|
+
|
|
15
|
+
1. 添加 .babelrc 中的 import 插件配置,实现按需引入
|
|
16
|
+
|
|
17
|
+
```diff title=".babelrc"
|
|
18
|
+
+ [
|
|
19
|
+
+ "import",
|
|
20
|
+
+ {
|
|
21
|
+
+ "libraryName": "tntd",
|
|
22
|
+
+ libraryDirectory: 'es',
|
|
23
|
+
+ },
|
|
24
|
+
+ "tntd"
|
|
25
|
+
+ ],
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
2. 更改 webpack.config.js 中的主题配置
|
|
29
|
+
|
|
30
|
+
```diff title="webpack.config.js"
|
|
31
|
+
{
|
|
32
|
+
loader: "less-loader",
|
|
33
|
+
options: {
|
|
34
|
+
javascriptEnabled: true,
|
|
35
|
+
...
|
|
36
|
+
modifyVars: {
|
|
37
|
+
- hack: "true; @import \"~@tntd/antd-cover/tnt.less\";"
|
|
38
|
+
+ hack: "true; @import \"~tntd/themes/default/variables.less\";"
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
3. 修改导入名称
|
|
45
|
+
|
|
46
|
+
Layout, Icon, Select 等 tntd 1.0 组件和 antd 组件名称存在冲突,请按下方例子进行重命名:
|
|
47
|
+
|
|
48
|
+
```diff
|
|
49
|
+
- import { Layout, Icon, Select } from 'tntd'
|
|
50
|
+
+ import { TntdLayout, TntdIcon, TntdSelect } from 'tntd'
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
4. 更改配置
|
|
54
|
+
|
|
55
|
+
```jsx
|
|
56
|
+
// 使用全新的空状态插画
|
|
57
|
+
import { renderEmpty } from 'tntd'
|
|
58
|
+
// 使用内置语言包替换 antd
|
|
59
|
+
// 英文语言包
|
|
60
|
+
const enUS = import 'tntd/es/locale/en_US'
|
|
61
|
+
// 中文语言包
|
|
62
|
+
const zhCN = import 'tntd/es/locale/zh_CN'
|
|
63
|
+
|
|
64
|
+
export const App = () => {
|
|
65
|
+
return (
|
|
66
|
+
// 使用空状态插画及语言包
|
|
67
|
+
<ConfigProvider locale={zhCN} renderEmpty={renderEmpty}>
|
|
68
|
+
...
|
|
69
|
+
</ConfigProvider>
|
|
70
|
+
)
|
|
71
|
+
}
|
|
72
|
+
```
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import classNames from 'classnames';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import './index.less';
|
|
4
|
+
const ProCardActions = (props) => {
|
|
5
|
+
const { actions, prefixCls } = props;
|
|
6
|
+
if (Array.isArray(actions) && (actions === null || actions === void 0 ? void 0 : actions.length)) {
|
|
7
|
+
return (React.createElement("ul", { className: classNames(`${prefixCls}-actions`) }, actions.map((action, index) => (React.createElement("li", { style: { width: `${100 / actions.length}%`, padding: 0, margin: 0 }, key: `action-${index}`, className: classNames(`${prefixCls}-actions-item`) }, action)))));
|
|
8
|
+
}
|
|
9
|
+
return React.createElement("ul", { className: classNames(`${prefixCls}-actions`) }, actions);
|
|
10
|
+
};
|
|
11
|
+
export default ProCardActions;
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/actions/index.tsx"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,cAAc,CAAA;AAarB,MAAM,cAAc,GAAkC,CAAC,KAAK,EAAE,EAAE;IAC9D,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,KAAK,CAAA;IAEpC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,KAAI,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,CAAA,EAAE;QAC7C,OAAO,CACL,4BAAI,SAAS,EAAE,UAAU,CAAC,GAAG,SAAS,UAAU,CAAC,IAC9C,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAC9B,4BACE,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,GAAG,GAAG,OAAO,CAAC,MAAM,GAAG,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EACnE,GAAG,EAAE,UAAU,KAAK,EAAE,EACtB,SAAS,EAAE,UAAU,CAAC,GAAG,SAAS,eAAe,CAAC,IAEjD,MAAM,CACJ,CACN,CAAC,CACC,CACN,CAAA;KACF;IACD,OAAO,4BAAI,SAAS,EAAE,UAAU,CAAC,GAAG,SAAS,UAAU,CAAC,IAAG,OAAO,CAAM,CAAA;AAC1E,CAAC,CAAA;AAED,eAAe,cAAc,CAAA","sourcesContent":["import classNames from 'classnames'\nimport React from 'react'\nimport './index.less'\n\nexport interface ProCardActionsProps {\n /**\n * 自定义前缀\n *\n * @ignore\n */\n prefixCls?: string\n /** 操作按钮 */\n actions?: React.ReactNode[] | React.ReactNode\n}\n\nconst ProCardActions: React.FC<ProCardActionsProps> = (props) => {\n const { actions, prefixCls } = props\n\n if (Array.isArray(actions) && actions?.length) {\n return (\n <ul className={classNames(`${prefixCls}-actions`)}>\n {actions.map((action, index) => (\n <li\n style={{ width: `${100 / actions.length}%`, padding: 0, margin: 0 }}\n key={`action-${index}`}\n className={classNames(`${prefixCls}-actions-item`)}\n >\n {action}\n </li>\n ))}\n </ul>\n )\n }\n return <ul className={classNames(`${prefixCls}-actions`)}>{actions}</ul>\n}\n\nexport default ProCardActions\n"]}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
.tntd-card-actions {
|
|
2
|
+
margin-block:0;
|
|
3
|
+
margin-inline:0;
|
|
4
|
+
padding-block:0;
|
|
5
|
+
padding-inline:0;
|
|
6
|
+
list-style:none;
|
|
7
|
+
display:flex;
|
|
8
|
+
gap:8px;
|
|
9
|
+
background:#ffffff;
|
|
10
|
+
border-block-start:1px solid rgba(5,5,5,0.06);
|
|
11
|
+
min-height:42px;
|
|
12
|
+
}
|
|
13
|
+
.tntd-card-actions>* {
|
|
14
|
+
align-items:center;
|
|
15
|
+
justify-content:center;
|
|
16
|
+
flex:1;
|
|
17
|
+
display:flex;
|
|
18
|
+
cursor:pointer;
|
|
19
|
+
color:rgba(42,46,54,0.65);
|
|
20
|
+
transition:color 0.3s;
|
|
21
|
+
}
|
|
22
|
+
.tntd-card-actions>*:hover {
|
|
23
|
+
color:#468fff;
|
|
24
|
+
}
|
|
25
|
+
.tntd-card-actions>li>div {
|
|
26
|
+
flex:1;
|
|
27
|
+
width:100%;
|
|
28
|
+
margin-block:12px;
|
|
29
|
+
margin-inline:0;
|
|
30
|
+
color:rgba(42,46,54,0.65);
|
|
31
|
+
text-align:center;
|
|
32
|
+
}
|
|
33
|
+
.tntd-card-actions>li>div a {
|
|
34
|
+
color:rgba(42,46,54,0.65);
|
|
35
|
+
transition:color 0.3s;
|
|
36
|
+
}
|
|
37
|
+
.tntd-card-actions>li>div a:hover {
|
|
38
|
+
color:#468fff;
|
|
39
|
+
}
|
|
40
|
+
.tntd-card-actions>li>div div {
|
|
41
|
+
position:relative;
|
|
42
|
+
display:block;
|
|
43
|
+
min-width:32px;
|
|
44
|
+
font-size:14px;
|
|
45
|
+
line-height:1.5714285714285714;
|
|
46
|
+
cursor:pointer;
|
|
47
|
+
}
|
|
48
|
+
.tntd-card-actions>li>div div:hover {
|
|
49
|
+
color:#468fff;
|
|
50
|
+
transition:color 0.3s;
|
|
51
|
+
}
|
|
52
|
+
.tntd-card-actions>li>div div a:not(.ant-btn),
|
|
53
|
+
.tntd-card-actions>li>div div >.anticon {
|
|
54
|
+
display:inline-block;
|
|
55
|
+
width:100%;
|
|
56
|
+
color:rgba(42,46,54,0.65);
|
|
57
|
+
line-height:22px;
|
|
58
|
+
transition:color 0.3s;
|
|
59
|
+
}
|
|
60
|
+
.tntd-card-actions>li>div div a:not(.ant-btn):hover,
|
|
61
|
+
.tntd-card-actions>li>div div >.anticon:hover {
|
|
62
|
+
color:#468fff;
|
|
63
|
+
}
|
|
64
|
+
.tntd-card-actions>li>div div .anticon {
|
|
65
|
+
font-size:16px;
|
|
66
|
+
line-height:22px;
|
|
67
|
+
}
|
|
68
|
+
.tntd-card-actions>li>div:not(:last-child) {
|
|
69
|
+
border-inline-end:1px solid rgba(5,5,5,0.06);
|
|
70
|
+
}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import useMountMergeState from 'rc-util/lib/hooks/useMergedState';
|
|
13
|
+
import { Col, Row } from '../index';
|
|
14
|
+
import classNames from 'classnames';
|
|
15
|
+
import { omit } from 'lodash';
|
|
16
|
+
import React, { createContext, useCallback, useMemo, useRef } from 'react';
|
|
17
|
+
import CheckCard from './index';
|
|
18
|
+
export const CardLoading = ({ prefixCls }) => {
|
|
19
|
+
const loadingBlockClass = `${prefixCls}-loading-block`;
|
|
20
|
+
return (React.createElement("div", { className: `${prefixCls}-loading-content` },
|
|
21
|
+
React.createElement(Row, { gutter: {
|
|
22
|
+
xs: 8,
|
|
23
|
+
sm: 8,
|
|
24
|
+
md: 8,
|
|
25
|
+
lg: 12,
|
|
26
|
+
} },
|
|
27
|
+
React.createElement(Col, { span: 22 },
|
|
28
|
+
React.createElement("div", { className: loadingBlockClass }))),
|
|
29
|
+
React.createElement(Row, { gutter: 8 },
|
|
30
|
+
React.createElement(Col, { span: 8 },
|
|
31
|
+
React.createElement("div", { className: loadingBlockClass })),
|
|
32
|
+
React.createElement(Col, { span: 14 },
|
|
33
|
+
React.createElement("div", { className: loadingBlockClass }))),
|
|
34
|
+
React.createElement(Row, { gutter: 8 },
|
|
35
|
+
React.createElement(Col, { span: 6 },
|
|
36
|
+
React.createElement("div", { className: loadingBlockClass })),
|
|
37
|
+
React.createElement(Col, { span: 16 },
|
|
38
|
+
React.createElement("div", { className: loadingBlockClass }))),
|
|
39
|
+
React.createElement(Row, { gutter: 8 },
|
|
40
|
+
React.createElement(Col, { span: 13 },
|
|
41
|
+
React.createElement("div", { className: loadingBlockClass })),
|
|
42
|
+
React.createElement(Col, { span: 9 },
|
|
43
|
+
React.createElement("div", { className: loadingBlockClass }))),
|
|
44
|
+
React.createElement(Row, { gutter: 8 },
|
|
45
|
+
React.createElement(Col, { span: 4 },
|
|
46
|
+
React.createElement("div", { className: loadingBlockClass })),
|
|
47
|
+
React.createElement(Col, { span: 3 },
|
|
48
|
+
React.createElement("div", { className: loadingBlockClass })),
|
|
49
|
+
React.createElement(Col, { span: 14 },
|
|
50
|
+
React.createElement("div", { className: loadingBlockClass })))));
|
|
51
|
+
};
|
|
52
|
+
export const CheckCardGroupConnext = createContext(null);
|
|
53
|
+
const CheckCardGroup = (props) => {
|
|
54
|
+
const { prefixCls: customizePrefixCls, className, style, options = [], loading = false, multiple = false, bordered = true, onChange } = props, restProps = __rest(props, ["prefixCls", "className", "style", "options", "loading", "multiple", "bordered", "onChange"]);
|
|
55
|
+
const getOptions = useCallback(() => {
|
|
56
|
+
return options === null || options === void 0 ? void 0 : options.map((option) => {
|
|
57
|
+
if (typeof option === 'string') {
|
|
58
|
+
return {
|
|
59
|
+
title: option,
|
|
60
|
+
value: option,
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
return option;
|
|
64
|
+
});
|
|
65
|
+
}, [options]);
|
|
66
|
+
const prefixCls = 'tntd-checkcard';
|
|
67
|
+
const groupPrefixCls = `${prefixCls}-group`;
|
|
68
|
+
const domProps = omit(restProps, ['children', 'defaultValue', 'value', 'disabled', 'size']);
|
|
69
|
+
const [stateValue, setStateValue] = useMountMergeState(props.defaultValue, {
|
|
70
|
+
value: props.value,
|
|
71
|
+
onChange: props.onChange,
|
|
72
|
+
});
|
|
73
|
+
const registerValueMap = useRef(new Map());
|
|
74
|
+
const registerValue = (value) => {
|
|
75
|
+
var _a;
|
|
76
|
+
(_a = registerValueMap.current) === null || _a === void 0 ? void 0 : _a.set(value, true);
|
|
77
|
+
};
|
|
78
|
+
const cancelValue = (value) => {
|
|
79
|
+
var _a;
|
|
80
|
+
(_a = registerValueMap.current) === null || _a === void 0 ? void 0 : _a.delete(value);
|
|
81
|
+
};
|
|
82
|
+
const toggleOption = (option) => {
|
|
83
|
+
var _a;
|
|
84
|
+
if (!multiple) {
|
|
85
|
+
let changeValue;
|
|
86
|
+
changeValue = stateValue;
|
|
87
|
+
// 单选模式
|
|
88
|
+
if (changeValue === option.value) {
|
|
89
|
+
changeValue = undefined;
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
changeValue = option.value;
|
|
93
|
+
}
|
|
94
|
+
setStateValue === null || setStateValue === void 0 ? void 0 : setStateValue(changeValue);
|
|
95
|
+
}
|
|
96
|
+
if (multiple) {
|
|
97
|
+
let changeValue = [];
|
|
98
|
+
const stateValues = stateValue;
|
|
99
|
+
const hasOption = stateValues === null || stateValues === void 0 ? void 0 : stateValues.includes(option.value);
|
|
100
|
+
changeValue = [...(stateValues || [])];
|
|
101
|
+
if (!hasOption) {
|
|
102
|
+
changeValue.push(option.value);
|
|
103
|
+
}
|
|
104
|
+
if (hasOption) {
|
|
105
|
+
changeValue = changeValue.filter((itemValue) => itemValue !== option.value);
|
|
106
|
+
}
|
|
107
|
+
const newOptions = getOptions();
|
|
108
|
+
const newValue = (_a = changeValue === null || changeValue === void 0 ? void 0 : changeValue.filter((val) => registerValueMap.current.has(val))) === null || _a === void 0 ? void 0 : _a.sort((a, b) => {
|
|
109
|
+
const indexA = newOptions.findIndex((opt) => opt.value === a);
|
|
110
|
+
const indexB = newOptions.findIndex((opt) => opt.value === b);
|
|
111
|
+
return indexA - indexB;
|
|
112
|
+
});
|
|
113
|
+
setStateValue(newValue);
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
const children = useMemo(() => {
|
|
117
|
+
if (loading) {
|
|
118
|
+
return new Array(options.length || React.Children.toArray(props.children).length || 1)
|
|
119
|
+
.fill(0)
|
|
120
|
+
.map((_, index) => React.createElement(CheckCard, { key: index, loading: true }));
|
|
121
|
+
}
|
|
122
|
+
if (options && options.length > 0) {
|
|
123
|
+
const optionValue = stateValue;
|
|
124
|
+
return getOptions().map((option) => {
|
|
125
|
+
var _a;
|
|
126
|
+
return (React.createElement(CheckCard, { key: option.value.toString(), disabled: option.disabled, size: (_a = option.size) !== null && _a !== void 0 ? _a : props.size, value: option.value, checked: multiple
|
|
127
|
+
? optionValue === null || optionValue === void 0 ? void 0 : optionValue.includes(option.value)
|
|
128
|
+
: optionValue === option.value, onChange: option.onChange, title: option.title, avatar: option.avatar, description: option.description, cover: option.cover }));
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
return props.children;
|
|
132
|
+
}, [getOptions, loading, multiple, options, props.children, props.size, stateValue]);
|
|
133
|
+
const classString = classNames(groupPrefixCls, className);
|
|
134
|
+
return (React.createElement(CheckCardGroupConnext.Provider, { value: {
|
|
135
|
+
toggleOption,
|
|
136
|
+
bordered,
|
|
137
|
+
value: stateValue,
|
|
138
|
+
disabled: props.disabled,
|
|
139
|
+
size: props.size,
|
|
140
|
+
loading: props.loading,
|
|
141
|
+
multiple: props.multiple,
|
|
142
|
+
// https://github.com/ant-design/ant-design/issues/16376
|
|
143
|
+
registerValue,
|
|
144
|
+
cancelValue,
|
|
145
|
+
} },
|
|
146
|
+
React.createElement("div", Object.assign({ className: classString, style: style }, domProps), children)));
|
|
147
|
+
};
|
|
148
|
+
export default CheckCardGroup;
|
|
149
|
+
//# sourceMappingURL=group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"group.js","sourceRoot":"","sources":["../../src/check-card/group.tsx"],"names":[],"mappings":"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","sourcesContent":["import useMountMergeState from 'rc-util/lib/hooks/useMergedState'\nimport { Col, ConfigProvider, Row } from '../index'\n\nimport classNames from 'classnames'\nimport { omit } from 'lodash'\n\nimport React, { createContext, useCallback, useMemo, useRef } from 'react'\nimport CheckCard from './index'\n\nexport type CheckCardValueType = string | number | boolean\n\nexport type CheckGroupValueType = CheckCardValueType[] | CheckCardValueType | undefined\n\nexport interface CheckCardOptionType {\n /**\n * 标题展示\n *\n * @title 标题\n */\n title?: React.ReactNode\n /**\n * 选项值\n *\n * @title 值\n */\n value: CheckCardValueType\n /**\n * 描述展示\n *\n * @title 描述\n */\n description?: React.ReactNode\n /**\n * 组件尺寸,支持大,中,小三种默认尺寸,用户可以自定义宽高\n *\n * @default default\n * @title 组件尺寸\n */\n size?: 'large' | 'default' | 'small'\n /**\n * 左侧头像展示,可以是一个链接也可以是是一个 ReactNode\n *\n * @title 左侧头像区域\n */\n avatar?: React.ReactNode\n /**\n * 图片封面默认,该模式下其他展示值被忽略\n *\n * @title 图片封面\n */\n cover?: React.ReactNode\n /**\n * 不可用\n *\n * @default false\n * @title 不可用\n */\n disabled?: boolean\n /** Change 回调 */\n onChange?: (checked: boolean) => void\n}\n\nexport interface AbstractCheckCardGroupProps {\n /** @ignore */\n prefixCls?: string\n /** @ignore */\n className?: string\n /** 指定可选项 */\n options?: (CheckCardOptionType | string)[]\n /** 整组失效 */\n disabled?: boolean\n /** @ignore */\n style?: React.CSSProperties\n /**\n * 组件尺寸,支持大,中,小三种默认尺寸,用户可以自定义宽高\n *\n * @default default\n */\n size?: 'large' | 'default' | 'small'\n\n /**\n * @acceptions CheckCard\n * @ignore\n */\n children?: React.ReactNode\n}\n\nexport const CardLoading: React.FC<{\n prefixCls: string\n}> = ({ prefixCls }) => {\n const loadingBlockClass = `${prefixCls}-loading-block`\n return (\n <div className={`${prefixCls}-loading-content`}>\n <Row\n gutter={{\n xs: 8,\n sm: 8,\n md: 8,\n lg: 12,\n }}\n >\n <Col span={22}>\n <div className={loadingBlockClass} />\n </Col>\n </Row>\n <Row gutter={8}>\n <Col span={8}>\n <div className={loadingBlockClass} />\n </Col>\n <Col span={14}>\n <div className={loadingBlockClass} />\n </Col>\n </Row>\n <Row gutter={8}>\n <Col span={6}>\n <div className={loadingBlockClass} />\n </Col>\n <Col span={16}>\n <div className={loadingBlockClass} />\n </Col>\n </Row>\n <Row gutter={8}>\n <Col span={13}>\n <div className={loadingBlockClass} />\n </Col>\n <Col span={9}>\n <div className={loadingBlockClass} />\n </Col>\n </Row>\n <Row gutter={8}>\n <Col span={4}>\n <div className={loadingBlockClass} />\n </Col>\n <Col span={3}>\n <div className={loadingBlockClass} />\n </Col>\n <Col span={14}>\n <div className={loadingBlockClass} />\n </Col>\n </Row>\n </div>\n )\n}\n\nexport interface CheckCardGroupProps extends AbstractCheckCardGroupProps {\n /**\n * 是否多选\n *\n * @title 是否多选\n */\n multiple?: boolean\n /**\n * 默认选中的选项\n *\n * @title 默认选中的选项\n */\n defaultValue?: CheckGroupValueType\n /**\n * 指定选中的选项\n *\n * @title 指定选中的选项\n */\n value?: CheckGroupValueType\n /**\n * 当卡片组内容还在加载中时,可以用 loading 展示一个占位\n *\n * @title 加载中\n */\n loading?: boolean\n /**\n * 是否显示边框\n *\n * @title 显示边框\n */\n bordered?: boolean\n /** 变化时回调函数 */\n onChange?: (checkedValue: CheckGroupValueType) => void\n}\n\nexport interface CheckCardGroupState {\n value: CheckGroupValueType\n registeredValues: CheckCardValueType[]\n}\n\nexport interface CheckCardGroupConnextType {\n toggleOption?: (option: CheckCardOptionType) => void\n value?: any\n disabled?: boolean\n size?: 'default' | 'large' | 'small'\n loading?: boolean\n bordered?: boolean\n multiple?: boolean\n registerValue?: (value: any) => void\n cancelValue?: (value: any) => void\n}\n\nexport const CheckCardGroupConnext = createContext<CheckCardGroupConnextType | null>(null)\n\nconst CheckCardGroup: React.FC<CheckCardGroupProps> = (props) => {\n const {\n prefixCls: customizePrefixCls,\n className,\n style,\n options = [],\n loading = false,\n multiple = false,\n bordered = true,\n onChange,\n ...restProps\n } = props\n\n const getOptions = useCallback(() => {\n return (options as CheckCardOptionType[])?.map((option) => {\n if (typeof option === 'string') {\n return {\n title: option,\n value: option,\n } as CheckCardOptionType\n }\n return option\n })\n }, [options])\n\n const prefixCls = 'tntd-checkcard'\n const groupPrefixCls = `${prefixCls}-group`\n const domProps = omit(restProps, ['children', 'defaultValue', 'value', 'disabled', 'size'])\n\n const [stateValue, setStateValue] = useMountMergeState<\n CheckCardValueType[] | CheckCardValueType | undefined\n >(props.defaultValue, {\n value: props.value,\n onChange: props.onChange,\n })\n\n const registerValueMap = useRef<Map<CheckCardValueType, any>>(new Map())\n\n const registerValue = (value: string) => {\n registerValueMap.current?.set(value, true)\n }\n\n const cancelValue = (value: string) => {\n registerValueMap.current?.delete(value)\n }\n\n const toggleOption = (option: CheckCardOptionType) => {\n if (!multiple) {\n let changeValue\n\n changeValue = stateValue\n // 单选模式\n if (changeValue === option.value) {\n changeValue = undefined\n } else {\n changeValue = option.value\n }\n setStateValue?.(changeValue)\n }\n\n if (multiple) {\n let changeValue = []\n const stateValues = stateValue as CheckCardValueType[]\n const hasOption = stateValues?.includes(option.value)\n changeValue = [...(stateValues || [])]\n if (!hasOption) {\n changeValue.push(option.value)\n }\n if (hasOption) {\n changeValue = changeValue.filter((itemValue) => itemValue !== option.value)\n }\n const newOptions = getOptions()\n const newValue = changeValue\n ?.filter((val) => registerValueMap.current.has(val))\n ?.sort((a, b) => {\n const indexA = newOptions.findIndex((opt) => opt.value === a)\n const indexB = newOptions.findIndex((opt) => opt.value === b)\n return indexA - indexB\n })\n\n setStateValue(newValue)\n }\n }\n\n const children = useMemo((): React.ReactNode => {\n if (loading) {\n return new Array(options.length || React.Children.toArray(props.children).length || 1)\n .fill(0)\n .map((_, index) => <CheckCard key={index} loading />) as React.ReactNode[]\n }\n\n if (options && options.length > 0) {\n const optionValue = stateValue as CheckCardValueType[] | CheckCardValueType\n return getOptions().map((option) => (\n <CheckCard\n key={option.value.toString()}\n disabled={option.disabled}\n size={option.size ?? props.size}\n value={option.value}\n checked={\n multiple\n ? (optionValue as CheckCardValueType[])?.includes(option.value)\n : (optionValue as CheckCardValueType) === option.value\n }\n onChange={option.onChange}\n title={option.title}\n avatar={option.avatar}\n description={option.description}\n cover={option.cover}\n />\n )) as React.ReactNode[]\n }\n return props.children as React.ReactNode\n }, [getOptions, loading, multiple, options, props.children, props.size, stateValue])\n\n const classString = classNames(groupPrefixCls, className)\n\n return (\n <CheckCardGroupConnext.Provider\n value={{\n toggleOption,\n bordered,\n value: stateValue,\n disabled: props.disabled,\n size: props.size,\n loading: props.loading,\n multiple: props.multiple,\n // https://github.com/ant-design/ant-design/issues/16376\n registerValue,\n cancelValue,\n }}\n >\n <div className={classString} style={style} {...domProps}>\n {children}\n </div>\n </CheckCardGroupConnext.Provider>\n )\n}\n\nexport default CheckCardGroup\n"]}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import useMountMergeState from 'rc-util/lib/hooks/useMergedState';
|
|
13
|
+
import { Avatar } from 'antd';
|
|
14
|
+
import classNames from 'classnames';
|
|
15
|
+
import React, { useContext, useEffect, useMemo } from 'react';
|
|
16
|
+
import ProCardActions from '../actions';
|
|
17
|
+
import CheckCardGroup, { CardLoading, CheckCardGroupConnext } from './group';
|
|
18
|
+
import './index.less';
|
|
19
|
+
const CheckCard = (props) => {
|
|
20
|
+
var _a;
|
|
21
|
+
const [stateChecked, setStateChecked] = useMountMergeState(props.defaultChecked || false, {
|
|
22
|
+
value: props.checked,
|
|
23
|
+
onChange: props.onChange,
|
|
24
|
+
});
|
|
25
|
+
const checkCardGroup = useContext(CheckCardGroupConnext);
|
|
26
|
+
const handleClick = (e) => {
|
|
27
|
+
var _a, _b;
|
|
28
|
+
(_a = props === null || props === void 0 ? void 0 : props.onClick) === null || _a === void 0 ? void 0 : _a.call(props, e);
|
|
29
|
+
const newChecked = !stateChecked;
|
|
30
|
+
(_b = checkCardGroup === null || checkCardGroup === void 0 ? void 0 : checkCardGroup.toggleOption) === null || _b === void 0 ? void 0 : _b.call(checkCardGroup, { value: props.value });
|
|
31
|
+
setStateChecked === null || setStateChecked === void 0 ? void 0 : setStateChecked(newChecked, e);
|
|
32
|
+
};
|
|
33
|
+
// small => sm large => lg
|
|
34
|
+
const getSizeCls = (size) => {
|
|
35
|
+
if (size === 'large')
|
|
36
|
+
return 'lg';
|
|
37
|
+
if (size === 'small')
|
|
38
|
+
return 'sm';
|
|
39
|
+
return '';
|
|
40
|
+
};
|
|
41
|
+
useEffect(() => {
|
|
42
|
+
var _a;
|
|
43
|
+
(_a = checkCardGroup === null || checkCardGroup === void 0 ? void 0 : checkCardGroup.registerValue) === null || _a === void 0 ? void 0 : _a.call(checkCardGroup, props.value);
|
|
44
|
+
return () => { var _a; return (_a = checkCardGroup === null || checkCardGroup === void 0 ? void 0 : checkCardGroup.cancelValue) === null || _a === void 0 ? void 0 : _a.call(checkCardGroup, props.value); };
|
|
45
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
46
|
+
}, [props.value]);
|
|
47
|
+
/**
|
|
48
|
+
* 头像自定义
|
|
49
|
+
*
|
|
50
|
+
* @param prefixCls
|
|
51
|
+
* @param cover
|
|
52
|
+
* @returns
|
|
53
|
+
*/
|
|
54
|
+
const renderCover = (prefixCls, cover) => {
|
|
55
|
+
return (React.createElement("div", { className: `${prefixCls}-cover` }, typeof cover === 'string' ? React.createElement("img", { src: cover, alt: "tntd-checkcard" }) : cover));
|
|
56
|
+
};
|
|
57
|
+
const { prefixCls: customizePrefixCls, className, avatar, title, description, cover, extra, style = {} } = props, others = __rest(props, ["prefixCls", "className", "avatar", "title", "description", "cover", "extra", "style"]);
|
|
58
|
+
const checkCardProps = Object.assign({}, others);
|
|
59
|
+
const prefixCls = 'tntd-checkcard';
|
|
60
|
+
checkCardProps.checked = stateChecked;
|
|
61
|
+
let multiple = false;
|
|
62
|
+
if (checkCardGroup) {
|
|
63
|
+
// 受组控制模式
|
|
64
|
+
checkCardProps.disabled = props.disabled || checkCardGroup.disabled;
|
|
65
|
+
checkCardProps.loading = props.loading || checkCardGroup.loading;
|
|
66
|
+
checkCardProps.bordered = props.bordered || checkCardGroup.bordered;
|
|
67
|
+
multiple = checkCardGroup.multiple;
|
|
68
|
+
const isChecked = checkCardGroup.multiple
|
|
69
|
+
? (_a = checkCardGroup.value) === null || _a === void 0 ? void 0 : _a.includes(props.value)
|
|
70
|
+
: checkCardGroup.value === props.value;
|
|
71
|
+
// loading时check为false
|
|
72
|
+
checkCardProps.checked = checkCardProps.loading ? false : isChecked;
|
|
73
|
+
checkCardProps.size = props.size || checkCardGroup.size;
|
|
74
|
+
}
|
|
75
|
+
const { disabled = false, size, loading: cardLoading, bordered = true, checked } = checkCardProps;
|
|
76
|
+
const sizeCls = getSizeCls(size);
|
|
77
|
+
const classString = classNames(prefixCls, className, {
|
|
78
|
+
[`${prefixCls}-loading`]: cardLoading,
|
|
79
|
+
[`${prefixCls}-${sizeCls}`]: sizeCls,
|
|
80
|
+
[`${prefixCls}-checked`]: checked,
|
|
81
|
+
[`${prefixCls}-multiple`]: multiple,
|
|
82
|
+
[`${prefixCls}-disabled`]: disabled,
|
|
83
|
+
[`${prefixCls}-bordered`]: bordered,
|
|
84
|
+
[`${prefixCls}-ghost`]: props.ghost,
|
|
85
|
+
});
|
|
86
|
+
const metaDom = useMemo(() => {
|
|
87
|
+
if (cardLoading) {
|
|
88
|
+
return React.createElement(CardLoading, { prefixCls: prefixCls || '' });
|
|
89
|
+
}
|
|
90
|
+
if (cover) {
|
|
91
|
+
return renderCover(prefixCls || '', cover);
|
|
92
|
+
}
|
|
93
|
+
const avatarDom = avatar ? (React.createElement("div", { className: `${prefixCls}-avatar` }, typeof avatar === 'string' ? React.createElement(Avatar, { size: 48, shape: "square", src: avatar }) : avatar)) : null;
|
|
94
|
+
const headerDom = (title !== null && title !== void 0 ? title : extra) != null && (React.createElement("div", { className: `${prefixCls}-header` },
|
|
95
|
+
React.createElement("div", { className: `${prefixCls}-header-left` },
|
|
96
|
+
React.createElement("div", { className: `${prefixCls}-title` }, title),
|
|
97
|
+
props.subTitle ? React.createElement("div", { className: `${prefixCls}-subTitle` }, props.subTitle) : null),
|
|
98
|
+
extra && React.createElement("div", { className: `${prefixCls}-extra` }, extra)));
|
|
99
|
+
const descriptionDom = description ? (React.createElement("div", { className: `${prefixCls}-description` }, description)) : null;
|
|
100
|
+
const metaClass = classNames(`${prefixCls}-content`, {
|
|
101
|
+
[`${prefixCls}-avatar-header`]: avatarDom && headerDom && !descriptionDom,
|
|
102
|
+
});
|
|
103
|
+
return (React.createElement("div", { className: metaClass },
|
|
104
|
+
avatarDom,
|
|
105
|
+
headerDom || descriptionDom ? (React.createElement("div", { className: `${prefixCls}-detail` },
|
|
106
|
+
headerDom,
|
|
107
|
+
descriptionDom)) : null));
|
|
108
|
+
}, [avatar, cardLoading, cover, description, extra, prefixCls, props.subTitle, title]);
|
|
109
|
+
return (React.createElement("div", { className: classString, style: style, onClick: (e) => {
|
|
110
|
+
if (!cardLoading && !disabled) {
|
|
111
|
+
handleClick(e);
|
|
112
|
+
}
|
|
113
|
+
}, onMouseEnter: props.onMouseEnter },
|
|
114
|
+
metaDom,
|
|
115
|
+
props.children ? (React.createElement("div", { className: classNames(`${prefixCls}-body`), style: props.bodyStyle }, props.children)) : null,
|
|
116
|
+
props.actions ? React.createElement(ProCardActions, { actions: props.actions, prefixCls: prefixCls }) : null));
|
|
117
|
+
};
|
|
118
|
+
CheckCard.Group = CheckCardGroup;
|
|
119
|
+
export default CheckCard;
|
|
120
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/check-card/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import useMountMergeState from 'rc-util/lib/hooks/useMergedState'\nimport { Avatar, ConfigProvider } from 'antd'\nimport classNames from 'classnames'\nimport type { MouseEventHandler } from 'react'\nimport React, { useContext, useEffect, useMemo } from 'react'\nimport ProCardActions from '../actions'\nimport type { CheckCardGroupProps } from './group'\nimport CheckCardGroup, { CardLoading, CheckCardGroupConnext } from './group'\nimport './index.less'\n\ninterface CheckCardProps {\n /**\n * 自定义前缀\n *\n * @ignore\n */\n prefixCls?: string\n /** Change 回调 */\n onChange?: (checked: boolean) => void\n /** Click 回调 */\n onClick?: (event: MouseEventHandler<HTMLDivElement> | undefined) => void\n /** 鼠标进入时的回调 */\n onMouseEnter?: MouseEventHandler<HTMLDivElement>\n /** 鼠标出来时的回调 */\n onMouseLeave?: (event: MouseEventHandler<HTMLDivElement> | undefined) => void\n /**\n * 默认是否勾选\n *\n * @default false\n * @title 默认勾选\n */\n defaultChecked?: boolean\n /**\n * 强制勾选\n *\n * @default false\n * @title 强制勾选\n */\n checked?: boolean\n /**\n * 不可用\n *\n * @default false\n * @title 禁用\n */\n disabled?: boolean\n /**\n * 选项卡样式\n *\n * @ignore\n */\n style?: React.CSSProperties\n /**\n * 选项卡 className\n *\n * @ignore\n */\n className?: string\n /**\n * 左侧头像展示,可以是一个链接也可以是是一个 ReactNode\n *\n * @title 头像\n */\n avatar?: React.ReactNode\n /**\n * 标题展示\n *\n * @title 标题\n */\n title?: React.ReactNode\n /**\n * 二级标题展示\n *\n * @title 二级标题\n */\n subTitle?: React.ReactNode\n /**\n * 描述展示\n *\n * @title 描述\n */\n description?: React.ReactNode\n /**\n * 选项值\n *\n * @title 值\n */\n value?: any\n /**\n * 内容是否在加载中\n *\n * @default false\n * @title 加载中\n */\n loading?: boolean\n /**\n * 图片封面默认,该模式下其他展示值被忽略\n *\n * @title 卡片背景图片\n */\n cover?: React.ReactNode\n /**\n * 组件尺寸,支持大,中,小三种默认尺寸,用户可以自定义宽高\n *\n * @default default\n * @title 选择框大小\n */\n size?: 'large' | 'default' | 'small'\n /**\n * 是否显示边框\n *\n * @default true\n * @title 显示边框\n */\n bordered?: boolean\n /**\n * 卡片右上角的操作区域\n *\n * @title 操作栏\n */\n extra?: React.ReactNode\n\n children?: React.ReactNode\n /**\n * 内容区域的样式设计\n */\n bodyStyle?: React.CSSProperties\n /**\n * 右下角的操作区\n */\n actions?: React.ReactNode[]\n\n ghost?: boolean\n}\n\nexport interface CheckCardState {\n checked: boolean\n}\n\nconst CheckCard: React.FC<CheckCardProps> & {\n Group: typeof CheckCardGroup\n} = (props) => {\n const [stateChecked, setStateChecked] = useMountMergeState<boolean>(\n props.defaultChecked || false,\n {\n value: props.checked,\n onChange: props.onChange,\n }\n )\n const checkCardGroup = useContext(CheckCardGroupConnext)\n\n const handleClick = (e: any) => {\n props?.onClick?.(e)\n const newChecked = !stateChecked\n checkCardGroup?.toggleOption?.({ value: props.value })\n setStateChecked?.(newChecked, e)\n }\n\n // small => sm large => lg\n const getSizeCls = (size?: string) => {\n if (size === 'large') return 'lg'\n if (size === 'small') return 'sm'\n return ''\n }\n\n useEffect(() => {\n checkCardGroup?.registerValue?.(props.value)\n return () => checkCardGroup?.cancelValue?.(props.value)\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [props.value])\n\n /**\n * 头像自定义\n *\n * @param prefixCls\n * @param cover\n * @returns\n */\n const renderCover = (prefixCls: string, cover: string | React.ReactNode) => {\n return (\n <div className={`${prefixCls}-cover`}>\n {typeof cover === 'string' ? <img src={cover} alt=\"tntd-checkcard\" /> : cover}\n </div>\n )\n }\n\n const {\n prefixCls: customizePrefixCls,\n className,\n avatar,\n title,\n description,\n cover,\n extra,\n style = {},\n ...others\n } = props\n\n const checkCardProps: CheckCardProps = { ...others }\n const prefixCls = 'tntd-checkcard'\n checkCardProps.checked = stateChecked\n\n let multiple: boolean | undefined = false\n\n if (checkCardGroup) {\n // 受组控制模式\n checkCardProps.disabled = props.disabled || checkCardGroup.disabled\n checkCardProps.loading = props.loading || checkCardGroup.loading\n checkCardProps.bordered = props.bordered || checkCardGroup.bordered\n\n multiple = checkCardGroup.multiple\n\n const isChecked = checkCardGroup.multiple\n ? checkCardGroup.value?.includes(props.value)\n : checkCardGroup.value === props.value\n\n // loading时check为false\n checkCardProps.checked = checkCardProps.loading ? false : isChecked\n checkCardProps.size = props.size || checkCardGroup.size\n }\n\n const { disabled = false, size, loading: cardLoading, bordered = true, checked } = checkCardProps\n const sizeCls = getSizeCls(size)\n\n const classString = classNames(prefixCls, className, {\n [`${prefixCls}-loading`]: cardLoading,\n [`${prefixCls}-${sizeCls}`]: sizeCls,\n [`${prefixCls}-checked`]: checked,\n [`${prefixCls}-multiple`]: multiple,\n [`${prefixCls}-disabled`]: disabled,\n [`${prefixCls}-bordered`]: bordered,\n [`${prefixCls}-ghost`]: props.ghost,\n })\n\n const metaDom = useMemo(() => {\n if (cardLoading) {\n return <CardLoading prefixCls={prefixCls || ''} />\n }\n\n if (cover) {\n return renderCover(prefixCls || '', cover)\n }\n\n const avatarDom = avatar ? (\n <div className={`${prefixCls}-avatar`}>\n {typeof avatar === 'string' ? <Avatar size={48} shape=\"square\" src={avatar} /> : avatar}\n </div>\n ) : null\n\n const headerDom = (title ?? extra) != null && (\n <div className={`${prefixCls}-header`}>\n <div className={`${prefixCls}-header-left`}>\n <div className={`${prefixCls}-title`}>{title}</div>\n {props.subTitle ? <div className={`${prefixCls}-subTitle`}>{props.subTitle}</div> : null}\n </div>\n {extra && <div className={`${prefixCls}-extra`}>{extra}</div>}\n </div>\n )\n\n const descriptionDom = description ? (\n <div className={`${prefixCls}-description`}>{description}</div>\n ) : null\n\n const metaClass = classNames(`${prefixCls}-content`, {\n [`${prefixCls}-avatar-header`]: avatarDom && headerDom && !descriptionDom,\n })\n\n return (\n <div className={metaClass}>\n {avatarDom}\n {headerDom || descriptionDom ? (\n <div className={`${prefixCls}-detail`}>\n {headerDom}\n {descriptionDom}\n </div>\n ) : null}\n </div>\n )\n }, [avatar, cardLoading, cover, description, extra, prefixCls, props.subTitle, title])\n\n return (\n <div\n className={classString}\n style={style}\n onClick={(e) => {\n if (!cardLoading && !disabled) {\n handleClick(e)\n }\n }}\n onMouseEnter={props.onMouseEnter}\n >\n {metaDom}\n {props.children ? (\n <div className={classNames(`${prefixCls}-body`)} style={props.bodyStyle}>\n {props.children}\n </div>\n ) : null}\n {props.actions ? <ProCardActions actions={props.actions} prefixCls={prefixCls} /> : null}\n </div>\n )\n}\n\nCheckCard.Group = CheckCardGroup\n\nexport type { CheckCardGroupProps, CheckCardProps }\n\nexport default CheckCard\n"]}
|