amis 1.8.0-beta.1 → 1.8.0-beta.13
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 +9 -2
- package/lib/Schema.js.map +1 -1
- package/lib/SchemaRenderer.js +19 -3
- package/lib/SchemaRenderer.js.map +2 -2
- package/lib/WithRootStore.d.ts +18 -0
- package/lib/WithStore.js +2 -1
- package/lib/WithStore.js.map +2 -2
- package/lib/actions/CmptAction.js +26 -4
- package/lib/actions/CmptAction.js.map +2 -2
- package/lib/actions/PageAction.d.ts +32 -0
- package/lib/actions/PageAction.js +72 -0
- package/lib/actions/PageAction.js.map +13 -0
- package/lib/actions/index.d.ts +1 -0
- package/lib/actions/index.js +1 -0
- package/lib/actions/index.js.map +2 -2
- package/lib/components/AssociatedSelection.js +9 -2
- package/lib/components/AssociatedSelection.js.map +2 -2
- package/lib/components/BarCode.js +1 -1
- package/lib/components/BarCode.js.map +2 -2
- package/lib/components/CalendarMobile.d.ts +84 -84
- package/lib/components/Cascader.d.ts +2 -0
- package/lib/components/Cascader.js +28 -12
- package/lib/components/Cascader.js.map +2 -2
- package/lib/components/Checkbox.d.ts +24 -23
- package/lib/components/Checkbox.js +5 -1
- package/lib/components/Checkbox.js.map +2 -2
- package/lib/components/Collapse.d.ts +20 -20
- package/lib/components/DatePicker.d.ts +84 -84
- package/lib/components/DatePicker.js +8 -5
- package/lib/components/DatePicker.js.map +2 -2
- package/lib/components/DateRangePicker.d.ts +285 -171
- package/lib/components/DateRangePicker.js +471 -66
- package/lib/components/DateRangePicker.js.map +2 -2
- package/lib/components/Drawer.js +1 -1
- package/lib/components/Drawer.js.map +2 -2
- package/lib/components/ListGroup.d.ts +21 -21
- package/lib/components/Modal.js +1 -1
- package/lib/components/Modal.js.map +2 -2
- package/lib/components/MonthRangePicker.d.ts +84 -84
- package/lib/components/Overlay.d.ts +1 -0
- package/lib/components/Overlay.js +4 -3
- package/lib/components/Overlay.js.map +2 -2
- package/lib/components/Progress.d.ts +29 -24
- package/lib/components/Progress.js +44 -16
- package/lib/components/Progress.js.map +2 -2
- package/lib/components/PullRefresh.d.ts +86 -0
- package/lib/components/PullRefresh.js +135 -0
- package/lib/components/PullRefresh.js.map +13 -0
- package/lib/components/Radios.d.ts +22 -22
- package/lib/components/Radios.js +3 -5
- package/lib/components/Radios.js.map +2 -2
- package/lib/components/Range.d.ts +2 -2
- package/lib/components/Range.js +24 -11
- package/lib/components/Range.js.map +2 -2
- package/lib/components/Spinner.d.ts +200 -107
- package/lib/components/Spinner.js +30 -26
- package/lib/components/Spinner.js.map +2 -2
- package/lib/components/Steps.d.ts +6 -0
- package/lib/components/Steps.js +13 -9
- package/lib/components/Steps.js.map +2 -2
- package/lib/components/Tooltip.d.ts +4 -0
- package/lib/components/Tooltip.js +6 -4
- package/lib/components/Tooltip.js.map +2 -2
- package/lib/components/TooltipWrapper.d.ts +66 -4
- package/lib/components/TooltipWrapper.js +40 -8
- package/lib/components/TooltipWrapper.js.map +2 -2
- package/lib/components/Transfer.d.ts +84 -84
- package/lib/components/TransferDropDown.d.ts +84 -84
- package/lib/components/Tree.d.ts +87 -85
- package/lib/components/Tree.js +13 -5
- package/lib/components/Tree.js.map +2 -2
- package/lib/components/TreeSelection.d.ts +84 -84
- package/lib/components/calendar/Calendar.js +0 -13
- package/lib/components/calendar/Calendar.js.map +2 -2
- package/lib/components/calendar/TimeView.d.ts +1 -0
- package/lib/components/calendar/TimeView.js +7 -0
- package/lib/components/calendar/TimeView.js.map +2 -2
- package/lib/components/calendar/YearsView.js +3 -3
- package/lib/components/calendar/YearsView.js.map +2 -2
- package/lib/components/condition-builder/Expression.d.ts +1 -0
- package/lib/components/condition-builder/Expression.js +4 -4
- package/lib/components/condition-builder/Expression.js.map +2 -2
- package/lib/components/condition-builder/Field.d.ts +1 -0
- package/lib/components/condition-builder/Field.js +3 -2
- package/lib/components/condition-builder/Field.js.map +2 -2
- package/lib/components/condition-builder/Group.d.ts +1 -0
- package/lib/components/condition-builder/Group.js +2 -2
- package/lib/components/condition-builder/Group.js.map +2 -2
- package/lib/components/condition-builder/GroupOrItem.d.ts +1 -0
- package/lib/components/condition-builder/GroupOrItem.js +2 -2
- package/lib/components/condition-builder/GroupOrItem.js.map +2 -2
- package/lib/components/condition-builder/InputSwitch.d.ts +2 -1
- 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.d.ts +1 -0
- package/lib/components/condition-builder/Item.js +9 -8
- package/lib/components/condition-builder/Item.js.map +2 -2
- package/lib/components/condition-builder/Value.d.ts +1 -0
- package/lib/components/condition-builder/Value.js +5 -5
- package/lib/components/condition-builder/Value.js.map +2 -2
- package/lib/components/condition-builder/index.d.ts +1 -0
- package/lib/components/condition-builder/index.js +2 -2
- package/lib/components/condition-builder/index.js.map +2 -2
- package/lib/components/formula/Editor.d.ts +87 -85
- package/lib/components/formula/Editor.js +10 -6
- package/lib/components/formula/Editor.js.map +2 -2
- package/lib/components/formula/Picker.js +3 -1
- package/lib/components/formula/Picker.js.map +2 -2
- package/lib/factory.d.ts +5 -0
- package/lib/factory.js +22 -1
- package/lib/factory.js.map +2 -2
- package/lib/index.js +1 -1
- package/lib/locale/de-DE.js +18 -1
- package/lib/locale/de-DE.js.map +2 -2
- package/lib/locale/en-US.js +18 -1
- package/lib/locale/en-US.js.map +2 -2
- package/lib/locale/zh-CN.js +18 -1
- package/lib/locale/zh-CN.js.map +2 -2
- package/lib/renderers/Action.d.ts +2 -0
- package/lib/renderers/Action.js +23 -5
- package/lib/renderers/Action.js.map +2 -2
- package/lib/renderers/App.d.ts +1 -0
- package/lib/renderers/App.js +3 -0
- package/lib/renderers/App.js.map +2 -2
- package/lib/renderers/CRUD.d.ts +8 -0
- package/lib/renderers/CRUD.js +12 -5
- package/lib/renderers/CRUD.js.map +2 -2
- package/lib/renderers/Carousel.d.ts +1 -0
- package/lib/renderers/Carousel.js +13 -1
- package/lib/renderers/Carousel.js.map +2 -2
- package/lib/renderers/Chart.d.ts +1 -0
- package/lib/renderers/Chart.js +3 -0
- package/lib/renderers/Chart.js.map +2 -2
- package/lib/renderers/Dialog.d.ts +1 -0
- package/lib/renderers/Dialog.js +3 -0
- package/lib/renderers/Dialog.js.map +2 -2
- package/lib/renderers/Drawer.d.ts +1 -0
- package/lib/renderers/Drawer.js +6 -1
- package/lib/renderers/Drawer.js.map +2 -2
- package/lib/renderers/Form/Checkbox.d.ts +5 -2
- package/lib/renderers/Form/Checkbox.js +2 -2
- package/lib/renderers/Form/Checkbox.js.map +2 -2
- package/lib/renderers/Form/Checkboxes.d.ts +7 -2
- package/lib/renderers/Form/Checkboxes.js +101 -12
- package/lib/renderers/Form/Checkboxes.js.map +2 -2
- package/lib/renderers/Form/Combo.d.ts +2 -1
- package/lib/renderers/Form/Combo.js +54 -16
- package/lib/renderers/Form/Combo.js.map +2 -2
- package/lib/renderers/Form/DiffEditor.d.ts +3 -2
- package/lib/renderers/Form/Editor.d.ts +2 -2
- package/lib/renderers/Form/InputCity.d.ts +87 -84
- package/lib/renderers/Form/InputCity.js +44 -2
- package/lib/renderers/Form/InputCity.js.map +2 -2
- package/lib/renderers/Form/InputDate.js +10 -3
- package/lib/renderers/Form/InputDate.js.map +2 -2
- package/lib/renderers/Form/InputDateRange.d.ts +5 -0
- package/lib/renderers/Form/InputDateRange.js +12 -3
- package/lib/renderers/Form/InputDateRange.js.map +2 -2
- package/lib/renderers/Form/InputFile.js +19 -8
- package/lib/renderers/Form/InputFile.js.map +2 -2
- package/lib/renderers/Form/InputImage.js +18 -7
- package/lib/renderers/Form/InputImage.js.map +2 -2
- package/lib/renderers/Form/InputMonthRange.js +5 -1
- package/lib/renderers/Form/InputMonthRange.js.map +2 -2
- package/lib/renderers/Form/InputRange.js +13 -14
- package/lib/renderers/Form/InputRange.js.map +2 -2
- package/lib/renderers/Form/InputText.d.ts +1 -1
- package/lib/renderers/Form/InputText.js +8 -10
- package/lib/renderers/Form/InputText.js.map +2 -2
- package/lib/renderers/Form/InputTree.d.ts +5 -0
- package/lib/renderers/Form/InputTree.js +51 -2
- package/lib/renderers/Form/InputTree.js.map +2 -2
- package/lib/renderers/Form/Item.d.ts +79 -76
- package/lib/renderers/Form/Item.js +3 -1
- package/lib/renderers/Form/Item.js.map +2 -2
- package/lib/renderers/Form/NestedSelect.d.ts +4 -0
- package/lib/renderers/Form/NestedSelect.js +14 -5
- package/lib/renderers/Form/NestedSelect.js.map +2 -2
- package/lib/renderers/Form/Options.js +61 -27
- package/lib/renderers/Form/Options.js.map +2 -2
- package/lib/renderers/Form/Select.js +4 -2
- package/lib/renderers/Form/Select.js.map +2 -2
- package/lib/renderers/Form/Textarea.js +2 -1
- package/lib/renderers/Form/Textarea.js.map +2 -2
- package/lib/renderers/Form/TreeSelect.d.ts +11 -2
- package/lib/renderers/Form/TreeSelect.js +56 -10
- package/lib/renderers/Form/TreeSelect.js.map +2 -2
- package/lib/renderers/Form/index.d.ts +3 -0
- package/lib/renderers/Form/index.js +53 -16
- package/lib/renderers/Form/index.js.map +2 -2
- package/lib/renderers/Form/wrapControl.d.ts +10 -0
- package/lib/renderers/Form/wrapControl.js +41 -19
- package/lib/renderers/Form/wrapControl.js.map +2 -2
- package/lib/renderers/Nav.d.ts +82 -67
- package/lib/renderers/Nav.js +49 -13
- package/lib/renderers/Nav.js.map +2 -2
- package/lib/renderers/Page.d.ts +21 -0
- package/lib/renderers/Page.js +54 -14
- package/lib/renderers/Page.js.map +2 -2
- package/lib/renderers/Progress.d.ts +3 -6
- package/lib/renderers/Progress.js +2 -2
- package/lib/renderers/Progress.js.map +2 -2
- package/lib/renderers/Service.d.ts +3 -0
- package/lib/renderers/Service.js +55 -20
- package/lib/renderers/Service.js.map +2 -2
- package/lib/renderers/Spinner.d.ts +58 -2
- package/lib/renderers/Spinner.js +8 -1
- package/lib/renderers/Spinner.js.map +2 -2
- package/lib/renderers/Steps.d.ts +8 -0
- package/lib/renderers/Steps.js +2 -2
- package/lib/renderers/Steps.js.map +2 -2
- package/lib/renderers/Table/ColumnToggler.d.ts +4 -0
- package/lib/renderers/Table/ColumnToggler.js +11 -6
- package/lib/renderers/Table/ColumnToggler.js.map +2 -2
- package/lib/renderers/Table/TableCell.js +27 -1
- package/lib/renderers/Table/TableCell.js.map +2 -2
- package/lib/renderers/Table/index.d.ts +2 -0
- package/lib/renderers/Table/index.js +23 -10
- package/lib/renderers/Table/index.js.map +2 -2
- package/lib/renderers/Tabs.d.ts +4 -0
- package/lib/renderers/Tabs.js +22 -6
- package/lib/renderers/Tabs.js.map +2 -2
- package/lib/renderers/TooltipWrapper.d.ts +35 -6
- package/lib/renderers/TooltipWrapper.js +19 -8
- package/lib/renderers/TooltipWrapper.js.map +2 -2
- package/lib/renderers/Wizard.d.ts +7 -3
- package/lib/renderers/Wizard.js +269 -152
- package/lib/renderers/Wizard.js.map +2 -2
- package/lib/store/combo.d.ts +2 -2
- package/lib/store/crud.d.ts +1 -0
- package/lib/store/crud.js +55 -19
- package/lib/store/crud.js.map +2 -2
- package/lib/store/form.d.ts +1 -1
- package/lib/store/form.js +5 -1
- package/lib/store/form.js.map +2 -2
- package/lib/store/formItem.js +1 -1
- package/lib/store/formItem.js.map +2 -2
- package/lib/store/index.d.ts +5 -0
- package/lib/store/index.js +14 -0
- package/lib/store/index.js.map +2 -2
- package/lib/store/table.d.ts +2 -2
- package/lib/store/table.js +2 -2
- package/lib/store/table.js.map +2 -2
- package/lib/themes/ang-ie11.css +768 -199
- package/lib/themes/ang.css +723 -142
- package/lib/themes/ang.css.map +1 -1
- package/lib/themes/antd-ie11.css +851 -282
- package/lib/themes/antd.css +724 -143
- package/lib/themes/antd.css.map +1 -1
- package/lib/themes/cxd-ie11.css +879 -310
- package/lib/themes/cxd.css +727 -146
- package/lib/themes/cxd.css.map +1 -1
- package/lib/themes/dark-ie11.css +769 -200
- package/lib/themes/dark.css +723 -142
- package/lib/themes/dark.css.map +1 -1
- package/lib/themes/default-ie11.css +879 -310
- package/lib/themes/default.css +727 -146
- package/lib/themes/default.css.map +1 -1
- package/lib/types.d.ts +3 -1
- package/lib/types.js.map +1 -1
- package/lib/utils/ColorScale.d.ts +19 -0
- package/lib/utils/ColorScale.js +104 -0
- package/lib/utils/ColorScale.js.map +13 -0
- package/lib/utils/api.js +20 -4
- package/lib/utils/api.js.map +2 -2
- package/lib/utils/columnsSplit.d.ts +1 -0
- package/lib/utils/columnsSplit.js +40 -0
- package/lib/utils/columnsSplit.js.map +13 -0
- package/lib/utils/debug.d.ts +1 -1
- package/lib/utils/debug.js +16 -22
- package/lib/utils/debug.js.map +2 -2
- package/lib/utils/dom.d.ts +1 -1
- package/lib/utils/dom.js +7 -5
- package/lib/utils/dom.js.map +2 -2
- package/lib/utils/position.js +0 -1
- package/lib/utils/position.js.map +2 -2
- package/lib/utils/scrollPosition.d.ts +6 -0
- package/lib/utils/scrollPosition.js +31 -0
- package/lib/utils/scrollPosition.js.map +13 -0
- package/package.json +3 -2
- package/schema.json +29681 -28936
- package/scss/_properties.scss +44 -13
- package/scss/components/_barcode.scss +1 -1
- package/scss/components/_carousel.scss +1 -0
- package/scss/components/_column-toggler.scss +21 -11
- package/scss/components/_debug.scss +3 -3
- package/scss/components/_formula.scss +1 -1
- package/scss/components/_nav.scss +51 -6
- package/scss/components/_progress.scss +4 -6
- package/scss/components/_pull-refresh.scss +25 -0
- package/scss/components/_spinner.scss +134 -56
- package/scss/components/_steps.scss +199 -8
- package/scss/components/_tooltip.scss +4 -9
- package/scss/components/form/_checks.scss +125 -2
- package/scss/components/form/_combo.scss +13 -1
- package/scss/components/form/_date-range.scss +27 -2
- package/scss/components/form/_date.scss +13 -1
- package/scss/components/form/_editor.scss +2 -1
- package/scss/components/form/_file.scss +4 -0
- package/scss/components/form/_form.scss +31 -8
- package/scss/components/form/_number.scss +3 -2
- package/scss/components/form/_select.scss +0 -1
- package/scss/components/form/_textarea.scss +1 -23
- package/scss/components/form/_transfer.scss +3 -2
- package/scss/themes/_antd-variables.scss +1 -1
- package/scss/themes/_common.scss +1 -0
- package/scss/themes/_cxd-variables.scss +4 -4
- package/sdk/ang-ie11.css +816 -182
- package/sdk/ang.css +775 -129
- package/sdk/antd-ie11.css +896 -262
- package/sdk/antd.css +776 -130
- package/sdk/barcode.js +51 -51
- package/sdk/charts.js +14 -14
- package/sdk/codemirror.js +7 -7
- package/sdk/color-picker.js +65 -65
- package/sdk/cropperjs.js +2 -2
- package/sdk/cxd-ie11.css +907 -273
- package/sdk/cxd.css +779 -133
- package/sdk/dark-ie11.css +817 -183
- package/sdk/dark.css +775 -129
- package/sdk/exceljs.js +1 -1
- package/sdk/locale/de-DE.js +18 -1
- package/sdk/markdown.js +69 -69
- package/sdk/papaparse.js +1 -1
- package/sdk/renderers/Form/CityDB.js +1 -1
- package/sdk/rest.js +17 -17
- package/sdk/rich-text.js +62 -62
- package/sdk/sdk-ie11.css +907 -273
- package/sdk/sdk.css +779 -133
- package/sdk/sdk.js +1317 -1273
- 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 +10 -0
- package/src/SchemaRenderer.tsx +32 -14
- package/src/WithStore.tsx +3 -1
- package/src/actions/CmptAction.ts +28 -0
- package/src/actions/PageAction.ts +62 -0
- package/src/actions/index.ts +1 -0
- package/src/components/AssociatedSelection.tsx +9 -3
- package/src/components/BarCode.tsx +2 -2
- package/src/components/Cascader.tsx +37 -11
- package/src/components/Checkbox.tsx +11 -5
- package/src/components/DatePicker.tsx +12 -4
- package/src/components/DateRangePicker.tsx +551 -88
- package/src/components/Drawer.tsx +1 -0
- package/src/components/Modal.tsx +1 -0
- package/src/components/Overlay.tsx +6 -3
- package/src/components/Progress.tsx +57 -22
- package/src/components/PullRefresh.tsx +197 -0
- package/src/components/Radios.tsx +6 -17
- package/src/components/Range.tsx +26 -12
- package/src/components/Spinner.tsx +77 -42
- package/src/components/Steps.tsx +28 -27
- package/src/components/Tooltip.tsx +12 -3
- package/src/components/TooltipWrapper.tsx +137 -33
- package/src/components/Tree.tsx +19 -5
- package/src/components/calendar/Calendar.tsx +0 -14
- package/src/components/calendar/TimeView.tsx +12 -0
- package/src/components/calendar/YearsView.tsx +3 -4
- package/src/components/condition-builder/Expression.tsx +6 -1
- package/src/components/condition-builder/Field.tsx +5 -1
- package/src/components/condition-builder/Group.tsx +4 -1
- package/src/components/condition-builder/GroupOrItem.tsx +4 -1
- package/src/components/condition-builder/InputSwitch.tsx +4 -1
- package/src/components/condition-builder/Item.tsx +28 -4
- package/src/components/condition-builder/Value.tsx +7 -1
- package/src/components/condition-builder/index.tsx +4 -2
- package/src/components/formula/Editor.tsx +20 -15
- package/src/components/formula/Picker.tsx +9 -5
- package/src/factory.tsx +29 -1
- package/src/locale/de-DE.ts +18 -1
- package/src/locale/en-US.ts +18 -1
- package/src/locale/zh-CN.ts +18 -1
- package/src/renderers/Action.tsx +22 -1
- package/src/renderers/App.tsx +4 -0
- package/src/renderers/CRUD.tsx +23 -5
- package/src/renderers/Carousel.tsx +8 -0
- package/src/renderers/Chart.tsx +4 -0
- package/src/renderers/Dialog.tsx +4 -0
- package/src/renderers/Drawer.tsx +14 -2
- package/src/renderers/Form/Checkbox.tsx +11 -2
- package/src/renderers/Form/Checkboxes.tsx +106 -23
- package/src/renderers/Form/Combo.tsx +104 -49
- package/src/renderers/Form/InputCity.tsx +33 -4
- package/src/renderers/Form/InputDate.tsx +18 -4
- package/src/renderers/Form/InputDateRange.tsx +27 -3
- package/src/renderers/Form/InputFile.tsx +23 -7
- package/src/renderers/Form/InputImage.tsx +22 -6
- package/src/renderers/Form/InputMonthRange.tsx +7 -1
- package/src/renderers/Form/InputRange.tsx +18 -16
- package/src/renderers/Form/InputText.tsx +14 -4
- package/src/renderers/Form/InputTree.tsx +40 -2
- package/src/renderers/Form/Item.tsx +7 -0
- package/src/renderers/Form/NestedSelect.tsx +23 -4
- package/src/renderers/Form/Options.tsx +26 -7
- package/src/renderers/Form/Select.tsx +5 -3
- package/src/renderers/Form/Textarea.tsx +3 -1
- package/src/renderers/Form/TreeSelect.tsx +47 -9
- package/src/renderers/Form/index.tsx +56 -25
- package/src/renderers/Form/wrapControl.tsx +23 -12
- package/src/renderers/Nav.tsx +231 -33
- package/src/renderers/Page.tsx +96 -33
- package/src/renderers/Progress.tsx +7 -9
- package/src/renderers/Service.tsx +66 -27
- package/src/renderers/Spinner.tsx +85 -3
- package/src/renderers/Steps.tsx +14 -0
- package/src/renderers/Table/ColumnToggler.tsx +36 -11
- package/src/renderers/Table/TableCell.tsx +39 -1
- package/src/renderers/Table/index.tsx +43 -19
- package/src/renderers/Tabs.tsx +75 -28
- package/src/renderers/TooltipWrapper.tsx +71 -28
- package/src/renderers/Wizard.tsx +169 -93
- package/src/store/crud.ts +50 -5
- package/src/store/form.ts +8 -3
- package/src/store/formItem.ts +1 -2
- package/src/store/index.ts +20 -0
- package/src/store/table.ts +2 -2
- package/src/types.ts +8 -1
- package/src/utils/ColorScale.ts +138 -0
- package/src/utils/api.ts +26 -4
- package/src/utils/columnsSplit.tsx +57 -0
- package/src/utils/debug.tsx +17 -24
- package/src/utils/dom.tsx +7 -6
- package/src/utils/position.ts +0 -1
- package/src/utils/scrollPosition.ts +29 -0
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/Field.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAAA,6DAA0B;AAC1B,sFAAmD;AACnD,sFAAgD;AAChD,wEAAqC;AACrC,qCAAgE;AAChE,kCAA8B;AAC9B,6CAAkD;AAClD,uCAAqD;AACrD,wEAAqC;
|
9
|
+
"mappings": "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",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import React from 'react';\nimport PopOverContainer from '../PopOverContainer';\nimport ListSelection from '../GroupedSelection';\nimport ResultBox from '../ResultBox';\nimport {ClassNamesFn, ThemeProps, themeable} from '../../theme';\nimport {Icon} from '../icons';\nimport {findTree, noop} from '../../utils/helper';\nimport {localeable, LocaleProps} from '../../locale';\nimport SearchBox from '../SearchBox';\n\nexport interface ConditionFieldProps extends ThemeProps, LocaleProps {\n options: Array<any>;\n value: any;\n onChange: (value: any) => void;\n disabled?: boolean;\n fieldClassName?: string;\n searchable?: boolean;\n}\n\nexport interface ConditionFieldState {\n searchText: string;\n}\n\nconst option2value = (item: any) => item.name;\n\nexport class ConditionField extends React.Component<\n ConditionFieldProps,\n ConditionFieldState\n> {\n constructor(props: ConditionFieldProps) {\n super(props);\n this.state = {\n searchText: ''\n };\n this.onSearch = this.onSearch.bind(this);\n this.filterOptions = this.filterOptions.bind(this);\n }\n\n onSearch(text: string) {\n let txt = text.toLowerCase();\n\n this.setState({searchText: txt});\n }\n\n filterOptions(options: any[]) {\n const txt = this.state.searchText;\n if (!txt) {\n return this.props.options;\n }\n return options\n .map((item: any) => {\n if (item.children) {\n let children = item.children.filter((child: any) => {\n return (\n child.name.toLowerCase().includes(txt) ||\n child.label.toLowerCase().includes(txt)\n );\n });\n return children.length > 0\n ? Object.assign({}, item, {children}) // 需要copy一份,防止覆盖原始数据\n : false;\n } else {\n return item.name.toLowerCase().includes(txt) ||\n item.label.toLowerCase().includes(txt)\n ? item\n : false;\n }\n })\n .filter((item: any) => {\n return !!item;\n });\n }\n\n // 选了值,还原options\n onPopClose(e: React.MouseEvent, onClose: () => void) {\n this.setState({searchText: ''});\n onClose();\n }\n\n render() {\n const {\n options,\n onChange,\n value,\n classnames: cx,\n fieldClassName,\n disabled,\n translate: __,\n searchable\n } = this.props;\n\n return (\n <PopOverContainer\n popOverRender={({onClose}) => (\n <>\n {searchable ? (\n <SearchBox mini={false} onSearch={this.onSearch} />\n ) : null}\n <ListSelection\n multiple={false}\n onClick={e => this.onPopClose(e, onClose)}\n options={this.filterOptions(this.props.options)}\n value={[value]}\n option2value={option2value}\n onChange={(value: any) =>\n onChange(Array.isArray(value) ? value[0] : value)\n }\n />\n </>\n )}\n >\n {({onClick, ref, isOpened}) => (\n <div className={cx('CBGroup-field')}>\n <ResultBox\n className={cx(\n 'CBGroup-fieldInput',\n fieldClassName,\n isOpened ? 'is-active' : ''\n )}\n ref={ref}\n allowInput={false}\n result={\n value ? findTree(options, item => item.name === value) : ''\n }\n onResultChange={noop}\n onResultClick={onClick}\n placeholder={__('Condition.field_placeholder')}\n disabled={disabled}\n >\n <span className={cx('CBGroup-fieldCaret')}>\n <Icon icon=\"caret\" className=\"icon\" />\n </span>\n </ResultBox>\n </div>\n )}\n </PopOverContainer>\n );\n }\n}\n\nexport default themeable(localeable(ConditionField));\n"
|
11
|
+
"import React from 'react';\nimport {findDOMNode} from 'react-dom';\nimport PopOverContainer from '../PopOverContainer';\nimport ListSelection from '../GroupedSelection';\nimport ResultBox from '../ResultBox';\nimport {ClassNamesFn, ThemeProps, themeable} from '../../theme';\nimport {Icon} from '../icons';\nimport {findTree, noop} from '../../utils/helper';\nimport {localeable, LocaleProps} from '../../locale';\nimport SearchBox from '../SearchBox';\n\nexport interface ConditionFieldProps extends ThemeProps, LocaleProps {\n options: Array<any>;\n value: any;\n onChange: (value: any) => void;\n disabled?: boolean;\n fieldClassName?: string;\n searchable?: boolean;\n popOverContainer?: any;\n}\n\nexport interface ConditionFieldState {\n searchText: string;\n}\n\nconst option2value = (item: any) => item.name;\n\nexport class ConditionField extends React.Component<\n ConditionFieldProps,\n ConditionFieldState\n> {\n constructor(props: ConditionFieldProps) {\n super(props);\n this.state = {\n searchText: ''\n };\n this.onSearch = this.onSearch.bind(this);\n this.filterOptions = this.filterOptions.bind(this);\n }\n\n onSearch(text: string) {\n let txt = text.toLowerCase();\n\n this.setState({searchText: txt});\n }\n\n filterOptions(options: any[]) {\n const txt = this.state.searchText;\n if (!txt) {\n return this.props.options;\n }\n return options\n .map((item: any) => {\n if (item.children) {\n let children = item.children.filter((child: any) => {\n return (\n child.name.toLowerCase().includes(txt) ||\n child.label.toLowerCase().includes(txt)\n );\n });\n return children.length > 0\n ? Object.assign({}, item, {children}) // 需要copy一份,防止覆盖原始数据\n : false;\n } else {\n return item.name.toLowerCase().includes(txt) ||\n item.label.toLowerCase().includes(txt)\n ? item\n : false;\n }\n })\n .filter((item: any) => {\n return !!item;\n });\n }\n\n // 选了值,还原options\n onPopClose(e: React.MouseEvent, onClose: () => void) {\n this.setState({searchText: ''});\n onClose();\n }\n\n render() {\n const {\n options,\n onChange,\n value,\n classnames: cx,\n fieldClassName,\n disabled,\n translate: __,\n searchable,\n popOverContainer\n } = this.props;\n\n return (\n <PopOverContainer\n popOverContainer={popOverContainer || (() => findDOMNode(this))}\n popOverRender={({onClose}) => (\n <>\n {searchable ? (\n <SearchBox mini={false} onSearch={this.onSearch} />\n ) : null}\n <ListSelection\n multiple={false}\n onClick={e => this.onPopClose(e, onClose)}\n options={this.filterOptions(this.props.options)}\n value={[value]}\n option2value={option2value}\n onChange={(value: any) =>\n onChange(Array.isArray(value) ? value[0] : value)\n }\n />\n </>\n )}\n >\n {({onClick, ref, isOpened}) => (\n <div className={cx('CBGroup-field')}>\n <ResultBox\n className={cx(\n 'CBGroup-fieldInput',\n fieldClassName,\n isOpened ? 'is-active' : ''\n )}\n ref={ref}\n allowInput={false}\n result={\n value ? findTree(options, item => item.name === value) : ''\n }\n onResultChange={noop}\n onResultClick={onClick}\n placeholder={__('Condition.field_placeholder')}\n disabled={disabled}\n >\n <span className={cx('CBGroup-fieldCaret')}>\n <Icon icon=\"caret\" className=\"icon\" />\n </span>\n </ResultBox>\n </div>\n )}\n </PopOverContainer>\n );\n }\n}\n\nexport default themeable(localeable(ConditionField));\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -22,6 +22,7 @@ export interface ConditionGroupProps extends ThemeProps, LocaleProps {
|
|
22
22
|
onDragStart?: (e: React.MouseEvent) => void;
|
23
23
|
fieldClassName?: string;
|
24
24
|
formula?: FormulaPickerProps;
|
25
|
+
popOverContainer?: any;
|
25
26
|
}
|
26
27
|
export declare class ConditionGroup extends React.Component<ConditionGroupProps> {
|
27
28
|
getValue(): ConditionGroupValue;
|
@@ -77,7 +77,7 @@ var ConditionGroup = /** @class */ (function (_super) {
|
|
77
77
|
};
|
78
78
|
ConditionGroup.prototype.render = function () {
|
79
79
|
var _this = this;
|
80
|
-
var _a = this.props, builderMode = _a.builderMode, cx = _a.classnames, fieldClassName = _a.fieldClassName, value = _a.value, data = _a.data, fields = _a.fields, funcs = _a.funcs, config = _a.config, removeable = _a.removeable, onRemove = _a.onRemove, onDragStart = _a.onDragStart, showNot = _a.showNot, _b = _a.showANDOR, showANDOR = _b === void 0 ? false : _b, disabled = _a.disabled, searchable = _a.searchable, __ = _a.translate, formula = _a.formula;
|
80
|
+
var _a = this.props, builderMode = _a.builderMode, cx = _a.classnames, fieldClassName = _a.fieldClassName, value = _a.value, data = _a.data, fields = _a.fields, funcs = _a.funcs, config = _a.config, removeable = _a.removeable, onRemove = _a.onRemove, onDragStart = _a.onDragStart, showNot = _a.showNot, _b = _a.showANDOR, showANDOR = _b === void 0 ? false : _b, disabled = _a.disabled, searchable = _a.searchable, __ = _a.translate, formula = _a.formula, popOverContainer = _a.popOverContainer;
|
81
81
|
return (react_1.default.createElement("div", { className: cx('CBGroup'), "data-group-id": value === null || value === void 0 ? void 0 : value.id },
|
82
82
|
react_1.default.createElement("div", { className: cx('CBGroup-toolbar') },
|
83
83
|
builderMode === 'simple' && showANDOR === false ? null : (react_1.default.createElement("div", { className: cx('CBGroup-toolbarCondition') },
|
@@ -95,7 +95,7 @@ var ConditionGroup = /** @class */ (function (_super) {
|
|
95
95
|
__('Condition.add_cond_group'))))),
|
96
96
|
removeable ? (react_1.default.createElement("a", { className: cx('CBDelete'), onClick: onRemove },
|
97
97
|
react_1.default.createElement(icons_1.Icon, { icon: "close", className: "icon" }))) : null),
|
98
|
-
react_1.default.createElement("div", { className: cx('CBGroup-body') }, Array.isArray(value === null || value === void 0 ? void 0 : value.children) && value.children.length ? (value.children.map(function (item, index) { return (react_1.default.createElement(GroupOrItem_1.default, { draggable: value.children.length > 1, onDragStart: onDragStart, config: config, key: item.id, fields: fields, fieldClassName: fieldClassName, value: item, index: index, onChange: _this.handleItemChange, funcs: funcs, onRemove: _this.handleItemRemove, data: data, disabled: disabled, searchable: searchable, builderMode: builderMode, formula: formula })); })) : (react_1.default.createElement("div", { className: cx("CBGroup-placeholder ".concat(builderMode === 'simple' ? 'simple' : '')) }, __('Condition.blank'))))));
|
98
|
+
react_1.default.createElement("div", { className: cx('CBGroup-body') }, Array.isArray(value === null || value === void 0 ? void 0 : value.children) && value.children.length ? (value.children.map(function (item, index) { return (react_1.default.createElement(GroupOrItem_1.default, { draggable: value.children.length > 1, onDragStart: onDragStart, config: config, key: item.id, fields: fields, fieldClassName: fieldClassName, value: item, index: index, onChange: _this.handleItemChange, funcs: funcs, onRemove: _this.handleItemRemove, data: data, disabled: disabled, searchable: searchable, builderMode: builderMode, formula: formula, popOverContainer: popOverContainer })); })) : (react_1.default.createElement("div", { className: cx("CBGroup-placeholder ".concat(builderMode === 'simple' ? 'simple' : '')) }, __('Condition.blank'))))));
|
99
99
|
};
|
100
100
|
(0, tslib_1.__decorate)([
|
101
101
|
helper_1.autobind,
|
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/Group.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAAA,6DAA0B;AAE1B,qCAAkD;AAClD,kEAA+B;AAC/B,2EAAwC;AACxC,6CAAkD;AAElD,kCAA8B;AAC9B,uCAAqD;
|
9
|
+
"mappings": "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",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import React from 'react';\nimport {Fields, ConditionGroupValue, Funcs} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport Button from '../Button';\nimport GroupOrItem from './GroupOrItem';\nimport {autobind, guid} from '../../utils/helper';\nimport {Config} from './config';\nimport {Icon} from '../icons';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nexport interface ConditionGroupProps extends ThemeProps, LocaleProps {\n builderMode?: 'simple' | 'full';\n config: Config;\n value?: ConditionGroupValue;\n fields: Fields;\n funcs?: Funcs;\n showNot?: boolean;\n showANDOR?: boolean;\n data?: any;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionGroupValue) => void;\n removeable?: boolean;\n onRemove?: (e: React.MouseEvent) => void;\n onDragStart?: (e: React.MouseEvent) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n}\n\nexport class ConditionGroup extends React.Component<ConditionGroupProps> {\n getValue() {\n return {\n id: guid(),\n conjunction: 'and' as 'and',\n ...this.props.value\n } as ConditionGroupValue;\n }\n\n @autobind\n handleNotClick() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n value.not = !value.not;\n\n onChange(value);\n }\n\n @autobind\n handleConjunctionClick() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n value.conjunction = value.conjunction === 'and' ? 'or' : 'and';\n onChange(value);\n }\n\n @autobind\n handleAdd() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.push({\n id: guid()\n });\n onChange(value);\n }\n\n @autobind\n handleAddGroup() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.push({\n id: guid(),\n conjunction: 'and',\n children: [\n {\n id: guid()\n }\n ]\n });\n onChange(value);\n }\n\n @autobind\n handleItemChange(item: any, index: number) {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.splice(index!, 1, item);\n onChange(value);\n }\n\n @autobind\n handleItemRemove(index: number) {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.splice(index, 1);\n onChange(value);\n }\n\n render() {\n const {\n builderMode,\n classnames: cx,\n fieldClassName,\n value,\n data,\n fields,\n funcs,\n config,\n removeable,\n onRemove,\n onDragStart,\n showNot,\n showANDOR = false,\n disabled,\n searchable,\n translate: __,\n formula\n } = this.props;\n return (\n <div className={cx('CBGroup')} data-group-id={value?.id}>\n <div className={cx('CBGroup-toolbar')}>\n {builderMode === 'simple' && showANDOR === false ? null : (\n <div className={cx('CBGroup-toolbarCondition')}>\n {showNot ? (\n <Button\n onClick={this.handleNotClick}\n className=\"m-r-xs\"\n size=\"xs\"\n active={value?.not}\n disabled={disabled}\n >\n {__('Condition.not')}\n </Button>\n ) : null}\n <div className={cx('ButtonGroup')}>\n <Button\n size=\"xs\"\n onClick={this.handleConjunctionClick}\n active={value?.conjunction !== 'or'}\n disabled={disabled}\n >\n {__('Condition.and')}\n </Button>\n <Button\n size=\"xs\"\n onClick={this.handleConjunctionClick}\n active={value?.conjunction === 'or'}\n disabled={disabled}\n >\n {__('Condition.or')}\n </Button>\n </div>\n </div>\n )}\n <div\n className={cx(\n `CBGroup-toolbarConditionAdd${\n builderMode === 'simple' ? '-simple' : ''\n }`\n )}\n >\n <div className={cx('ButtonGroup')}>\n <Button onClick={this.handleAdd} size=\"xs\" disabled={disabled}>\n <Icon icon=\"plus\" className=\"icon\" />\n {__('Condition.add_cond')}\n </Button>\n {builderMode === 'simple' ? null : (\n <Button\n onClick={this.handleAddGroup}\n size=\"xs\"\n disabled={disabled}\n >\n <Icon icon=\"plus-cicle\" className=\"icon\" />\n {__('Condition.add_cond_group')}\n </Button>\n )}\n </div>\n </div>\n {removeable ? (\n <a className={cx('CBDelete')} onClick={onRemove}>\n <Icon icon=\"close\" className=\"icon\" />\n </a>\n ) : null}\n </div>\n <div className={cx('CBGroup-body')}>\n {Array.isArray(value?.children) && value!.children.length ? (\n value!.children.map((item, index) => (\n <GroupOrItem\n draggable={value!.children!.length > 1}\n onDragStart={onDragStart}\n config={config}\n key={item.id}\n fields={fields}\n fieldClassName={fieldClassName}\n value={item as ConditionGroupValue}\n index={index}\n onChange={this.handleItemChange}\n funcs={funcs}\n onRemove={this.handleItemRemove}\n data={data}\n disabled={disabled}\n searchable={searchable}\n builderMode={builderMode}\n formula={formula}\n />\n ))\n ) : (\n <div\n className={cx(\n `CBGroup-placeholder ${\n builderMode === 'simple' ? 'simple' : ''\n }`\n )}\n >\n {__('Condition.blank')}\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n\nexport default themeable(localeable(ConditionGroup));\n"
|
11
|
+
"import React from 'react';\nimport {Fields, ConditionGroupValue, Funcs} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport Button from '../Button';\nimport GroupOrItem from './GroupOrItem';\nimport {autobind, guid} from '../../utils/helper';\nimport {Config} from './config';\nimport {Icon} from '../icons';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nexport interface ConditionGroupProps extends ThemeProps, LocaleProps {\n builderMode?: 'simple' | 'full';\n config: Config;\n value?: ConditionGroupValue;\n fields: Fields;\n funcs?: Funcs;\n showNot?: boolean;\n showANDOR?: boolean;\n data?: any;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionGroupValue) => void;\n removeable?: boolean;\n onRemove?: (e: React.MouseEvent) => void;\n onDragStart?: (e: React.MouseEvent) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n popOverContainer?: any;\n}\n\nexport class ConditionGroup extends React.Component<ConditionGroupProps> {\n getValue() {\n return {\n id: guid(),\n conjunction: 'and' as 'and',\n ...this.props.value\n } as ConditionGroupValue;\n }\n\n @autobind\n handleNotClick() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n value.not = !value.not;\n\n onChange(value);\n }\n\n @autobind\n handleConjunctionClick() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n value.conjunction = value.conjunction === 'and' ? 'or' : 'and';\n onChange(value);\n }\n\n @autobind\n handleAdd() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.push({\n id: guid()\n });\n onChange(value);\n }\n\n @autobind\n handleAddGroup() {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.push({\n id: guid(),\n conjunction: 'and',\n children: [\n {\n id: guid()\n }\n ]\n });\n onChange(value);\n }\n\n @autobind\n handleItemChange(item: any, index: number) {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.splice(index!, 1, item);\n onChange(value);\n }\n\n @autobind\n handleItemRemove(index: number) {\n const onChange = this.props.onChange;\n let value = this.getValue();\n\n value.children = Array.isArray(value.children)\n ? value.children.concat()\n : [];\n\n value.children.splice(index, 1);\n onChange(value);\n }\n\n render() {\n const {\n builderMode,\n classnames: cx,\n fieldClassName,\n value,\n data,\n fields,\n funcs,\n config,\n removeable,\n onRemove,\n onDragStart,\n showNot,\n showANDOR = false,\n disabled,\n searchable,\n translate: __,\n formula,\n popOverContainer\n } = this.props;\n return (\n <div className={cx('CBGroup')} data-group-id={value?.id}>\n <div className={cx('CBGroup-toolbar')}>\n {builderMode === 'simple' && showANDOR === false ? null : (\n <div className={cx('CBGroup-toolbarCondition')}>\n {showNot ? (\n <Button\n onClick={this.handleNotClick}\n className=\"m-r-xs\"\n size=\"xs\"\n active={value?.not}\n disabled={disabled}\n >\n {__('Condition.not')}\n </Button>\n ) : null}\n <div className={cx('ButtonGroup')}>\n <Button\n size=\"xs\"\n onClick={this.handleConjunctionClick}\n active={value?.conjunction !== 'or'}\n disabled={disabled}\n >\n {__('Condition.and')}\n </Button>\n <Button\n size=\"xs\"\n onClick={this.handleConjunctionClick}\n active={value?.conjunction === 'or'}\n disabled={disabled}\n >\n {__('Condition.or')}\n </Button>\n </div>\n </div>\n )}\n <div\n className={cx(\n `CBGroup-toolbarConditionAdd${\n builderMode === 'simple' ? '-simple' : ''\n }`\n )}\n >\n <div className={cx('ButtonGroup')}>\n <Button onClick={this.handleAdd} size=\"xs\" disabled={disabled}>\n <Icon icon=\"plus\" className=\"icon\" />\n {__('Condition.add_cond')}\n </Button>\n {builderMode === 'simple' ? null : (\n <Button\n onClick={this.handleAddGroup}\n size=\"xs\"\n disabled={disabled}\n >\n <Icon icon=\"plus-cicle\" className=\"icon\" />\n {__('Condition.add_cond_group')}\n </Button>\n )}\n </div>\n </div>\n {removeable ? (\n <a className={cx('CBDelete')} onClick={onRemove}>\n <Icon icon=\"close\" className=\"icon\" />\n </a>\n ) : null}\n </div>\n <div className={cx('CBGroup-body')}>\n {Array.isArray(value?.children) && value!.children.length ? (\n value!.children.map((item, index) => (\n <GroupOrItem\n draggable={value!.children!.length > 1}\n onDragStart={onDragStart}\n config={config}\n key={item.id}\n fields={fields}\n fieldClassName={fieldClassName}\n value={item as ConditionGroupValue}\n index={index}\n onChange={this.handleItemChange}\n funcs={funcs}\n onRemove={this.handleItemRemove}\n data={data}\n disabled={disabled}\n searchable={searchable}\n builderMode={builderMode}\n formula={formula}\n popOverContainer={popOverContainer}\n />\n ))\n ) : (\n <div\n className={cx(\n `CBGroup-placeholder ${\n builderMode === 'simple' ? 'simple' : ''\n }`\n )}\n >\n {__('Condition.blank')}\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n\nexport default themeable(localeable(ConditionGroup));\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -21,6 +21,7 @@ export interface CBGroupOrItemProps extends ThemeProps {
|
|
21
21
|
onRemove?: (index: number) => void;
|
22
22
|
fieldClassName?: string;
|
23
23
|
formula?: FormulaPickerProps;
|
24
|
+
popOverContainer?: any;
|
24
25
|
}
|
25
26
|
export declare class CBGroupOrItem extends React.Component<CBGroupOrItemProps> {
|
26
27
|
handleItemChange(value: any): void;
|
@@ -21,13 +21,13 @@ var CBGroupOrItem = /** @class */ (function (_super) {
|
|
21
21
|
(_b = (_a = this.props).onRemove) === null || _b === void 0 ? void 0 : _b.call(_a, this.props.index);
|
22
22
|
};
|
23
23
|
CBGroupOrItem.prototype.render = function () {
|
24
|
-
var _a = this.props, builderMode = _a.builderMode, cx = _a.classnames, fieldClassName = _a.fieldClassName, value = _a.value, config = _a.config, fields = _a.fields, funcs = _a.funcs, draggable = _a.draggable, data = _a.data, disabled = _a.disabled, searchable = _a.searchable, onDragStart = _a.onDragStart, formula = _a.formula;
|
24
|
+
var _a = this.props, builderMode = _a.builderMode, cx = _a.classnames, fieldClassName = _a.fieldClassName, value = _a.value, config = _a.config, fields = _a.fields, funcs = _a.funcs, draggable = _a.draggable, data = _a.data, disabled = _a.disabled, searchable = _a.searchable, onDragStart = _a.onDragStart, formula = _a.formula, popOverContainer = _a.popOverContainer;
|
25
25
|
return (react_1.default.createElement("div", { className: cx("CBGroupOrItem".concat(builderMode === 'simple' ? '-simple' : '')), "data-id": value === null || value === void 0 ? void 0 : value.id },
|
26
26
|
react_1.default.createElement("div", { className: cx('CBGroupOrItem-body') },
|
27
27
|
draggable ? (react_1.default.createElement("a", { draggable: true, onDragStart: onDragStart, className: cx('CBGroupOrItem-dragbar') },
|
28
28
|
react_1.default.createElement(icons_1.Icon, { icon: "drag-bar", className: "icon" }))) : null,
|
29
29
|
(value === null || value === void 0 ? void 0 : value.conjunction) ? (react_1.default.createElement(Group_1.default, { disabled: disabled, searchable: searchable, onDragStart: onDragStart, config: config, fields: fields, value: value, onChange: this.handleItemChange, fieldClassName: fieldClassName, funcs: funcs, removeable: true, onRemove: this.handleItemRemove, data: data })) : (react_1.default.createElement(react_1.default.Fragment, null,
|
30
|
-
react_1.default.createElement(Item_1.default, { disabled: disabled, searchable: searchable, config: config, fields: fields, value: value, onChange: this.handleItemChange, fieldClassName: fieldClassName, funcs: funcs, data: data, formula: formula }),
|
30
|
+
react_1.default.createElement(Item_1.default, { disabled: disabled, searchable: searchable, config: config, fields: fields, value: value, onChange: this.handleItemChange, fieldClassName: fieldClassName, funcs: funcs, data: data, formula: formula, popOverContainer: popOverContainer }),
|
31
31
|
react_1.default.createElement("a", { className: cx('CBDelete'), onClick: this.handleItemRemove },
|
32
32
|
react_1.default.createElement(icons_1.Icon, { icon: "close", className: "icon" })))))));
|
33
33
|
};
|
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/GroupOrItem.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAEA,qCAAkD;AAClD,6DAA0B;AAC1B,kCAA8B;AAC9B,6CAA4C;AAC5C,+DAAqC;AACrC,6DAAmC;
|
9
|
+
"mappings": ";;;;AAEA,qCAAkD;AAClD,6DAA0B;AAC1B,kCAA8B;AAC9B,6CAA4C;AAC5C,+DAAqC;AACrC,6DAAmC;AAuBnC;IAAmC,8CAAmC;IAAtE;;IAsFA,CAAC;IApFC,wCAAgB,GAAhB,UAAiB,KAAU;QACzB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IAGD,wCAAgB,GAAhB;;QACE,MAAA,MAAA,IAAI,CAAC,KAAK,EAAC,QAAQ,mDAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,8BAAM,GAAN;QACQ,IAAA,KAeF,IAAI,CAAC,KAAK,EAdZ,WAAW,iBAAA,EACC,EAAE,gBAAA,EACd,cAAc,oBAAA,EACd,KAAK,WAAA,EACL,MAAM,YAAA,EACN,MAAM,YAAA,EACN,KAAK,WAAA,EACL,SAAS,eAAA,EACT,IAAI,UAAA,EACJ,QAAQ,cAAA,EACR,UAAU,gBAAA,EACV,WAAW,iBAAA,EACX,OAAO,aAAA,EACP,gBAAgB,sBACJ,CAAC;QAEf,OAAO,CACL,uCACE,SAAS,EAAE,EAAE,CACX,uBAAgB,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAE,CAC5D,aACQ,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,EAAE;YAElB,uCAAK,SAAS,EAAE,EAAE,CAAC,oBAAoB,CAAC;gBACrC,SAAS,CAAC,CAAC,CAAC,CACX,qCACE,SAAS,QACT,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,EAAE,CAAC,uBAAuB,CAAC;oBAEtC,8BAAC,YAAI,IAAC,IAAI,EAAC,UAAU,EAAC,SAAS,EAAC,MAAM,GAAG,CACvC,CACL,CAAC,CAAC,CAAC,IAAI;gBAEP,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW,EAAC,CAAC,CAAC,CACpB,8BAAC,eAAc,IACb,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAA4B,EACnC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAC/B,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,KAAK,EACZ,UAAU,QACV,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAC/B,IAAI,EAAE,IAAI,GACV,CACH,CAAC,CAAC,CAAC,CACF;oBACE,8BAAC,cAAa,IACZ,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,UAAU,EACtB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAuB,EAC9B,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAC/B,cAAc,EAAE,cAAc,EAC9B,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,gBAAgB,EAAE,gBAAgB,GAClC;oBACF,qCAAG,SAAS,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,gBAAgB;wBAC1D,8BAAC,YAAI,IAAC,IAAI,EAAC,OAAO,EAAC,SAAS,EAAC,MAAM,GAAG,CACpC,CACH,CACJ,CACG,CACF,CACP,CAAC;IACJ,CAAC;IAnFD;QADC,iBAAQ;;;;yDAGR;IAGD;QADC,iBAAQ;;;;yDAGR;IA6EH,oBAAC;CAAA,AAtFD,CAAmC,eAAK,CAAC,SAAS,GAsFjD;AAtFY,sCAAa;AAwF1B,kBAAe,IAAA,iBAAS,EAAC,aAAa,CAAC,CAAC",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import {Config} from './config';\nimport {Fields, ConditionGroupValue, Funcs, ConditionValue} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport React from 'react';\nimport {Icon} from '../icons';\nimport {autobind} from '../../utils/helper';\nimport ConditionGroup from './Group';\nimport ConditionItem from './Item';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nexport interface CBGroupOrItemProps extends ThemeProps {\n builderMode?: 'simple' | 'full';\n config: Config;\n value?: ConditionGroupValue;\n fields: Fields;\n funcs?: Funcs;\n index: number;\n data?: any;\n draggable?: boolean;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionGroupValue, index: number) => void;\n removeable?: boolean;\n onDragStart?: (e: React.MouseEvent) => void;\n onRemove?: (index: number) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n}\n\nexport class CBGroupOrItem extends React.Component<CBGroupOrItemProps> {\n @autobind\n handleItemChange(value: any) {\n this.props.onChange(value, this.props.index);\n }\n\n @autobind\n handleItemRemove() {\n this.props.onRemove?.(this.props.index);\n }\n\n render() {\n const {\n builderMode,\n classnames: cx,\n fieldClassName,\n value,\n config,\n fields,\n funcs,\n draggable,\n data,\n disabled,\n searchable,\n onDragStart,\n formula\n } = this.props;\n\n return (\n <div\n className={cx(\n `CBGroupOrItem${builderMode === 'simple' ? '-simple' : ''}`\n )}\n data-id={value?.id}\n >\n <div className={cx('CBGroupOrItem-body')}>\n {draggable ? (\n <a\n draggable\n onDragStart={onDragStart}\n className={cx('CBGroupOrItem-dragbar')}\n >\n <Icon icon=\"drag-bar\" className=\"icon\" />\n </a>\n ) : null}\n\n {value?.conjunction ? (\n <ConditionGroup\n disabled={disabled}\n searchable={searchable}\n onDragStart={onDragStart}\n config={config}\n fields={fields}\n value={value as ConditionGroupValue}\n onChange={this.handleItemChange}\n fieldClassName={fieldClassName}\n funcs={funcs}\n removeable\n onRemove={this.handleItemRemove}\n data={data}\n />\n ) : (\n <>\n <ConditionItem\n disabled={disabled}\n searchable={searchable}\n config={config}\n fields={fields}\n value={value as ConditionValue}\n onChange={this.handleItemChange}\n fieldClassName={fieldClassName}\n funcs={funcs}\n data={data}\n formula={formula}\n />\n <a className={cx('CBDelete')} onClick={this.handleItemRemove}>\n <Icon icon=\"close\" className=\"icon\" />\n </a>\n </>\n )}\n </div>\n </div>\n );\n }\n}\n\nexport default themeable(CBGroupOrItem);\n"
|
11
|
+
"import {Config} from './config';\nimport {Fields, ConditionGroupValue, Funcs, ConditionValue} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport React from 'react';\nimport {Icon} from '../icons';\nimport {autobind} from '../../utils/helper';\nimport ConditionGroup from './Group';\nimport ConditionItem from './Item';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nexport interface CBGroupOrItemProps extends ThemeProps {\n builderMode?: 'simple' | 'full';\n config: Config;\n value?: ConditionGroupValue;\n fields: Fields;\n funcs?: Funcs;\n index: number;\n data?: any;\n draggable?: boolean;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionGroupValue, index: number) => void;\n removeable?: boolean;\n onDragStart?: (e: React.MouseEvent) => void;\n onRemove?: (index: number) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n popOverContainer?: any;\n}\n\nexport class CBGroupOrItem extends React.Component<CBGroupOrItemProps> {\n @autobind\n handleItemChange(value: any) {\n this.props.onChange(value, this.props.index);\n }\n\n @autobind\n handleItemRemove() {\n this.props.onRemove?.(this.props.index);\n }\n\n render() {\n const {\n builderMode,\n classnames: cx,\n fieldClassName,\n value,\n config,\n fields,\n funcs,\n draggable,\n data,\n disabled,\n searchable,\n onDragStart,\n formula,\n popOverContainer\n } = this.props;\n\n return (\n <div\n className={cx(\n `CBGroupOrItem${builderMode === 'simple' ? '-simple' : ''}`\n )}\n data-id={value?.id}\n >\n <div className={cx('CBGroupOrItem-body')}>\n {draggable ? (\n <a\n draggable\n onDragStart={onDragStart}\n className={cx('CBGroupOrItem-dragbar')}\n >\n <Icon icon=\"drag-bar\" className=\"icon\" />\n </a>\n ) : null}\n\n {value?.conjunction ? (\n <ConditionGroup\n disabled={disabled}\n searchable={searchable}\n onDragStart={onDragStart}\n config={config}\n fields={fields}\n value={value as ConditionGroupValue}\n onChange={this.handleItemChange}\n fieldClassName={fieldClassName}\n funcs={funcs}\n removeable\n onRemove={this.handleItemRemove}\n data={data}\n />\n ) : (\n <>\n <ConditionItem\n disabled={disabled}\n searchable={searchable}\n config={config}\n fields={fields}\n value={value as ConditionValue}\n onChange={this.handleItemChange}\n fieldClassName={fieldClassName}\n funcs={funcs}\n data={data}\n formula={formula}\n popOverContainer={popOverContainer}\n />\n <a className={cx('CBDelete')} onClick={this.handleItemRemove}>\n <Icon icon=\"close\" className=\"icon\" />\n </a>\n </>\n )}\n </div>\n </div>\n );\n }\n}\n\nexport default themeable(CBGroupOrItem);\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -4,10 +4,11 @@ import { ThemeProps } from '../../theme';
|
|
4
4
|
export interface InputSwitchProps extends ThemeProps {
|
5
5
|
options: Array<any>;
|
6
6
|
disabled?: boolean;
|
7
|
+
popOverContainer?: any;
|
7
8
|
value: any;
|
8
9
|
onChange: (value: any) => void;
|
9
10
|
}
|
10
|
-
export declare function InputSwitch({ options, value, onChange, classnames: cx, disabled }: InputSwitchProps): JSX.Element;
|
11
|
+
export declare function InputSwitch({ options, value, onChange, classnames: cx, disabled, popOverContainer }: InputSwitchProps): JSX.Element;
|
11
12
|
declare const _default: {
|
12
13
|
new (props: (Omit<InputSwitchProps, keyof ThemeProps> & import("../../theme").ThemeOutterProps) | Readonly<Omit<InputSwitchProps, keyof ThemeProps> & import("../../theme").ThemeOutterProps>): {
|
13
14
|
render(): JSX.Element;
|
@@ -9,8 +9,8 @@ var GroupedSelection_1 = (0, tslib_1.__importDefault)(require("../GroupedSelecti
|
|
9
9
|
var theme_1 = require("../../theme");
|
10
10
|
var option2value = function (item) { return item.value; };
|
11
11
|
function InputSwitch(_a) {
|
12
|
-
var options = _a.options, value = _a.value, onChange = _a.onChange, cx = _a.classnames, disabled = _a.disabled;
|
13
|
-
return (react_1.default.createElement(PopOverContainer_1.default, { popOverRender: function (_a) {
|
12
|
+
var options = _a.options, value = _a.value, onChange = _a.onChange, cx = _a.classnames, disabled = _a.disabled, popOverContainer = _a.popOverContainer;
|
13
|
+
return (react_1.default.createElement(PopOverContainer_1.default, { popOverContainer: popOverContainer, popOverRender: function (_a) {
|
14
14
|
var onClose = _a.onClose;
|
15
15
|
return (react_1.default.createElement(GroupedSelection_1.default, { onClick: onClose, option2value: option2value, onChange: onChange, options: options, value: value, multiple: false, disabled: disabled }));
|
16
16
|
} }, function (_a) {
|
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/InputSwitch.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAAA,6DAA0B;AAC1B,sFAAmD;AACnD,kCAA8B;AAC9B,sFAAmD;AACnD,qCAAgE;
|
9
|
+
"mappings": ";;;;AAAA,6DAA0B;AAC1B,sFAAmD;AACnD,kCAA8B;AAC9B,sFAAmD;AACnD,qCAAgE;AAUhE,IAAM,YAAY,GAAG,UAAC,IAAS,IAAK,OAAA,IAAI,CAAC,KAAK,EAAV,CAAU,CAAC;AAE/C,SAAgB,WAAW,CAAC,EAOT;QANjB,OAAO,aAAA,EACP,KAAK,WAAA,EACL,QAAQ,cAAA,EACI,EAAE,gBAAA,EACd,QAAQ,cAAA,EACR,gBAAgB,sBAAA;IAEhB,OAAO,CACL,8BAAC,0BAAgB,IACf,gBAAgB,EAAE,gBAAgB,EAClC,aAAa,EAAE,UAAC,EAAS;gBAAR,OAAO,aAAA;YAAM,OAAA,CAC5B,8BAAC,0BAAgB,IACf,OAAO,EAAE,OAAO,EAChB,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,QAAQ,GAClB,CACH;QAV6B,CAU7B,IAEA,UAAC,EAAwB;YAAvB,OAAO,aAAA,EAAE,QAAQ,cAAA,EAAE,GAAG,SAAA;QAAM,OAAA,CAC7B,uCAAK,SAAS,EAAE,EAAE,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;YAC9D,qCAAG,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,GAAG;gBAC3B,8BAAC,YAAI,IAAC,IAAI,EAAC,YAAY,GAAG,CACxB,CACA,CACP;IAN8B,CAM9B,CACgB,CACpB,CAAC;AACJ,CAAC;AAhCD,kCAgCC;AAED,kBAAe,IAAA,iBAAS,EAAC,WAAW,CAAC,CAAC",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import React from 'react';\nimport PopOverContainer from '../PopOverContainer';\nimport {Icon} from '../icons';\nimport GroupedSelection from '../GroupedSelection';\nimport {ClassNamesFn, themeable, ThemeProps} from '../../theme';\n\nexport interface InputSwitchProps extends ThemeProps {\n options: Array<any>;\n disabled?: boolean;\n value: any;\n onChange: (value: any) => void;\n}\n\nconst option2value = (item: any) => item.value;\n\nexport function InputSwitch({\n options,\n value,\n onChange,\n classnames: cx,\n disabled\n}: InputSwitchProps) {\n return (\n <PopOverContainer\n popOverRender={({onClose}) => (\n <GroupedSelection\n onClick={onClose}\n option2value={option2value}\n onChange={onChange}\n options={options}\n value={value}\n multiple={false}\n disabled={disabled}\n />\n )}\n >\n {({onClick, isOpened, ref}) => (\n <div className={cx('CBInputSwitch', isOpened ? 'is-active' : '')}>\n <a onClick={onClick} ref={ref}>\n <Icon icon=\"ellipsis-v\" />\n </a>\n </div>\n )}\n </PopOverContainer>\n );\n}\n\nexport default themeable(InputSwitch);\n"
|
11
|
+
"import React from 'react';\nimport PopOverContainer from '../PopOverContainer';\nimport {Icon} from '../icons';\nimport GroupedSelection from '../GroupedSelection';\nimport {ClassNamesFn, themeable, ThemeProps} from '../../theme';\n\nexport interface InputSwitchProps extends ThemeProps {\n options: Array<any>;\n disabled?: boolean;\n popOverContainer?: any;\n value: any;\n onChange: (value: any) => void;\n}\n\nconst option2value = (item: any) => item.value;\n\nexport function InputSwitch({\n options,\n value,\n onChange,\n classnames: cx,\n disabled,\n popOverContainer\n}: InputSwitchProps) {\n return (\n <PopOverContainer\n popOverContainer={popOverContainer}\n popOverRender={({onClose}) => (\n <GroupedSelection\n onClick={onClose}\n option2value={option2value}\n onChange={onChange}\n options={options}\n value={value}\n multiple={false}\n disabled={disabled}\n />\n )}\n >\n {({onClick, isOpened, ref}) => (\n <div className={cx('CBInputSwitch', isOpened ? 'is-active' : '')}>\n <a onClick={onClick} ref={ref}>\n <Icon icon=\"ellipsis-v\" />\n </a>\n </div>\n )}\n </PopOverContainer>\n );\n}\n\nexport default themeable(InputSwitch);\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -17,6 +17,7 @@ export interface ConditionItemProps extends ThemeProps, LocaleProps {
|
|
17
17
|
onChange: (value: ConditionRule, index?: number) => void;
|
18
18
|
fieldClassName?: string;
|
19
19
|
formula?: FormulaPickerProps;
|
20
|
+
popOverContainer?: any;
|
20
21
|
}
|
21
22
|
export declare class ConditionItem extends React.Component<ConditionItemProps> {
|
22
23
|
handleLeftFieldSelect(field: any): void;
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ConditionItem = void 0;
|
4
4
|
var tslib_1 = require("tslib");
|
5
5
|
var react_1 = (0, tslib_1.__importDefault)(require("react"));
|
6
|
+
var react_dom_1 = require("react-dom");
|
6
7
|
var types_1 = require("./types");
|
7
8
|
var theme_1 = require("../../theme");
|
8
9
|
var icons_1 = require("../icons");
|
@@ -61,13 +62,13 @@ var ConditionItem = /** @class */ (function (_super) {
|
|
61
62
|
onChange(value, this.props.index);
|
62
63
|
};
|
63
64
|
ConditionItem.prototype.renderLeft = function () {
|
64
|
-
var _a = this.props, value = _a.value, fields = _a.fields, funcs = _a.funcs, config = _a.config, disabled = _a.disabled, fieldClassName = _a.fieldClassName, searchable = _a.searchable;
|
65
|
-
return (react_1.default.createElement(Expression_1.default, { config: config, funcs: funcs, value: value.left, fieldClassName: fieldClassName, onChange: this.handleLeftChange, fields: fields, disabled: disabled, searchable: searchable, allowedTypes: ['field', 'func'].filter(function (type) { return type === 'field' || type === 'func'; }) }));
|
65
|
+
var _a = this.props, value = _a.value, fields = _a.fields, funcs = _a.funcs, config = _a.config, disabled = _a.disabled, fieldClassName = _a.fieldClassName, searchable = _a.searchable, popOverContainer = _a.popOverContainer;
|
66
|
+
return (react_1.default.createElement(Expression_1.default, { config: config, funcs: funcs, value: value.left, fieldClassName: fieldClassName, onChange: this.handleLeftChange, fields: fields, disabled: disabled, searchable: searchable, popOverContainer: popOverContainer, allowedTypes: ['field', 'func'].filter(function (type) { return type === 'field' || type === 'func'; }) }));
|
66
67
|
};
|
67
68
|
ConditionItem.prototype.renderOperator = function () {
|
68
69
|
var _this = this;
|
69
70
|
var _a, _b, _c, _d;
|
70
|
-
var _e = this.props, funcs = _e.funcs, config = _e.config, fields = _e.fields, value = _e.value, cx = _e.classnames, disabled = _e.disabled;
|
71
|
+
var _e = this.props, funcs = _e.funcs, config = _e.config, fields = _e.fields, value = _e.value, cx = _e.classnames, disabled = _e.disabled, popOverContainer = _e.popOverContainer;
|
71
72
|
var left = value === null || value === void 0 ? void 0 : value.left;
|
72
73
|
var operators = [];
|
73
74
|
if (((_a = left) === null || _a === void 0 ? void 0 : _a.type) === 'func') {
|
@@ -84,7 +85,7 @@ var ConditionItem = /** @class */ (function (_super) {
|
|
84
85
|
}
|
85
86
|
if (Array.isArray(operators) && operators.length) {
|
86
87
|
var __1 = this.props.translate;
|
87
|
-
return (react_1.default.createElement(PopOverContainer_1.default, { popOverRender: function (_a) {
|
88
|
+
return (react_1.default.createElement(PopOverContainer_1.default, { popOverContainer: popOverContainer || (function () { return (0, react_dom_1.findDOMNode)(_this); }), popOverRender: function (_a) {
|
88
89
|
var onClose = _a.onClose;
|
89
90
|
return (react_1.default.createElement(GroupedSelection_1.default, { onClick: onClose, option2value: option2value, onChange: _this.handleOperatorChange, options: operators.map(function (operator) { return ({
|
90
91
|
label: __1(config_1.OperationMap[operator]),
|
@@ -127,7 +128,7 @@ var ConditionItem = /** @class */ (function (_super) {
|
|
127
128
|
};
|
128
129
|
ConditionItem.prototype.renderRightWidgets = function (type, op) {
|
129
130
|
var _a, _b, _c;
|
130
|
-
var _d = this.props, funcs = _d.funcs, value = _d.value, data = _d.data, fields = _d.fields, config = _d.config, cx = _d.classnames, disabled = _d.disabled, formula = _d.formula;
|
131
|
+
var _d = this.props, funcs = _d.funcs, value = _d.value, data = _d.data, fields = _d.fields, config = _d.config, cx = _d.classnames, disabled = _d.disabled, formula = _d.formula, popOverContainer = _d.popOverContainer;
|
131
132
|
var field = (0, tslib_1.__assign)((0, tslib_1.__assign)({}, config.types[type]), { type: type });
|
132
133
|
if (((_a = value === null || value === void 0 ? void 0 : value.left) === null || _a === void 0 ? void 0 : _a.type) === 'field') {
|
133
134
|
var leftField = (0, helper_1.findTree)(fields, function (i) { return i.name === (value === null || value === void 0 ? void 0 : value.left).field; });
|
@@ -141,13 +142,13 @@ var ConditionItem = /** @class */ (function (_super) {
|
|
141
142
|
else if (op === 'between' || op === 'not_between') {
|
142
143
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
143
144
|
react_1.default.createElement(Expression_1.default, { config: config, funcs: funcs, valueField: field, value: (_b = value.right) === null || _b === void 0 ? void 0 : _b[0], data: data, onChange: this.handleRightSubChange.bind(this, 0), fields: fields, allowedTypes: (field === null || field === void 0 ? void 0 : field.valueTypes) ||
|
144
|
-
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula }),
|
145
|
+
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula, popOverContainer: popOverContainer }),
|
145
146
|
react_1.default.createElement("span", { className: cx('CBSeprator') }, "~"),
|
146
147
|
react_1.default.createElement(Expression_1.default, { config: config, funcs: funcs, valueField: field, value: (_c = value.right) === null || _c === void 0 ? void 0 : _c[1], data: data, onChange: this.handleRightSubChange.bind(this, 1), fields: fields, allowedTypes: (field === null || field === void 0 ? void 0 : field.valueTypes) ||
|
147
|
-
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula })));
|
148
|
+
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula, popOverContainer: popOverContainer })));
|
148
149
|
}
|
149
150
|
return (react_1.default.createElement(Expression_1.default, { config: config, op: op, funcs: funcs, valueField: field, value: value.right, data: data, onChange: this.handleRightChange, fields: fields, allowedTypes: (field === null || field === void 0 ? void 0 : field.valueTypes) ||
|
150
|
-
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula }));
|
151
|
+
config.valueTypes || ['value', 'field', 'func', 'formula'], disabled: disabled, formula: formula, popOverContainer: popOverContainer }));
|
151
152
|
};
|
152
153
|
ConditionItem.prototype.render = function () {
|
153
154
|
var cx = this.props.classnames;
|
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/Item.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAAA,6DAA0B;AAC1B,iCAYiB;AACjB,qCAAkD;AAClD,kCAA8B;AAC9B,6CAA4D;AAC5D,yEAAsC;AACtC,mCAA8C;AAC9C,sFAAmD;AACnD,sFAAmD;AACnD,wEAAqC;AACrC,uCAAqD;AAGrD,IAAM,YAAY,GAAG,UAAC,IAAS,IAAK,OAAA,IAAI,CAAC,KAAK,EAAV,CAAU,CAAC;
|
9
|
+
"mappings": "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",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import React from 'react';\nimport {\n Fields,\n ConditionRule,\n ConditionGroupValue,\n Funcs,\n ExpressionFunc,\n Func,\n Field,\n FieldSimple,\n ExpressionField,\n OperatorType,\n ExpressionComplex\n} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport {Icon} from '../icons';\nimport {autobind, findTree, noop} from '../../utils/helper';\nimport Expression from './Expression';\nimport {Config, OperationMap} from './config';\nimport PopOverContainer from '../PopOverContainer';\nimport GroupedSelection from '../GroupedSelection';\nimport ResultBox from '../ResultBox';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nconst option2value = (item: any) => item.value;\n\nexport interface ConditionItemProps extends ThemeProps, LocaleProps {\n config: Config;\n fields: Fields;\n funcs?: Funcs;\n index?: number;\n value: ConditionRule;\n data?: any;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionRule, index?: number) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n}\n\nexport class ConditionItem extends React.Component<ConditionItemProps> {\n @autobind\n handleLeftFieldSelect(field: any) {\n const value = {...this.props.value};\n const onChange = this.props.onChange;\n value.left = field;\n onChange(value, this.props.index);\n }\n\n @autobind\n handleLeftInputTypeChange(type: 'func' | 'field') {\n const value = {...this.props.value};\n const onChange = this.props.onChange;\n\n if (type === 'func') {\n value.left = {type: 'func'};\n } else {\n value.left = '';\n }\n\n onChange(value, this.props.index);\n }\n\n @autobind\n handleLeftChange(leftValue: any) {\n const value = {\n ...this.props.value,\n left: leftValue,\n op: undefined,\n right: undefined\n };\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n @autobind\n handleOperatorChange(op: OperatorType) {\n const value = {...this.props.value, op: op, right: undefined};\n this.props.onChange(value, this.props.index);\n }\n\n @autobind\n handleRightChange(rightValue: any) {\n const value = {...this.props.value, right: rightValue};\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n handleRightSubChange(index: number, rightValue: any) {\n const origin = Array.isArray(this.props.value?.right)\n ? this.props.value.right.concat()\n : [];\n\n origin[index] = rightValue;\n const value = {...this.props.value, right: origin};\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n renderLeft() {\n const {value
|
11
|
+
"import React from 'react';\nimport {findDOMNode} from 'react-dom';\nimport {\n Fields,\n ConditionRule,\n ConditionGroupValue,\n Funcs,\n ExpressionFunc,\n Func,\n Field,\n FieldSimple,\n ExpressionField,\n OperatorType,\n ExpressionComplex\n} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport {Icon} from '../icons';\nimport {autobind, findTree, noop} from '../../utils/helper';\nimport Expression from './Expression';\nimport {Config, OperationMap} from './config';\nimport PopOverContainer from '../PopOverContainer';\nimport GroupedSelection from '../GroupedSelection';\nimport ResultBox from '../ResultBox';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPickerProps} from '../formula/Picker';\n\nconst option2value = (item: any) => item.value;\n\nexport interface ConditionItemProps extends ThemeProps, LocaleProps {\n config: Config;\n fields: Fields;\n funcs?: Funcs;\n index?: number;\n value: ConditionRule;\n data?: any;\n disabled?: boolean;\n searchable?: boolean;\n onChange: (value: ConditionRule, index?: number) => void;\n fieldClassName?: string;\n formula?: FormulaPickerProps;\n popOverContainer?: any;\n}\n\nexport class ConditionItem extends React.Component<ConditionItemProps> {\n @autobind\n handleLeftFieldSelect(field: any) {\n const value = {...this.props.value};\n const onChange = this.props.onChange;\n value.left = field;\n onChange(value, this.props.index);\n }\n\n @autobind\n handleLeftInputTypeChange(type: 'func' | 'field') {\n const value = {...this.props.value};\n const onChange = this.props.onChange;\n\n if (type === 'func') {\n value.left = {type: 'func'};\n } else {\n value.left = '';\n }\n\n onChange(value, this.props.index);\n }\n\n @autobind\n handleLeftChange(leftValue: any) {\n const value = {\n ...this.props.value,\n left: leftValue,\n op: undefined,\n right: undefined\n };\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n @autobind\n handleOperatorChange(op: OperatorType) {\n const value = {...this.props.value, op: op, right: undefined};\n this.props.onChange(value, this.props.index);\n }\n\n @autobind\n handleRightChange(rightValue: any) {\n const value = {...this.props.value, right: rightValue};\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n handleRightSubChange(index: number, rightValue: any) {\n const origin = Array.isArray(this.props.value?.right)\n ? this.props.value.right.concat()\n : [];\n\n origin[index] = rightValue;\n const value = {...this.props.value, right: origin};\n const onChange = this.props.onChange;\n\n onChange(value, this.props.index);\n }\n\n renderLeft() {\n const {\n value,\n fields,\n funcs,\n config,\n disabled,\n fieldClassName,\n searchable,\n popOverContainer\n } = this.props;\n return (\n <Expression\n config={config}\n funcs={funcs}\n value={value.left}\n fieldClassName={fieldClassName}\n onChange={this.handleLeftChange}\n fields={fields}\n disabled={disabled}\n searchable={searchable}\n popOverContainer={popOverContainer}\n allowedTypes={\n ['field', 'func'].filter(\n type => type === 'field' || type === 'func'\n ) as any\n }\n />\n );\n }\n\n renderOperator() {\n const {\n funcs,\n config,\n fields,\n value,\n classnames: cx,\n disabled,\n popOverContainer\n } = this.props;\n const left = value?.left;\n let operators: Array<string> = [];\n\n if ((left as ExpressionFunc)?.type === 'func') {\n const func: Func = findTree(\n funcs!,\n (i: Func) => i.type === (left as ExpressionFunc).func\n ) as Func;\n\n if (func) {\n operators = config.types[func.returnType]?.operators;\n }\n } else if ((left as ExpressionField)?.type === 'field') {\n const field: FieldSimple = findTree(\n fields,\n (i: FieldSimple) => i.name === (left as ExpressionField).field\n ) as FieldSimple;\n\n if (field) {\n operators = field.operators || config.types[field.type]?.operators;\n }\n }\n\n if (Array.isArray(operators) && operators.length) {\n const __ = this.props.translate;\n return (\n <PopOverContainer\n popOverContainer={popOverContainer || (() => findDOMNode(this))}\n popOverRender={({onClose}) => (\n <GroupedSelection\n onClick={onClose}\n option2value={option2value}\n onChange={this.handleOperatorChange}\n options={operators.map(operator => ({\n label: __(OperationMap[operator as keyof typeof OperationMap]),\n value: operator\n }))}\n value={value.op}\n multiple={false}\n />\n )}\n >\n {({onClick, isOpened, ref}) => (\n <div className={cx('CBGroup-operator')}>\n <ResultBox\n className={cx(\n 'CBGroup-operatorInput',\n isOpened ? 'is-active' : ''\n )}\n ref={ref}\n allowInput={false}\n result={__(\n OperationMap[value?.op as keyof typeof OperationMap]\n )}\n onResultChange={noop}\n onResultClick={onClick}\n disabled={disabled}\n placeholder={__('Condition.cond_placeholder')}\n >\n <span className={cx('CBGroup-operatorCaret')}>\n <Icon icon=\"caret\" className=\"icon\" />\n </span>\n </ResultBox>\n </div>\n )}\n </PopOverContainer>\n );\n }\n\n return null;\n }\n\n renderRight() {\n const {value, funcs, fields} = this.props;\n\n if (!value?.op) {\n return null;\n }\n\n const left = value?.left;\n let leftType = '';\n\n if ((left as ExpressionFunc)?.type === 'func') {\n const func: Func = findTree(\n funcs!,\n (i: Func) => i.type === (left as ExpressionFunc).func\n ) as Func;\n\n if (func) {\n leftType = func.returnType;\n }\n } else if ((left as ExpressionField)?.type === 'field') {\n const field: FieldSimple = findTree(\n fields,\n (i: FieldSimple) => i.name === (left as ExpressionField).field\n ) as FieldSimple;\n\n if (field) {\n leftType = field.type;\n }\n }\n\n if (leftType) {\n return this.renderRightWidgets(leftType, value.op!);\n }\n\n return null;\n }\n\n renderRightWidgets(type: string, op: OperatorType) {\n const {\n funcs,\n value,\n data,\n fields,\n config,\n classnames: cx,\n disabled,\n formula,\n popOverContainer\n } = this.props;\n let field = {\n ...config.types[type],\n type\n } as FieldSimple;\n\n if ((value?.left as ExpressionField)?.type === 'field') {\n const leftField: FieldSimple = findTree(\n fields,\n (i: FieldSimple) => i.name === (value?.left as ExpressionField).field\n ) as FieldSimple;\n\n if (leftField) {\n field = {\n ...field,\n ...leftField\n };\n }\n }\n\n if (op === 'is_empty' || op === 'is_not_empty') {\n return null;\n } else if (op === 'between' || op === 'not_between') {\n return (\n <>\n <Expression\n config={config}\n funcs={funcs}\n valueField={field}\n value={(value.right as Array<ExpressionComplex>)?.[0]}\n data={data}\n onChange={this.handleRightSubChange.bind(this, 0)}\n fields={fields}\n allowedTypes={\n field?.valueTypes ||\n config.valueTypes || ['value', 'field', 'func', 'formula']\n }\n disabled={disabled}\n formula={formula}\n popOverContainer={popOverContainer}\n />\n\n <span className={cx('CBSeprator')}>~</span>\n\n <Expression\n config={config}\n funcs={funcs}\n valueField={field}\n value={(value.right as Array<ExpressionComplex>)?.[1]}\n data={data}\n onChange={this.handleRightSubChange.bind(this, 1)}\n fields={fields}\n allowedTypes={\n field?.valueTypes ||\n config.valueTypes || ['value', 'field', 'func', 'formula']\n }\n disabled={disabled}\n formula={formula}\n popOverContainer={popOverContainer}\n />\n </>\n );\n }\n\n return (\n <Expression\n config={config}\n op={op}\n funcs={funcs}\n valueField={field}\n value={value.right}\n data={data}\n onChange={this.handleRightChange}\n fields={fields}\n allowedTypes={\n field?.valueTypes ||\n config.valueTypes || ['value', 'field', 'func', 'formula']\n }\n disabled={disabled}\n formula={formula}\n popOverContainer={popOverContainer}\n />\n );\n }\n\n render() {\n const {classnames: cx} = this.props;\n\n return (\n <div className={cx('CBItem')}>\n {this.renderLeft()}\n {this.renderOperator()}\n {this.renderRight()}\n </div>\n );\n }\n}\n\nexport default themeable(localeable(ConditionItem));\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -12,6 +12,7 @@ export interface ValueProps extends ThemeProps, LocaleProps {
|
|
12
12
|
op?: OperatorType;
|
13
13
|
disabled?: boolean;
|
14
14
|
formula?: FormulaPickerProps;
|
15
|
+
popOverContainer?: any;
|
15
16
|
}
|
16
17
|
export declare class Value extends React.Component<ValueProps> {
|
17
18
|
render(): JSX.Element;
|
@@ -18,7 +18,7 @@ var Value = /** @class */ (function (_super) {
|
|
18
18
|
}
|
19
19
|
Value.prototype.render = function () {
|
20
20
|
var _a;
|
21
|
-
var _b = this.props, cx = _b.classnames, field = _b.field, value = _b.value, onChange = _b.onChange, op = _b.op, __ = _b.translate, data = _b.data, disabled = _b.disabled, formula = _b.formula;
|
21
|
+
var _b = this.props, cx = _b.classnames, field = _b.field, value = _b.value, onChange = _b.onChange, op = _b.op, __ = _b.translate, data = _b.data, disabled = _b.disabled, formula = _b.formula, popOverContainer = _b.popOverContainer;
|
22
22
|
var input = undefined;
|
23
23
|
if (formula) {
|
24
24
|
// 如果配置了 formula 字段,则所有的输入变为 formula 形式
|
@@ -39,17 +39,17 @@ var Value = /** @class */ (function (_super) {
|
|
39
39
|
input = (react_1.default.createElement(NumberInput_1.default, { placeholder: __(field.placeholder) || __('NumberInput.placeholder'), step: field.step, min: field.minimum, max: field.maximum, precision: field.precision, value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, disabled: disabled }));
|
40
40
|
}
|
41
41
|
else if (field.type === 'date') {
|
42
|
-
input = (react_1.default.createElement(DatePicker_1.default, { placeholder: __(field.placeholder) || __('Date.placeholder'), format: field.format || 'YYYY-MM-DD', inputFormat: field.inputFormat || 'YYYY-MM-DD', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, timeFormat: "", disabled: disabled }));
|
42
|
+
input = (react_1.default.createElement(DatePicker_1.default, { placeholder: __(field.placeholder) || __('Date.placeholder'), format: field.format || 'YYYY-MM-DD', inputFormat: field.inputFormat || 'YYYY-MM-DD', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, timeFormat: "", disabled: disabled, popOverContainer: popOverContainer }));
|
43
43
|
}
|
44
44
|
else if (field.type === 'time') {
|
45
|
-
input = (react_1.default.createElement(DatePicker_1.default, { viewMode: "time", placeholder: __(field.placeholder) || 'Time.placeholder', format: field.format || 'HH:mm', inputFormat: field.inputFormat || 'HH:mm', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, dateFormat: "", timeFormat: field.format || 'HH:mm', disabled: disabled }));
|
45
|
+
input = (react_1.default.createElement(DatePicker_1.default, { viewMode: "time", placeholder: __(field.placeholder) || 'Time.placeholder', format: field.format || 'HH:mm', inputFormat: field.inputFormat || 'HH:mm', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, dateFormat: "", timeFormat: field.format || 'HH:mm', disabled: disabled, popOverContainer: popOverContainer }));
|
46
46
|
}
|
47
47
|
else if (field.type === 'datetime') {
|
48
|
-
input = (react_1.default.createElement(DatePicker_1.default, { placeholder: __(field.placeholder) || 'Time.placeholder', format: field.format || '', inputFormat: field.inputFormat || 'YYYY-MM-DD HH:mm', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, timeFormat: field.timeFormat || 'HH:mm', disabled: disabled }));
|
48
|
+
input = (react_1.default.createElement(DatePicker_1.default, { placeholder: __(field.placeholder) || 'Time.placeholder', format: field.format || '', inputFormat: field.inputFormat || 'YYYY-MM-DD HH:mm', value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, timeFormat: field.timeFormat || 'HH:mm', disabled: disabled, popOverContainer: popOverContainer }));
|
49
49
|
}
|
50
50
|
else if (field.type === 'select') {
|
51
51
|
var autoComplete = field.autoComplete;
|
52
|
-
input = (react_1.default.createElement(Select_1.SelectWithRemoteOptions, { simpleValue: true, options: field.options, source: field.source, autoComplete: autoComplete, searchable: field.searchable, value: (_a = value !== null && value !== void 0 ? value : field.defaultValue) !== null && _a !== void 0 ? _a : '', data: data, onChange: onChange, multiple: op === 'select_any_in' || op === 'select_not_any_in', disabled: disabled }));
|
52
|
+
input = (react_1.default.createElement(Select_1.SelectWithRemoteOptions, { simpleValue: true, options: field.options, source: field.source, autoComplete: autoComplete, searchable: field.searchable, value: (_a = value !== null && value !== void 0 ? value : field.defaultValue) !== null && _a !== void 0 ? _a : '', data: data, onChange: onChange, multiple: op === 'select_any_in' || op === 'select_not_any_in', disabled: disabled, popOverContainer: popOverContainer }));
|
53
53
|
}
|
54
54
|
else if (field.type === 'boolean') {
|
55
55
|
input = (react_1.default.createElement(Switch_1.default, { value: value !== null && value !== void 0 ? value : field.defaultValue, onChange: onChange, disabled: disabled }));
|
@@ -6,8 +6,8 @@
|
|
6
6
|
"/src/components/condition-builder/Value.tsx"
|
7
7
|
],
|
8
8
|
"names": [],
|
9
|
-
"mappings": ";;;;AAAA,6DAA0B;AAE1B,qCAAkD;AAClD,sEAAmC;AACnC,4EAAyC;AACzC,0EAAuC;AACvC,oCAA4D;AAC5D,kEAA+B;AAC/B,uCAAqD;AACrD,4CAAoE;
|
9
|
+
"mappings": "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",
|
10
10
|
"sourcesContent": [
|
11
|
-
"import React from 'react';\nimport {FieldSimple, OperatorType} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport InputBox from '../InputBox';\nimport NumberInput from '../NumberInput';\nimport DatePicker from '../DatePicker';\nimport {SelectWithRemoteOptions as Select} from '../Select';\nimport Switch from '../Switch';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPicker, FormulaPickerProps} from '../formula/Picker';\n\nexport interface ValueProps extends ThemeProps, LocaleProps {\n value: any;\n data?: any;\n onChange: (value: any) => void;\n field: FieldSimple;\n op?: OperatorType;\n disabled?: boolean;\n formula?: FormulaPickerProps;\n}\n\nexport class Value extends React.Component<ValueProps> {\n render() {\n let {\n classnames: cx,\n field,\n value,\n onChange,\n op,\n translate: __,\n data,\n disabled,\n formula\n } = this.props;\n let input: JSX.Element | undefined = undefined;\n if (formula) {\n // 如果配置了 formula 字段,则所有的输入变为 formula 形式\n formula = Object.assign(formula, {\n translate: __,\n classnames: cx,\n data,\n value: value ?? field.defaultValue,\n onChange,\n disabled\n });\n input = <FormulaPicker {...formula} />;\n } else if (field.type === 'text') {\n input = (\n <InputBox\n value={value ?? field.defaultValue}\n onChange={onChange}\n placeholder={__(field.placeholder)}\n disabled={disabled}\n />\n );\n } else if (field.type === 'number') {\n input = (\n <NumberInput\n placeholder={__(field.placeholder) || __('NumberInput.placeholder')}\n step={field.step}\n min={field.minimum}\n max={field.maximum}\n precision={field.precision}\n value={value ?? field.defaultValue}\n onChange={onChange}\n disabled={disabled}\n />\n );\n } else if (field.type === 'date') {\n input = (\n <DatePicker\n placeholder={__(field.placeholder) || __('Date.placeholder')}\n format={field.format || 'YYYY-MM-DD'}\n inputFormat={field.inputFormat || 'YYYY-MM-DD'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n timeFormat=\"\"\n disabled={disabled}\n />\n );\n } else if (field.type === 'time') {\n input = (\n <DatePicker\n viewMode=\"time\"\n placeholder={__(field.placeholder) || 'Time.placeholder'}\n format={field.format || 'HH:mm'}\n inputFormat={field.inputFormat || 'HH:mm'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n dateFormat=\"\"\n timeFormat={field.format || 'HH:mm'}\n disabled={disabled}\n />\n );\n } else if (field.type === 'datetime') {\n input = (\n <DatePicker\n placeholder={__(field.placeholder) || 'Time.placeholder'}\n format={field.format || ''}\n inputFormat={field.inputFormat || 'YYYY-MM-DD HH:mm'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n timeFormat={field.timeFormat || 'HH:mm'}\n disabled={disabled}\n />\n );\n } else if (field.type === 'select') {\n const autoComplete = field.autoComplete;\n\n input = (\n <Select\n simpleValue\n options={field.options!}\n source={field.source}\n autoComplete={autoComplete}\n searchable={field.searchable}\n value={value ?? field.defaultValue ?? ''}\n data={data}\n onChange={onChange}\n multiple={op === 'select_any_in' || op === 'select_not_any_in'}\n disabled={disabled}\n />\n );\n } else if (field.type === 'boolean') {\n input = (\n <Switch\n value={value ?? field.defaultValue}\n onChange={onChange}\n disabled={disabled}\n />\n );\n }\n\n return <div className={cx('CBValue')}>{input}</div>;\n }\n}\n\nexport default themeable(localeable(Value));\n"
|
11
|
+
"import React from 'react';\nimport {FieldSimple, OperatorType} from './types';\nimport {ThemeProps, themeable} from '../../theme';\nimport InputBox from '../InputBox';\nimport NumberInput from '../NumberInput';\nimport DatePicker from '../DatePicker';\nimport {SelectWithRemoteOptions as Select} from '../Select';\nimport Switch from '../Switch';\nimport {localeable, LocaleProps} from '../../locale';\nimport {FormulaPicker, FormulaPickerProps} from '../formula/Picker';\n\nexport interface ValueProps extends ThemeProps, LocaleProps {\n value: any;\n data?: any;\n onChange: (value: any) => void;\n field: FieldSimple;\n op?: OperatorType;\n disabled?: boolean;\n formula?: FormulaPickerProps;\n popOverContainer?: any;\n}\n\nexport class Value extends React.Component<ValueProps> {\n render() {\n let {\n classnames: cx,\n field,\n value,\n onChange,\n op,\n translate: __,\n data,\n disabled,\n formula,\n popOverContainer\n } = this.props;\n let input: JSX.Element | undefined = undefined;\n if (formula) {\n // 如果配置了 formula 字段,则所有的输入变为 formula 形式\n formula = Object.assign(formula, {\n translate: __,\n classnames: cx,\n data,\n value: value ?? field.defaultValue,\n onChange,\n disabled\n });\n input = <FormulaPicker {...formula} />;\n } else if (field.type === 'text') {\n input = (\n <InputBox\n value={value ?? field.defaultValue}\n onChange={onChange}\n placeholder={__(field.placeholder)}\n disabled={disabled}\n />\n );\n } else if (field.type === 'number') {\n input = (\n <NumberInput\n placeholder={__(field.placeholder) || __('NumberInput.placeholder')}\n step={field.step}\n min={field.minimum}\n max={field.maximum}\n precision={field.precision}\n value={value ?? field.defaultValue}\n onChange={onChange}\n disabled={disabled}\n />\n );\n } else if (field.type === 'date') {\n input = (\n <DatePicker\n placeholder={__(field.placeholder) || __('Date.placeholder')}\n format={field.format || 'YYYY-MM-DD'}\n inputFormat={field.inputFormat || 'YYYY-MM-DD'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n timeFormat=\"\"\n disabled={disabled}\n popOverContainer={popOverContainer}\n />\n );\n } else if (field.type === 'time') {\n input = (\n <DatePicker\n viewMode=\"time\"\n placeholder={__(field.placeholder) || 'Time.placeholder'}\n format={field.format || 'HH:mm'}\n inputFormat={field.inputFormat || 'HH:mm'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n dateFormat=\"\"\n timeFormat={field.format || 'HH:mm'}\n disabled={disabled}\n popOverContainer={popOverContainer}\n />\n );\n } else if (field.type === 'datetime') {\n input = (\n <DatePicker\n placeholder={__(field.placeholder) || 'Time.placeholder'}\n format={field.format || ''}\n inputFormat={field.inputFormat || 'YYYY-MM-DD HH:mm'}\n value={value ?? field.defaultValue}\n onChange={onChange}\n timeFormat={field.timeFormat || 'HH:mm'}\n disabled={disabled}\n popOverContainer={popOverContainer}\n />\n );\n } else if (field.type === 'select') {\n const autoComplete = field.autoComplete;\n\n input = (\n <Select\n simpleValue\n options={field.options!}\n source={field.source}\n autoComplete={autoComplete}\n searchable={field.searchable}\n value={value ?? field.defaultValue ?? ''}\n data={data}\n onChange={onChange}\n multiple={op === 'select_any_in' || op === 'select_not_any_in'}\n disabled={disabled}\n popOverContainer={popOverContainer}\n />\n );\n } else if (field.type === 'boolean') {\n input = (\n <Switch\n value={value ?? field.defaultValue}\n onChange={onChange}\n disabled={disabled}\n />\n );\n }\n\n return <div className={cx('CBValue')}>{input}</div>;\n }\n}\n\nexport default themeable(localeable(Value));\n"
|
12
12
|
]
|
13
13
|
}
|
@@ -19,6 +19,7 @@ export interface ConditionBuilderProps extends ThemeProps, LocaleProps {
|
|
19
19
|
searchable?: boolean;
|
20
20
|
fieldClassName?: string;
|
21
21
|
formula?: FormulaPickerProps;
|
22
|
+
popOverContainer?: any;
|
22
23
|
}
|
23
24
|
export declare class QueryBuilder extends React.Component<ConditionBuilderProps> {
|
24
25
|
config: {
|
@@ -138,7 +138,7 @@ var QueryBuilder = /** @class */ (function (_super) {
|
|
138
138
|
delete this.ghost;
|
139
139
|
};
|
140
140
|
QueryBuilder.prototype.render = function () {
|
141
|
-
var _a = this.props, cx = _a.classnames, fieldClassName = _a.fieldClassName, fields = _a.fields, funcs = _a.funcs, onChange = _a.onChange, value = _a.value, showNot = _a.showNot, showANDOR = _a.showANDOR, data = _a.data, disabled = _a.disabled, searchable = _a.searchable, builderMode = _a.builderMode, formula = _a.formula;
|
141
|
+
var _a = this.props, cx = _a.classnames, fieldClassName = _a.fieldClassName, fields = _a.fields, funcs = _a.funcs, onChange = _a.onChange, value = _a.value, showNot = _a.showNot, showANDOR = _a.showANDOR, data = _a.data, disabled = _a.disabled, searchable = _a.searchable, builderMode = _a.builderMode, formula = _a.formula, popOverContainer = _a.popOverContainer;
|
142
142
|
var normalizedValue = Array.isArray(value === null || value === void 0 ? void 0 : value.children)
|
143
143
|
? (0, tslib_1.__assign)((0, tslib_1.__assign)({}, value), { children: (0, helper_1.mapTree)(value.children, function (value) {
|
144
144
|
if (value.id) {
|
@@ -146,7 +146,7 @@ var QueryBuilder = /** @class */ (function (_super) {
|
|
146
146
|
}
|
147
147
|
return (0, tslib_1.__assign)((0, tslib_1.__assign)({}, value), { id: (0, helper_1.guid)() });
|
148
148
|
}) }) : value;
|
149
|
-
return (react_1.default.createElement(Group_1.default, { builderMode: builderMode, config: this.config, funcs: funcs || this.config.funcs, fields: fields || this.config.fields, value: normalizedValue, onChange: onChange, classnames: cx, fieldClassName: fieldClassName, removeable: false, onDragStart: this.handleDragStart, showANDOR: showANDOR, showNot: showNot, data: data, disabled: disabled, searchable: searchable, formula: formula }));
|
149
|
+
return (react_1.default.createElement(Group_1.default, { builderMode: builderMode, config: this.config, funcs: funcs || this.config.funcs, fields: fields || this.config.fields, value: normalizedValue, onChange: onChange, classnames: cx, fieldClassName: fieldClassName, removeable: false, onDragStart: this.handleDragStart, showANDOR: showANDOR, showNot: showNot, data: data, disabled: disabled, searchable: searchable, formula: formula, popOverContainer: popOverContainer }));
|
150
150
|
};
|
151
151
|
var _a, _b, _c;
|
152
152
|
(0, tslib_1.__decorate)([
|