amis 1.5.7 → 1.6.1
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/.husky/pre-commit +1 -1
- package/README.md +1 -0
- package/lib/RootRenderer.d.ts +2 -0
- package/lib/RootRenderer.js +19 -1
- package/lib/RootRenderer.js.map +2 -2
- package/lib/Schema.d.ts +3 -2
- package/lib/Schema.js.map +1 -1
- package/lib/SchemaRenderer.js +52 -1
- package/lib/SchemaRenderer.js.map +2 -2
- package/lib/Scoped.d.ts +2 -0
- package/lib/Scoped.js +27 -1
- package/lib/Scoped.js.map +2 -2
- package/lib/actions/Action.d.ts +33 -0
- package/lib/actions/Action.js +100 -0
- package/lib/actions/Action.js.map +13 -0
- package/lib/actions/AjaxAction.d.ts +14 -0
- package/lib/actions/AjaxAction.js +68 -0
- package/lib/actions/AjaxAction.js.map +13 -0
- package/lib/actions/BreakAction.d.ts +12 -0
- package/lib/actions/BreakAction.js +28 -0
- package/lib/actions/BreakAction.js.map +13 -0
- package/lib/actions/BroadcastAction.d.ts +12 -0
- package/lib/actions/BroadcastAction.js +40 -0
- package/lib/actions/BroadcastAction.js.map +13 -0
- package/lib/actions/CmptAction.d.ts +12 -0
- package/lib/actions/CmptAction.js +40 -0
- package/lib/actions/CmptAction.js.map +13 -0
- package/lib/actions/ContinueAction.d.ts +12 -0
- package/lib/actions/ContinueAction.js +28 -0
- package/lib/actions/ContinueAction.js.map +13 -0
- package/lib/actions/CopyAction.d.ts +12 -0
- package/lib/actions/CopyAction.js +35 -0
- package/lib/actions/CopyAction.js.map +13 -0
- package/lib/actions/CustomAction.d.ts +12 -0
- package/lib/actions/CustomAction.js +43 -0
- package/lib/actions/CustomAction.js.map +13 -0
- package/lib/actions/DialogAction.d.ts +12 -0
- package/lib/actions/DialogAction.js +31 -0
- package/lib/actions/DialogAction.js.map +13 -0
- package/lib/actions/DrawerAction.d.ts +12 -0
- package/lib/actions/DrawerAction.js +31 -0
- package/lib/actions/DrawerAction.js.map +13 -0
- package/lib/actions/EmailAction.d.ts +12 -0
- package/lib/actions/EmailAction.js +37 -0
- package/lib/actions/EmailAction.js.map +13 -0
- package/lib/actions/LoopAction.d.ts +12 -0
- package/lib/actions/LoopAction.js +93 -0
- package/lib/actions/LoopAction.js.map +13 -0
- package/lib/actions/OpenPageAction.d.ts +12 -0
- package/lib/actions/OpenPageAction.js +33 -0
- package/lib/actions/OpenPageAction.js.map +13 -0
- package/lib/actions/ParallelAction.d.ts +5 -0
- package/lib/actions/ParallelAction.js +33 -0
- package/lib/actions/ParallelAction.js.map +13 -0
- package/lib/actions/SwitchAction.d.ts +8 -0
- package/lib/actions/SwitchAction.js +45 -0
- package/lib/actions/SwitchAction.js.map +13 -0
- package/lib/actions/index.d.ts +18 -0
- package/lib/actions/index.js +22 -0
- package/lib/actions/index.js.map +13 -0
- package/lib/components/AnchorNav.d.ts +20 -20
- package/lib/components/AssociatedSelection.d.ts +84 -84
- package/lib/components/AssociatedSelection.js +2 -2
- package/lib/components/AssociatedSelection.js.map +2 -2
- package/lib/components/Avatar.d.ts +135 -0
- package/lib/components/Avatar.js +120 -0
- package/lib/components/Avatar.js.map +13 -0
- package/lib/components/BaiduMapPicker.js.map +2 -2
- package/lib/components/Button.d.ts +20 -20
- package/lib/components/CalendarMobile.d.ts +573 -0
- package/lib/components/CalendarMobile.js +486 -0
- package/lib/components/CalendarMobile.js.map +13 -0
- package/lib/components/Cascader.d.ts +123 -0
- package/lib/components/Cascader.js +487 -0
- package/lib/components/Cascader.js.map +13 -0
- package/lib/components/ChainedSelection.d.ts +84 -84
- package/lib/components/ChainedSelection.js +15 -3
- package/lib/components/ChainedSelection.js.map +2 -2
- package/lib/components/CityArea.d.ts +527 -0
- package/lib/components/CityArea.js +177 -0
- package/lib/components/CityArea.js.map +13 -0
- package/lib/components/Collapse.d.ts +20 -20
- package/lib/components/ColorPicker.d.ts +84 -84
- package/lib/components/ColorPicker.js +4 -3
- package/lib/components/ColorPicker.js.map +2 -2
- package/lib/components/DatePicker.d.ts +85 -84
- package/lib/components/DatePicker.js +21 -8
- package/lib/components/DatePicker.js.map +2 -2
- package/lib/components/DateRangePicker.d.ts +85 -84
- package/lib/components/DateRangePicker.js +19 -6
- package/lib/components/DateRangePicker.js.map +2 -2
- package/lib/components/GroupedSelection.d.ts +84 -84
- package/lib/components/GroupedSelection.js +14 -2
- package/lib/components/GroupedSelection.js.map +2 -2
- package/lib/components/InputBox.d.ts +21 -21
- package/lib/components/ListGroup.d.ts +21 -21
- package/lib/components/ListMenu.d.ts +84 -84
- package/lib/components/MonthRangePicker.d.ts +85 -84
- package/lib/components/MonthRangePicker.js +18 -7
- package/lib/components/MonthRangePicker.js.map +2 -2
- package/lib/components/Overlay.d.ts +1 -1
- package/lib/components/Overlay.js.map +1 -1
- package/lib/components/Picker.d.ts +1 -0
- package/lib/components/Picker.js +16 -7
- package/lib/components/Picker.js.map +2 -2
- package/lib/components/PickerColumn.d.ts +1 -0
- package/lib/components/PickerColumn.js +21 -18
- package/lib/components/PickerColumn.js.map +2 -2
- package/lib/components/PickerContainer.d.ts +3 -0
- package/lib/components/PickerContainer.js +12 -5
- package/lib/components/PickerContainer.js.map +2 -2
- package/lib/components/PopOverContainer.d.ts +1 -0
- package/lib/components/PopOverContainer.js +5 -3
- package/lib/components/PopOverContainer.js.map +2 -2
- package/lib/components/PopUp.d.ts +1041 -28
- package/lib/components/PopUp.js +32 -8
- package/lib/components/PopUp.js.map +2 -2
- package/lib/components/Radios.d.ts +21 -21
- package/lib/components/Rating.d.ts +21 -21
- package/lib/components/ResultBox.d.ts +85 -84
- package/lib/components/ResultBox.js +9 -4
- package/lib/components/ResultBox.js.map +2 -2
- package/lib/components/ResultList.d.ts +9 -2
- package/lib/components/ResultList.js +22 -2
- package/lib/components/ResultList.js.map +2 -2
- package/lib/components/Select.d.ts +238 -238
- package/lib/components/Select.js +13 -9
- package/lib/components/Select.js.map +2 -2
- package/lib/components/Selection.d.ts +94 -86
- package/lib/components/Selection.js +11 -2
- package/lib/components/Selection.js.map +2 -2
- package/lib/components/Steps.js.map +2 -2
- package/lib/components/TableSelection.d.ts +85 -85
- package/lib/components/TableSelection.js +1 -9
- package/lib/components/TableSelection.js.map +2 -2
- package/lib/components/Tabs.js +31 -33
- package/lib/components/Tabs.js.map +2 -2
- package/lib/components/TabsTransfer.d.ts +87 -256
- package/lib/components/TabsTransfer.js +52 -9
- package/lib/components/TabsTransfer.js.map +2 -2
- package/lib/components/TabsTransferPicker.d.ts +1 -1
- package/lib/components/TabsTransferPicker.js +20 -18
- package/lib/components/TabsTransferPicker.js.map +2 -2
- package/lib/components/Timeline.d.ts +69 -0
- package/lib/components/Timeline.js +16 -0
- package/lib/components/Timeline.js.map +13 -0
- package/lib/components/TimelineItem.d.ts +517 -0
- package/lib/components/TimelineItem.js +40 -0
- package/lib/components/TimelineItem.js.map +13 -0
- package/lib/components/Transfer.d.ts +100 -98
- package/lib/components/Transfer.js +2 -3
- package/lib/components/Transfer.js.map +2 -2
- package/lib/components/TransferDropDown.d.ts +85 -84
- package/lib/components/TransferDropDown.js +9 -10
- package/lib/components/TransferDropDown.js.map +2 -2
- package/lib/components/TransferPicker.d.ts +1 -0
- package/lib/components/TransferPicker.js +19 -4
- package/lib/components/TransferPicker.js.map +2 -2
- package/lib/components/Tree.d.ts +84 -84
- package/lib/components/TreeSelection.d.ts +85 -85
- package/lib/components/TreeSelection.js +7 -1
- package/lib/components/TreeSelection.js.map +2 -2
- package/lib/components/calendar/Calendar.d.ts +19 -0
- package/lib/components/calendar/Calendar.js +71 -1
- package/lib/components/calendar/Calendar.js.map +2 -2
- package/lib/components/calendar/DaysView.d.ts +21 -0
- package/lib/components/calendar/DaysView.js +76 -17
- package/lib/components/calendar/DaysView.js.map +2 -2
- package/lib/components/calendar/MonthsView.d.ts +34 -0
- package/lib/components/calendar/MonthsView.js +68 -3
- package/lib/components/calendar/MonthsView.js.map +2 -2
- package/lib/components/calendar/QuartersView.d.ts +1 -0
- package/lib/components/calendar/QuartersView.js +2 -2
- package/lib/components/calendar/QuartersView.js.map +2 -2
- package/lib/components/calendar/TimeView.d.ts +30 -18
- package/lib/components/calendar/TimeView.js +47 -8
- package/lib/components/calendar/TimeView.js.map +2 -2
- package/lib/components/calendar/YearsView.d.ts +6 -0
- package/lib/components/calendar/YearsView.js +21 -10
- package/lib/components/calendar/YearsView.js.map +2 -2
- package/lib/components/condition-builder/Field.js +1 -4
- package/lib/components/condition-builder/Field.js.map +2 -2
- package/lib/components/condition-builder/Func.js +1 -1
- package/lib/components/condition-builder/Func.js.map +2 -2
- package/lib/components/formula/Editor.d.ts +3 -0
- package/lib/components/formula/Editor.js +3 -2
- package/lib/components/formula/Editor.js.map +2 -2
- package/lib/components/formula/FuncList.js +2 -1
- package/lib/components/formula/FuncList.js.map +2 -2
- package/lib/components/formula/Picker.js +1 -1
- package/lib/components/formula/Picker.js.map +2 -2
- package/lib/components/formula/plugin.js +0 -1
- package/lib/components/formula/plugin.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 +2 -1
- package/lib/components/index.js +4 -2
- package/lib/components/index.js.map +2 -2
- package/lib/components/virtual-list/SizeAndPositionManager.js.map +2 -2
- package/lib/components/virtual-list/index.js +1 -2
- package/lib/components/virtual-list/index.js.map +2 -2
- package/lib/env.d.ts +4 -0
- package/lib/env.js.map +2 -2
- package/lib/factory.d.ts +2 -1
- package/lib/factory.js +83 -0
- package/lib/factory.js.map +2 -2
- package/lib/helper.css.map +1 -1
- package/lib/icons/tree-down.js +7 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +4 -1
- package/lib/index.js.map +2 -2
- package/lib/locale/de-DE.js +17 -2
- package/lib/locale/de-DE.js.map +2 -2
- package/lib/locale/en-US.js +17 -2
- package/lib/locale/en-US.js.map +2 -2
- package/lib/locale/zh-CN.js +16 -1
- package/lib/locale/zh-CN.js.map +2 -2
- package/lib/renderers/Action.d.ts +1 -1
- package/lib/renderers/Action.js +26 -10
- package/lib/renderers/Action.js.map +2 -2
- package/lib/renderers/Avatar.d.ts +35 -26
- package/lib/renderers/Avatar.js +14 -19
- package/lib/renderers/Avatar.js.map +2 -2
- package/lib/renderers/Card.js +6 -5
- package/lib/renderers/Card.js.map +2 -2
- package/lib/renderers/Custom.d.ts +1 -1
- package/lib/renderers/Custom.js +1 -1
- package/lib/renderers/Custom.js.map +2 -2
- package/lib/renderers/DropDownButton.d.ts +11 -2
- package/lib/renderers/DropDownButton.js +30 -12
- package/lib/renderers/DropDownButton.js.map +2 -2
- package/lib/renderers/Each.js +5 -2
- package/lib/renderers/Each.js.map +2 -2
- package/lib/renderers/Flex.js +1 -5
- package/lib/renderers/Flex.js.map +2 -2
- package/lib/renderers/Form/ChartRadios.js.map +2 -2
- package/lib/renderers/Form/Checkboxes.js.map +2 -2
- package/lib/renderers/Form/CityDB.js +526 -2
- package/lib/renderers/Form/CityDB.js.map +2 -2
- package/lib/renderers/Form/DiffEditor.d.ts +6 -0
- package/lib/renderers/Form/DiffEditor.js +2 -1
- package/lib/renderers/Form/DiffEditor.js.map +2 -2
- package/lib/renderers/Form/Editor.d.ts +6 -0
- package/lib/renderers/Form/InputCity.d.ts +85 -84
- package/lib/renderers/Form/InputCity.js +4 -2
- package/lib/renderers/Form/InputCity.js.map +2 -2
- package/lib/renderers/Form/InputColor.d.ts +84 -84
- package/lib/renderers/Form/InputColor.js +6 -2
- package/lib/renderers/Form/InputColor.js.map +2 -2
- package/lib/renderers/Form/InputDate.js +10 -5
- package/lib/renderers/Form/InputDate.js.map +2 -2
- package/lib/renderers/Form/InputDateRange.js +6 -2
- package/lib/renderers/Form/InputDateRange.js.map +2 -2
- package/lib/renderers/Form/InputFormula.d.ts +4 -1
- package/lib/renderers/Form/InputFormula.js +2 -2
- package/lib/renderers/Form/InputFormula.js.map +2 -2
- package/lib/renderers/Form/InputImage.d.ts +1 -0
- package/lib/renderers/Form/InputImage.js +8 -4
- package/lib/renderers/Form/InputImage.js.map +2 -2
- package/lib/renderers/Form/InputMonthRange.js +1 -1
- package/lib/renderers/Form/InputMonthRange.js.map +2 -2
- package/lib/renderers/Form/InputQuarterRange.js +1 -1
- package/lib/renderers/Form/InputQuarterRange.js.map +2 -2
- package/lib/renderers/Form/InputRichText.d.ts +4 -0
- package/lib/renderers/Form/InputRichText.js +2 -1
- package/lib/renderers/Form/InputRichText.js.map +2 -2
- package/lib/renderers/Form/InputYearRange.js +1 -1
- package/lib/renderers/Form/InputYearRange.js.map +2 -2
- package/lib/renderers/Form/Item.d.ts +10 -14
- package/lib/renderers/Form/Item.js +18 -9
- package/lib/renderers/Form/Item.js.map +2 -2
- package/lib/renderers/Form/NestedSelect.d.ts +1 -0
- package/lib/renderers/Form/NestedSelect.js +8 -4
- package/lib/renderers/Form/NestedSelect.js.map +2 -2
- package/lib/renderers/Form/Options.js +9 -7
- package/lib/renderers/Form/Options.js.map +2 -2
- package/lib/renderers/Form/Select.d.ts +2 -0
- package/lib/renderers/Form/Select.js +9 -6
- package/lib/renderers/Form/Select.js.map +2 -2
- package/lib/renderers/Form/TabsTransfer.d.ts +5 -32
- package/lib/renderers/Form/TabsTransfer.js +20 -1
- package/lib/renderers/Form/TabsTransfer.js.map +2 -2
- package/lib/renderers/Form/TabsTransferPicker.d.ts +5 -35
- package/lib/renderers/Form/TabsTransferPicker.js +21 -2
- package/lib/renderers/Form/TabsTransferPicker.js.map +2 -2
- package/lib/renderers/Form/Transfer.d.ts +15 -4
- package/lib/renderers/Form/Transfer.js +55 -18
- package/lib/renderers/Form/Transfer.js.map +2 -2
- package/lib/renderers/Form/TransferPicker.d.ts +3 -32
- package/lib/renderers/Form/TransferPicker.js +1 -1
- package/lib/renderers/Form/TransferPicker.js.map +2 -2
- package/lib/renderers/Form/TreeSelect.js +4 -4
- package/lib/renderers/Form/TreeSelect.js.map +2 -2
- package/lib/renderers/Form/index.js +8 -1
- package/lib/renderers/Form/index.js.map +2 -2
- package/lib/renderers/IFrame.js +0 -2
- package/lib/renderers/IFrame.js.map +2 -2
- package/lib/renderers/Link.d.ts +1 -1
- package/lib/renderers/Link.js +27 -6
- package/lib/renderers/Link.js.map +2 -2
- package/lib/renderers/Log.js +15 -10
- package/lib/renderers/Log.js.map +2 -2
- package/lib/renderers/Nav.d.ts +21 -21
- package/lib/renderers/Remark.d.ts +5 -1
- package/lib/renderers/Remark.js +39 -7
- package/lib/renderers/Remark.js.map +2 -2
- package/lib/renderers/Steps.js +5 -5
- package/lib/renderers/Steps.js.map +2 -2
- package/lib/renderers/Table/index.js +4 -1
- package/lib/renderers/Table/index.js.map +2 -2
- package/lib/renderers/Tabs.js +1 -1
- package/lib/renderers/Tabs.js.map +2 -2
- package/lib/renderers/Timeline.d.ts +65 -0
- package/lib/renderers/Timeline.js +54 -0
- package/lib/renderers/Timeline.js.map +13 -0
- package/lib/renderers/Video.js.map +2 -2
- package/lib/schemaExtend.js +23 -9
- package/lib/schemaExtend.js.map +2 -2
- package/lib/store/combo.js.map +2 -2
- package/lib/store/formItem.js +1 -1
- package/lib/store/formItem.js.map +2 -2
- package/lib/themes/ang-ie11.css +1149 -53
- package/lib/themes/ang.css +1149 -53
- package/lib/themes/ang.css.map +1 -1
- package/lib/themes/antd-ie11.css +1187 -53
- package/lib/themes/antd.css +1187 -53
- package/lib/themes/antd.css.map +1 -1
- package/lib/themes/cxd-ie11.css +1189 -70
- package/lib/themes/cxd.css +1189 -70
- package/lib/themes/cxd.css.map +1 -1
- package/lib/themes/dark-ie11.css +1152 -53
- package/lib/themes/dark.css +1152 -53
- package/lib/themes/dark.css.map +1 -1
- package/lib/themes/default.css +1189 -70
- package/lib/themes/default.css.map +1 -1
- package/lib/utils/RootClose.js +3 -1
- package/lib/utils/RootClose.js.map +2 -2
- package/lib/utils/api.js +14 -3
- package/lib/utils/api.js.map +2 -2
- package/lib/utils/debug.d.ts +26 -0
- package/lib/utils/debug.js +351 -0
- package/lib/utils/debug.js.map +13 -0
- package/lib/utils/helper.d.ts +1 -6
- package/lib/utils/helper.js +6 -17
- package/lib/utils/helper.js.map +2 -2
- package/lib/utils/renderer-event.d.ts +38 -0
- package/lib/utils/renderer-event.js +28 -0
- package/lib/utils/renderer-event.js.map +13 -0
- package/package.json +12 -6
- package/schema.json +3516 -839
- package/scss/_properties.scss +20 -6
- package/scss/_variables.scss +1 -0
- package/scss/components/_avatar.scss +27 -9
- package/scss/components/_calendar.scss +291 -0
- package/scss/components/_card.scss +1 -1
- package/scss/components/_cascader.scss +102 -0
- package/scss/components/_city-area.scss +27 -0
- package/scss/components/_collapse-group.scss +1 -3
- package/scss/components/_debug.scss +167 -0
- package/scss/components/_dropdown.scss +39 -9
- package/scss/components/_formula.scss +30 -6
- package/scss/components/_modal.scss +18 -0
- package/scss/components/_panel.scss +45 -0
- package/scss/components/_picker-columns.scss +15 -5
- package/scss/components/_popup.scss +43 -16
- package/scss/components/_result-box.scss +31 -0
- package/scss/components/_timeline.scss +198 -0
- package/scss/components/form/_checks.scss +2 -0
- package/scss/components/form/_color.scss +2 -2
- package/scss/components/form/_date-range.scss +34 -1
- package/scss/components/form/_date.scss +46 -1
- package/scss/components/form/_form.scss +170 -0
- package/scss/components/form/_nested-select.scss +3 -0
- package/scss/components/form/_result-list.scss +2 -0
- package/scss/components/form/_select.scss +32 -3
- package/scss/components/form/_selection.scss +5 -4
- package/scss/components/form/_transfer.scss +3 -0
- package/scss/components/form/_tree-select.scss +1 -1
- package/scss/themes/_antd-variables.scss +45 -0
- package/scss/themes/_common.scss +5 -0
- package/scss/themes/_cxd-variables.scss +50 -1
- package/scss/themes/_dark-variables.scss +4 -0
- package/scss/themes/cxd.scss +0 -19
- package/sdk/ang-ie11.css +1450 -142
- package/sdk/ang.css +1473 -159
- package/sdk/antd-ie11.css +1451 -142
- package/sdk/antd.css +1511 -159
- package/sdk/charts.js +15 -15
- package/sdk/codemirror.js +7 -7
- package/sdk/color-picker.js +65 -65
- package/sdk/cropperjs.js +2 -2
- package/sdk/cxd-ie11.css +1448 -158
- package/sdk/cxd.css +1513 -178
- package/sdk/dark-ie11.css +1450 -142
- package/sdk/dark.css +1476 -159
- package/sdk/exceljs.js +1 -1
- package/sdk/helper.css.map +1 -1
- package/sdk/locale/de-DE.js +17 -2
- package/sdk/markdown.js +69 -69
- package/sdk/papaparse.js +1 -1
- package/sdk/renderers/Form/CityDB.js +1 -1
- package/sdk/rest.js +18 -18
- package/sdk/rich-text.js +62 -62
- package/sdk/sdk-ie11.css +1448 -158
- package/sdk/sdk.css +1513 -178
- package/sdk/sdk.js +1309 -1251
- 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/RootRenderer.tsx +27 -1
- package/src/Schema.ts +3 -0
- package/src/SchemaRenderer.tsx +70 -4
- package/src/Scoped.tsx +46 -4
- package/src/actions/Action.ts +138 -0
- package/src/actions/AjaxAction.ts +58 -0
- package/src/actions/BreakAction.ts +27 -0
- package/src/actions/BroadcastAction.ts +41 -0
- package/src/actions/CmptAction.ts +36 -0
- package/src/actions/ContinueAction.ts +27 -0
- package/src/actions/CopyAction.ts +41 -0
- package/src/actions/CustomAction.ts +46 -0
- package/src/actions/DialogAction.ts +28 -0
- package/src/actions/DrawerAction.ts +28 -0
- package/src/actions/EmailAction.ts +38 -0
- package/src/actions/LoopAction.ts +77 -0
- package/src/actions/OpenPageAction.ts +39 -0
- package/src/actions/ParallelAction.ts +26 -0
- package/src/actions/SwitchAction.ts +35 -0
- package/src/actions/index.ts +20 -0
- package/src/components/AssociatedSelection.tsx +5 -1
- package/src/components/Avatar.tsx +253 -0
- package/src/components/BaiduMapPicker.tsx +19 -14
- package/src/components/CalendarMobile.tsx +658 -0
- package/src/components/Cascader.tsx +564 -0
- package/src/components/ChainedSelection.tsx +16 -3
- package/src/components/CityArea.tsx +315 -0
- package/src/components/ColorPicker.tsx +41 -40
- package/src/components/DatePicker.tsx +80 -34
- package/src/components/DateRangePicker.tsx +85 -30
- package/src/components/GroupedSelection.tsx +14 -2
- package/src/components/MonthRangePicker.tsx +78 -31
- package/src/components/Overlay.tsx +1 -1
- package/src/components/Picker.tsx +55 -35
- package/src/components/PickerColumn.tsx +43 -36
- package/src/components/PickerContainer.tsx +13 -1
- package/src/components/PopOverContainer.tsx +31 -17
- package/src/components/PopUp.tsx +84 -57
- package/src/components/ResultBox.tsx +14 -2
- package/src/components/ResultList.tsx +36 -6
- package/src/components/Select.tsx +24 -26
- package/src/components/Selection.tsx +21 -3
- package/src/components/Steps.tsx +23 -10
- package/src/components/TableSelection.tsx +1 -44
- package/src/components/Tabs.tsx +65 -54
- package/src/components/TabsTransfer.tsx +78 -9
- package/src/components/TabsTransferPicker.tsx +25 -13
- package/src/components/Timeline.tsx +36 -0
- package/src/components/TimelineItem.tsx +140 -0
- package/src/components/Transfer.tsx +11 -8
- package/src/components/TransferDropDown.tsx +20 -12
- package/src/components/TransferPicker.tsx +25 -4
- package/src/components/TreeSelection.tsx +7 -1
- package/src/components/calendar/Calendar.tsx +101 -4
- package/src/components/calendar/DaysView.tsx +165 -33
- package/src/components/calendar/MonthsView.tsx +108 -1
- package/src/components/calendar/QuartersView.tsx +3 -2
- package/src/components/calendar/TimeView.tsx +104 -41
- package/src/components/calendar/YearsView.tsx +34 -17
- package/src/components/condition-builder/Field.tsx +1 -3
- package/src/components/condition-builder/Func.tsx +1 -1
- package/src/components/formula/Editor.tsx +16 -11
- package/src/components/formula/FuncList.tsx +3 -1
- package/src/components/formula/Picker.tsx +2 -1
- package/src/components/formula/plugin.ts +0 -2
- package/src/components/icons.tsx +2 -0
- package/src/components/index.tsx +2 -0
- package/src/components/virtual-list/SizeAndPositionManager.ts +6 -3
- package/src/components/virtual-list/index.tsx +4 -6
- package/src/env.tsx +22 -0
- package/src/factory.tsx +93 -1
- package/src/icons/tree-down.svg +5 -0
- package/src/index.tsx +5 -0
- package/src/locale/de-DE.ts +17 -2
- package/src/locale/en-US.ts +17 -2
- package/src/locale/zh-CN.ts +16 -1
- package/src/renderers/Action.tsx +11 -2
- package/src/renderers/Avatar.tsx +83 -74
- package/src/renderers/Card.tsx +10 -6
- package/src/renderers/Custom.tsx +7 -4
- package/src/renderers/DropDownButton.tsx +69 -35
- package/src/renderers/Each.tsx +4 -4
- package/src/renderers/Flex.tsx +3 -7
- package/src/renderers/Form/ChartRadios.tsx +2 -7
- package/src/renderers/Form/Checkboxes.tsx +1 -1
- package/src/renderers/Form/CityDB.ts +526 -2
- package/src/renderers/Form/DiffEditor.tsx +2 -3
- package/src/renderers/Form/InputCity.tsx +23 -3
- package/src/renderers/Form/InputColor.tsx +21 -2
- package/src/renderers/Form/InputDate.tsx +48 -20
- package/src/renderers/Form/InputDateRange.tsx +9 -2
- package/src/renderers/Form/InputFormula.tsx +9 -4
- package/src/renderers/Form/InputImage.tsx +9 -4
- package/src/renderers/Form/InputMonthRange.tsx +0 -1
- package/src/renderers/Form/InputQuarterRange.tsx +0 -1
- package/src/renderers/Form/InputRichText.tsx +11 -1
- package/src/renderers/Form/InputYearRange.tsx +0 -1
- package/src/renderers/Form/Item.tsx +29 -8
- package/src/renderers/Form/NestedSelect.tsx +32 -4
- package/src/renderers/Form/Options.tsx +15 -7
- package/src/renderers/Form/Select.tsx +21 -5
- package/src/renderers/Form/TabsTransfer.tsx +28 -38
- package/src/renderers/Form/TabsTransferPicker.tsx +28 -46
- package/src/renderers/Form/Transfer.tsx +75 -24
- package/src/renderers/Form/TransferPicker.tsx +6 -38
- package/src/renderers/Form/TreeSelect.tsx +18 -16
- package/src/renderers/Form/index.tsx +7 -1
- package/src/renderers/IFrame.tsx +0 -2
- package/src/renderers/Link.tsx +18 -3
- package/src/renderers/Log.tsx +5 -1
- package/src/renderers/Remark.tsx +68 -18
- package/src/renderers/Steps.tsx +11 -13
- package/src/renderers/Table/index.tsx +7 -1
- package/src/renderers/Tabs.tsx +6 -2
- package/src/renderers/Timeline.tsx +141 -0
- package/src/renderers/Video.tsx +4 -20
- package/src/schemaExtend.ts +22 -10
- package/src/store/combo.ts +1 -3
- package/src/store/formItem.ts +1 -1
- package/src/utils/RootClose.ts +5 -1
- package/src/utils/api.ts +15 -2
- package/src/utils/debug.tsx +438 -0
- package/src/utils/helper.ts +6 -16
- package/src/utils/renderer-event.ts +75 -0
@@ -21,6 +21,7 @@ import useTouch from '../hooks/use-touch';
|
|
21
21
|
|
22
22
|
export interface PickerColumnItem {
|
23
23
|
labelField?: string;
|
24
|
+
valueField?: string;
|
24
25
|
readonly?: boolean;
|
25
26
|
value?: PickerOption;
|
26
27
|
swipeDuration?: number;
|
@@ -33,7 +34,7 @@ export interface PickerColumnItem {
|
|
33
34
|
index?: number,
|
34
35
|
confirm?: boolean
|
35
36
|
) => void;
|
36
|
-
}
|
37
|
+
}
|
37
38
|
|
38
39
|
export interface PickerColumnProps extends PickerColumnItem, ThemeProps {}
|
39
40
|
|
@@ -64,12 +65,13 @@ function getElementTranslateY(element: HTMLElement | null) {
|
|
64
65
|
function isOptionDisabled(option: PickerOption) {
|
65
66
|
return isObject(option) && option.disabled;
|
66
67
|
}
|
67
|
-
|
68
|
+
|
68
69
|
const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
69
70
|
const {
|
70
71
|
visibleItemCount = 5,
|
71
|
-
itemHeight =
|
72
|
+
itemHeight = 48,
|
72
73
|
value,
|
74
|
+
valueField = 'value',
|
73
75
|
swipeDuration = 1000,
|
74
76
|
labelField = 'text',
|
75
77
|
options = [],
|
@@ -88,7 +90,24 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
88
90
|
|
89
91
|
const touch = useTouch();
|
90
92
|
const count = options.length;
|
91
|
-
|
93
|
+
|
94
|
+
const getOptionText = (option: [] | PickerOption) => {
|
95
|
+
if (isObject(option) && labelField in option) {
|
96
|
+
//@ts-ignore
|
97
|
+
return option[labelField];
|
98
|
+
}
|
99
|
+
return option;
|
100
|
+
};
|
101
|
+
|
102
|
+
const getOptionValue = (option: [] | PickerOption) => {
|
103
|
+
if (isObject(option) && valueField in option) {
|
104
|
+
//@ts-ignore
|
105
|
+
return option[valueField];
|
106
|
+
}
|
107
|
+
return option;
|
108
|
+
};
|
109
|
+
|
110
|
+
const defaultIndex = options.findIndex(item => getOptionValue(item) === value);
|
92
111
|
|
93
112
|
const baseOffset = useMemo(() => {
|
94
113
|
// 默认转入第一个选项的位置
|
@@ -134,12 +153,9 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
134
153
|
if (emitChange && props.onChange) {
|
135
154
|
requestAnimationFrame(
|
136
155
|
() => {
|
137
|
-
props.onChange?.(options[index], index, confirm);
|
156
|
+
props.onChange?.(getOptionValue(options[index]), index, confirm);
|
138
157
|
}
|
139
158
|
);
|
140
|
-
// setTimeout(() => {
|
141
|
-
// props.onChange?.(options[index], index, confirm);
|
142
|
-
// }, 0);
|
143
159
|
}
|
144
160
|
};
|
145
161
|
|
@@ -156,7 +172,7 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
156
172
|
const setOptions = (options: Array<PickerOption>) => {
|
157
173
|
if (JSON.stringify(options) !== JSON.stringify(state.options)) {
|
158
174
|
updateState({options});
|
159
|
-
const index = options.findIndex(item => item === value) || 0;
|
175
|
+
const index = options.findIndex(item => getOptionValue(item) === value) || 0;
|
160
176
|
setIndex(index, true, true);
|
161
177
|
}
|
162
178
|
};
|
@@ -170,14 +186,6 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
170
186
|
setIndex(index, true, true);
|
171
187
|
};
|
172
188
|
|
173
|
-
const getOptionText = (option: [] | PickerOption) => {
|
174
|
-
if (isObject(option) && labelField in option) {
|
175
|
-
//@ts-ignore
|
176
|
-
return option[labelField];
|
177
|
-
}
|
178
|
-
return option;
|
179
|
-
};
|
180
|
-
|
181
189
|
const getIndexByOffset = (offset: number) =>
|
182
190
|
range(Math.round(-offset / itemHeight), 0, count - 1);
|
183
191
|
|
@@ -301,7 +309,7 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
301
309
|
onClickItem(index);
|
302
310
|
}
|
303
311
|
};
|
304
|
-
|
312
|
+
|
305
313
|
const childData = {
|
306
314
|
className: 'text-ellipsis',
|
307
315
|
children: text
|
@@ -357,23 +365,23 @@ const PickerColumn = forwardRef<{}, PickerColumnProps>((props, ref) => {
|
|
357
365
|
transitionProperty: state.duration ? 'all' : 'none'
|
358
366
|
};
|
359
367
|
return (
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
368
|
+
<div
|
369
|
+
ref={root}
|
370
|
+
className={props.classnames('PickerColumns', props.className)}
|
371
|
+
onTouchStart={onTouchStart}
|
372
|
+
onTouchMove={onTouchMove}
|
373
|
+
onTouchEnd={onTouchEnd}
|
374
|
+
onTouchCancel={onTouchEnd}
|
375
|
+
>
|
376
|
+
<ul
|
377
|
+
ref={wrapper}
|
378
|
+
style={wrapperStyle}
|
379
|
+
className={props.classnames('PickerColumns-columnWrapper')}
|
380
|
+
onTransitionEnd={stopMomentum}
|
367
381
|
>
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
className={props.classnames('PickerColumns-columnWrapper')}
|
372
|
-
onTransitionEnd={stopMomentum}
|
373
|
-
>
|
374
|
-
{renderOptions()}
|
375
|
-
</ul>
|
376
|
-
</div>
|
382
|
+
{renderOptions()}
|
383
|
+
</ul>
|
384
|
+
</div>
|
377
385
|
);
|
378
386
|
});
|
379
387
|
|
@@ -381,7 +389,7 @@ PickerColumn.defaultProps = {
|
|
381
389
|
options: [],
|
382
390
|
visibleItemCount: 5,
|
383
391
|
swipeDuration: 1000,
|
384
|
-
itemHeight:
|
392
|
+
itemHeight: 48
|
385
393
|
};
|
386
394
|
|
387
395
|
export default themeable(
|
@@ -389,4 +397,3 @@ export default themeable(
|
|
389
397
|
value: 'onChange'
|
390
398
|
})
|
391
399
|
);
|
392
|
-
|
@@ -19,6 +19,8 @@ export interface PickerContainerProps extends ThemeProps, LocaleProps {
|
|
19
19
|
onClose: () => void;
|
20
20
|
value: any;
|
21
21
|
onChange: (value: any) => void;
|
22
|
+
setState: (state: any) => void;
|
23
|
+
[propName: string]: any;
|
22
24
|
}) => JSX.Element;
|
23
25
|
value?: any;
|
24
26
|
onConfirm?: (value?: any) => void;
|
@@ -83,6 +85,15 @@ export class PickerContainer extends React.Component<
|
|
83
85
|
this.close(undefined, () => onConfirm?.(this.state.value));
|
84
86
|
}
|
85
87
|
|
88
|
+
@autobind
|
89
|
+
updateState(state: any = {}) {
|
90
|
+
const {isOpened, ...rest} = state;
|
91
|
+
this.setState({
|
92
|
+
...this.state,
|
93
|
+
...rest
|
94
|
+
});
|
95
|
+
}
|
96
|
+
|
86
97
|
render() {
|
87
98
|
const {
|
88
99
|
children,
|
@@ -112,8 +123,9 @@ export class PickerContainer extends React.Component<
|
|
112
123
|
) : null}
|
113
124
|
<Modal.Body>
|
114
125
|
{popOverRender({
|
126
|
+
...(this.state as any),
|
127
|
+
setState: this.updateState,
|
115
128
|
onClose: this.close,
|
116
|
-
value: this.state.value,
|
117
129
|
onChange: this.handleChange
|
118
130
|
})}
|
119
131
|
</Modal.Body>
|
@@ -1,7 +1,8 @@
|
|
1
1
|
import React from 'react';
|
2
|
-
import {autobind} from '../utils/helper';
|
2
|
+
import {autobind, isMobile} from '../utils/helper';
|
3
3
|
import Overlay from './Overlay';
|
4
4
|
import PopOver from './PopOver';
|
5
|
+
import PopUp from './PopUp';
|
5
6
|
import {findDOMNode} from 'react-dom';
|
6
7
|
|
7
8
|
export interface PopOverContainerProps {
|
@@ -13,6 +14,7 @@ export interface PopOverContainerProps {
|
|
13
14
|
popOverRender: (props: {onClose: () => void}) => JSX.Element;
|
14
15
|
popOverContainer?: any;
|
15
16
|
popOverClassName?: string;
|
17
|
+
useMobileUI?: boolean;
|
16
18
|
}
|
17
19
|
|
18
20
|
export interface PopOverContainerState {
|
@@ -60,11 +62,13 @@ export class PopOverContainer extends React.Component<
|
|
60
62
|
|
61
63
|
render() {
|
62
64
|
const {
|
65
|
+
useMobileUI,
|
63
66
|
children,
|
64
67
|
popOverContainer,
|
65
68
|
popOverClassName,
|
66
69
|
popOverRender: dropdownRender
|
67
70
|
} = this.props;
|
71
|
+
const mobileUI = useMobileUI && isMobile();
|
68
72
|
return (
|
69
73
|
<>
|
70
74
|
{children({
|
@@ -72,26 +76,36 @@ export class PopOverContainer extends React.Component<
|
|
72
76
|
onClick: this.handleClick,
|
73
77
|
ref: this.targetRef
|
74
78
|
})}
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
placement={'auto'}
|
80
|
-
show={this.state.isOpened}
|
81
|
-
>
|
82
|
-
<PopOver
|
83
|
-
overlay
|
79
|
+
{mobileUI ? (
|
80
|
+
<PopUp
|
81
|
+
isShow={this.state.isOpened}
|
82
|
+
container={popOverContainer}
|
84
83
|
className={popOverClassName}
|
85
|
-
style={{
|
86
|
-
minWidth: this.target
|
87
|
-
? Math.max(this.target.offsetWidth, 100)
|
88
|
-
: 'auto'
|
89
|
-
}}
|
90
84
|
onHide={this.close}
|
91
85
|
>
|
92
86
|
{dropdownRender({onClose: this.close})}
|
93
|
-
</
|
94
|
-
|
87
|
+
</PopUp>
|
88
|
+
) : (
|
89
|
+
<Overlay
|
90
|
+
container={popOverContainer || this.getParent}
|
91
|
+
target={this.getTarget}
|
92
|
+
placement={'auto'}
|
93
|
+
show={this.state.isOpened}
|
94
|
+
>
|
95
|
+
<PopOver
|
96
|
+
overlay
|
97
|
+
className={popOverClassName}
|
98
|
+
style={{
|
99
|
+
minWidth: this.target
|
100
|
+
? Math.max(this.target.offsetWidth, 100)
|
101
|
+
: 'auto'
|
102
|
+
}}
|
103
|
+
onHide={this.close}
|
104
|
+
>
|
105
|
+
{dropdownRender({onClose: this.close})}
|
106
|
+
</PopOver>
|
107
|
+
</Overlay>
|
108
|
+
)}
|
95
109
|
</>
|
96
110
|
);
|
97
111
|
}
|
package/src/components/PopUp.tsx
CHANGED
@@ -5,7 +5,8 @@
|
|
5
5
|
*/
|
6
6
|
|
7
7
|
import React from 'react';
|
8
|
-
import {
|
8
|
+
import {themeable, ThemeProps} from '../theme';
|
9
|
+
import {localeable, LocaleProps} from '../locale';
|
9
10
|
import Transition, {
|
10
11
|
ENTERED,
|
11
12
|
EXITING,
|
@@ -13,23 +14,24 @@ import Transition, {
|
|
13
14
|
ENTERING
|
14
15
|
} from 'react-transition-group/Transition';
|
15
16
|
import Portal from 'react-overlays/Portal';
|
16
|
-
import {
|
17
|
+
import {Icon} from './icons';
|
18
|
+
import Button from './Button';
|
17
19
|
|
18
|
-
|
19
|
-
|
20
|
+
export interface PopUpPorps extends ThemeProps, LocaleProps {
|
21
|
+
title?: string;
|
20
22
|
className?: string;
|
21
23
|
style?: {
|
22
24
|
[styleName: string]: string;
|
23
25
|
};
|
24
26
|
overlay?: boolean;
|
25
27
|
onHide?: () => void;
|
26
|
-
classPrefix: string;
|
27
|
-
classnames: ClassNamesFn;
|
28
|
-
[propName: string]: any;
|
29
28
|
isShow?: boolean;
|
30
29
|
container?: any;
|
31
|
-
|
30
|
+
showConfirm?: boolean;
|
31
|
+
onConfirm?: (value: any) => void;
|
32
|
+
showClose?: boolean;
|
32
33
|
placement?: 'left' | 'center' | 'right';
|
34
|
+
header?: JSX.Element;
|
33
35
|
}
|
34
36
|
|
35
37
|
const fadeStyles: {
|
@@ -41,16 +43,28 @@ const fadeStyles: {
|
|
41
43
|
[ENTERING]: 'in'
|
42
44
|
};
|
43
45
|
export class PopUp extends React.PureComponent<PopUpPorps> {
|
46
|
+
scrollTop: number = 0;
|
44
47
|
static defaultProps = {
|
45
48
|
className: '',
|
46
49
|
overlay: true,
|
47
50
|
isShow: false,
|
48
51
|
container: document.body,
|
49
|
-
|
52
|
+
showClose: true,
|
53
|
+
onConfirm: () => {}
|
50
54
|
};
|
51
|
-
|
52
|
-
|
53
|
-
|
55
|
+
componentDidUpdate() {
|
56
|
+
if (this.props.isShow) {
|
57
|
+
this.scrollTop =
|
58
|
+
document.body.scrollTop || document.documentElement.scrollTop;
|
59
|
+
document.body.style.overflow = 'hidden';
|
60
|
+
} else {
|
61
|
+
document.body.style.overflow = 'auto';
|
62
|
+
document.body.scrollTop = this.scrollTop;
|
63
|
+
}
|
64
|
+
}
|
65
|
+
componentWillUnmount() {
|
66
|
+
document.body.style.overflow = 'auto';
|
67
|
+
document.body.scrollTop = this.scrollTop;
|
54
68
|
}
|
55
69
|
handleClick(e: React.MouseEvent) {
|
56
70
|
e.stopPropagation();
|
@@ -59,75 +73,88 @@ export class PopUp extends React.PureComponent<PopUpPorps> {
|
|
59
73
|
render() {
|
60
74
|
const {
|
61
75
|
style,
|
76
|
+
title,
|
62
77
|
children,
|
63
78
|
overlay,
|
64
79
|
onHide,
|
80
|
+
onConfirm,
|
65
81
|
classPrefix: ns,
|
66
82
|
classnames: cx,
|
67
83
|
className,
|
68
84
|
isShow,
|
69
85
|
container,
|
70
|
-
|
71
|
-
|
86
|
+
showConfirm,
|
87
|
+
translate: __,
|
88
|
+
showClose,
|
89
|
+
header,
|
90
|
+
placement = 'center',
|
72
91
|
...rest
|
73
92
|
} = this.props;
|
74
93
|
|
75
94
|
const outerStyle: any = {
|
76
|
-
...style
|
95
|
+
...style
|
77
96
|
};
|
78
97
|
delete outerStyle.top;
|
79
98
|
return (
|
80
99
|
<Portal container={container}>
|
81
|
-
<Transition
|
82
|
-
mountOnEnter
|
83
|
-
unmountOnExit
|
84
|
-
in={isShow}
|
85
|
-
timeout={500}
|
86
|
-
appear
|
87
|
-
>
|
100
|
+
<Transition mountOnEnter unmountOnExit in={isShow} timeout={500} appear>
|
88
101
|
{(status: string) => {
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
{
|
98
|
-
|
99
|
-
>
|
100
|
-
{
|
101
|
-
<div className={`${ns}PopUp-
|
102
|
-
|
103
|
-
|
104
|
-
|
102
|
+
return (
|
103
|
+
<div
|
104
|
+
className={cx(`${ns}PopUp`, className, fadeStyles[status])}
|
105
|
+
style={outerStyle}
|
106
|
+
{...rest}
|
107
|
+
onClick={this.handleClick}
|
108
|
+
>
|
109
|
+
{overlay && (
|
110
|
+
<div className={`${ns}PopUp-overlay`} onClick={onHide} />
|
111
|
+
)}
|
112
|
+
<div className={cx(`${ns}PopUp-inner`)}>
|
113
|
+
{!showConfirm && showClose ? (
|
114
|
+
<div className={cx(`${ns}PopUp-closeWrap`)}>
|
115
|
+
{header}
|
116
|
+
<Icon
|
117
|
+
icon="close"
|
118
|
+
className={cx('icon', `${ns}PopUp-close`)}
|
119
|
+
onClick={onHide}
|
120
|
+
/>
|
121
|
+
</div>
|
122
|
+
) : null}
|
123
|
+
{showConfirm && (
|
124
|
+
<div className={cx(`${ns}PopUp-toolbar`)}>
|
125
|
+
<Button
|
126
|
+
className={cx(`${ns}PopUp-cancel`)}
|
127
|
+
level="text"
|
128
|
+
onClick={onHide}
|
129
|
+
>
|
130
|
+
{__('cancel')}
|
131
|
+
</Button>
|
132
|
+
{title && (
|
133
|
+
<span className={cx(`${ns}PopUp-title`)}>{title}</span>
|
134
|
+
)}
|
135
|
+
<Button
|
136
|
+
className={cx(`${ns}PopUp-confirm`)}
|
137
|
+
level="text"
|
138
|
+
onClick={onConfirm}
|
139
|
+
>
|
140
|
+
{__('confirm')}
|
141
|
+
</Button>
|
142
|
+
</div>
|
105
143
|
)}
|
144
|
+
<div
|
145
|
+
className={cx(`${ns}PopUp-content`, `justify-${placement}`)}
|
106
146
|
>
|
107
|
-
{
|
108
|
-
!hideClose && (
|
109
|
-
<div className={cx(`${ns}PopUp-closeWrap`, 'text-right')}>
|
110
|
-
<Icon
|
111
|
-
icon="close"
|
112
|
-
className={cx('icon', `${ns}PopUp-close`)}
|
113
|
-
onClick={onHide}
|
114
|
-
/>
|
115
|
-
</div>
|
116
|
-
)
|
117
|
-
}
|
118
|
-
<div
|
119
|
-
className={cx(`${ns}PopUp-content`, `justify-${placement}`)}
|
120
|
-
>
|
121
|
-
{children}
|
122
|
-
</div>
|
147
|
+
{isShow ? children : null}
|
123
148
|
</div>
|
149
|
+
<div className={cx(`PopUp-safearea`)}></div>
|
124
150
|
</div>
|
125
|
-
|
151
|
+
</div>
|
152
|
+
);
|
126
153
|
}}
|
127
154
|
</Transition>
|
128
155
|
</Portal>
|
129
|
-
)
|
156
|
+
);
|
130
157
|
}
|
131
158
|
}
|
132
159
|
|
133
|
-
export default themeable(PopUp);
|
160
|
+
export default themeable(localeable(PopUp));
|
@@ -4,8 +4,9 @@ import {InputBoxProps} from './InputBox';
|
|
4
4
|
import {uncontrollable} from 'uncontrollable';
|
5
5
|
import {Icon} from './icons';
|
6
6
|
import Input from './Input';
|
7
|
-
import {autobind, ucFirst} from '../utils/helper';
|
7
|
+
import {autobind, isMobile, ucFirst} from '../utils/helper';
|
8
8
|
import {LocaleProps, localeable} from '../locale';
|
9
|
+
import isPlainObject = require('lodash/isPlainObject');
|
9
10
|
|
10
11
|
export interface ResultBoxProps
|
11
12
|
extends ThemeProps,
|
@@ -18,6 +19,7 @@ export interface ResultBoxProps
|
|
18
19
|
onResultChange?: (value: Array<any>) => void;
|
19
20
|
allowInput?: boolean;
|
20
21
|
inputPlaceholder: string;
|
22
|
+
useMobileUI?: boolean;
|
21
23
|
}
|
22
24
|
|
23
25
|
export class ResultBox extends React.Component<ResultBoxProps> {
|
@@ -114,9 +116,11 @@ export class ResultBox extends React.Component<ResultBoxProps> {
|
|
114
116
|
onFocus,
|
115
117
|
onBlur,
|
116
118
|
borderMode,
|
119
|
+
useMobileUI,
|
117
120
|
...rest
|
118
121
|
} = this.props;
|
119
122
|
const isFocused = this.state.isFocused;
|
123
|
+
const mobileUI = useMobileUI && isMobile();
|
120
124
|
|
121
125
|
return (
|
122
126
|
<div
|
@@ -125,6 +129,7 @@ export class ResultBox extends React.Component<ResultBoxProps> {
|
|
125
129
|
'is-disabled': disabled,
|
126
130
|
'is-error': hasError,
|
127
131
|
'is-clickable': onResultClick,
|
132
|
+
'is-mobile': mobileUI,
|
128
133
|
[`ResultBox--border${ucFirst(borderMode)}`]: borderMode
|
129
134
|
})}
|
130
135
|
onClick={onResultClick}
|
@@ -147,7 +152,9 @@ export class ResultBox extends React.Component<ResultBoxProps> {
|
|
147
152
|
</div>
|
148
153
|
))
|
149
154
|
) : result && !Array.isArray(result) ? (
|
150
|
-
<span className={cx('ResultBox-singleValue')}>
|
155
|
+
<span className={cx('ResultBox-singleValue')}>
|
156
|
+
{isPlainObject(result) ? itemRender(result) : result}
|
157
|
+
</span>
|
151
158
|
) : allowInput && !disabled ? null : (
|
152
159
|
<span className={cx('ResultBox-placeholder')}>
|
153
160
|
{__(placeholder || 'placeholder.noData')}
|
@@ -180,6 +187,11 @@ export class ResultBox extends React.Component<ResultBoxProps> {
|
|
180
187
|
<Icon icon="close" className="icon" />
|
181
188
|
</a>
|
182
189
|
) : null}
|
190
|
+
{!allowInput && mobileUI ? (
|
191
|
+
<span className={cx('ResultBox-arrow')}>
|
192
|
+
<Icon icon="caret" className="icon" />
|
193
|
+
</span>
|
194
|
+
) : null}
|
183
195
|
</div>
|
184
196
|
);
|
185
197
|
}
|
@@ -13,21 +13,28 @@ import {LocaleProps, localeable} from '../locale';
|
|
13
13
|
export interface ResultListProps extends ThemeProps, LocaleProps {
|
14
14
|
className?: string;
|
15
15
|
value?: Array<Option>;
|
16
|
-
onChange?: (value: Array<Option
|
16
|
+
onChange?: (value: Array<Option>, optionModified?: boolean) => void;
|
17
17
|
sortable?: boolean;
|
18
18
|
disabled?: boolean;
|
19
19
|
title?: string;
|
20
20
|
placeholder: string;
|
21
|
-
itemRender: (option: Option) => JSX.Element;
|
21
|
+
itemRender: (option: Option, states: ItemRenderStates) => JSX.Element;
|
22
22
|
itemClassName?: string;
|
23
23
|
}
|
24
24
|
|
25
|
+
export interface ItemRenderStates {
|
26
|
+
index: number;
|
27
|
+
disabled?: boolean;
|
28
|
+
onChange: (value: any, name: string) => void;
|
29
|
+
}
|
30
|
+
|
25
31
|
export class ResultList extends React.Component<ResultListProps> {
|
32
|
+
static itemRender(option: any) {
|
33
|
+
return <span>{`${option.scopeLabel || ''}${option.label}`}</span>;
|
34
|
+
}
|
26
35
|
static defaultProps: Pick<ResultListProps, 'placeholder' | 'itemRender'> = {
|
27
36
|
placeholder: 'placeholder.selectData',
|
28
|
-
itemRender:
|
29
|
-
<span>{`${option.scopeLabel || ''}${option.label}`}</span>
|
30
|
-
)
|
37
|
+
itemRender: ResultList.itemRender
|
31
38
|
};
|
32
39
|
|
33
40
|
id = guid();
|
@@ -114,6 +121,23 @@ export class ResultList extends React.Component<ResultListProps> {
|
|
114
121
|
delete this.sortable;
|
115
122
|
}
|
116
123
|
|
124
|
+
handleValueChange(index: number, value: any, name: string) {
|
125
|
+
if (typeof name !== 'string') {
|
126
|
+
return;
|
127
|
+
}
|
128
|
+
const {value: list, onChange} = this.props;
|
129
|
+
|
130
|
+
const result = Array.isArray(list) ? list.concat() : [];
|
131
|
+
if (!result[index]) {
|
132
|
+
return;
|
133
|
+
}
|
134
|
+
result.splice(index, 1, {
|
135
|
+
...result[index],
|
136
|
+
[name]: value
|
137
|
+
});
|
138
|
+
onChange?.(result, true);
|
139
|
+
}
|
140
|
+
|
117
141
|
render() {
|
118
142
|
const {
|
119
143
|
classnames: cx,
|
@@ -150,7 +174,13 @@ export class ResultList extends React.Component<ResultListProps> {
|
|
150
174
|
/>
|
151
175
|
) : null}
|
152
176
|
|
153
|
-
<label>
|
177
|
+
<label>
|
178
|
+
{itemRender(option, {
|
179
|
+
index,
|
180
|
+
disabled,
|
181
|
+
onChange: this.handleValueChange.bind(this, index)
|
182
|
+
})}
|
183
|
+
</label>
|
154
184
|
|
155
185
|
{!disabled ? (
|
156
186
|
<a
|