amis-rev-ui 6.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/esm/HTMLFilterContext.d.ts +3 -0
- package/esm/HTMLFilterContext.js +10 -0
- package/esm/components/404.js +35 -0
- package/esm/components/Alert.js +266 -0
- package/esm/components/Alert2.js +58 -0
- package/esm/components/AlphabetIndexer.d.ts +11 -0
- package/esm/components/AlphabetIndexer.js +48 -0
- package/esm/components/AnchorNav.js +153 -0
- package/esm/components/AnchorNavSection.d.ts +2 -0
- package/esm/components/AnchorNavSection.js +7 -0
- package/esm/components/ArrayInput.js +146 -0
- package/esm/components/AsideNav.js +133 -0
- package/esm/components/AssociatedSelection.js +107 -0
- package/esm/components/AutoFoldedList.js +124 -0
- package/esm/components/AutoSizer.d.ts +2 -0
- package/esm/components/AutoSizer.js +8 -0
- package/esm/components/Avatar.js +126 -0
- package/esm/components/Badge.d.ts +20 -0
- package/esm/components/Badge.js +154 -0
- package/esm/components/BaiduMapPicker.js +366 -0
- package/esm/components/BarCode.js +42 -0
- package/esm/components/Breadcrumb.js +160 -0
- package/esm/components/Button.js +64 -0
- package/esm/components/CalendarMobile.js +538 -0
- package/esm/components/Card.js +88 -0
- package/esm/components/Cascader.js +515 -0
- package/esm/components/ChainedDropdownSelection.js +104 -0
- package/esm/components/ChainedSelection.js +184 -0
- package/esm/components/Checkbox.js +87 -0
- package/esm/components/CityArea.js +190 -0
- package/esm/components/CityDB.d.ts +13 -0
- package/esm/components/CityDB.js +3942 -0
- package/esm/components/CodeMirror.d.ts +29 -0
- package/esm/components/CodeMirror.js +140 -0
- package/esm/components/Collapse.js +184 -0
- package/esm/components/CollapseGroup.js +117 -0
- package/esm/components/ColorPicker.js +259 -0
- package/esm/components/Combo.js +212 -0
- package/esm/components/ConditionBuilder.d.ts +2 -0
- package/esm/components/ConditionBuilder.js +7 -0
- package/esm/components/ConfirmBox.js +128 -0
- package/esm/components/ContextMenu.js +310 -0
- package/esm/components/DatePicker.js +716 -0
- package/esm/components/DateRangePicker.js +1385 -0
- package/esm/components/DiffEditor.d.ts +21 -0
- package/esm/components/DiffEditor.js +119 -0
- package/esm/components/DndContainer.js +25 -0
- package/esm/components/Drawer.js +272 -0
- package/esm/components/DropDownSelection.js +77 -0
- package/esm/components/DropdownContextMenus.js +93 -0
- package/esm/components/Editor.js +238 -0
- package/esm/components/Form.d.ts +31 -0
- package/esm/components/Form.js +84 -0
- package/esm/components/FormField.js +78 -0
- package/esm/components/FormulaPicker.d.ts +2 -0
- package/esm/components/FormulaPicker.js +7 -0
- package/esm/components/GaodeMapPicker.js +204 -0
- package/esm/components/GridNav.d.ts +53 -0
- package/esm/components/GridNav.js +125 -0
- package/esm/components/GridNavItem.d.ts +2 -0
- package/esm/components/GridNavItem.js +7 -0
- package/esm/components/GroupedSelection.js +138 -0
- package/esm/components/HeadCellDropDown.d.ts +2 -0
- package/esm/components/HeadCellDropDown.js +7 -0
- package/esm/components/HorizontalScroll.d.ts +74 -0
- package/esm/components/HorizontalScroll.js +271 -0
- package/esm/components/Html.js +55 -0
- package/esm/components/Icon.d.ts +2 -0
- package/esm/components/Icon.js +7 -0
- package/esm/components/ImageGallery.js +396 -0
- package/esm/components/Input.d.ts +18 -0
- package/esm/components/Input.js +75 -0
- package/esm/components/InputBox.js +99 -0
- package/esm/components/InputBoxWithSuggestion.js +70 -0
- package/esm/components/InputJSONSchema.d.ts +2 -0
- package/esm/components/InputJSONSchema.js +7 -0
- package/esm/components/InputTable.js +176 -0
- package/esm/components/JSONSchemaEditor.d.ts +2 -0
- package/esm/components/JSONSchemaEditor.js +7 -0
- package/esm/components/Layout.js +60 -0
- package/esm/components/Link.js +44 -0
- package/esm/components/ListGroup.js +31 -0
- package/esm/components/ListMenu.js +62 -0
- package/esm/components/LocationPicker.js +208 -0
- package/esm/components/Markdown.d.ts +25 -0
- package/esm/components/Markdown.js +70 -0
- package/esm/components/Menu.d.ts +2 -0
- package/esm/components/Menu.js +7 -0
- package/esm/components/MixedInput.js +88 -0
- package/esm/components/MobileDevTool.d.ts +12 -0
- package/esm/components/MobileDevTool.js +312 -0
- package/esm/components/Modal.js +261 -0
- package/esm/components/ModalManager.d.ts +16 -0
- package/esm/components/ModalManager.js +42 -0
- package/esm/components/MultilineText.js +90 -0
- package/esm/components/NumberInput.js +274 -0
- package/esm/components/OverflowTpl.js +100 -0
- package/esm/components/Pagination.js +377 -0
- package/esm/components/PdfViewer.js +83 -0
- package/esm/components/Picker.js +73 -0
- package/esm/components/PickerColumn.js +276 -0
- package/esm/components/PickerContainer.js +157 -0
- package/esm/components/PopOverContainer.d.ts +59 -0
- package/esm/components/PopOverContainer.js +148 -0
- package/esm/components/PopUp.js +85 -0
- package/esm/components/Progress.js +136 -0
- package/esm/components/PullRefresh.js +172 -0
- package/esm/components/Radios.js +129 -0
- package/esm/components/Range.js +516 -0
- package/esm/components/Rating.js +341 -0
- package/esm/components/ResultBox.js +195 -0
- package/esm/components/ResultList.js +253 -0
- package/esm/components/ResultTableList.js +152 -0
- package/esm/components/ResultTreeList.js +241 -0
- package/esm/components/RichText.d.ts +48 -0
- package/esm/components/RichText.js +271 -0
- package/esm/components/SearchBox.js +298 -0
- package/esm/components/Select.js +814 -0
- package/esm/components/SelectMobile.d.ts +38 -0
- package/esm/components/SelectMobile.js +369 -0
- package/esm/components/Selection.js +166 -0
- package/esm/components/Shape.js +429 -0
- package/esm/components/Signature.js +294 -0
- package/esm/components/Slider.js +140 -0
- package/esm/components/SparkLine.js +62 -0
- package/esm/components/Spinner.js +202 -0
- package/esm/components/Steps.js +76 -0
- package/esm/components/Switch.js +73 -0
- package/esm/components/Tab.d.ts +2 -0
- package/esm/components/Tab.js +7 -0
- package/esm/components/Table.d.ts +2 -0
- package/esm/components/Table.js +7 -0
- package/esm/components/TableSelection.js +169 -0
- package/esm/components/Tabs.js +607 -0
- package/esm/components/TabsTransfer.js +221 -0
- package/esm/components/TabsTransferPicker.js +81 -0
- package/esm/components/Tag.js +137 -0
- package/esm/components/Textarea.js +146 -0
- package/esm/components/Timeline.js +60 -0
- package/esm/components/TimelineItem.js +101 -0
- package/esm/components/Tinymce.d.ts +66 -0
- package/esm/components/Tinymce.js +634 -0
- package/esm/components/TitleBar.js +48 -0
- package/esm/components/Toast.js +247 -0
- package/esm/components/Tooltip.js +36 -0
- package/esm/components/TooltipWrapper.js +180 -0
- package/esm/components/Transfer.js +485 -0
- package/esm/components/TransferDropDown.js +98 -0
- package/esm/components/TransferPicker.js +98 -0
- package/esm/components/TransferSearch.js +100 -0
- package/esm/components/Tree.js +1256 -0
- package/esm/components/TreeSelection.js +201 -0
- package/esm/components/UserSelect.js +674 -0
- package/esm/components/UserTabSelect.js +227 -0
- package/esm/components/VerificationCode.js +172 -0
- package/esm/components/VirtualList.d.ts +2 -0
- package/esm/components/VirtualList.js +7 -0
- package/esm/components/WithRemoteConfig.d.ts +70 -0
- package/esm/components/WithRemoteConfig.js +301 -0
- package/esm/components/WithStore.d.ts +13 -0
- package/esm/components/WithStore.js +48 -0
- package/esm/components/calendar/Calendar.d.ts +83 -0
- package/esm/components/calendar/Calendar.js +529 -0
- package/esm/components/calendar/CalendarContainer.d.ts +10 -0
- package/esm/components/calendar/CalendarContainer.js +27 -0
- package/esm/components/calendar/DaysView.js +528 -0
- package/esm/components/calendar/MonthsView.js +175 -0
- package/esm/components/calendar/QuartersView.js +125 -0
- package/esm/components/calendar/TimeView.js +559 -0
- package/esm/components/calendar/YearsView.js +122 -0
- package/esm/components/condition-builder/Expression.js +121 -0
- package/esm/components/condition-builder/Field.js +32 -0
- package/esm/components/condition-builder/Func.js +75 -0
- package/esm/components/condition-builder/Group.js +196 -0
- package/esm/components/condition-builder/GroupOrItem.js +107 -0
- package/esm/components/condition-builder/InputSwitch.js +28 -0
- package/esm/components/condition-builder/Item.js +233 -0
- package/esm/components/condition-builder/Value.js +115 -0
- package/esm/components/condition-builder/config.d.ts +36 -0
- package/esm/components/condition-builder/config.js +120 -0
- package/esm/components/condition-builder/index.js +242 -0
- package/esm/components/condition-builder/types.d.ts +116 -0
- package/esm/components/formula/CodeEditor.js +99 -0
- package/esm/components/formula/Editor.js +446 -0
- package/esm/components/formula/FuncList.js +64 -0
- package/esm/components/formula/Input.js +141 -0
- package/esm/components/formula/Picker.js +454 -0
- package/esm/components/formula/VariableList.js +185 -0
- package/esm/components/formula/plugin.d.ts +51 -0
- package/esm/components/formula/plugin.js +445 -0
- package/esm/components/icons.d.ts +61 -0
- package/esm/components/icons.js +458 -0
- package/esm/components/index.d.ts +138 -0
- package/esm/components/json-schema/Array.d.ts +3 -0
- package/esm/components/json-schema/Array.js +129 -0
- package/esm/components/json-schema/Item.d.ts +5 -0
- package/esm/components/json-schema/Item.js +63 -0
- package/esm/components/json-schema/Object.d.ts +5 -0
- package/esm/components/json-schema/Object.js +272 -0
- package/esm/components/json-schema/index.js +29 -0
- package/esm/components/menu/MenuContext.d.ts +82 -0
- package/esm/components/menu/MenuContext.js +25 -0
- package/esm/components/menu/MenuItem.js +112 -0
- package/esm/components/menu/PanelMenu.js +68 -0
- package/esm/components/menu/SubMenu.js +137 -0
- package/esm/components/menu/index.js +368 -0
- package/esm/components/schema-editor/Array.d.ts +11 -0
- package/esm/components/schema-editor/Array.js +84 -0
- package/esm/components/schema-editor/Common.d.ts +61 -0
- package/esm/components/schema-editor/Common.js +162 -0
- package/esm/components/schema-editor/Item.d.ts +8 -0
- package/esm/components/schema-editor/Item.js +24 -0
- package/esm/components/schema-editor/Object.d.ts +51 -0
- package/esm/components/schema-editor/Object.js +294 -0
- package/esm/components/schema-editor/SchemaVariableList.js +74 -0
- package/esm/components/schema-editor/SchemaVariableListPicker.js +34 -0
- package/esm/components/schema-editor/index.js +122 -0
- package/esm/components/table/Cell.d.ts +36 -0
- package/esm/components/table/Cell.js +43 -0
- package/esm/components/table/ColGroup.d.ts +24 -0
- package/esm/components/table/ColGroup.js +77 -0
- package/esm/components/table/Head.d.ts +45 -0
- package/esm/components/table/Head.js +150 -0
- package/esm/components/table/HeadCellDropDown.js +54 -0
- package/esm/components/table/HeadCellFilter.js +130 -0
- package/esm/components/table/HeadCellSelect.js +51 -0
- package/esm/components/table/HeadCellSort.js +88 -0
- package/esm/components/table/ItemActionsWrapper.d.ts +10 -0
- package/esm/components/table/ItemActionsWrapper.js +29 -0
- package/esm/components/table/Row.d.ts +56 -0
- package/esm/components/table/Row.js +224 -0
- package/esm/components/table/SummaryRow.d.ts +28 -0
- package/esm/components/table/SummaryRow.js +73 -0
- package/esm/components/table/index.js +1095 -0
- package/esm/components/table/util.d.ts +25 -0
- package/esm/components/table/util.js +279 -0
- package/esm/components/virtual-list/AutoSizer.d.ts +19 -0
- package/esm/components/virtual-list/AutoSizer.js +48 -0
- package/esm/components/virtual-list/SizeAndPositionManager.d.ts +70 -0
- package/esm/components/virtual-list/SizeAndPositionManager.js +216 -0
- package/esm/components/virtual-list/constants.d.ts +34 -0
- package/esm/components/virtual-list/constants.js +45 -0
- package/esm/components/virtual-list/index.d.ts +98 -0
- package/esm/components/virtual-list/index.js +288 -0
- package/esm/components/withBadge.d.ts +2 -0
- package/esm/components/withBadge.js +7 -0
- package/esm/hooks/index.d.ts +8 -0
- package/esm/hooks/use-click-away.d.ts +12 -0
- package/esm/hooks/use-click-away.js +55 -0
- package/esm/hooks/use-on-screen.d.ts +2 -0
- package/esm/hooks/use-on-screen.js +28 -0
- package/esm/hooks/use-set-state.d.ts +2 -0
- package/esm/hooks/use-set-state.js +19 -0
- package/esm/hooks/use-sub-form.d.ts +4 -0
- package/esm/hooks/use-sub-form.js +39 -0
- package/esm/hooks/use-touch.d.ts +16 -0
- package/esm/hooks/use-touch.js +77 -0
- package/esm/hooks/use-update-effect.d.ts +3 -0
- package/esm/hooks/use-update-effect.js +21 -0
- package/esm/hooks/use-validation-resolver.d.ts +7 -0
- package/esm/hooks/use-validation-resolver.js +115 -0
- package/esm/icons/alert-danger.svg.js +22 -0
- package/esm/icons/alert-info.svg.js +22 -0
- package/esm/icons/alert-success.svg.js +22 -0
- package/esm/icons/alert-warning.svg.js +22 -0
- package/esm/icons/arrow-double-left.svg.js +24 -0
- package/esm/icons/arrow-double-right.svg.js +24 -0
- package/esm/icons/back.svg.js +21 -0
- package/esm/icons/calendar.svg.js +31 -0
- package/esm/icons/caret.svg.js +21 -0
- package/esm/icons/check.svg.js +21 -0
- package/esm/icons/clock.svg.js +29 -0
- package/esm/icons/close-small.svg.js +24 -0
- package/esm/icons/close.svg.js +21 -0
- package/esm/icons/cloud-upload.svg.js +22 -0
- package/esm/icons/column-filter.svg.js +22 -0
- package/esm/icons/columns.svg.js +21 -0
- package/esm/icons/compress-alt.svg.js +21 -0
- package/esm/icons/copy.svg.js +26 -0
- package/esm/icons/date.svg.js +26 -0
- package/esm/icons/department.svg.js +52 -0
- package/esm/icons/desk-empty.svg.js +73 -0
- package/esm/icons/dot.svg.js +36 -0
- package/esm/icons/down-arrow-bold.svg.js +22 -0
- package/esm/icons/down.svg.js +23 -0
- package/esm/icons/download.svg.js +24 -0
- package/esm/icons/drag-bar.svg.js +53 -0
- package/esm/icons/drag.svg.js +22 -0
- package/esm/icons/edit.svg.js +21 -0
- package/esm/icons/ellipsis-v.svg.js +21 -0
- package/esm/icons/enter.svg.js +20 -0
- package/esm/icons/exchange.svg.js +21 -0
- package/esm/icons/expand-alt.svg.js +21 -0
- package/esm/icons/fail.svg.js +31 -0
- package/esm/icons/file.svg.js +22 -0
- package/esm/icons/filter.svg.js +21 -0
- package/esm/icons/folder.svg.js +24 -0
- package/esm/icons/fullscreen.svg.js +21 -0
- package/esm/icons/function.svg.js +21 -0
- package/esm/icons/home.svg.js +21 -0
- package/esm/icons/if.svg.js +21 -0
- package/esm/icons/image.svg.js +20 -0
- package/esm/icons/info-circle.svg.js +21 -0
- package/esm/icons/info.svg.js +27 -0
- package/esm/icons/input-clear.svg.js +20 -0
- package/esm/icons/invisible.svg.js +22 -0
- package/esm/icons/left-arrow.svg.js +23 -0
- package/esm/icons/loading-outline.svg.js +21 -0
- package/esm/icons/location.svg.js +20 -0
- package/esm/icons/menu.svg.js +20 -0
- package/esm/icons/minus.svg.js +21 -0
- package/esm/icons/move.svg.js +22 -0
- package/esm/icons/mute.svg.js +21 -0
- package/esm/icons/new-edit.svg.js +22 -0
- package/esm/icons/pause.svg.js +21 -0
- package/esm/icons/pencil.svg.js +21 -0
- package/esm/icons/play.svg.js +20 -0
- package/esm/icons/plus-cicle.svg.js +20 -0
- package/esm/icons/plus-fine.svg.js +21 -0
- package/esm/icons/plus.svg.js +21 -0
- package/esm/icons/post.svg.js +48 -0
- package/esm/icons/question-mark.svg.js +26 -0
- package/esm/icons/question.svg.js +21 -0
- package/esm/icons/question2.svg.js +34 -0
- package/esm/icons/redo.svg.js +21 -0
- package/esm/icons/refresh.svg.js +21 -0
- package/esm/icons/reload.svg.js +21 -0
- package/esm/icons/remove.svg.js +21 -0
- package/esm/icons/retry.svg.js +24 -0
- package/esm/icons/right-arrow-bold.svg.js +21 -0
- package/esm/icons/right-arrow.svg.js +23 -0
- package/esm/icons/right-double-arrow.svg.js +22 -0
- package/esm/icons/role.svg.js +43 -0
- package/esm/icons/rotate-left.svg.js +22 -0
- package/esm/icons/rotate-right.svg.js +22 -0
- package/esm/icons/rotate-screen.svg.js +21 -0
- package/esm/icons/scale-origin.svg.js +24 -0
- package/esm/icons/schedule.svg.js +24 -0
- package/esm/icons/search.svg.js +21 -0
- package/esm/icons/setting.svg.js +21 -0
- package/esm/icons/slider-handle-icon.svg.js +22 -0
- package/esm/icons/sort-asc.svg.js +21 -0
- package/esm/icons/sort-default.svg.js +21 -0
- package/esm/icons/sort-desc.svg.js +21 -0
- package/esm/icons/star.svg.js +21 -0
- package/esm/icons/status-close.svg.js +23 -0
- package/esm/icons/steps-finsh.svg.js +22 -0
- package/esm/icons/sub-plus.svg.js +20 -0
- package/esm/icons/success.svg.js +29 -0
- package/esm/icons/transparent.svg.js +38 -0
- package/esm/icons/trash.svg.js +22 -0
- package/esm/icons/tree-down.svg.js +21 -0
- package/esm/icons/undo-normal.svg.js +25 -0
- package/esm/icons/undo.svg.js +21 -0
- package/esm/icons/unfullscreen.svg.js +21 -0
- package/esm/icons/upload.svg.js +21 -0
- package/esm/icons/user-remove.svg.js +33 -0
- package/esm/icons/view.svg.js +22 -0
- package/esm/icons/volume.svg.js +24 -0
- package/esm/icons/warning-mark.svg.js +22 -0
- package/esm/icons/warning.svg.js +21 -0
- package/esm/icons/window-restore.svg.js +21 -0
- package/esm/icons/zoom-in.svg.js +21 -0
- package/esm/icons/zoom-out.svg.js +21 -0
- package/esm/index.d.ts +16 -0
- package/esm/index.js +157 -0
- package/esm/locale/de-DE.d.ts +1 -0
- package/esm/locale/de-DE.js +423 -0
- package/esm/locale/en-US.d.ts +1 -0
- package/esm/locale/en-US.js +429 -0
- package/esm/locale/zh-CN.d.ts +1 -0
- package/esm/locale/zh-CN.js +438 -0
- package/esm/themes/ang.d.ts +3 -0
- package/esm/themes/ang.js +15 -0
- package/esm/themes/antd.d.ts +1 -0
- package/esm/themes/antd.js +42 -0
- package/esm/themes/cxd.d.ts +3 -0
- package/esm/themes/cxd.js +455 -0
- package/esm/themes/dark.d.ts +3 -0
- package/esm/themes/dark.js +23 -0
- package/esm/themes/default.d.ts +4 -0
- package/esm/utils/index.d.ts +2 -0
- package/esm/utils/smoothSignature.d.ts +86 -0
- package/esm/utils/vectorComputed.d.ts +20 -0
- package/esm/utils/vectorComputed.js +75 -0
- package/esm/withRemoteConfig.d.ts +2 -0
- package/esm/withRemoteConfig.js +7 -0
- package/esm/withStore.d.ts +2 -0
- package/esm/withStore.js +7 -0
- package/lib/HTMLFilterContext.d.ts +3 -0
- package/lib/components/AlphabetIndexer.d.ts +11 -0
- package/lib/components/AnchorNavSection.d.ts +2 -0
- package/lib/components/AutoSizer.d.ts +2 -0
- package/lib/components/Badge.d.ts +20 -0
- package/lib/components/BarCode.js +44 -0
- package/lib/components/CityDB.d.ts +13 -0
- package/lib/components/CityDB.js +3945 -0
- package/lib/components/CodeMirror.d.ts +29 -0
- package/lib/components/ColorPicker.js +267 -0
- package/lib/components/ConditionBuilder.d.ts +2 -0
- package/lib/components/DiffEditor.d.ts +21 -0
- package/lib/components/Form.d.ts +31 -0
- package/lib/components/FormulaPicker.d.ts +2 -0
- package/lib/components/GridNav.d.ts +53 -0
- package/lib/components/GridNavItem.d.ts +2 -0
- package/lib/components/HeadCellDropDown.d.ts +2 -0
- package/lib/components/HorizontalScroll.d.ts +74 -0
- package/lib/components/Icon.d.ts +2 -0
- package/lib/components/Input.d.ts +18 -0
- package/lib/components/InputJSONSchema.d.ts +2 -0
- package/lib/components/JSONSchemaEditor.d.ts +2 -0
- package/lib/components/Markdown.d.ts +25 -0
- package/lib/components/Markdown.js +76 -0
- package/lib/components/Menu.d.ts +2 -0
- package/lib/components/MobileDevTool.d.ts +12 -0
- package/lib/components/ModalManager.d.ts +16 -0
- package/lib/components/PdfViewer.js +83 -0
- package/lib/components/PopOverContainer.d.ts +59 -0
- package/lib/components/RichText.d.ts +48 -0
- package/lib/components/RichText.js +275 -0
- package/lib/components/SelectMobile.d.ts +38 -0
- package/lib/components/Tab.d.ts +2 -0
- package/lib/components/Table.d.ts +2 -0
- package/lib/components/Tinymce.d.ts +66 -0
- package/lib/components/Tinymce.js +641 -0
- package/lib/components/VirtualList.d.ts +2 -0
- package/lib/components/WithRemoteConfig.d.ts +70 -0
- package/lib/components/WithStore.d.ts +13 -0
- package/lib/components/calendar/Calendar.d.ts +83 -0
- package/lib/components/calendar/CalendarContainer.d.ts +10 -0
- package/lib/components/condition-builder/config.d.ts +36 -0
- package/lib/components/condition-builder/types.d.ts +116 -0
- package/lib/components/formula/plugin.d.ts +51 -0
- package/lib/components/icons.d.ts +61 -0
- package/lib/components/index.d.ts +138 -0
- package/lib/components/json-schema/Array.d.ts +3 -0
- package/lib/components/json-schema/Item.d.ts +5 -0
- package/lib/components/json-schema/Object.d.ts +5 -0
- package/lib/components/menu/MenuContext.d.ts +82 -0
- package/lib/components/schema-editor/Array.d.ts +11 -0
- package/lib/components/schema-editor/Common.d.ts +61 -0
- package/lib/components/schema-editor/Item.d.ts +8 -0
- package/lib/components/schema-editor/Object.d.ts +51 -0
- package/lib/components/table/Cell.d.ts +36 -0
- package/lib/components/table/ColGroup.d.ts +24 -0
- package/lib/components/table/Head.d.ts +45 -0
- package/lib/components/table/ItemActionsWrapper.d.ts +10 -0
- package/lib/components/table/Row.d.ts +56 -0
- package/lib/components/table/SummaryRow.d.ts +28 -0
- package/lib/components/table/util.d.ts +25 -0
- package/lib/components/virtual-list/AutoSizer.d.ts +19 -0
- package/lib/components/virtual-list/SizeAndPositionManager.d.ts +70 -0
- package/lib/components/virtual-list/constants.d.ts +34 -0
- package/lib/components/virtual-list/index.d.ts +98 -0
- package/lib/components/withBadge.d.ts +2 -0
- package/lib/helper.css +47762 -0
- package/lib/hooks/index.d.ts +8 -0
- package/lib/hooks/use-click-away.d.ts +12 -0
- package/lib/hooks/use-on-screen.d.ts +2 -0
- package/lib/hooks/use-set-state.d.ts +2 -0
- package/lib/hooks/use-sub-form.d.ts +4 -0
- package/lib/hooks/use-touch.d.ts +16 -0
- package/lib/hooks/use-update-effect.d.ts +3 -0
- package/lib/hooks/use-validation-resolver.d.ts +7 -0
- package/lib/index.d.ts +16 -0
- package/lib/index.js +28 -0
- package/lib/locale/de-DE.d.ts +1 -0
- package/lib/locale/en-US.d.ts +1 -0
- package/lib/locale/zh-CN.d.ts +1 -0
- package/lib/scss/helper.scss.js +12 -0
- package/lib/scss/themes/ang.scss.js +12 -0
- package/lib/scss/themes/antd.scss.js +12 -0
- package/lib/scss/themes/cxd.scss.js +12 -0
- package/lib/scss/themes/dark.scss.js +12 -0
- package/lib/scss/themes/default.scss.js +12 -0
- package/lib/themes/ang.css +45895 -0
- package/lib/themes/ang.d.ts +3 -0
- package/lib/themes/antd.css +45882 -0
- package/lib/themes/antd.d.ts +1 -0
- package/lib/themes/cxd.css +45871 -0
- package/lib/themes/cxd.d.ts +3 -0
- package/lib/themes/dark.css +45902 -0
- package/lib/themes/dark.d.ts +3 -0
- package/lib/themes/default.css +45871 -0
- package/lib/themes/default.d.ts +4 -0
- package/lib/utils/index.d.ts +2 -0
- package/lib/utils/smoothSignature.d.ts +86 -0
- package/lib/utils/vectorComputed.d.ts +20 -0
- package/lib/withRemoteConfig.d.ts +2 -0
- package/lib/withStore.d.ts +2 -0
- package/package.json +158 -0
- package/scss/README.md +9 -0
- package/scss/_components.scss +4346 -0
- package/scss/_functions.scss +137 -0
- package/scss/_mixins.scss +805 -0
- package/scss/_properties.scss +898 -0
- package/scss/_thirds.scss +12 -0
- package/scss/_utilities.scss +1757 -0
- package/scss/_variables.scss +439 -0
- package/scss/base/_animate.scss +84 -0
- package/scss/base/_common.scss +19 -0
- package/scss/base/_normalize.scss +376 -0
- package/scss/base/_reset.scss +18 -0
- package/scss/base/_typography.scss +79 -0
- package/scss/components/_alert.scss +123 -0
- package/scss/components/_anchor-nav.scss +158 -0
- package/scss/components/_app.scss +46 -0
- package/scss/components/_array-input.scss +107 -0
- package/scss/components/_audio.scss +146 -0
- package/scss/components/_auto-folder.scss +40 -0
- package/scss/components/_avatar.scss +55 -0
- package/scss/components/_badge.scss +145 -0
- package/scss/components/_barcode.scss +6 -0
- package/scss/components/_breadcrumb.scss +110 -0
- package/scss/components/_button-group.scss +165 -0
- package/scss/components/_button.scss +871 -0
- package/scss/components/_calendar.scss +442 -0
- package/scss/components/_card.scss +389 -0
- package/scss/components/_card2.scss +28 -0
- package/scss/components/_cards.scss +221 -0
- package/scss/components/_carousel.scss +292 -0
- package/scss/components/_cascader.scss +157 -0
- package/scss/components/_chart.scss +22 -0
- package/scss/components/_city-area.scss +37 -0
- package/scss/components/_code.scss +10 -0
- package/scss/components/_collapse-group.scss +83 -0
- package/scss/components/_collapse.scss +245 -0
- package/scss/components/_color.scss +17 -0
- package/scss/components/_column-toggler.scss +261 -0
- package/scss/components/_condition-builder.scss +521 -0
- package/scss/components/_context-menu.scss +204 -0
- package/scss/components/_copyable.scss +10 -0
- package/scss/components/_crud.scss +195 -0
- package/scss/components/_crud2.scss +345 -0
- package/scss/components/_debug.scss +259 -0
- package/scss/components/_divider.scss +81 -0
- package/scss/components/_drawer.scss +393 -0
- package/scss/components/_dropdown-context-menus.scss +27 -0
- package/scss/components/_dropdown.scss +159 -0
- package/scss/components/_each.scss +7 -0
- package/scss/components/_formula.scss +723 -0
- package/scss/components/_grid-nav.scss +128 -0
- package/scss/components/_horizontal-scroll.scss +51 -0
- package/scss/components/_icon.scss +4 -0
- package/scss/components/_image-gallery.scss +331 -0
- package/scss/components/_images.scss +650 -0
- package/scss/components/_input-box.scss +111 -0
- package/scss/components/_json-schema-editor.scss +149 -0
- package/scss/components/_json-schema.scss +166 -0
- package/scss/components/_json.scss +7 -0
- package/scss/components/_link.scss +22 -0
- package/scss/components/_list-menu.scss +114 -0
- package/scss/components/_list.scss +313 -0
- package/scss/components/_log.scss +169 -0
- package/scss/components/_mapping.scss +6 -0
- package/scss/components/_markdown.scss +266 -0
- package/scss/components/_menu.scss +795 -0
- package/scss/components/_mobile-dev-tool.scss +175 -0
- package/scss/components/_modal.scss +282 -0
- package/scss/components/_multiline-text.scss +20 -0
- package/scss/components/_nav.scss +45 -0
- package/scss/components/_overflow-tpl.scss +5 -0
- package/scss/components/_page.scss +198 -0
- package/scss/components/_pagination.scss +403 -0
- package/scss/components/_panel.scss +263 -0
- package/scss/components/_pdf_viewer.scss +47 -0
- package/scss/components/_picker-columns.scss +140 -0
- package/scss/components/_popover.scss +54 -0
- package/scss/components/_popoverable.scss +100 -0
- package/scss/components/_popup.scss +171 -0
- package/scss/components/_portlet.scss +51 -0
- package/scss/components/_print.scss +13 -0
- package/scss/components/_progress.scss +165 -0
- package/scss/components/_property.scss +47 -0
- package/scss/components/_pull-refresh.scss +30 -0
- package/scss/components/_quick-edit.scss +53 -0
- package/scss/components/_remark.scss +58 -0
- package/scss/components/_result-box.scss +380 -0
- package/scss/components/_search-box.scss +267 -0
- package/scss/components/_service.scss +3 -0
- package/scss/components/_shape.scss +19 -0
- package/scss/components/_signature.scss +98 -0
- package/scss/components/_slider.scss +27 -0
- package/scss/components/_sparkline.scss +18 -0
- package/scss/components/_spinner.scss +214 -0
- package/scss/components/_status.scss +118 -0
- package/scss/components/_steps.scss +481 -0
- package/scss/components/_table.scss +1234 -0
- package/scss/components/_table2.scss +1066 -0
- package/scss/components/_tabs.scss +1410 -0
- package/scss/components/_tag.scss +191 -0
- package/scss/components/_timeline.scss +572 -0
- package/scss/components/_toast.scss +342 -0
- package/scss/components/_tooltip.scss +340 -0
- package/scss/components/_tpl.scss +51 -0
- package/scss/components/_verificationCode.scss +33 -0
- package/scss/components/_video.scss +38 -0
- package/scss/components/_wizard.scss +287 -0
- package/scss/components/_wrapper.scss +26 -0
- package/scss/components/form/_chained-select.scss +10 -0
- package/scss/components/form/_checks.scss +433 -0
- package/scss/components/form/_city.scss +33 -0
- package/scss/components/form/_color.scss +148 -0
- package/scss/components/form/_combo.scss +360 -0
- package/scss/components/form/_date-range.scss +332 -0
- package/scss/components/form/_date.scss +807 -0
- package/scss/components/form/_editor.scss +139 -0
- package/scss/components/form/_excel.scss +150 -0
- package/scss/components/form/_fieldset.scss +202 -0
- package/scss/components/form/_file.scss +308 -0
- package/scss/components/form/_form.scss +936 -0
- package/scss/components/form/_group.scss +116 -0
- package/scss/components/form/_icon-picker.scss +113 -0
- package/scss/components/form/_icon-select.scss +245 -0
- package/scss/components/form/_image.scss +359 -0
- package/scss/components/form/_input-group.scss +213 -0
- package/scss/components/form/_input-table.scss +17 -0
- package/scss/components/form/_list.scss +225 -0
- package/scss/components/form/_location.scss +210 -0
- package/scss/components/form/_matrix.scss +7 -0
- package/scss/components/form/_nested-select.scss +149 -0
- package/scss/components/form/_number.scss +633 -0
- package/scss/components/form/_picker.scss +237 -0
- package/scss/components/form/_qr-code.scss +4 -0
- package/scss/components/form/_range.scss +438 -0
- package/scss/components/form/_rating.scss +94 -0
- package/scss/components/form/_repeat.scss +40 -0
- package/scss/components/form/_result-list.scss +98 -0
- package/scss/components/form/_rich-text.scss +163 -0
- package/scss/components/form/_select.scss +712 -0
- package/scss/components/form/_selection.scss +485 -0
- package/scss/components/form/_sub-form.scss +118 -0
- package/scss/components/form/_switch.scss +228 -0
- package/scss/components/form/_tag.scss +146 -0
- package/scss/components/form/_text.scss +508 -0
- package/scss/components/form/_textarea.scss +78 -0
- package/scss/components/form/_tinymce.scss +6 -0
- package/scss/components/form/_transfer.scss +624 -0
- package/scss/components/form/_tree-select.scss +47 -0
- package/scss/components/form/_tree.scss +458 -0
- package/scss/components/form/_user-select.scss +643 -0
- package/scss/components/react-datetime.scss +267 -0
- package/scss/helper/background/_background-color.md +131 -0
- package/scss/helper/background/_background-color.scss +214 -0
- package/scss/helper/border/_border-color.md +109 -0
- package/scss/helper/border/_border-color.scss +178 -0
- package/scss/helper/border/_border-radius.md +86 -0
- package/scss/helper/border/_border-radius.scss +152 -0
- package/scss/helper/border/_border-style.md +11 -0
- package/scss/helper/border/_border-style.scss +40 -0
- package/scss/helper/border/_border-width.md +31 -0
- package/scss/helper/border/_border-width.scss +72 -0
- package/scss/helper/box-alignment/_align-content.md +12 -0
- package/scss/helper/box-alignment/_align-content.scss +44 -0
- package/scss/helper/box-alignment/_align-items.md +11 -0
- package/scss/helper/box-alignment/_align-items.scss +41 -0
- package/scss/helper/box-alignment/_align-self.md +11 -0
- package/scss/helper/box-alignment/_align-self.scss +40 -0
- package/scss/helper/box-alignment/_justify-content.md +12 -0
- package/scss/helper/box-alignment/_justify-content.scss +44 -0
- package/scss/helper/box-alignment/_justify-items.md +11 -0
- package/scss/helper/box-alignment/_justify-items.scss +40 -0
- package/scss/helper/box-alignment/_justify-self.md +11 -0
- package/scss/helper/box-alignment/_justify-self.scss +40 -0
- package/scss/helper/box-alignment/_place-content.md +13 -0
- package/scss/helper/box-alignment/_place-content.scss +48 -0
- package/scss/helper/box-alignment/_place-items.md +11 -0
- package/scss/helper/box-alignment/_place-items.scss +40 -0
- package/scss/helper/box-alignment/_place-self.md +11 -0
- package/scss/helper/box-alignment/_place-self.scss +40 -0
- package/scss/helper/effect/_box-shadow.md +16 -0
- package/scss/helper/effect/_box-shadow.scss +74 -0
- package/scss/helper/effect/_opacity.md +21 -0
- package/scss/helper/effect/_opacity.scss +66 -0
- package/scss/helper/flex/_direction.md +10 -0
- package/scss/helper/flex/_direction.scss +41 -0
- package/scss/helper/flex/_flex.md +10 -0
- package/scss/helper/flex/_flex.scss +38 -0
- package/scss/helper/flex/_grow.md +8 -0
- package/scss/helper/flex/_grow.scss +28 -0
- package/scss/helper/flex/_order.md +20 -0
- package/scss/helper/flex/_order.scss +56 -0
- package/scss/helper/flex/_shrink.md +8 -0
- package/scss/helper/flex/_shrink.scss +27 -0
- package/scss/helper/flex/_wrap.md +9 -0
- package/scss/helper/flex/_wrap.scss +36 -0
- package/scss/helper/grid/_auto-columns.md +10 -0
- package/scss/helper/grid/_auto-columns.scss +38 -0
- package/scss/helper/grid/_auto-flow.md +10 -0
- package/scss/helper/grid/_auto-flow.scss +38 -0
- package/scss/helper/grid/_auto-rows.md +10 -0
- package/scss/helper/grid/_auto-rows.scss +38 -0
- package/scss/helper/grid/_column-start-end.md +48 -0
- package/scss/helper/grid/_column-start-end.scss +201 -0
- package/scss/helper/grid/_columns.md +19 -0
- package/scss/helper/grid/_columns.scss +74 -0
- package/scss/helper/grid/_gap.md +117 -0
- package/scss/helper/grid/_gap.scss +154 -0
- package/scss/helper/grid/_row-start-end.md +48 -0
- package/scss/helper/grid/_row-start-end.scss +201 -0
- package/scss/helper/grid/_rows.md +13 -0
- package/scss/helper/grid/_rows.scss +50 -0
- package/scss/helper/layout/_box-sizing.md +35 -0
- package/scss/helper/layout/_box-sizing.scss +51 -0
- package/scss/helper/layout/_clear.md +27 -0
- package/scss/helper/layout/_clear.scss +56 -0
- package/scss/helper/layout/_display.md +41 -0
- package/scss/helper/layout/_display.scss +82 -0
- package/scss/helper/layout/_float.md +47 -0
- package/scss/helper/layout/_float.scss +71 -0
- package/scss/helper/layout/_overflow.md +34 -0
- package/scss/helper/layout/_overflow.scss +85 -0
- package/scss/helper/layout/_position.md +27 -0
- package/scss/helper/layout/_position.scss +55 -0
- package/scss/helper/layout/_top-right-bottom-left.md +150 -0
- package/scss/helper/layout/_top-right-bottom-left.scss +292 -0
- package/scss/helper/layout/_visibility.md +21 -0
- package/scss/helper/layout/_visibility.scss +42 -0
- package/scss/helper/layout/_z-index.md +37 -0
- package/scss/helper/layout/_z-index.scss +67 -0
- package/scss/helper/sizing/_height.md +103 -0
- package/scss/helper/sizing/_height.scss +161 -0
- package/scss/helper/sizing/_width.md +109 -0
- package/scss/helper/sizing/_width.scss +174 -0
- package/scss/helper/spacing/_margin.md +527 -0
- package/scss/helper/spacing/_margin.scss +821 -0
- package/scss/helper/spacing/_padding.md +265 -0
- package/scss/helper/spacing/_padding.scss +394 -0
- package/scss/helper/spacing/_space-between.md +155 -0
- package/scss/helper/spacing/_space-between.scss +224 -0
- package/scss/helper/typography/_font-family.md +9 -0
- package/scss/helper/typography/_font-family.scss +28 -0
- package/scss/helper/typography/_font-size.md +19 -0
- package/scss/helper/typography/_font-size.scss +40 -0
- package/scss/helper/typography/_font-style.md +8 -0
- package/scss/helper/typography/_font-style.scss +31 -0
- package/scss/helper/typography/_font-weight.md +15 -0
- package/scss/helper/typography/_font-weight.scss +49 -0
- package/scss/helper/typography/_letter-spacing.md +12 -0
- package/scss/helper/typography/_letter-spacing.scss +43 -0
- package/scss/helper/typography/_line-height.md +20 -0
- package/scss/helper/typography/_line-height.scss +59 -0
- package/scss/helper/typography/_list-style-type.md +11 -0
- package/scss/helper/typography/_list-style-type.scss +43 -0
- package/scss/helper/typography/_text-align.md +10 -0
- package/scss/helper/typography/_text-align.scss +34 -0
- package/scss/helper/typography/_text-color.md +110 -0
- package/scss/helper/typography/_text-color.scss +184 -0
- package/scss/helper/typography/_text-decoration.md +9 -0
- package/scss/helper/typography/_text-decoration.scss +34 -0
- package/scss/helper/typography/_text-overflow.md +9 -0
- package/scss/helper/typography/_text-overflow.scss +40 -0
- package/scss/helper/typography/_text-transform.md +10 -0
- package/scss/helper/typography/_text-transform.scss +40 -0
- package/scss/helper/typography/_vertical-align.md +12 -0
- package/scss/helper/typography/_vertical-align.scss +44 -0
- package/scss/helper/typography/_whitespace.md +11 -0
- package/scss/helper/typography/_whitespace.scss +42 -0
- package/scss/helper/typography/_word-break.md +9 -0
- package/scss/helper/typography/_word-break.scss +36 -0
- package/scss/helper.scss +72 -0
- package/scss/layout/_aside.scss +361 -0
- package/scss/layout/_grid.scss +173 -0
- package/scss/layout/_hbox.scss +127 -0
- package/scss/layout/_header.scss +0 -0
- package/scss/layout/_layout.scss +492 -0
- package/scss/layout/_vbox.scss +38 -0
- package/scss/themes/_ang-variables.scss +224 -0
- package/scss/themes/_antd-variables.scss +238 -0
- package/scss/themes/_common.scss +157 -0
- package/scss/themes/_cxd-variables.scss +222 -0
- package/scss/themes/_dark-variables.scss +229 -0
- package/scss/themes/ang-ie11.scss +1 -0
- package/scss/themes/ang.scss +27 -0
- package/scss/themes/antd-ie11.scss +1 -0
- package/scss/themes/antd.scss +5 -0
- package/scss/themes/cxd-ie11.scss +1 -0
- package/scss/themes/cxd.scss +5 -0
- package/scss/themes/dark-ie11.scss +1 -0
- package/scss/themes/dark.scss +34 -0
- package/scss/themes/default.scss +2 -0
- package/scss/themes/extract-antd-color.py +27 -0
|
@@ -0,0 +1,454 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* amis-rev-ui v6.13.0
|
|
3
|
+
* Copyright 2018-2026 fex
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { __extends, __awaiter, __generator, __assign, __rest, __read, __decorate, __metadata } from 'tslib';
|
|
7
|
+
import { anyChanged, isExpression, parse, autobind, themeable, localeable, uncontrollable, resolveVariableAndFilterForAsync } from 'amis-rev-core';
|
|
8
|
+
import React__default from 'react';
|
|
9
|
+
import Editor, { FormulaEditor } from './Editor.js';
|
|
10
|
+
import Button from '../Button.js';
|
|
11
|
+
import { Icon } from '../icons.js';
|
|
12
|
+
import FinalModal from '../Modal.js';
|
|
13
|
+
import PopUp from '../PopUp.js';
|
|
14
|
+
import FormulaInput from './Input.js';
|
|
15
|
+
|
|
16
|
+
var InputSchemaType = [
|
|
17
|
+
'text',
|
|
18
|
+
'number',
|
|
19
|
+
'boolean',
|
|
20
|
+
'date',
|
|
21
|
+
'time',
|
|
22
|
+
'datetime',
|
|
23
|
+
'select',
|
|
24
|
+
'custom'
|
|
25
|
+
];
|
|
26
|
+
var FormulaPicker = /** @class */ (function (_super) {
|
|
27
|
+
__extends(FormulaPicker, _super);
|
|
28
|
+
function FormulaPicker(props) {
|
|
29
|
+
var _this = _super.call(this, props) || this;
|
|
30
|
+
_this.unmounted = false;
|
|
31
|
+
_this.props.onRef && _this.props.onRef(_this);
|
|
32
|
+
_this.state = {
|
|
33
|
+
isOpened: false,
|
|
34
|
+
value: _this.props.value,
|
|
35
|
+
editorValue: _this.value2EditorValue(_this.props),
|
|
36
|
+
isError: false,
|
|
37
|
+
variables: Array.isArray(props.variables) ? props.variables : []
|
|
38
|
+
};
|
|
39
|
+
return _this;
|
|
40
|
+
}
|
|
41
|
+
FormulaPicker.prototype.componentDidMount = function () {
|
|
42
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
43
|
+
var _a, variables, data, list, result;
|
|
44
|
+
return __generator(this, function (_b) {
|
|
45
|
+
switch (_b.label) {
|
|
46
|
+
case 0:
|
|
47
|
+
_a = this.props, variables = _a.variables, data = _a.data;
|
|
48
|
+
if (!(typeof variables === 'function')) return [3 /*break*/, 2];
|
|
49
|
+
return [4 /*yield*/, variables(this.props)];
|
|
50
|
+
case 1:
|
|
51
|
+
list = _b.sent();
|
|
52
|
+
this.setState({ variables: list });
|
|
53
|
+
return [3 /*break*/, 4];
|
|
54
|
+
case 2:
|
|
55
|
+
if (!(typeof variables === 'string' && isExpression(variables))) return [3 /*break*/, 4];
|
|
56
|
+
return [4 /*yield*/, resolveVariableAndFilterForAsync(variables, data, '|raw')];
|
|
57
|
+
case 3:
|
|
58
|
+
result = _b.sent();
|
|
59
|
+
this.setState({ variables: result });
|
|
60
|
+
_b.label = 4;
|
|
61
|
+
case 4:
|
|
62
|
+
this.buildFunctions();
|
|
63
|
+
return [2 /*return*/];
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
FormulaPicker.prototype.componentDidUpdate = function (prevProps) {
|
|
69
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
70
|
+
var value, _a, variables, data, list, result;
|
|
71
|
+
return __generator(this, function (_b) {
|
|
72
|
+
switch (_b.label) {
|
|
73
|
+
case 0:
|
|
74
|
+
value = this.props.value;
|
|
75
|
+
if (value !== prevProps.value && !this.state.isOpened) {
|
|
76
|
+
this.setState({
|
|
77
|
+
value: typeof value === 'string' || !this.isTextInput() ? value : '',
|
|
78
|
+
editorValue: this.value2EditorValue(this.props)
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
if (!anyChanged(['variables', 'data'], this.props, prevProps)) return [3 /*break*/, 5];
|
|
82
|
+
_a = this.props, variables = _a.variables, data = _a.data;
|
|
83
|
+
if (!(Array.isArray(variables) && variables !== prevProps.variables)) return [3 /*break*/, 1];
|
|
84
|
+
this.setState({ variables: variables });
|
|
85
|
+
return [3 /*break*/, 5];
|
|
86
|
+
case 1:
|
|
87
|
+
if (!(typeof variables === 'function')) return [3 /*break*/, 3];
|
|
88
|
+
return [4 /*yield*/, variables(this.props)];
|
|
89
|
+
case 2:
|
|
90
|
+
list = _b.sent();
|
|
91
|
+
this.setState({ variables: list });
|
|
92
|
+
return [3 /*break*/, 5];
|
|
93
|
+
case 3:
|
|
94
|
+
if (!(typeof variables === 'string' && isExpression(variables))) return [3 /*break*/, 5];
|
|
95
|
+
return [4 /*yield*/, resolveVariableAndFilterForAsync(variables, data, '|raw')];
|
|
96
|
+
case 4:
|
|
97
|
+
result = _b.sent();
|
|
98
|
+
this.setState({ variables: result });
|
|
99
|
+
_b.label = 5;
|
|
100
|
+
case 5:
|
|
101
|
+
if (prevProps.functions !== this.props.functions) {
|
|
102
|
+
this.buildFunctions();
|
|
103
|
+
}
|
|
104
|
+
return [2 /*return*/];
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
};
|
|
109
|
+
FormulaPicker.prototype.componentWillUnmount = function () {
|
|
110
|
+
this.unmounted = true;
|
|
111
|
+
};
|
|
112
|
+
FormulaPicker.prototype.buildFunctions = function () {
|
|
113
|
+
return __awaiter(this, arguments, void 0, function (functions, setState) {
|
|
114
|
+
var functionList;
|
|
115
|
+
if (functions === void 0) { functions = this.props.functions; }
|
|
116
|
+
if (setState === void 0) { setState = true; }
|
|
117
|
+
return __generator(this, function (_a) {
|
|
118
|
+
switch (_a.label) {
|
|
119
|
+
case 0: return [4 /*yield*/, FormulaEditor.buildFunctions(functions, this.props.functionsFilter)];
|
|
120
|
+
case 1:
|
|
121
|
+
functionList = _a.sent();
|
|
122
|
+
if (this.unmounted) {
|
|
123
|
+
return [2 /*return*/];
|
|
124
|
+
}
|
|
125
|
+
if (!setState) {
|
|
126
|
+
return [2 /*return*/, functionList];
|
|
127
|
+
}
|
|
128
|
+
this.setState({
|
|
129
|
+
functions: functionList
|
|
130
|
+
});
|
|
131
|
+
return [2 /*return*/];
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
};
|
|
136
|
+
FormulaPicker.prototype.value2EditorValue = function (props) {
|
|
137
|
+
var value = props.value, mixedMode = props.mixedMode; props.inputSettings;
|
|
138
|
+
if (mixedMode &&
|
|
139
|
+
typeof value === 'string' &&
|
|
140
|
+
/^\s*\$\{([\s\S]+)\}\s*$/.test(value)) {
|
|
141
|
+
return RegExp.$1;
|
|
142
|
+
}
|
|
143
|
+
else if (typeof value !== 'string') {
|
|
144
|
+
var editorValue = '';
|
|
145
|
+
try {
|
|
146
|
+
editorValue = JSON.stringify(value);
|
|
147
|
+
}
|
|
148
|
+
catch (error) { }
|
|
149
|
+
return editorValue;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
return value
|
|
153
|
+
? mixedMode
|
|
154
|
+
? isExpression(value)
|
|
155
|
+
? "`".concat(value.replace(/`/g, '\\`'), "`")
|
|
156
|
+
: JSON.stringify(value)
|
|
157
|
+
: value
|
|
158
|
+
: '';
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
FormulaPicker.prototype.isTextInput = function () {
|
|
162
|
+
var inputSettings = this.props.inputSettings;
|
|
163
|
+
return (!inputSettings ||
|
|
164
|
+
(inputSettings === null || inputSettings === void 0 ? void 0 : inputSettings.type) === 'text' ||
|
|
165
|
+
!InputSchemaType.includes(inputSettings === null || inputSettings === void 0 ? void 0 : inputSettings.type));
|
|
166
|
+
};
|
|
167
|
+
FormulaPicker.prototype.handleConfirm = function () {
|
|
168
|
+
var _a, _b;
|
|
169
|
+
var value = this.state.value;
|
|
170
|
+
if (this.props.onConfirm) {
|
|
171
|
+
this.props.onConfirm(value);
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
(_b = (_a = this.props).onChange) === null || _b === void 0 ? void 0 : _b.call(_a, value);
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
FormulaPicker.prototype.handleInputChange = function (value) {
|
|
178
|
+
var _this = this;
|
|
179
|
+
this.setState({ value: value }, function () { return _this.handleConfirm(); });
|
|
180
|
+
};
|
|
181
|
+
FormulaPicker.prototype.handleInputGroupChange = function (e) {
|
|
182
|
+
var onChange = this.props.onChange;
|
|
183
|
+
onChange && onChange(e.currentTarget.value);
|
|
184
|
+
};
|
|
185
|
+
FormulaPicker.prototype.handleEditorChange = function (value) {
|
|
186
|
+
this.setState({
|
|
187
|
+
editorValue: value,
|
|
188
|
+
isError: false
|
|
189
|
+
});
|
|
190
|
+
};
|
|
191
|
+
FormulaPicker.prototype.handleEditorConfirm = function () {
|
|
192
|
+
var _a, _b;
|
|
193
|
+
var _c = this.props; _c.translate; var inputSettings = _c.inputSettings;
|
|
194
|
+
var editorValue = this.state.editorValue;
|
|
195
|
+
var ast;
|
|
196
|
+
try {
|
|
197
|
+
ast = parse(editorValue, {
|
|
198
|
+
// mixedMode 弹窗中的一定是表达式
|
|
199
|
+
evalMode: this.props.mixedMode ? true : this.props.evalMode,
|
|
200
|
+
allowFilter: false
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
this.setState({ isError: (_a = error === null || error === void 0 ? void 0 : error.message) !== null && _a !== void 0 ? _a : true });
|
|
205
|
+
return;
|
|
206
|
+
}
|
|
207
|
+
if ((inputSettings === null || inputSettings === void 0 ? void 0 : inputSettings.type) &&
|
|
208
|
+
['boolean', 'number'].includes(inputSettings === null || inputSettings === void 0 ? void 0 : inputSettings.type)) {
|
|
209
|
+
var result = editorValue;
|
|
210
|
+
// const schemaType = inputSettings?.type;
|
|
211
|
+
if (ast.type === 'literal' || ast.type === 'string') {
|
|
212
|
+
result = (_b = ast.value) !== null && _b !== void 0 ? _b : '';
|
|
213
|
+
}
|
|
214
|
+
this.setState({ isError: false });
|
|
215
|
+
return this.confirm(result);
|
|
216
|
+
}
|
|
217
|
+
return this.confirm(editorValue, ast);
|
|
218
|
+
};
|
|
219
|
+
FormulaPicker.prototype.confirm = function (value, ast) {
|
|
220
|
+
var _this = this;
|
|
221
|
+
var mixedMode = this.props.mixedMode;
|
|
222
|
+
var stateOnConfirm = this.state.onConfirm;
|
|
223
|
+
var validate = this.validate(value);
|
|
224
|
+
if (validate === true) {
|
|
225
|
+
var result = value;
|
|
226
|
+
if (mixedMode && typeof value === 'string') {
|
|
227
|
+
result =
|
|
228
|
+
(ast === null || ast === void 0 ? void 0 : ast.type) === 'string'
|
|
229
|
+
? ast.value
|
|
230
|
+
: (ast === null || ast === void 0 ? void 0 : ast.type) === 'template' &&
|
|
231
|
+
ast.body.length === 1 &&
|
|
232
|
+
ast.body[0].type === 'template_raw'
|
|
233
|
+
? ast.body[0].value
|
|
234
|
+
: "${".concat(value, "}");
|
|
235
|
+
}
|
|
236
|
+
this.setState({ value: result, onConfirm: undefined }, function () {
|
|
237
|
+
_this.close(undefined, function () {
|
|
238
|
+
stateOnConfirm
|
|
239
|
+
? stateOnConfirm(_this.state.value)
|
|
240
|
+
: _this.handleConfirm();
|
|
241
|
+
});
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
this.setState({ isError: validate });
|
|
246
|
+
}
|
|
247
|
+
};
|
|
248
|
+
FormulaPicker.prototype.handleClick = function () {
|
|
249
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
250
|
+
return __generator(this, function (_a) {
|
|
251
|
+
return [2 /*return*/, this.openEditor(this.value2EditorValue(this.props))];
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
};
|
|
255
|
+
FormulaPicker.prototype.openEditor = function (editorValue, onConfirm) {
|
|
256
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
257
|
+
var state, _a, _b;
|
|
258
|
+
var _c, _d;
|
|
259
|
+
return __generator(this, function (_e) {
|
|
260
|
+
switch (_e.label) {
|
|
261
|
+
case 0:
|
|
262
|
+
_a = [{}];
|
|
263
|
+
return [4 /*yield*/, ((_d = (_c = this.props).onPickerOpen) === null || _d === void 0 ? void 0 : _d.call(_c, this.props))];
|
|
264
|
+
case 1:
|
|
265
|
+
state = __assign.apply(void 0, [__assign.apply(void 0, _a.concat([(_e.sent())])), { editorValue: editorValue, isOpened: true, onConfirm: onConfirm }]);
|
|
266
|
+
if (!state.functions) return [3 /*break*/, 3];
|
|
267
|
+
_b = state;
|
|
268
|
+
return [4 /*yield*/, this.buildFunctions(state.functions, false)];
|
|
269
|
+
case 2:
|
|
270
|
+
_b.functions = _e.sent();
|
|
271
|
+
_e.label = 3;
|
|
272
|
+
case 3:
|
|
273
|
+
this.setState(state);
|
|
274
|
+
return [2 /*return*/];
|
|
275
|
+
}
|
|
276
|
+
});
|
|
277
|
+
});
|
|
278
|
+
};
|
|
279
|
+
FormulaPicker.prototype.close = function (e, callback) {
|
|
280
|
+
this.setState({
|
|
281
|
+
isOpened: false,
|
|
282
|
+
isError: false
|
|
283
|
+
}, function () {
|
|
284
|
+
if (callback) {
|
|
285
|
+
callback();
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
};
|
|
290
|
+
FormulaPicker.prototype.updateState = function (state) {
|
|
291
|
+
if (state === void 0) { state = {}; }
|
|
292
|
+
state.isOpened; var rest = __rest(state, ["isOpened"]);
|
|
293
|
+
this.setState(__assign(__assign({}, this.state), rest));
|
|
294
|
+
};
|
|
295
|
+
FormulaPicker.prototype.validate = function (value) {
|
|
296
|
+
var _a = this.props, __ = _a.translate, inputSettings = _a.inputSettings;
|
|
297
|
+
/** 处理非文本输入场景 */
|
|
298
|
+
if (inputSettings && !this.isTextInput()) {
|
|
299
|
+
var schemaType = inputSettings === null || inputSettings === void 0 ? void 0 : inputSettings.type;
|
|
300
|
+
var errorMsg = __('FormulaEditor.invalidValue');
|
|
301
|
+
/** 变量类型 */
|
|
302
|
+
if (typeof value === 'string') {
|
|
303
|
+
return true;
|
|
304
|
+
}
|
|
305
|
+
if (['number', 'boolean'].includes(schemaType)) {
|
|
306
|
+
return typeof value === schemaType ? true : errorMsg;
|
|
307
|
+
}
|
|
308
|
+
else if (['text', 'date', 'time', 'datetime'].includes(schemaType)) {
|
|
309
|
+
return typeof value === 'string' ? true : errorMsg;
|
|
310
|
+
}
|
|
311
|
+
else if (schemaType === 'select' && inputSettings.multiple) {
|
|
312
|
+
return Array.isArray(value) ? true : errorMsg;
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
return true;
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
try {
|
|
319
|
+
value &&
|
|
320
|
+
parse(value, {
|
|
321
|
+
// mixedMode 值是模版, 要 ${} 包裹表达式
|
|
322
|
+
evalMode: this.props.mixedMode ? false : this.props.evalMode,
|
|
323
|
+
allowFilter: false
|
|
324
|
+
});
|
|
325
|
+
return true;
|
|
326
|
+
}
|
|
327
|
+
catch (e) {
|
|
328
|
+
if (/\s(\d+:\d+)$/.test(e.message)) {
|
|
329
|
+
var _b = __read(/\s(\d+:\d+)$/.exec(e.message) || [], 2), position = _b[1];
|
|
330
|
+
return position;
|
|
331
|
+
}
|
|
332
|
+
return e.message;
|
|
333
|
+
}
|
|
334
|
+
};
|
|
335
|
+
FormulaPicker.prototype.render = function () {
|
|
336
|
+
var _a, _b, _c;
|
|
337
|
+
var _d, _e, _f, _g, _h, _j, _k, _l;
|
|
338
|
+
var _m = this.props, cx = _m.classnames, __ = _m.translate, disabled = _m.disabled, className = _m.className, style = _m.style; _m.onChange; _m.size; var borderMode = _m.borderMode, placeholder = _m.placeholder, _o = _m.mode, mode = _o === void 0 ? 'input-button' : _o, btnLabel = _m.btnLabel, level = _m.level, btnSize = _m.btnSize, icon = _m.icon, title = _m.title, clearable = _m.clearable, functions = _m.functions, children = _m.children, variableMode = _m.variableMode, mixedMode = _m.mixedMode, evalMode = _m.evalMode, popOverContainer = _m.popOverContainer, mobileUI = _m.mobileUI, inputSettings = _m.inputSettings, customInputRender = _m.customInputRender, rest = __rest(_m, ["classnames", "translate", "disabled", "className", "style", "onChange", "size", "borderMode", "placeholder", "mode", "btnLabel", "level", "btnSize", "icon", "title", "clearable", "functions", "children", "variableMode", "mixedMode", "evalMode", "popOverContainer", "mobileUI", "inputSettings", "customInputRender"]);
|
|
339
|
+
var _p = this.state, isOpened = _p.isOpened, value = _p.value, editorValue = _p.editorValue, isError = _p.isError;
|
|
340
|
+
var iconElement = React__default.createElement(Icon, { cx: cx, icon: icon, className: "Icon" });
|
|
341
|
+
return (React__default.createElement(React__default.Fragment, null,
|
|
342
|
+
children ? (children({
|
|
343
|
+
isOpened: this.state.isOpened,
|
|
344
|
+
onClick: this.handleClick,
|
|
345
|
+
setState: this.updateState,
|
|
346
|
+
value: value,
|
|
347
|
+
onChange: this.handleInputChange,
|
|
348
|
+
disabled: disabled
|
|
349
|
+
})) : (React__default.createElement("div", { className: cx('FormulaPicker', mode === 'input-group' ? 'is-input-group' : '', {
|
|
350
|
+
'FormulaPicker--text': this.isTextInput()
|
|
351
|
+
}, className), style: style },
|
|
352
|
+
mode === 'button' && (React__default.createElement(Button, { className: cx('FormulaPicker-action', 'w-full'), level: level, size: btnSize, active: !!value, onClick: this.handleClick },
|
|
353
|
+
iconElement ? (React__default.cloneElement(iconElement, {
|
|
354
|
+
className: cx((_e = (_d = iconElement === null || iconElement === void 0 ? void 0 : iconElement.props) === null || _d === void 0 ? void 0 : _d.className) !== null && _e !== void 0 ? _e : '', 'FormulaPicker-icon', (_a = {},
|
|
355
|
+
_a['is-filled'] = !!value,
|
|
356
|
+
_a))
|
|
357
|
+
})) : (React__default.createElement(Icon, { icon: "function", className: cx('FormulaPicker-icon', 'icon', (_b = {},
|
|
358
|
+
_b['is-filled'] = !!value,
|
|
359
|
+
_b)) })),
|
|
360
|
+
React__default.createElement("span", { className: cx('FormulaPicker-label') }, __(btnLabel || 'FormulaEditor.btnLabel')))),
|
|
361
|
+
mode === 'input-button' && (React__default.createElement(React__default.Fragment, null,
|
|
362
|
+
React__default.createElement(FormulaInput, { className: cx('FormulaPicker-input', isOpened ? 'is-active' : '', !!isError ? 'is-error' : ''), inputSettings: inputSettings, customInputRender: customInputRender, clearable: clearable, evalMode: mixedMode ? false : evalMode, variables: this.state.variables, functions: (_f = this.state.functions) !== null && _f !== void 0 ? _f : functions, value: value, onChange: this.handleInputChange, disabled: disabled, borderMode: borderMode, placeholder: placeholder }),
|
|
363
|
+
React__default.createElement(Button, { className: cx('FormulaPicker-action'), onClick: this.handleClick },
|
|
364
|
+
React__default.createElement(Icon, { icon: "function", className: cx('FormulaPicker-icon', 'icon', (_c = {},
|
|
365
|
+
_c['is-filled'] = !!value,
|
|
366
|
+
_c)) })))),
|
|
367
|
+
mode === 'input-group' && (React__default.createElement(React__default.Fragment, null,
|
|
368
|
+
React__default.createElement(FormulaInput, { className: cx('FormulaPicker-input', isOpened ? 'is-active' : '', !!isError ? 'is-error' : ''), inputSettings: inputSettings, customInputRender: customInputRender, clearable: clearable, evalMode: mixedMode ? false : evalMode, variables: this.state.variables, functions: (_g = this.state.functions) !== null && _g !== void 0 ? _g : functions, value: value, onChange: this.handleInputChange, disabled: disabled, borderMode: borderMode, placeholder: placeholder }),
|
|
369
|
+
React__default.createElement("a", { className: cx("FormulaPicker-toggler"), onClick: this.handleClick },
|
|
370
|
+
React__default.createElement(Icon, { icon: "function", className: "icon" })))))),
|
|
371
|
+
mobileUI ? (React__default.createElement(PopUp, { className: cx("FormulaPicker-popup"), isShow: this.state.isOpened, showConfirm: true, onHide: this.close, onConfirm: this.handleEditorConfirm, container: popOverContainer },
|
|
372
|
+
React__default.createElement("div", { className: cx('FormulaPicker-popup-inner') },
|
|
373
|
+
React__default.createElement(Editor, __assign({}, rest, { evalMode: mixedMode ? true : evalMode, variables: this.state.variables, functions: (_h = this.state.functions) !== null && _h !== void 0 ? _h : functions, variableMode: (_j = this.state.variableMode) !== null && _j !== void 0 ? _j : variableMode, value: editorValue, onChange: this.handleEditorChange, selfVariableName: this.props.selfVariableName })),
|
|
374
|
+
!!isError ? (React__default.createElement("div", { className: cx('Dialog-info'), key: "info" },
|
|
375
|
+
React__default.createElement("span", { className: cx('Dialog-error') }, __('FormulaEditor.invalidData', { err: isError })))) : null))) : (React__default.createElement(FinalModal, { size: "lg", closeOnEsc: true, show: this.state.isOpened, onHide: this.close, container: popOverContainer },
|
|
376
|
+
React__default.createElement(FinalModal.Header, { onClose: this.close, className: "font-bold" }, __(title || 'FormulaEditor.title')),
|
|
377
|
+
React__default.createElement(FinalModal.Body, null,
|
|
378
|
+
React__default.createElement(Editor, __assign({}, rest, { evalMode: mixedMode ? true : evalMode, variables: this.state.variables, functions: (_k = this.state.functions) !== null && _k !== void 0 ? _k : functions, variableMode: (_l = this.state.variableMode) !== null && _l !== void 0 ? _l : variableMode, value: editorValue, onChange: this.handleEditorChange, selfVariableName: this.props.selfVariableName }))),
|
|
379
|
+
React__default.createElement(FinalModal.Footer, null,
|
|
380
|
+
!!isError ? (React__default.createElement("div", { className: cx('Dialog-info'), key: "info" },
|
|
381
|
+
React__default.createElement("span", { className: cx('Dialog-error') }, __('FormulaEditor.invalidData', { err: isError })))) : null,
|
|
382
|
+
React__default.createElement(Button, { onClick: this.close }, __('cancel')),
|
|
383
|
+
React__default.createElement(Button, { onClick: this.handleEditorConfirm, level: "primary" }, __('confirm')))))));
|
|
384
|
+
};
|
|
385
|
+
FormulaPicker.defaultProps = {
|
|
386
|
+
evalMode: true
|
|
387
|
+
};
|
|
388
|
+
__decorate([
|
|
389
|
+
autobind,
|
|
390
|
+
__metadata("design:type", Function),
|
|
391
|
+
__metadata("design:paramtypes", []),
|
|
392
|
+
__metadata("design:returntype", void 0)
|
|
393
|
+
], FormulaPicker.prototype, "handleConfirm", null);
|
|
394
|
+
__decorate([
|
|
395
|
+
autobind,
|
|
396
|
+
__metadata("design:type", Function),
|
|
397
|
+
__metadata("design:paramtypes", [String]),
|
|
398
|
+
__metadata("design:returntype", void 0)
|
|
399
|
+
], FormulaPicker.prototype, "handleInputChange", null);
|
|
400
|
+
__decorate([
|
|
401
|
+
autobind,
|
|
402
|
+
__metadata("design:type", Function),
|
|
403
|
+
__metadata("design:paramtypes", [Object]),
|
|
404
|
+
__metadata("design:returntype", void 0)
|
|
405
|
+
], FormulaPicker.prototype, "handleInputGroupChange", null);
|
|
406
|
+
__decorate([
|
|
407
|
+
autobind,
|
|
408
|
+
__metadata("design:type", Function),
|
|
409
|
+
__metadata("design:paramtypes", [String]),
|
|
410
|
+
__metadata("design:returntype", void 0)
|
|
411
|
+
], FormulaPicker.prototype, "handleEditorChange", null);
|
|
412
|
+
__decorate([
|
|
413
|
+
autobind,
|
|
414
|
+
__metadata("design:type", Function),
|
|
415
|
+
__metadata("design:paramtypes", []),
|
|
416
|
+
__metadata("design:returntype", void 0)
|
|
417
|
+
], FormulaPicker.prototype, "handleEditorConfirm", null);
|
|
418
|
+
__decorate([
|
|
419
|
+
autobind,
|
|
420
|
+
__metadata("design:type", Function),
|
|
421
|
+
__metadata("design:paramtypes", []),
|
|
422
|
+
__metadata("design:returntype", Promise)
|
|
423
|
+
], FormulaPicker.prototype, "handleClick", null);
|
|
424
|
+
__decorate([
|
|
425
|
+
autobind,
|
|
426
|
+
__metadata("design:type", Function),
|
|
427
|
+
__metadata("design:paramtypes", [String, Function]),
|
|
428
|
+
__metadata("design:returntype", Promise)
|
|
429
|
+
], FormulaPicker.prototype, "openEditor", null);
|
|
430
|
+
__decorate([
|
|
431
|
+
autobind,
|
|
432
|
+
__metadata("design:type", Function),
|
|
433
|
+
__metadata("design:paramtypes", [Object, Function]),
|
|
434
|
+
__metadata("design:returntype", void 0)
|
|
435
|
+
], FormulaPicker.prototype, "close", null);
|
|
436
|
+
__decorate([
|
|
437
|
+
autobind,
|
|
438
|
+
__metadata("design:type", Function),
|
|
439
|
+
__metadata("design:paramtypes", [Object]),
|
|
440
|
+
__metadata("design:returntype", void 0)
|
|
441
|
+
], FormulaPicker.prototype, "updateState", null);
|
|
442
|
+
__decorate([
|
|
443
|
+
autobind,
|
|
444
|
+
__metadata("design:type", Function),
|
|
445
|
+
__metadata("design:paramtypes", [String]),
|
|
446
|
+
__metadata("design:returntype", void 0)
|
|
447
|
+
], FormulaPicker.prototype, "validate", null);
|
|
448
|
+
return FormulaPicker;
|
|
449
|
+
}(React__default.Component));
|
|
450
|
+
var FormulaPicker$1 = themeable(localeable(uncontrollable(FormulaPicker, {
|
|
451
|
+
value: 'onChange'
|
|
452
|
+
})));
|
|
453
|
+
|
|
454
|
+
export { FormulaPicker, InputSchemaType, FormulaPicker$1 as default };
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* amis-rev-ui v6.13.0
|
|
3
|
+
* Copyright 2018-2026 fex
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { __read, __assign } from 'tslib';
|
|
7
|
+
import React__default from 'react';
|
|
8
|
+
import { themeable, mapTree, filterTree } from 'amis-rev-core';
|
|
9
|
+
import GroupedSelection from '../GroupedSelection.js';
|
|
10
|
+
import ThemedTabs, { Tab } from '../Tabs.js';
|
|
11
|
+
import TreeSelection from '../TreeSelection.js';
|
|
12
|
+
import SearchBox from '../SearchBox.js';
|
|
13
|
+
import { Icon } from '../icons.js';
|
|
14
|
+
import { Badge } from '../Badge.js';
|
|
15
|
+
import { PopOverContainer } from '../PopOverContainer.js';
|
|
16
|
+
import { matchSorter } from 'match-sorter';
|
|
17
|
+
import TooltipWrapper from '../TooltipWrapper.js';
|
|
18
|
+
|
|
19
|
+
// 数组成员读取
|
|
20
|
+
var memberOpers = [
|
|
21
|
+
{
|
|
22
|
+
label: '取列值',
|
|
23
|
+
value: 'ARRAYMAP(${arr}, item => item.${member})',
|
|
24
|
+
description: '取当前列的所有值(数组)'
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
label: '取条件值',
|
|
28
|
+
value: 'ARRAYFILTER(ARRAYMAP(${arr}, item => item.${member}), item => item === 条件)',
|
|
29
|
+
description: '取当前列中符合配置条件的值(数组)'
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
label: '取表值',
|
|
33
|
+
value: 'ARRAYFILTER(${arr}, item => item.${member} === 条件)',
|
|
34
|
+
description: '取列表中符合配置条件的值(数组)'
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
label: '计数',
|
|
38
|
+
value: 'COUNT(ARRAYFILTER(${arr}, item => item.${member} === 条件))',
|
|
39
|
+
description: '统计表中符合配置条件的值的总数'
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
label: '去重计数',
|
|
43
|
+
value: 'COUNT(UNIQ(${arr}, item.${member}))',
|
|
44
|
+
description: '对表中当前值进行去重,并统计去重后的值的数量',
|
|
45
|
+
simple: true
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
label: '求和',
|
|
49
|
+
value: 'SUM(ARRAYMAP(${arr}, item => item.${member}))',
|
|
50
|
+
description: '求当前列的所有值之和',
|
|
51
|
+
simple: true
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
label: '平均值',
|
|
55
|
+
value: 'AVG(ARRAYMAP(${arr}, item => item.${member}))',
|
|
56
|
+
description: '求当前列的平均值',
|
|
57
|
+
simple: true
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
label: '最大值',
|
|
61
|
+
value: 'MAX(ARRAYMAP(${arr}, item => item.${member}))',
|
|
62
|
+
description: '取当前列的最大值',
|
|
63
|
+
simple: true
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
label: '最小值',
|
|
67
|
+
value: 'MIN(ARRAYMAP(${arr}, item => item.${member}))',
|
|
68
|
+
description: '取当前列的最小值',
|
|
69
|
+
simple: true
|
|
70
|
+
}
|
|
71
|
+
];
|
|
72
|
+
function VariableList(props) {
|
|
73
|
+
var variableListRef = React__default.useRef(null);
|
|
74
|
+
var className = props.className, cx = props.classnames, _a = props.tabsMode, tabsMode = _a === void 0 ? 'line' : _a, themePrefix = props.classPrefix, itemClassName = props.itemClassName, selectMode = props.selectMode, onSelect = props.onSelect, placeholderRender = props.placeholderRender, selfVariableName = props.selfVariableName, expandTree = props.expandTree, simplifyMemberOprs = props.simplifyMemberOprs, popOverContainer = props.popOverContainer;
|
|
75
|
+
var _b = __read(React__default.useState([]), 2), variables = _b[0], setVariables = _b[1];
|
|
76
|
+
var _c = __read(React__default.useState([]), 2), filterVars = _c[0], setFilterVars = _c[1];
|
|
77
|
+
var classPrefix = "".concat(themePrefix, "FormulaEditor-VariableList");
|
|
78
|
+
React__default.useEffect(function () {
|
|
79
|
+
// 追加path,用于分级高亮
|
|
80
|
+
var list = mapTree(props.data, function (item, key, level, paths) {
|
|
81
|
+
var _a;
|
|
82
|
+
var path = paths === null || paths === void 0 ? void 0 : paths.reduce(function (prev, item) {
|
|
83
|
+
var _a;
|
|
84
|
+
return !item.value
|
|
85
|
+
? prev
|
|
86
|
+
: "".concat(prev).concat(prev ? '.' : '').concat((_a = item.label) !== null && _a !== void 0 ? _a : item.value);
|
|
87
|
+
}, '');
|
|
88
|
+
return __assign(__assign(__assign({}, item), { path: "".concat(path).concat(path ? '.' : '').concat(item.label) }), (item.isMember || paths.some(function (item) { return item.isMember; })
|
|
89
|
+
? {
|
|
90
|
+
memberDepth: (_a = paths === null || paths === void 0 ? void 0 : paths.filter(function (item) { return item.type === 'array'; })) === null || _a === void 0 ? void 0 : _a.length
|
|
91
|
+
}
|
|
92
|
+
: {}));
|
|
93
|
+
});
|
|
94
|
+
setVariables(list);
|
|
95
|
+
setFilterVars(list);
|
|
96
|
+
}, [props.data]);
|
|
97
|
+
var itemRender = props.itemRender && typeof props.itemRender === 'function'
|
|
98
|
+
? props.itemRender
|
|
99
|
+
: function (option, states) {
|
|
100
|
+
var _a;
|
|
101
|
+
return (React__default.createElement("div", { key: states.index },
|
|
102
|
+
React__default.createElement("div", { className: cx("".concat(classPrefix, "-item"), itemClassName) },
|
|
103
|
+
option.label &&
|
|
104
|
+
selfVariableName &&
|
|
105
|
+
option.value === selfVariableName && (React__default.createElement(Badge, { classnames: cx, badge: {
|
|
106
|
+
mode: 'text',
|
|
107
|
+
text: 'self',
|
|
108
|
+
offset: [15, 2]
|
|
109
|
+
} },
|
|
110
|
+
React__default.createElement("label", null, option.label))),
|
|
111
|
+
option.memberDepth === undefined &&
|
|
112
|
+
option.label &&
|
|
113
|
+
(!selfVariableName || option.value !== selfVariableName) && (React__default.createElement(TooltipWrapper, { tooltip: (_a = option.description) !== null && _a !== void 0 ? _a : option.label, tooltipTheme: "dark" },
|
|
114
|
+
React__default.createElement("label", null, option.label))),
|
|
115
|
+
option.memberDepth !== undefined &&
|
|
116
|
+
option.label &&
|
|
117
|
+
(!selfVariableName || option.value !== selfVariableName) ? (option.memberDepth < 2 ? (React__default.createElement(PopOverContainer, { popOverContainer: popOverContainer ||
|
|
118
|
+
(function () {
|
|
119
|
+
return document.querySelector(".".concat(cx('FormulaPicker-Modal')));
|
|
120
|
+
}), popOverRender: function (_a) {
|
|
121
|
+
var onClose = _a.onClose;
|
|
122
|
+
return (React__default.createElement("ul", { className: cx("".concat(classPrefix, "-item-oper")) }, memberOpers
|
|
123
|
+
.filter(function (item) { return !simplifyMemberOprs || item.simple; })
|
|
124
|
+
.map(function (item, i) {
|
|
125
|
+
return (React__default.createElement(TooltipWrapper, { key: i, tooltip: item.description, tooltipTheme: "dark" },
|
|
126
|
+
React__default.createElement("li", { key: i, onClick: function () {
|
|
127
|
+
return handleMemberClick(__assign(__assign({}, item), { isMember: true }), option, onClose);
|
|
128
|
+
} },
|
|
129
|
+
React__default.createElement("span", null, item.label))));
|
|
130
|
+
})));
|
|
131
|
+
} }, function (_a) {
|
|
132
|
+
var _b;
|
|
133
|
+
var onClick = _a.onClick; _a.ref; _a.isOpened;
|
|
134
|
+
return (React__default.createElement(TooltipWrapper, { tooltip: (_b = option.description) !== null && _b !== void 0 ? _b : option.label, tooltipTheme: "dark" },
|
|
135
|
+
React__default.createElement(React__default.Fragment, null,
|
|
136
|
+
React__default.createElement("label", { onClick: onClick }, option.label),
|
|
137
|
+
React__default.createElement(Icon, { onClick: onClick, icon: "ellipsis-v", className: "icon" }))));
|
|
138
|
+
})) : (React__default.createElement("label", null, option.label))) : null,
|
|
139
|
+
(option === null || option === void 0 ? void 0 : option.tag) ? (React__default.createElement("span", { className: cx("".concat(classPrefix, "-item-tag")) }, option.tag)) : null)));
|
|
140
|
+
};
|
|
141
|
+
function handleMemberClick(item, option, onClose) {
|
|
142
|
+
// todo:暂时只提供一层的快捷操作
|
|
143
|
+
var lastPointIdx = option.value.lastIndexOf('.');
|
|
144
|
+
// const firstPointIdx = option.value.indexOf('.');
|
|
145
|
+
var arr = option.value.substring(0, lastPointIdx);
|
|
146
|
+
var member = option.value.substring(lastPointIdx + 1);
|
|
147
|
+
var value = item.value
|
|
148
|
+
.replace('${arr}', arr)
|
|
149
|
+
.replace('${member}', member);
|
|
150
|
+
onClose === null || onClose === void 0 ? void 0 : onClose();
|
|
151
|
+
onSelect === null || onSelect === void 0 ? void 0 : onSelect(__assign(__assign({}, item), { label: value, value: value }));
|
|
152
|
+
}
|
|
153
|
+
function onSearch(term) {
|
|
154
|
+
term = term.trim();
|
|
155
|
+
var tree = filterTree(variables, function (i, key, level, paths) {
|
|
156
|
+
return !!((Array.isArray(i.children) && i.children.length) ||
|
|
157
|
+
!!matchSorter([i].concat(paths), term, {
|
|
158
|
+
keys: ['label', 'value'],
|
|
159
|
+
threshold: matchSorter.rankings.CONTAINS
|
|
160
|
+
}).length);
|
|
161
|
+
}, 1, true);
|
|
162
|
+
setFilterVars(!term ? variables : tree);
|
|
163
|
+
}
|
|
164
|
+
function renderSearchBox() {
|
|
165
|
+
return (React__default.createElement("div", { className: cx('FormulaEditor-VariableList-searchBox') },
|
|
166
|
+
React__default.createElement(SearchBox, { mini: false, onSearch: onSearch, mobileUI: props.mobileUI })));
|
|
167
|
+
}
|
|
168
|
+
function handleChange(item) {
|
|
169
|
+
// 允许所有有 value 的元素被点击插入
|
|
170
|
+
// 注释掉原来的阻止逻辑,允许 isMember 元素直接点击
|
|
171
|
+
// if (item.isMember || item.memberDepth !== undefined) {
|
|
172
|
+
// return;
|
|
173
|
+
// }
|
|
174
|
+
onSelect === null || onSelect === void 0 ? void 0 : onSelect(item);
|
|
175
|
+
}
|
|
176
|
+
return (React__default.createElement("div", { className: cx(className, 'FormulaEditor-VariableList', selectMode && "FormulaEditor-VariableList-".concat(selectMode)), ref: variableListRef }, selectMode === 'tabs' ? (React__default.createElement(ThemedTabs, { tabsMode: tabsMode, className: cx("".concat(classPrefix, "-base ").concat(classPrefix, "-tabs")) }, filterVars.map(function (item, index) { return (React__default.createElement(Tab, { className: cx("".concat(classPrefix, "-tab")), eventKey: index, key: index, title: item.label },
|
|
177
|
+
React__default.createElement(VariableList, { classnames: cx, classPrefix: "".concat(classPrefix, "-sub-"), className: cx("".concat(classPrefix, "-sub")), itemRender: itemRender, placeholderRender: placeholderRender, selectMode: item.selectMode, data: item.children, onSelect: handleChange, selfVariableName: selfVariableName }))); }))) : selectMode === 'tree' ? (React__default.createElement("div", { className: cx('FormulaEditor-VariableList-body') },
|
|
178
|
+
renderSearchBox(),
|
|
179
|
+
React__default.createElement(TreeSelection, { itemRender: itemRender, placeholderRender: placeholderRender, className: cx("".concat(classPrefix, "-base"), 'is-scrollable'), multiple: false, expand: expandTree ? 'all' : 'none', options: filterVars, onChange: function (item) { return handleChange(item); } }))) : (React__default.createElement("div", { className: cx('FormulaEditor-VariableList-body') },
|
|
180
|
+
renderSearchBox(),
|
|
181
|
+
React__default.createElement(GroupedSelection, { itemRender: itemRender, placeholderRender: placeholderRender, className: cx("".concat(classPrefix, "-base"), 'is-scrollable'), multiple: false, options: filterVars, onChange: function (item) { return handleChange(item); } })))));
|
|
182
|
+
}
|
|
183
|
+
var VariableList$1 = themeable(VariableList);
|
|
184
|
+
|
|
185
|
+
export { VariableList$1 as default };
|