amis 1.4.2-beta.1 → 1.4.2-beta.15
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/lib/Schema.d.ts +11 -3
- package/lib/Schema.js.map +1 -1
- package/lib/components/AnchorNav.d.ts +22 -21
- package/lib/components/AnchorNav.js +7 -3
- package/lib/components/AnchorNav.js.map +2 -2
- package/lib/components/ArrayInput.d.ts +84 -84
- package/lib/components/AssociatedSelection.d.ts +930 -0
- package/lib/components/AssociatedSelection.js +89 -0
- package/lib/components/AssociatedSelection.js.map +13 -0
- package/lib/components/Badge.js +2 -2
- package/lib/components/Badge.js.map +2 -2
- package/lib/components/{ChainedCheckboxes.d.ts → ChainedSelection.d.ts} +267 -98
- package/lib/components/{ChainedCheckboxes.js → ChainedSelection.js} +30 -24
- package/lib/components/ChainedSelection.js.map +13 -0
- package/lib/components/Checkbox.d.ts +20 -20
- package/lib/components/Collapse.d.ts +51 -23
- package/lib/components/Collapse.js +69 -11
- package/lib/components/Collapse.js.map +2 -2
- package/lib/components/CollapseGroup.d.ts +88 -0
- package/lib/components/CollapseGroup.js +81 -0
- package/lib/components/CollapseGroup.js.map +13 -0
- package/lib/components/ColorPicker.d.ts +84 -84
- package/lib/components/DatePicker.d.ts +84 -84
- package/lib/components/DateRangePicker.d.ts +84 -84
- package/lib/components/Editor.d.ts +84 -84
- package/lib/components/GridNav.d.ts +52 -0
- package/lib/components/GridNav.js +123 -0
- package/lib/components/GridNav.js.map +13 -0
- package/lib/components/GroupedSelection.d.ts +907 -0
- package/lib/components/GroupedSelection.js +48 -0
- package/lib/components/GroupedSelection.js.map +13 -0
- package/lib/components/InputBox.d.ts +22 -21
- package/lib/components/InputBox.js +10 -2
- package/lib/components/InputBox.js.map +2 -2
- package/lib/components/Link.d.ts +29 -36
- package/lib/components/Link.js +14 -15
- package/lib/components/Link.js.map +2 -2
- package/lib/components/ListGroup.d.ts +21 -21
- package/lib/components/ModalManager.js +1 -1
- package/lib/components/ModalManager.js.map +2 -2
- package/lib/components/MonthRangePicker.d.ts +84 -84
- package/lib/components/NumberInput.d.ts +20 -20
- package/lib/components/PickerColumn.d.ts +514 -0
- package/lib/components/PickerColumn.js +279 -0
- package/lib/components/PickerColumn.js.map +13 -0
- package/lib/components/PickerContainer.d.ts +513 -0
- package/lib/components/PickerContainer.js +96 -0
- package/lib/components/PickerContainer.js.map +13 -0
- package/lib/components/Radios.d.ts +22 -21
- package/lib/components/Radios.js +1 -0
- package/lib/components/Radios.js.map +2 -2
- package/lib/components/Rating.d.ts +21 -21
- package/lib/components/ResultBox.d.ts +84 -84
- package/lib/components/ResultBox.js +10 -2
- package/lib/components/ResultBox.js.map +2 -2
- package/lib/components/SearchBox.d.ts +84 -84
- package/lib/components/SearchBox.js +4 -4
- package/lib/components/SearchBox.js.map +2 -2
- package/lib/components/Select.d.ts +245 -237
- package/lib/components/Select.js +25 -4
- package/lib/components/Select.js.map +2 -2
- package/lib/components/{Checkboxes.d.ts → Selection.d.ts} +273 -98
- package/lib/components/Selection.js +134 -0
- package/lib/components/Selection.js.map +13 -0
- package/lib/components/{TableCheckboxes.d.ts → TableSelection.d.ts} +266 -96
- package/lib/components/{TableCheckboxes.js → TableSelection.js} +30 -30
- package/lib/components/TableSelection.js.map +13 -0
- package/lib/components/Tabs.d.ts +20 -20
- package/lib/components/TabsTransfer.d.ts +84 -84
- package/lib/components/TabsTransfer.js +9 -9
- package/lib/components/TabsTransfer.js.map +2 -2
- package/lib/components/TabsTransferPicker.d.ts +489 -0
- package/lib/components/TabsTransferPicker.js +60 -0
- package/lib/components/TabsTransferPicker.js.map +13 -0
- package/lib/components/Toast.d.ts +86 -85
- package/lib/components/Toast.js +6 -3
- package/lib/components/Toast.js.map +2 -2
- package/lib/components/Transfer.d.ts +908 -274
- package/lib/components/Transfer.js +31 -24
- package/lib/components/Transfer.js.map +2 -2
- package/lib/components/TransferDropDown.d.ts +488 -0
- package/lib/components/TransferDropDown.js +59 -0
- package/lib/components/TransferDropDown.js.map +13 -0
- package/lib/components/TransferPicker.d.ts +493 -0
- package/lib/components/TransferPicker.js +60 -0
- package/lib/components/TransferPicker.js.map +13 -0
- package/lib/components/Tree.d.ts +115 -84
- package/lib/components/Tree.js +183 -30
- package/lib/components/Tree.js.map +2 -2
- package/lib/components/{TreeCheckboxes.d.ts → TreeSelection.d.ts} +269 -99
- package/lib/components/{TreeCheckboxes.js → TreeSelection.js} +36 -32
- package/lib/components/TreeSelection.js.map +13 -0
- package/lib/components/WithRemoteConfig.js +1 -1
- package/lib/components/WithRemoteConfig.js.map +2 -2
- package/lib/components/condition-builder/Field.js +5 -2
- package/lib/components/condition-builder/Field.js.map +2 -2
- package/lib/components/condition-builder/Func.js +2 -2
- package/lib/components/condition-builder/Func.js.map +2 -2
- package/lib/components/condition-builder/InputSwitch.js +2 -2
- package/lib/components/condition-builder/InputSwitch.js.map +2 -2
- package/lib/components/condition-builder/Item.js +3 -3
- package/lib/components/condition-builder/Item.js.map +2 -2
- package/lib/components/icons.js +2 -0
- package/lib/components/icons.js.map +2 -2
- package/lib/components/index.d.ts +8 -8
- package/lib/components/index.js +16 -16
- package/lib/components/index.js.map +2 -2
- package/lib/envOverwrite.d.ts +1 -1
- package/lib/envOverwrite.js +24 -9
- package/lib/envOverwrite.js.map +2 -2
- package/lib/factory.d.ts +15 -1
- package/lib/factory.js +35 -6
- package/lib/factory.js.map +2 -2
- package/lib/helper.css.map +1 -1
- package/lib/hooks/index.d.ts +5 -0
- package/lib/hooks/index.js +14 -0
- package/lib/hooks/index.js.map +13 -0
- package/lib/hooks/use-set-state.d.ts +2 -0
- package/lib/hooks/use-set-state.js +15 -0
- package/lib/hooks/use-set-state.js.map +13 -0
- package/lib/hooks/use-touch.d.ts +16 -0
- package/lib/hooks/use-touch.js +73 -0
- package/lib/hooks/use-touch.js.map +13 -0
- package/lib/hooks/use-update-effect.d.ts +3 -0
- package/lib/hooks/use-update-effect.js +17 -0
- package/lib/hooks/use-update-effect.js.map +13 -0
- package/lib/icons/download.js +7 -0
- package/lib/icons/drag-bar.js +10 -3
- package/lib/index.d.ts +5 -0
- package/lib/index.js +6 -1
- package/lib/index.js.map +2 -2
- package/lib/locale/de-DE.js +2 -0
- package/lib/locale/de-DE.js.map +2 -2
- package/lib/locale/en-US.js +3 -0
- package/lib/locale/en-US.js.map +2 -2
- package/lib/locale/zh-CN.js +5 -2
- package/lib/locale/zh-CN.js.map +2 -2
- package/lib/renderers/Action.d.ts +4 -3
- package/lib/renderers/Action.js +17 -4
- package/lib/renderers/Action.js.map +2 -2
- package/lib/renderers/AnchorNav.d.ts +1 -0
- package/lib/renderers/AnchorNav.js +2 -2
- package/lib/renderers/AnchorNav.js.map +2 -2
- package/lib/renderers/Avatar.js +3 -3
- package/lib/renderers/Avatar.js.map +2 -2
- package/lib/renderers/Breadcrumb.js +1 -1
- package/lib/renderers/Breadcrumb.js.map +2 -2
- package/lib/renderers/CRUD.d.ts +9 -0
- package/lib/renderers/CRUD.js +24 -4
- package/lib/renderers/CRUD.js.map +2 -2
- package/lib/renderers/Card.d.ts +4 -0
- package/lib/renderers/Card.js +29 -23
- package/lib/renderers/Card.js.map +2 -2
- package/lib/renderers/Chart.js +1 -1
- package/lib/renderers/Chart.js.map +2 -2
- package/lib/renderers/Collapse.d.ts +25 -20
- package/lib/renderers/Collapse.js +10 -72
- package/lib/renderers/Collapse.js.map +2 -2
- package/lib/renderers/CollapseGroup.d.ts +42 -0
- package/lib/renderers/CollapseGroup.js +33 -0
- package/lib/renderers/CollapseGroup.js.map +13 -0
- package/lib/renderers/DropDownButton.js +1 -1
- package/lib/renderers/DropDownButton.js.map +2 -2
- package/lib/renderers/Form/DiffEditor.d.ts +4 -3
- package/lib/renderers/Form/Editor.d.ts +3 -2
- package/lib/renderers/Form/InputCity.d.ts +84 -84
- package/lib/renderers/Form/InputCity.js +7 -6
- package/lib/renderers/Form/InputCity.js.map +2 -2
- package/lib/renderers/Form/InputColor.d.ts +84 -84
- package/lib/renderers/Form/InputFile.d.ts +6 -0
- package/lib/renderers/Form/InputFile.js +28 -8
- package/lib/renderers/Form/InputFile.js.map +2 -2
- package/lib/renderers/Form/InputImage.js +11 -4
- package/lib/renderers/Form/InputImage.js.map +2 -2
- package/lib/renderers/Form/Item.d.ts +1 -1
- package/lib/renderers/Form/Item.js +2 -1
- package/lib/renderers/Form/Item.js.map +2 -2
- package/lib/renderers/Form/Options.js +13 -3
- package/lib/renderers/Form/Options.js.map +2 -2
- package/lib/renderers/Form/Select.d.ts +42 -4
- package/lib/renderers/Form/Select.js +37 -3
- package/lib/renderers/Form/Select.js.map +2 -2
- package/lib/renderers/Form/TabsTransferPicker.d.ts +48 -0
- package/lib/renderers/Form/TabsTransferPicker.js +29 -0
- package/lib/renderers/Form/TabsTransferPicker.js.map +13 -0
- package/lib/renderers/Form/Transfer.js +18 -3
- package/lib/renderers/Form/Transfer.js.map +2 -2
- package/lib/renderers/Form/TransferPicker.d.ts +52 -0
- package/lib/renderers/Form/TransferPicker.js +43 -0
- package/lib/renderers/Form/TransferPicker.js.map +13 -0
- package/lib/renderers/Form/TreeSelect.js +2 -2
- package/lib/renderers/Form/TreeSelect.js.map +2 -2
- package/lib/renderers/Form/index.d.ts +5 -0
- package/lib/renderers/Form/index.js +5 -3
- package/lib/renderers/Form/index.js.map +2 -2
- package/lib/renderers/Form/wrapControl.js +13 -1
- package/lib/renderers/Form/wrapControl.js.map +2 -2
- package/lib/renderers/GridNav.d.ts +99 -0
- package/lib/renderers/GridNav.js +82 -0
- package/lib/renderers/GridNav.js.map +13 -0
- package/lib/renderers/IFrame.js +1 -3
- package/lib/renderers/IFrame.js.map +2 -2
- package/lib/renderers/Json.d.ts +4 -0
- package/lib/renderers/Json.js +4 -13
- package/lib/renderers/Json.js.map +2 -2
- package/lib/renderers/Link.d.ts +4 -2
- package/lib/renderers/Link.js +15 -6
- package/lib/renderers/Link.js.map +2 -2
- package/lib/renderers/List.js +1 -1
- package/lib/renderers/List.js.map +2 -2
- package/lib/renderers/Mapping.d.ts +9 -2
- package/lib/renderers/Mapping.js +18 -6
- package/lib/renderers/Mapping.js.map +2 -2
- package/lib/renderers/Nav.d.ts +21 -21
- package/lib/renderers/Nav.js +39 -21
- package/lib/renderers/Nav.js.map +2 -2
- package/lib/renderers/Portlet.d.ts +125 -0
- package/lib/renderers/Portlet.js +156 -0
- package/lib/renderers/Portlet.js.map +13 -0
- package/lib/renderers/Property.js +2 -1
- package/lib/renderers/Property.js.map +2 -2
- package/lib/renderers/SearchBox.d.ts +6 -1
- package/lib/renderers/SearchBox.js +19 -5
- package/lib/renderers/SearchBox.js.map +2 -2
- package/lib/renderers/Table/TableContent.d.ts +4 -1
- package/lib/renderers/Table/TableContent.js +21 -1
- package/lib/renderers/Table/TableContent.js.map +2 -2
- package/lib/renderers/Table/index.d.ts +5 -1
- package/lib/renderers/Table/index.js +65 -30
- package/lib/renderers/Table/index.js.map +2 -2
- package/lib/renderers/Tabs.js +9 -1
- package/lib/renderers/Tabs.js.map +2 -2
- package/lib/renderers/WebComponent.js +1 -1
- package/lib/renderers/WebComponent.js.map +2 -2
- package/lib/store/combo.d.ts +2 -16
- package/lib/store/crud.js +3 -7
- package/lib/store/crud.js.map +2 -2
- package/lib/store/form.d.ts +1 -1
- package/lib/store/form.js +5 -6
- package/lib/store/form.js.map +2 -2
- package/lib/store/formItem.js +44 -4
- package/lib/store/formItem.js.map +2 -2
- package/lib/store/service.js +5 -4
- package/lib/store/service.js.map +2 -2
- package/lib/store/table.d.ts +3 -2
- package/lib/store/table.js +35 -12
- package/lib/store/table.js.map +2 -2
- package/lib/themes/ang-ie11.css +689 -175
- package/lib/themes/ang.css +689 -175
- package/lib/themes/ang.css.map +1 -1
- package/lib/themes/antd-ie11.css +689 -175
- package/lib/themes/antd.css +689 -175
- package/lib/themes/antd.css.map +1 -1
- package/lib/themes/cxd-ie11.css +728 -213
- package/lib/themes/cxd.css +728 -213
- package/lib/themes/cxd.css.map +1 -1
- package/lib/themes/dark-ie11.css +689 -175
- package/lib/themes/dark.css +689 -175
- package/lib/themes/dark.css.map +1 -1
- package/lib/themes/default.css +728 -213
- package/lib/themes/default.css.map +1 -1
- package/lib/types.d.ts +38 -1
- package/lib/types.js +0 -5
- package/lib/types.js.map +2 -2
- package/lib/utils/api.d.ts +4 -2
- package/lib/utils/api.js +104 -17
- package/lib/utils/api.js.map +2 -2
- package/lib/utils/dom.d.ts +4 -0
- package/lib/utils/dom.js +11 -1
- package/lib/utils/dom.js.map +2 -2
- package/lib/utils/helper.d.ts +8 -0
- package/lib/utils/helper.js +28 -2
- package/lib/utils/helper.js.map +2 -2
- package/lib/utils/icon.js +3 -0
- package/lib/utils/icon.js.map +2 -2
- package/package.json +1 -1
- package/schema.json +3326 -836
- package/scss/_mixins.scss +1 -3
- package/scss/_properties.scss +25 -1
- package/scss/base/_common.scss +3 -0
- package/scss/base/_normalize.scss +2 -0
- package/scss/components/_anchor-nav.scss +89 -29
- package/scss/components/_card.scss +8 -14
- package/scss/components/_collapse-group.scss +11 -0
- package/scss/components/_collapse.scss +48 -22
- package/scss/components/_grid-nav.scss +128 -0
- package/scss/components/_input-box.scss +1 -0
- package/scss/components/_mapping.scss +6 -0
- package/scss/components/_nav.scss +2 -2
- package/scss/components/_picker-columns.scss +124 -0
- package/scss/components/_popover.scss +13 -0
- package/scss/components/_portlet.scss +51 -0
- package/scss/components/_result-box.scss +1 -0
- package/scss/components/_spinner.scss +5 -4
- package/scss/components/_status.scss +1 -1
- package/scss/components/_table.scss +32 -0
- package/scss/components/form/_checks.scss +0 -351
- package/scss/components/form/_combo.scss +4 -0
- package/scss/components/form/_fieldset.scss +5 -1
- package/scss/components/form/_file.scss +11 -0
- package/scss/components/form/_form.scss +48 -0
- package/scss/components/form/_selection.scss +354 -0
- package/scss/components/form/_transfer.scss +75 -18
- package/scss/components/form/_tree.scss +42 -0
- package/scss/themes/_common.scss +7 -0
- package/scss/themes/_cxd-variables.scss +8 -6
- package/scss/themes/cxd.scss +17 -12
- package/sdk/ang-ie11.css +786 -196
- package/sdk/ang.css +820 -213
- package/sdk/antd-ie11.css +786 -196
- package/sdk/antd.css +820 -213
- package/sdk/charts.js +13 -13
- package/sdk/color-picker.js +65 -69
- package/sdk/cropperjs.js +2 -2
- package/sdk/cxd-ie11.css +825 -236
- package/sdk/cxd.css +862 -254
- package/sdk/dark-ie11.css +787 -197
- package/sdk/dark.css +820 -213
- package/sdk/exceljs.js +1 -1
- package/sdk/helper.css.map +1 -1
- package/sdk/iconfont.svg +2513 -0
- package/sdk/iconfont.ttf +0 -0
- package/sdk/iconfont.woff +0 -0
- package/sdk/locale/de-DE.js +2 -0
- package/sdk/markdown.js +69 -69
- package/sdk/papaparse.js +1 -1
- package/sdk/renderers/Form/CityDB.js +1 -1
- package/sdk/rest.js +20 -28
- package/sdk/rich-text.js +62 -62
- package/sdk/sdk-ie11.css +825 -236
- package/sdk/sdk.css +862 -254
- package/sdk/sdk.js +1243 -1175
- package/sdk/thirds/hls.js/hls.js +1 -1
- package/sdk/thirds/mpegts.js/mpegts.js +1 -1
- package/sdk/tinymce.js +57 -57
- package/src/Schema.ts +19 -1
- package/src/components/AnchorNav.tsx +15 -4
- package/src/components/{AssociatedCheckboxes.tsx → AssociatedSelection.tsx} +43 -37
- package/src/components/Badge.tsx +3 -3
- package/src/components/{ChainedCheckboxes.tsx → ChainedSelection.tsx} +57 -40
- package/src/components/Collapse.tsx +144 -20
- package/src/components/CollapseGroup.tsx +130 -0
- package/src/components/GridNav.tsx +233 -0
- package/src/components/{ListCheckboxes.tsx → GroupedSelection.tsx} +26 -21
- package/src/components/InputBox.tsx +10 -9
- package/src/components/Link.tsx +28 -37
- package/src/components/ModalManager.ts +1 -1
- package/src/components/PickerColumn.tsx +429 -0
- package/src/components/PickerContainer.tsx +128 -0
- package/src/components/Radios.tsx +3 -8
- package/src/components/ResultBox.tsx +9 -9
- package/src/components/SearchBox.tsx +4 -5
- package/src/components/Select.tsx +57 -5
- package/src/components/{Checkboxes.tsx → Selection.tsx} +75 -21
- package/src/components/{TableCheckboxes.tsx → TableSelection.tsx} +46 -25
- package/src/components/TabsTransfer.tsx +13 -7
- package/src/components/TabsTransferPicker.tsx +85 -0
- package/src/components/Toast.tsx +23 -16
- package/src/components/Transfer.tsx +71 -50
- package/src/components/TransferDropDown.tsx +120 -0
- package/src/components/TransferPicker.tsx +91 -0
- package/src/components/Tree.tsx +194 -8
- package/src/components/{TreeCheckboxes.tsx → TreeSelection.tsx} +33 -26
- package/src/components/WithRemoteConfig.tsx +7 -2
- package/src/components/condition-builder/Field.tsx +5 -5
- package/src/components/condition-builder/Func.tsx +3 -3
- package/src/components/condition-builder/InputSwitch.tsx +3 -3
- package/src/components/condition-builder/Item.tsx +5 -12
- package/src/components/icons.tsx +2 -0
- package/src/components/index.tsx +13 -13
- package/src/envOverwrite.ts +20 -8
- package/src/factory.tsx +70 -9
- package/src/hooks/index.ts +5 -0
- package/src/hooks/use-set-state.ts +19 -0
- package/src/hooks/use-touch.ts +100 -0
- package/src/hooks/use-update-effect.ts +16 -0
- package/src/icons/download.svg +4 -0
- package/src/icons/drag-bar.svg +12 -6
- package/src/index.tsx +5 -0
- package/src/locale/de-DE.ts +2 -0
- package/src/locale/en-US.ts +3 -0
- package/src/locale/zh-CN.ts +5 -2
- package/src/renderers/Action.tsx +28 -2
- package/src/renderers/AnchorNav.tsx +4 -0
- package/src/renderers/Avatar.tsx +8 -4
- package/src/renderers/Breadcrumb.tsx +5 -1
- package/src/renderers/CRUD.tsx +33 -3
- package/src/renderers/Card.tsx +63 -34
- package/src/renderers/Chart.tsx +6 -2
- package/src/renderers/Collapse.tsx +70 -115
- package/src/renderers/CollapseGroup.tsx +80 -0
- package/src/renderers/DropDownButton.tsx +1 -1
- package/src/renderers/Form/InputCity.tsx +4 -8
- package/src/renderers/Form/InputFile.tsx +65 -24
- package/src/renderers/Form/InputImage.tsx +11 -3
- package/src/renderers/Form/Item.tsx +3 -2
- package/src/renderers/Form/Options.tsx +16 -2
- package/src/renderers/Form/Select.tsx +162 -21
- package/src/renderers/Form/TabsTransferPicker.tsx +123 -0
- package/src/renderers/Form/Transfer.tsx +19 -4
- package/src/renderers/Form/TransferPicker.tsx +145 -0
- package/src/renderers/Form/TreeSelect.tsx +25 -0
- package/src/renderers/Form/index.tsx +15 -2
- package/src/renderers/Form/wrapControl.tsx +26 -1
- package/src/renderers/GridNav.tsx +204 -0
- package/src/renderers/IFrame.tsx +2 -4
- package/src/renderers/Json.tsx +9 -9
- package/src/renderers/Link.tsx +27 -13
- package/src/renderers/List.tsx +1 -1
- package/src/renderers/Mapping.tsx +27 -11
- package/src/renderers/Nav.tsx +108 -60
- package/src/renderers/Portlet.tsx +423 -0
- package/src/renderers/Property.tsx +3 -2
- package/src/renderers/SearchBox.tsx +23 -4
- package/src/renderers/Table/TableContent.tsx +40 -2
- package/src/renderers/Table/index.tsx +88 -43
- package/src/renderers/Tabs.tsx +9 -1
- package/src/renderers/WebComponent.tsx +2 -2
- package/src/store/crud.ts +3 -8
- package/src/store/form.ts +5 -10
- package/src/store/formItem.ts +94 -2
- package/src/store/service.ts +5 -4
- package/src/store/table.ts +55 -14
- package/src/types.ts +58 -1
- package/src/utils/api.ts +133 -26
- package/src/utils/dom.tsx +12 -0
- package/src/utils/helper.ts +27 -0
- package/src/utils/icon.tsx +4 -0
- package/tsconfig-for-declaration.json +1 -1
- package/dump.rdb +0 -0
- package/lib/components/AssociatedCheckboxes.d.ts +0 -762
- package/lib/components/AssociatedCheckboxes.js +0 -90
- package/lib/components/AssociatedCheckboxes.js.map +0 -13
- package/lib/components/ChainedCheckboxes.js.map +0 -13
- package/lib/components/Checkboxes.js +0 -101
- package/lib/components/Checkboxes.js.map +0 -13
- package/lib/components/ListCheckboxes.d.ts +0 -739
- package/lib/components/ListCheckboxes.js +0 -48
- package/lib/components/ListCheckboxes.js.map +0 -13
- package/lib/components/ListRadios.d.ts +0 -763
- package/lib/components/ListRadios.js +0 -86
- package/lib/components/ListRadios.js.map +0 -13
- package/lib/components/TableCheckboxes.js.map +0 -13
- package/lib/components/TreeCheckboxes.js.map +0 -13
- package/lib/components/TreeRadios.d.ts +0 -838
- package/lib/components/TreeRadios.js +0 -116
- package/lib/components/TreeRadios.js.map +0 -13
- package/src/components/ListRadios.tsx +0 -159
- package/src/components/TreeRadios.tsx +0 -202
@@ -12,6 +12,8 @@ import Transition, {
|
|
12
12
|
EXITING
|
13
13
|
} from 'react-transition-group/Transition';
|
14
14
|
import {autobind} from '../utils/helper';
|
15
|
+
import {isClickOnInput} from '../utils/helper';
|
16
|
+
import {TranslateFn} from '../locale';
|
15
17
|
|
16
18
|
const collapseStyles: {
|
17
19
|
[propName: string]: string;
|
@@ -22,24 +24,87 @@ const collapseStyles: {
|
|
22
24
|
};
|
23
25
|
|
24
26
|
export interface CollapseProps {
|
25
|
-
|
27
|
+
key?: string;
|
28
|
+
id?: string;
|
26
29
|
mountOnEnter?: boolean;
|
27
30
|
unmountOnExit?: boolean;
|
28
31
|
className?: string;
|
29
32
|
classPrefix: string;
|
30
33
|
classnames: ClassNamesFn;
|
34
|
+
headerPosition?: 'top' | 'bottom';
|
35
|
+
header?: React.ReactElement;
|
36
|
+
body: any;
|
37
|
+
bodyClassName?: string;
|
38
|
+
disabled?: boolean;
|
39
|
+
collapsable?: boolean;
|
40
|
+
collapsed?: boolean;
|
41
|
+
showArrow?: boolean;
|
42
|
+
expandIcon?: React.ReactElement | null;
|
43
|
+
headingClassName?: string;
|
44
|
+
collapseHeader?: React.ReactElement | null;
|
45
|
+
size?: 'xs' | 'sm' | 'md' | 'lg' | 'base';
|
46
|
+
onCollapse?: (item: any, collapsed: boolean) => void;
|
47
|
+
wrapperComponent?: any;
|
48
|
+
headingComponent?: any;
|
49
|
+
translate?: TranslateFn;
|
50
|
+
propsUpdate?: boolean;
|
31
51
|
}
|
32
52
|
|
33
|
-
export
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
53
|
+
export interface CollapseState {
|
54
|
+
collapsed: boolean;
|
55
|
+
}
|
56
|
+
|
57
|
+
export class Collapse extends React.Component<CollapseProps, CollapseState> {
|
58
|
+
|
59
|
+
static defaultProps: Partial<CollapseProps> = {
|
39
60
|
mountOnEnter: false,
|
40
|
-
unmountOnExit: false
|
61
|
+
unmountOnExit: false,
|
62
|
+
headerPosition: 'top',
|
63
|
+
wrapperComponent: 'div',
|
64
|
+
headingComponent: 'div',
|
65
|
+
className: '',
|
66
|
+
headingClassName: '',
|
67
|
+
bodyClassName: '',
|
68
|
+
collapsable: true,
|
69
|
+
disabled: false,
|
70
|
+
showArrow: true,
|
71
|
+
propsUpdate: false
|
72
|
+
};
|
73
|
+
|
74
|
+
state: CollapseState = {
|
75
|
+
collapsed: false
|
41
76
|
};
|
42
77
|
|
78
|
+
constructor(props: CollapseProps) {
|
79
|
+
super(props);
|
80
|
+
|
81
|
+
this.toggleCollapsed = this.toggleCollapsed.bind(this);
|
82
|
+
this.state.collapsed = !!props.collapsed;
|
83
|
+
}
|
84
|
+
|
85
|
+
static getDerivedStateFromProps(nextProps: CollapseProps, preState: CollapseState) {
|
86
|
+
if (nextProps.propsUpdate && nextProps.collapsed !== preState.collapsed) {
|
87
|
+
return {
|
88
|
+
collapsed: !!nextProps.collapsed
|
89
|
+
};
|
90
|
+
}
|
91
|
+
return null;
|
92
|
+
}
|
93
|
+
|
94
|
+
toggleCollapsed(e: React.MouseEvent<HTMLElement>) {
|
95
|
+
if (isClickOnInput(e)) {
|
96
|
+
return;
|
97
|
+
}
|
98
|
+
const props = this.props;
|
99
|
+
if (props.disabled || props.collapsable === false) {
|
100
|
+
return;
|
101
|
+
}
|
102
|
+
props.onCollapse && props.onCollapse(props, !this.state.collapsed);
|
103
|
+
this.setState({
|
104
|
+
collapsed: !this.state.collapsed
|
105
|
+
});
|
106
|
+
}
|
107
|
+
|
43
108
|
contentDom: any;
|
44
109
|
contentRef = (ref: any) => (this.contentDom = ref);
|
45
110
|
|
@@ -77,18 +142,53 @@ export class Collapse extends React.Component<CollapseProps, any> {
|
|
77
142
|
|
78
143
|
render() {
|
79
144
|
const {
|
80
|
-
show,
|
81
|
-
children,
|
82
145
|
classnames: cx,
|
83
146
|
mountOnEnter,
|
84
|
-
unmountOnExit
|
147
|
+
unmountOnExit,
|
148
|
+
classPrefix: ns,
|
149
|
+
size,
|
150
|
+
wrapperComponent: WrapperComponent,
|
151
|
+
headingComponent: HeadingComponent,
|
152
|
+
className,
|
153
|
+
headingClassName,
|
154
|
+
headerPosition,
|
155
|
+
collapseHeader,
|
156
|
+
header,
|
157
|
+
body,
|
158
|
+
bodyClassName,
|
159
|
+
collapsable,
|
160
|
+
translate: __,
|
161
|
+
showArrow,
|
162
|
+
expandIcon,
|
163
|
+
disabled
|
85
164
|
} = this.props;
|
86
165
|
|
87
|
-
|
166
|
+
const finalHeader = this.state.collapsed ? header : collapseHeader || header;
|
167
|
+
|
168
|
+
let dom = [
|
169
|
+
finalHeader ? (
|
170
|
+
<HeadingComponent
|
171
|
+
key="header"
|
172
|
+
onClick={this.toggleCollapsed}
|
173
|
+
className={cx(`Collapse-header`, headingClassName)}
|
174
|
+
>
|
175
|
+
{showArrow && collapsable
|
176
|
+
? expandIcon
|
177
|
+
? React.cloneElement(expandIcon, {
|
178
|
+
...expandIcon.props,
|
179
|
+
className: cx('Collapse-icon-tranform')
|
180
|
+
})
|
181
|
+
: <span className={cx('Collapse-arrow')} />
|
182
|
+
: ''}
|
183
|
+
{finalHeader}
|
184
|
+
</HeadingComponent>
|
185
|
+
) : null,
|
186
|
+
|
88
187
|
<Transition
|
188
|
+
key="body"
|
89
189
|
mountOnEnter={mountOnEnter}
|
90
190
|
unmountOnExit={unmountOnExit}
|
91
|
-
in={
|
191
|
+
in={!this.state.collapsed}
|
92
192
|
timeout={300}
|
93
193
|
onEnter={this.handleEnter}
|
94
194
|
onEntering={this.handleEntering}
|
@@ -105,17 +205,41 @@ export class Collapse extends React.Component<CollapseProps, any> {
|
|
105
205
|
className={cx('Collapse-contentWrapper', collapseStyles[status])}
|
106
206
|
ref={this.contentRef}
|
107
207
|
>
|
108
|
-
{
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
208
|
+
<div className={cx('Collapse-body', bodyClassName)}>
|
209
|
+
{React.cloneElement(body as any, {
|
210
|
+
...(body as React.ReactElement).props,
|
211
|
+
className: cx(
|
212
|
+
'Collapse-content',
|
213
|
+
(body as React.ReactElement).props.className
|
214
|
+
)
|
215
|
+
})}
|
216
|
+
</div>
|
115
217
|
</div>
|
116
218
|
);
|
117
219
|
}}
|
118
220
|
</Transition>
|
221
|
+
|
222
|
+
];
|
223
|
+
|
224
|
+
if (headerPosition === 'bottom') {
|
225
|
+
dom.reverse();
|
226
|
+
}
|
227
|
+
|
228
|
+
return (
|
229
|
+
<WrapperComponent
|
230
|
+
className={cx(
|
231
|
+
`Collapse`,
|
232
|
+
{
|
233
|
+
'is-active': !this.state.collapsed,
|
234
|
+
[`Collapse--${size}`]: size,
|
235
|
+
'Collapse--disabled': disabled || collapsable === false,
|
236
|
+
'Collapse--title-bottom': headerPosition === 'bottom'
|
237
|
+
},
|
238
|
+
className
|
239
|
+
)}
|
240
|
+
>
|
241
|
+
{dom}
|
242
|
+
</WrapperComponent>
|
119
243
|
);
|
120
244
|
}
|
121
245
|
}
|
@@ -0,0 +1,130 @@
|
|
1
|
+
/**
|
2
|
+
* @file CollapseGroup
|
3
|
+
* @description 折叠面板group
|
4
|
+
* @author hongyang03
|
5
|
+
*/
|
6
|
+
|
7
|
+
import React from 'react';
|
8
|
+
import {CollapseProps} from '../renderers/Collapse';
|
9
|
+
import {SchemaNode} from '../types';
|
10
|
+
import {ClassNamesFn, themeable} from '../theme';
|
11
|
+
|
12
|
+
export interface CollapseGroupProps {
|
13
|
+
defaultActiveKey?: Array<string | number | never> | string | number;
|
14
|
+
accordion?: boolean;
|
15
|
+
expandIcon?: SchemaNode;
|
16
|
+
expandIconPosition?: 'left' | 'right';
|
17
|
+
body?: Array<React.ReactElement>;
|
18
|
+
className?: string;
|
19
|
+
classnames: ClassNamesFn;
|
20
|
+
classPrefix: string;
|
21
|
+
}
|
22
|
+
|
23
|
+
export interface CollapseGroupState {
|
24
|
+
activeKey: Array<string | number | never>;
|
25
|
+
}
|
26
|
+
|
27
|
+
class CollapseGroup extends React.Component<
|
28
|
+
CollapseGroupProps,
|
29
|
+
CollapseGroupState
|
30
|
+
> {
|
31
|
+
|
32
|
+
static defaultProps: Partial<CollapseGroupProps> = {
|
33
|
+
className: '',
|
34
|
+
accordion: false,
|
35
|
+
expandIconPosition: 'left'
|
36
|
+
};
|
37
|
+
|
38
|
+
constructor(props: CollapseGroupProps) {
|
39
|
+
super(props);
|
40
|
+
|
41
|
+
// 传入的activeKey会被自动转换为defaultActiveKey
|
42
|
+
let activeKey = props.defaultActiveKey;
|
43
|
+
if (!Array.isArray(activeKey)) {
|
44
|
+
activeKey = activeKey ? [activeKey] : [];
|
45
|
+
}
|
46
|
+
if (props.accordion) {
|
47
|
+
// 手风琴模式下只展开第一个元素
|
48
|
+
activeKey = activeKey.length ? [activeKey[0]] : [];
|
49
|
+
}
|
50
|
+
|
51
|
+
this.state = {
|
52
|
+
activeKey: activeKey.map((key: number | string) => String(key))
|
53
|
+
};
|
54
|
+
}
|
55
|
+
|
56
|
+
collapseChange(item: CollapseProps, collapsed: boolean) {
|
57
|
+
let activeKey = this.state.activeKey;
|
58
|
+
if (collapsed) {
|
59
|
+
if (this.props.accordion) {
|
60
|
+
activeKey = [];
|
61
|
+
}
|
62
|
+
else {
|
63
|
+
for(let i = 0; i < activeKey.length; i++) {
|
64
|
+
if (activeKey[i] === item.id) {
|
65
|
+
activeKey.splice(i, 1);
|
66
|
+
break;
|
67
|
+
}
|
68
|
+
}
|
69
|
+
}
|
70
|
+
}
|
71
|
+
else {
|
72
|
+
if (this.props.accordion) {
|
73
|
+
activeKey = [item.id];
|
74
|
+
}
|
75
|
+
else {
|
76
|
+
activeKey.push(item.id);
|
77
|
+
}
|
78
|
+
}
|
79
|
+
this.setState({
|
80
|
+
activeKey
|
81
|
+
});
|
82
|
+
}
|
83
|
+
|
84
|
+
getItems = (children: React.ReactNode) => {
|
85
|
+
if (!Array.isArray(children)) {
|
86
|
+
return children;
|
87
|
+
}
|
88
|
+
|
89
|
+
return children.map((child: React.ReactElement, index: number) => {
|
90
|
+
let props = child.props;
|
91
|
+
const id = props.schema.key || String(index);
|
92
|
+
const collapsed = this.state.activeKey.indexOf(id) === -1;
|
93
|
+
|
94
|
+
return React.cloneElement(child as any, {
|
95
|
+
...props,
|
96
|
+
key: id,
|
97
|
+
id,
|
98
|
+
collapsed,
|
99
|
+
expandIcon: this.props.expandIcon,
|
100
|
+
propsUpdate: true,
|
101
|
+
onCollapse: (item: CollapseProps, collapsed: boolean) => this.collapseChange(item, collapsed)
|
102
|
+
});
|
103
|
+
});
|
104
|
+
};
|
105
|
+
|
106
|
+
render() {
|
107
|
+
const {
|
108
|
+
classnames: cx,
|
109
|
+
className,
|
110
|
+
expandIconPosition,
|
111
|
+
children
|
112
|
+
} = this.props;
|
113
|
+
|
114
|
+
return (
|
115
|
+
<div
|
116
|
+
className={cx(
|
117
|
+
`CollapseGroup`,
|
118
|
+
{
|
119
|
+
'icon-position-right': expandIconPosition === 'right',
|
120
|
+
},
|
121
|
+
className
|
122
|
+
)}
|
123
|
+
>
|
124
|
+
{this.getItems(children)}
|
125
|
+
</div>
|
126
|
+
);
|
127
|
+
}
|
128
|
+
}
|
129
|
+
|
130
|
+
export default themeable(CollapseGroup);
|
@@ -0,0 +1,233 @@
|
|
1
|
+
/**
|
2
|
+
* @file GridNav
|
3
|
+
* @description 金刚位宫格导航 参考react-vant
|
4
|
+
*/
|
5
|
+
|
6
|
+
import React, {useMemo} from 'react';
|
7
|
+
import {ClassNamesFn} from '../theme';
|
8
|
+
import {Badge, BadgeProps} from './Badge';
|
9
|
+
|
10
|
+
export type GridNavDirection = 'horizontal' | 'vertical';
|
11
|
+
|
12
|
+
export interface GridNavProps {
|
13
|
+
/** 是否将格子固定为正方形 */
|
14
|
+
square?: boolean;
|
15
|
+
/** 是否将格子内容居中显示 */
|
16
|
+
center?: boolean;
|
17
|
+
/** 是否显示边框 */
|
18
|
+
border?: boolean;
|
19
|
+
/** 格子之间的间距,默认单位为`px` */
|
20
|
+
gutter?: number;
|
21
|
+
/** 是否调换图标和文本的位置 */
|
22
|
+
reverse?: boolean;
|
23
|
+
/** 图标占比,默认单位为`%` */
|
24
|
+
iconRatio?: number;
|
25
|
+
/** 格子内容排列的方向,可选值为 `horizontal` */
|
26
|
+
direction?: GridNavDirection;
|
27
|
+
/** 列数 */
|
28
|
+
columnNum?: number;
|
29
|
+
className?: string;
|
30
|
+
itemClassName?: string;
|
31
|
+
classnames: ClassNamesFn;
|
32
|
+
style?: React.CSSProperties;
|
33
|
+
}
|
34
|
+
|
35
|
+
export interface GridNavItemProps {
|
36
|
+
/** 图标右上角徽标 */
|
37
|
+
badge?: BadgeProps;
|
38
|
+
/** 文字 */
|
39
|
+
text?: string | React.ReactNode;
|
40
|
+
/** 图标名称或图片链接 */
|
41
|
+
icon?: string | React.ReactNode;
|
42
|
+
className?: string;
|
43
|
+
style?: React.CSSProperties;
|
44
|
+
contentClassName?: string;
|
45
|
+
contentStyle?: React.CSSProperties;
|
46
|
+
children?: React.ReactNode;
|
47
|
+
classnames: ClassNamesFn;
|
48
|
+
onClick?: (event: React.MouseEvent) => void;
|
49
|
+
}
|
50
|
+
|
51
|
+
type InternalProps = {
|
52
|
+
parent?: GridNavProps;
|
53
|
+
index?: number;
|
54
|
+
};
|
55
|
+
|
56
|
+
function addUnit(value?: string | number): string | undefined {
|
57
|
+
if (value === undefined || value === null) {
|
58
|
+
return undefined;
|
59
|
+
}
|
60
|
+
value = String(value);
|
61
|
+
return /^\d+(\.\d+)?$/.test(value) ? `${value}px` : value;
|
62
|
+
}
|
63
|
+
|
64
|
+
export const GridNavItem: React.FC<GridNavItemProps & InternalProps> = ({
|
65
|
+
children,
|
66
|
+
classnames: cx,
|
67
|
+
className,
|
68
|
+
style,
|
69
|
+
...props
|
70
|
+
}) => {
|
71
|
+
const {index = 0, parent} = props;
|
72
|
+
if (!parent) {
|
73
|
+
if (process.env.NODE_ENV !== 'production') {
|
74
|
+
// eslint-disable-next-line no-console
|
75
|
+
console.error(
|
76
|
+
'[React Vant] <GridNavItem> must be a child component of <GridNav>.'
|
77
|
+
);
|
78
|
+
}
|
79
|
+
return null;
|
80
|
+
}
|
81
|
+
|
82
|
+
const rootStyle = useMemo(() => {
|
83
|
+
const {square, gutter, columnNum = 4} = parent;
|
84
|
+
const percent = `${100 / +columnNum}%`;
|
85
|
+
const internalStyle: React.CSSProperties = {
|
86
|
+
...style,
|
87
|
+
flexBasis: percent
|
88
|
+
};
|
89
|
+
|
90
|
+
if (square) {
|
91
|
+
internalStyle.paddingTop = percent;
|
92
|
+
} else if (gutter) {
|
93
|
+
const gutterValue = addUnit(gutter);
|
94
|
+
internalStyle.paddingRight = gutterValue;
|
95
|
+
|
96
|
+
if (index >= columnNum) {
|
97
|
+
internalStyle.marginTop = gutterValue;
|
98
|
+
}
|
99
|
+
}
|
100
|
+
|
101
|
+
return internalStyle;
|
102
|
+
}, [parent.style, parent.gutter, parent.columnNum]);
|
103
|
+
|
104
|
+
const contentStyle = useMemo(() => {
|
105
|
+
const {square, gutter} = parent;
|
106
|
+
|
107
|
+
if (square && gutter) {
|
108
|
+
const gutterValue = addUnit(gutter);
|
109
|
+
return {
|
110
|
+
...props.contentStyle,
|
111
|
+
right: gutterValue,
|
112
|
+
bottom: gutterValue,
|
113
|
+
height: 'auto'
|
114
|
+
};
|
115
|
+
}
|
116
|
+
return props.contentStyle;
|
117
|
+
}, [parent.gutter, parent.columnNum, props.contentStyle]);
|
118
|
+
|
119
|
+
const renderIcon = () => {
|
120
|
+
const ratio = parent.iconRatio || 60;
|
121
|
+
if (typeof props.icon === 'string') {
|
122
|
+
if (props.badge) {
|
123
|
+
return (
|
124
|
+
<Badge {...props.badge}>
|
125
|
+
<div className={cx('GridNavItem-image')}>
|
126
|
+
<img src={props.icon} style={{width: ratio + '%'}} />
|
127
|
+
</div>
|
128
|
+
</Badge>
|
129
|
+
);
|
130
|
+
}
|
131
|
+
return (
|
132
|
+
<div className={cx('GridNavItem-image')}>
|
133
|
+
<img src={props.icon} style={{width: ratio + '%'}} />
|
134
|
+
</div>
|
135
|
+
);
|
136
|
+
}
|
137
|
+
|
138
|
+
if (React.isValidElement(props.icon)) {
|
139
|
+
return <Badge {...(props.badge as BadgeProps)}>{props.icon}</Badge>;
|
140
|
+
}
|
141
|
+
|
142
|
+
return null;
|
143
|
+
};
|
144
|
+
|
145
|
+
const renderText = () => {
|
146
|
+
if (React.isValidElement(props.text)) {
|
147
|
+
return props.text;
|
148
|
+
}
|
149
|
+
if (props.text) {
|
150
|
+
return <span className={cx('GridNavItem-text')}>{props.text}</span>;
|
151
|
+
}
|
152
|
+
return null;
|
153
|
+
};
|
154
|
+
|
155
|
+
const renderContent = () => {
|
156
|
+
if (children) {
|
157
|
+
return children;
|
158
|
+
}
|
159
|
+
return (
|
160
|
+
<>
|
161
|
+
{renderIcon()}
|
162
|
+
{renderText()}
|
163
|
+
</>
|
164
|
+
);
|
165
|
+
};
|
166
|
+
|
167
|
+
const {center, border, square, gutter, reverse, direction} = parent;
|
168
|
+
|
169
|
+
const prefix = 'GridNavItem-content';
|
170
|
+
const classes = cx(`${prefix} ${props.contentClassName || ''}`, {
|
171
|
+
[`${prefix}--${direction}`]: !!direction,
|
172
|
+
[`${prefix}--center`]: center,
|
173
|
+
[`${prefix}--square`]: square,
|
174
|
+
[`${prefix}--reverse`]: reverse,
|
175
|
+
[`${prefix}--clickable`]: !!props.onClick,
|
176
|
+
[`${prefix}--surround`]: border && gutter,
|
177
|
+
[`${prefix}--border u-hairline`]: border
|
178
|
+
});
|
179
|
+
|
180
|
+
return (
|
181
|
+
<div
|
182
|
+
className={cx(className, {'GridNavItem--square': square})}
|
183
|
+
style={rootStyle}
|
184
|
+
>
|
185
|
+
<div
|
186
|
+
role={props.onClick ? 'button' : undefined}
|
187
|
+
className={classes}
|
188
|
+
style={contentStyle}
|
189
|
+
onClick={props.onClick}
|
190
|
+
>
|
191
|
+
{renderContent()}
|
192
|
+
</div>
|
193
|
+
</div>
|
194
|
+
);
|
195
|
+
};
|
196
|
+
|
197
|
+
const GridNav: React.FC<GridNavProps> = ({
|
198
|
+
children,
|
199
|
+
className,
|
200
|
+
classnames: cx,
|
201
|
+
itemClassName,
|
202
|
+
style,
|
203
|
+
...props
|
204
|
+
}) => {
|
205
|
+
return (
|
206
|
+
<div
|
207
|
+
style={{paddingLeft: addUnit(props.gutter), ...style}}
|
208
|
+
className={cx(`GridNav ${className || ''}`, {
|
209
|
+
'GridNav-top u-hairline': props.border && !props.gutter
|
210
|
+
})}
|
211
|
+
>
|
212
|
+
{React.Children.toArray(children)
|
213
|
+
.filter(Boolean)
|
214
|
+
.map((child: React.ReactElement, index: number) =>
|
215
|
+
React.cloneElement(child, {
|
216
|
+
index,
|
217
|
+
parent: props,
|
218
|
+
className: itemClassName,
|
219
|
+
classnames: cx
|
220
|
+
})
|
221
|
+
)}
|
222
|
+
</div>
|
223
|
+
);
|
224
|
+
};
|
225
|
+
|
226
|
+
GridNav.defaultProps = {
|
227
|
+
direction: 'vertical',
|
228
|
+
center: true,
|
229
|
+
border: true,
|
230
|
+
columnNum: 4
|
231
|
+
};
|
232
|
+
|
233
|
+
export default GridNav;
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import {
|
1
|
+
import {BaseSelection} from './Selection';
|
2
2
|
import {themeable} from '../theme';
|
3
3
|
import React from 'react';
|
4
4
|
import {uncontrollable} from 'uncontrollable';
|
@@ -6,7 +6,7 @@ import Checkbox from './Checkbox';
|
|
6
6
|
import {Option} from './Select';
|
7
7
|
import {localeable} from '../locale';
|
8
8
|
|
9
|
-
export class
|
9
|
+
export class GroupedSelection extends BaseSelection {
|
10
10
|
valueArray: Array<Option>;
|
11
11
|
|
12
12
|
renderOption(option: Option, index: number) {
|
@@ -15,7 +15,8 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
15
15
|
disabled,
|
16
16
|
classnames: cx,
|
17
17
|
itemClassName,
|
18
|
-
itemRender
|
18
|
+
itemRender,
|
19
|
+
multiple
|
19
20
|
} = this.props;
|
20
21
|
const valueArray = this.valueArray;
|
21
22
|
|
@@ -23,13 +24,13 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
23
24
|
return (
|
24
25
|
<div
|
25
26
|
key={index}
|
26
|
-
className={cx('
|
27
|
+
className={cx('GroupedSelection-group', option.className)}
|
27
28
|
>
|
28
|
-
<div className={cx('
|
29
|
+
<div className={cx('GroupedSelection-itemLabel')}>
|
29
30
|
{itemRender(option)}
|
30
31
|
</div>
|
31
32
|
|
32
|
-
<div className={cx('
|
33
|
+
<div className={cx('GroupedSelection-items', option.className)}>
|
33
34
|
{option.children.map((child, index) =>
|
34
35
|
this.renderOption(child, index)
|
35
36
|
)}
|
@@ -42,24 +43,27 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
42
43
|
<div
|
43
44
|
key={index}
|
44
45
|
className={cx(
|
45
|
-
'
|
46
|
+
'GroupedSelection-item',
|
46
47
|
itemClassName,
|
47
48
|
option.className,
|
48
|
-
disabled || option.disabled ? 'is-disabled' : ''
|
49
|
+
disabled || option.disabled ? 'is-disabled' : '',
|
50
|
+
!!~valueArray.indexOf(option) ? 'is-active' : ''
|
49
51
|
)}
|
50
52
|
onClick={() => this.toggleOption(option)}
|
51
53
|
>
|
52
|
-
<div className={cx('
|
54
|
+
<div className={cx('GroupedSelection-itemLabel')}>
|
53
55
|
{itemRender(option)}
|
54
56
|
</div>
|
55
57
|
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
58
|
+
{multiple ? (
|
59
|
+
<Checkbox
|
60
|
+
size="sm"
|
61
|
+
checked={!!~valueArray.indexOf(option)}
|
62
|
+
disabled={disabled || option.disabled}
|
63
|
+
labelClassName={labelClassName}
|
64
|
+
description={option.description}
|
65
|
+
/>
|
66
|
+
) : null}
|
63
67
|
</div>
|
64
68
|
);
|
65
69
|
}
|
@@ -71,11 +75,12 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
71
75
|
className,
|
72
76
|
placeholder,
|
73
77
|
classnames: cx,
|
74
|
-
option2value
|
78
|
+
option2value,
|
79
|
+
onClick
|
75
80
|
} = this.props;
|
76
81
|
const __ = this.props.translate;
|
77
82
|
|
78
|
-
this.valueArray =
|
83
|
+
this.valueArray = BaseSelection.value2array(value, options, option2value);
|
79
84
|
let body: Array<React.ReactNode> = [];
|
80
85
|
|
81
86
|
if (Array.isArray(options) && options.length) {
|
@@ -83,11 +88,11 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
83
88
|
}
|
84
89
|
|
85
90
|
return (
|
86
|
-
<div className={cx('
|
91
|
+
<div className={cx('GroupedSelection', className)} onClick={onClick}>
|
87
92
|
{body && body.length ? (
|
88
93
|
body
|
89
94
|
) : (
|
90
|
-
<div className={cx('
|
95
|
+
<div className={cx('GroupedSelection-placeholder')}>
|
91
96
|
{__(placeholder)}
|
92
97
|
</div>
|
93
98
|
)}
|
@@ -98,7 +103,7 @@ export class ListCheckboxes extends BaseCheckboxes {
|
|
98
103
|
|
99
104
|
export default themeable(
|
100
105
|
localeable(
|
101
|
-
uncontrollable(
|
106
|
+
uncontrollable(GroupedSelection, {
|
102
107
|
value: 'onChange'
|
103
108
|
})
|
104
109
|
)
|