@luck-design-biz/luckda 0.0.22-3 → 0.0.22-5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +40 -40
- package/es/components/Builder/index.js +1 -1
- package/es/components/LdGrid/index.js +4 -4
- package/es/components/LdGridForm/index.less +7 -7
- package/es/components/LdRuntimeCom/index.js +42 -0
- package/es/components/LdTree/index.less +36 -36
- package/es/helper/action.js +6 -6
- package/es/helper/form.js +14 -14
- package/es/helper/index.less +7 -7
- package/es/index.js +1 -0
- package/es/lowcode/constants/api-url.js +3 -0
- package/es/lowcode/constants/event-topics.js +31 -0
- package/es/lowcode/constants/index.js +12 -0
- package/es/lowcode/engine/factory/DataFactory.js +1 -0
- package/es/lowcode/engine/factory/panel-item-factory/DynamicStrategy.js +60 -0
- package/es/lowcode/engine/factory/panel-item-factory/SegmentedStrategy.js +32 -0
- package/es/lowcode/engine/factory/panel-item-factory/SelectStrategy.js +32 -0
- package/es/lowcode/engine/factory/panel-item-factory/Strategy.js +21 -0
- package/es/lowcode/engine/factory/panel-item-factory/StringStrategy.js +32 -0
- package/es/lowcode/engine/factory/panel-item-factory/SwitchStrategy.js +32 -0
- package/es/lowcode/engine/factory/panel-item-factory/index.js +40 -0
- package/es/lowcode/engine/meta/box.props.default.json +10 -0
- package/es/lowcode/engine/meta/box.props.json +40 -0
- package/es/lowcode/engine/meta/button.props.default.json +16 -0
- package/es/lowcode/engine/meta/button.props.json +117 -0
- package/es/lowcode/engine/meta/cardlist.props.default.json +18 -0
- package/es/lowcode/engine/meta/cardlist.props.json +144 -0
- package/es/lowcode/engine/meta/components-list.json +128 -0
- package/es/lowcode/engine/meta/dialog.props.default.json +19 -0
- package/es/lowcode/engine/meta/dialog.props.json +121 -0
- package/es/lowcode/engine/meta/drawer.props.default.json +18 -0
- package/es/lowcode/engine/meta/drawer.props.json +144 -0
- package/es/lowcode/engine/meta/form.props.default.json +13 -0
- package/es/lowcode/engine/meta/form.props.json +117 -0
- package/es/lowcode/engine/meta/iframe.props.default.json +11 -0
- package/es/lowcode/engine/meta/iframe.props.json +32 -0
- package/es/lowcode/engine/meta/image.props.default.json +16 -0
- package/es/lowcode/engine/meta/image.props.json +114 -0
- package/es/lowcode/engine/meta/imex.props.default.json +12 -0
- package/es/lowcode/engine/meta/imex.props.json +82 -0
- package/es/lowcode/engine/meta/js-editor/auto-complete.json +29 -0
- package/es/lowcode/engine/meta/jsx.props.default.json +10 -0
- package/es/lowcode/engine/meta/jsx.props.json +25 -0
- package/es/lowcode/engine/meta/layout.props.default.json +13 -0
- package/es/lowcode/engine/meta/layout.props.json +108 -0
- package/es/lowcode/engine/meta/link.props.default.json +14 -0
- package/es/lowcode/engine/meta/link.props.json +112 -0
- package/es/lowcode/engine/meta/section.props.default.json +17 -0
- package/es/lowcode/engine/meta/section.props.json +108 -0
- package/es/lowcode/engine/meta/split.props.default.json +13 -0
- package/es/lowcode/engine/meta/split.props.json +72 -0
- package/es/lowcode/engine/meta/table.props.default.json +18 -0
- package/es/lowcode/engine/meta/table.props.json +162 -0
- package/es/lowcode/engine/meta/tabs.props.default.json +18 -0
- package/es/lowcode/engine/meta/tabs.props.json +141 -0
- package/es/lowcode/engine/meta/text.props.default.json +12 -0
- package/es/lowcode/engine/meta/text.props.json +66 -0
- package/es/lowcode/engine/meta/tree.props.default.json +17 -0
- package/es/lowcode/engine/meta/tree.props.json +157 -0
- package/es/lowcode/engine/provider/ContextProvider.js +165 -0
- package/es/lowcode/engine/provider/EventBusProvider.js +120 -0
- package/es/lowcode/engine/tools/dataProcess.js +263 -0
- package/es/lowcode/engine/tools/helper.js +4 -0
- package/es/lowcode/engine/tools/lcid.js +16 -0
- package/es/lowcode/index.js +3 -0
- package/es/lowcode/painter/Components.js +104 -0
- package/es/lowcode/painter/Design.js +210 -0
- package/es/lowcode/painter/I18n.js +202 -0
- package/es/lowcode/painter/Outline.js +208 -0
- package/es/lowcode/painter/Panel.js +195 -0
- package/es/lowcode/painter/Ribbon.js +142 -0
- package/es/lowcode/painter/components/PanelItem.js +35 -0
- package/es/lowcode/painter/components/PopConfirm.js +20 -0
- package/es/lowcode/painter/components/PopForm.js +71 -0
- package/es/lowcode/painter/components/RuleInput.js +105 -0
- package/es/lowcode/painter/components/SortBox.js +92 -0
- package/es/lowcode/painter/components/TabEditor.js +88 -0
- package/es/lowcode/painter/components/code-editor/BaseEditor.js +49 -0
- package/es/lowcode/painter/components/code-editor/JSEditor.js +77 -0
- package/es/lowcode/painter/components/code-editor/index.js +2 -0
- package/es/lowcode/painter/index.js +45 -0
- package/es/lowcode/painter/panel-section/Icon.js +48 -0
- package/es/lowcode/painter/panel-section/IconSelector.js +139 -0
- package/es/lowcode/painter/panel-section/LayoutRatio.js +140 -0
- package/es/lowcode/painter/panel-section/TabItems.js +238 -0
- package/es/lowcode/painter/services/I18n.js +85 -0
- package/es/lowcode/painter/style/components.less +90 -0
- package/es/lowcode/painter/style/design.less +82 -0
- package/es/lowcode/painter/style/icon-selector.less +22 -0
- package/es/lowcode/painter/style/icon.less +11 -0
- package/es/lowcode/painter/style/index.less +6 -0
- package/es/lowcode/painter/style/layout-ratio.less +51 -0
- package/es/lowcode/painter/style/outline.less +28 -0
- package/es/lowcode/painter/style/panel-item.less +22 -0
- package/es/lowcode/painter/style/panel.less +119 -0
- package/es/lowcode/painter/style/pop-confirm.less +10 -0
- package/es/lowcode/painter/style/pop-form.less +20 -0
- package/es/lowcode/painter/style/radio.less +24 -0
- package/es/lowcode/painter/style/ribbon.less +5 -0
- package/es/lowcode/painter/style/rule-input.less +13 -0
- package/es/lowcode/painter/style/tabeditor.less +90 -0
- package/es/lowcode/painter/style/tabitems.less +90 -0
- package/es/lowcode/view/Canvas.js +135 -0
- package/es/lowcode/view/Loading.js +23 -0
- package/es/lowcode/view/Page.js +251 -0
- package/es/lowcode/view/index.js +18 -0
- package/es/lowcode/view/lc-components/Box/index.js +24 -0
- package/es/lowcode/view/lc-components/Box/meta.json +40 -0
- package/es/lowcode/view/lc-components/Button/index.js +37 -0
- package/es/lowcode/view/lc-components/Button/meta.json +117 -0
- package/es/lowcode/view/lc-components/CardList/index.js +20 -0
- package/es/lowcode/view/lc-components/CardList/meta.json +144 -0
- package/es/lowcode/view/lc-components/Dialog/index.js +61 -0
- package/es/lowcode/view/lc-components/Dialog/index.less +3 -0
- package/es/lowcode/view/lc-components/Dialog/meta.json +121 -0
- package/es/lowcode/view/lc-components/Drawer/index.js +62 -0
- package/es/lowcode/view/lc-components/Drawer/meta.json +144 -0
- package/es/lowcode/view/lc-components/Drawer/style.less +7 -0
- package/es/lowcode/view/lc-components/Form/index.js +20 -0
- package/es/lowcode/view/lc-components/Form/meta.json +117 -0
- package/es/lowcode/view/lc-components/Iframe/index.js +20 -0
- package/es/lowcode/view/lc-components/Iframe/meta.json +32 -0
- package/es/lowcode/view/lc-components/ImEx/index.js +20 -0
- package/es/lowcode/view/lc-components/ImEx/meta.json +82 -0
- package/es/lowcode/view/lc-components/Image/index.js +20 -0
- package/es/lowcode/view/lc-components/Image/meta.json +114 -0
- package/es/lowcode/view/lc-components/JSX/index.js +20 -0
- package/es/lowcode/view/lc-components/JSX/meta.json +25 -0
- package/es/lowcode/view/lc-components/Layout/index.js +98 -0
- package/es/lowcode/view/lc-components/Layout/index.less +9 -0
- package/es/lowcode/view/lc-components/Layout/meta.json +108 -0
- package/es/lowcode/view/lc-components/Link/index.js +20 -0
- package/es/lowcode/view/lc-components/Link/meta.json +112 -0
- package/es/lowcode/view/lc-components/Section/index.js +34 -0
- package/es/lowcode/view/lc-components/Section/meta.json +108 -0
- package/es/lowcode/view/lc-components/Split/index.js +21 -0
- package/es/lowcode/view/lc-components/Split/meta.json +72 -0
- package/es/lowcode/view/lc-components/Table/index.js +23 -0
- package/es/lowcode/view/lc-components/Table/meta.json +162 -0
- package/es/lowcode/view/lc-components/Tabs/index.js +21 -0
- package/es/lowcode/view/lc-components/Tabs/meta.json +141 -0
- package/es/lowcode/view/lc-components/Text/index.js +23 -0
- package/es/lowcode/view/lc-components/Text/meta.json +66 -0
- package/es/lowcode/view/lc-components/Tree/index.js +20 -0
- package/es/lowcode/view/lc-components/Tree/meta.json +157 -0
- package/es/lowcode/view/lc-components/Wrapper.js +52 -0
- package/es/lowcode/view/style/canvas.less +5 -0
- package/es/lowcode/view/style/loading.less +84 -0
- package/es/lowcode/view/style/page.less +5 -0
- package/es/upload/Form/gridForm.js +24 -6
- package/es/upload/Form/index.less +7 -7
- package/es/upload/FormItem/index.js +30 -18
- package/es/utils/form.js +22 -22
- package/es/utils/grid.js +2 -2
- package/lib/components/Builder/index.js +1 -1
- package/lib/components/LdGrid/index.js +4 -4
- package/lib/components/LdGridForm/index.less +7 -7
- package/lib/components/LdRuntimeCom/index.js +49 -0
- package/lib/components/LdTree/index.less +36 -36
- package/lib/helper/action.js +6 -6
- package/lib/helper/form.js +14 -14
- package/lib/helper/index.less +7 -7
- package/lib/index.js +9 -1
- package/lib/lowcode/constants/api-url.js +9 -0
- package/lib/lowcode/constants/event-topics.js +37 -0
- package/lib/lowcode/constants/index.js +18 -0
- package/lib/lowcode/engine/factory/DataFactory.js +3 -0
- package/lib/lowcode/engine/factory/panel-item-factory/DynamicStrategy.js +73 -0
- package/lib/lowcode/engine/factory/panel-item-factory/SegmentedStrategy.js +38 -0
- package/lib/lowcode/engine/factory/panel-item-factory/SelectStrategy.js +38 -0
- package/lib/lowcode/engine/factory/panel-item-factory/Strategy.js +27 -0
- package/lib/lowcode/engine/factory/panel-item-factory/StringStrategy.js +38 -0
- package/lib/lowcode/engine/factory/panel-item-factory/SwitchStrategy.js +38 -0
- package/lib/lowcode/engine/factory/panel-item-factory/index.js +46 -0
- package/lib/lowcode/engine/meta/box.props.default.json +10 -0
- package/lib/lowcode/engine/meta/box.props.json +40 -0
- package/lib/lowcode/engine/meta/button.props.default.json +16 -0
- package/lib/lowcode/engine/meta/button.props.json +117 -0
- package/lib/lowcode/engine/meta/cardlist.props.default.json +18 -0
- package/lib/lowcode/engine/meta/cardlist.props.json +144 -0
- package/lib/lowcode/engine/meta/components-list.json +128 -0
- package/lib/lowcode/engine/meta/dialog.props.default.json +19 -0
- package/lib/lowcode/engine/meta/dialog.props.json +121 -0
- package/lib/lowcode/engine/meta/drawer.props.default.json +18 -0
- package/lib/lowcode/engine/meta/drawer.props.json +144 -0
- package/lib/lowcode/engine/meta/form.props.default.json +13 -0
- package/lib/lowcode/engine/meta/form.props.json +117 -0
- package/lib/lowcode/engine/meta/iframe.props.default.json +11 -0
- package/lib/lowcode/engine/meta/iframe.props.json +32 -0
- package/lib/lowcode/engine/meta/image.props.default.json +16 -0
- package/lib/lowcode/engine/meta/image.props.json +114 -0
- package/lib/lowcode/engine/meta/imex.props.default.json +12 -0
- package/lib/lowcode/engine/meta/imex.props.json +82 -0
- package/lib/lowcode/engine/meta/js-editor/auto-complete.json +29 -0
- package/lib/lowcode/engine/meta/jsx.props.default.json +10 -0
- package/lib/lowcode/engine/meta/jsx.props.json +25 -0
- package/lib/lowcode/engine/meta/layout.props.default.json +13 -0
- package/lib/lowcode/engine/meta/layout.props.json +108 -0
- package/lib/lowcode/engine/meta/link.props.default.json +14 -0
- package/lib/lowcode/engine/meta/link.props.json +112 -0
- package/lib/lowcode/engine/meta/section.props.default.json +17 -0
- package/lib/lowcode/engine/meta/section.props.json +108 -0
- package/lib/lowcode/engine/meta/split.props.default.json +13 -0
- package/lib/lowcode/engine/meta/split.props.json +72 -0
- package/lib/lowcode/engine/meta/table.props.default.json +18 -0
- package/lib/lowcode/engine/meta/table.props.json +162 -0
- package/lib/lowcode/engine/meta/tabs.props.default.json +18 -0
- package/lib/lowcode/engine/meta/tabs.props.json +141 -0
- package/lib/lowcode/engine/meta/text.props.default.json +12 -0
- package/lib/lowcode/engine/meta/text.props.json +66 -0
- package/lib/lowcode/engine/meta/tree.props.default.json +17 -0
- package/lib/lowcode/engine/meta/tree.props.json +157 -0
- package/lib/lowcode/engine/provider/ContextProvider.js +173 -0
- package/lib/lowcode/engine/provider/EventBusProvider.js +128 -0
- package/lib/lowcode/engine/tools/dataProcess.js +277 -0
- package/lib/lowcode/engine/tools/helper.js +11 -0
- package/lib/lowcode/engine/tools/lcid.js +22 -0
- package/lib/lowcode/index.js +20 -0
- package/lib/lowcode/painter/Components.js +112 -0
- package/lib/lowcode/painter/Design.js +218 -0
- package/lib/lowcode/painter/I18n.js +209 -0
- package/lib/lowcode/painter/Outline.js +216 -0
- package/lib/lowcode/painter/Panel.js +203 -0
- package/lib/lowcode/painter/Ribbon.js +150 -0
- package/lib/lowcode/painter/components/PanelItem.js +41 -0
- package/lib/lowcode/painter/components/PopConfirm.js +26 -0
- package/lib/lowcode/painter/components/PopForm.js +77 -0
- package/lib/lowcode/painter/components/RuleInput.js +112 -0
- package/lib/lowcode/painter/components/SortBox.js +99 -0
- package/lib/lowcode/painter/components/TabEditor.js +94 -0
- package/lib/lowcode/painter/components/code-editor/BaseEditor.js +57 -0
- package/lib/lowcode/painter/components/code-editor/JSEditor.js +88 -0
- package/lib/lowcode/painter/components/code-editor/index.js +20 -0
- package/lib/lowcode/painter/index.js +54 -0
- package/lib/lowcode/painter/panel-section/Icon.js +54 -0
- package/lib/lowcode/painter/panel-section/IconSelector.js +146 -0
- package/lib/lowcode/painter/panel-section/LayoutRatio.js +148 -0
- package/lib/lowcode/painter/panel-section/TabItems.js +246 -0
- package/lib/lowcode/painter/services/I18n.js +95 -0
- package/lib/lowcode/painter/style/components.less +90 -0
- package/lib/lowcode/painter/style/design.less +82 -0
- package/lib/lowcode/painter/style/icon-selector.less +22 -0
- package/lib/lowcode/painter/style/icon.less +11 -0
- package/lib/lowcode/painter/style/index.less +6 -0
- package/lib/lowcode/painter/style/layout-ratio.less +51 -0
- package/lib/lowcode/painter/style/outline.less +28 -0
- package/lib/lowcode/painter/style/panel-item.less +22 -0
- package/lib/lowcode/painter/style/panel.less +119 -0
- package/lib/lowcode/painter/style/pop-confirm.less +10 -0
- package/lib/lowcode/painter/style/pop-form.less +20 -0
- package/lib/lowcode/painter/style/radio.less +24 -0
- package/lib/lowcode/painter/style/ribbon.less +5 -0
- package/lib/lowcode/painter/style/rule-input.less +13 -0
- package/lib/lowcode/painter/style/tabeditor.less +90 -0
- package/lib/lowcode/painter/style/tabitems.less +90 -0
- package/lib/lowcode/view/Canvas.js +150 -0
- package/lib/lowcode/view/Loading.js +30 -0
- package/lib/lowcode/view/Page.js +259 -0
- package/lib/lowcode/view/index.js +25 -0
- package/lib/lowcode/view/lc-components/Box/index.js +32 -0
- package/lib/lowcode/view/lc-components/Box/meta.json +40 -0
- package/lib/lowcode/view/lc-components/Button/index.js +45 -0
- package/lib/lowcode/view/lc-components/Button/meta.json +117 -0
- package/lib/lowcode/view/lc-components/CardList/index.js +28 -0
- package/lib/lowcode/view/lc-components/CardList/meta.json +144 -0
- package/lib/lowcode/view/lc-components/Dialog/index.js +69 -0
- package/lib/lowcode/view/lc-components/Dialog/index.less +3 -0
- package/lib/lowcode/view/lc-components/Dialog/meta.json +121 -0
- package/lib/lowcode/view/lc-components/Drawer/index.js +70 -0
- package/lib/lowcode/view/lc-components/Drawer/meta.json +144 -0
- package/lib/lowcode/view/lc-components/Drawer/style.less +7 -0
- package/lib/lowcode/view/lc-components/Form/index.js +28 -0
- package/lib/lowcode/view/lc-components/Form/meta.json +117 -0
- package/lib/lowcode/view/lc-components/Iframe/index.js +28 -0
- package/lib/lowcode/view/lc-components/Iframe/meta.json +32 -0
- package/lib/lowcode/view/lc-components/ImEx/index.js +28 -0
- package/lib/lowcode/view/lc-components/ImEx/meta.json +82 -0
- package/lib/lowcode/view/lc-components/Image/index.js +28 -0
- package/lib/lowcode/view/lc-components/Image/meta.json +114 -0
- package/lib/lowcode/view/lc-components/JSX/index.js +28 -0
- package/lib/lowcode/view/lc-components/JSX/meta.json +25 -0
- package/lib/lowcode/view/lc-components/Layout/index.js +106 -0
- package/lib/lowcode/view/lc-components/Layout/index.less +9 -0
- package/lib/lowcode/view/lc-components/Layout/meta.json +108 -0
- package/lib/lowcode/view/lc-components/Link/index.js +28 -0
- package/lib/lowcode/view/lc-components/Link/meta.json +112 -0
- package/lib/lowcode/view/lc-components/Section/index.js +42 -0
- package/lib/lowcode/view/lc-components/Section/meta.json +108 -0
- package/lib/lowcode/view/lc-components/Split/index.js +29 -0
- package/lib/lowcode/view/lc-components/Split/meta.json +72 -0
- package/lib/lowcode/view/lc-components/Table/index.js +31 -0
- package/lib/lowcode/view/lc-components/Table/meta.json +162 -0
- package/lib/lowcode/view/lc-components/Tabs/index.js +29 -0
- package/lib/lowcode/view/lc-components/Tabs/meta.json +141 -0
- package/lib/lowcode/view/lc-components/Text/index.js +31 -0
- package/lib/lowcode/view/lc-components/Text/meta.json +66 -0
- package/lib/lowcode/view/lc-components/Tree/index.js +28 -0
- package/lib/lowcode/view/lc-components/Tree/meta.json +157 -0
- package/lib/lowcode/view/lc-components/Wrapper.js +59 -0
- package/lib/lowcode/view/style/canvas.less +5 -0
- package/lib/lowcode/view/style/loading.less +84 -0
- package/lib/lowcode/view/style/page.less +5 -0
- package/lib/upload/Form/gridForm.js +22 -4
- package/lib/upload/Form/index.less +7 -7
- package/lib/upload/FormItem/index.js +29 -17
- package/lib/utils/form.js +22 -22
- package/lib/utils/grid.js +2 -2
- package/lowcode.js +1 -0
- package/package.json +163 -151
- package/upload.js +1 -1
- package/utils.js +1 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
10
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var _luckDesign = require("luck-design");
|
|
14
|
+
var _antd = require("luck-design/antd");
|
|
15
|
+
var _Outline = _interopRequireDefault(require("./Outline"));
|
|
16
|
+
var _Components = _interopRequireDefault(require("./Components"));
|
|
17
|
+
var _I18n = _interopRequireDefault(require("./I18n"));
|
|
18
|
+
var _utils = require("@luck-design-biz/base/utils");
|
|
19
|
+
var _ribbon = _interopRequireDefault(require("./style/ribbon.less"));
|
|
20
|
+
var _WIDTH_ = 48;
|
|
21
|
+
var _DRAWER_PROPS = {
|
|
22
|
+
placement: 'left',
|
|
23
|
+
mask: false,
|
|
24
|
+
getContainer: false,
|
|
25
|
+
zIndex: 10000,
|
|
26
|
+
headerStyle: {
|
|
27
|
+
borderBottom: 'none'
|
|
28
|
+
},
|
|
29
|
+
style: {
|
|
30
|
+
position: 'absolute',
|
|
31
|
+
left: _WIDTH_
|
|
32
|
+
},
|
|
33
|
+
bodyStyle: {
|
|
34
|
+
overflowY: 'auto',
|
|
35
|
+
height: 'calc(100% - 55px)',
|
|
36
|
+
padding: 0
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
var _DRAWER_OUTLINE_ = {
|
|
40
|
+
width: 300,
|
|
41
|
+
key: 'outline',
|
|
42
|
+
title: '大纲树',
|
|
43
|
+
fix: true
|
|
44
|
+
};
|
|
45
|
+
var _DRAWER_COMPONENTS_ = {
|
|
46
|
+
width: 310,
|
|
47
|
+
key: 'components',
|
|
48
|
+
title: '组件',
|
|
49
|
+
fix: true
|
|
50
|
+
};
|
|
51
|
+
var _DRAWER_I18N_ = {
|
|
52
|
+
width: 450,
|
|
53
|
+
key: 'i18n',
|
|
54
|
+
title: '多语言文案管理',
|
|
55
|
+
fix: false
|
|
56
|
+
};
|
|
57
|
+
var Ribbon = function Ribbon() {
|
|
58
|
+
var _useState = (0, _react.useState)(null),
|
|
59
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
60
|
+
drawer = _useState2[0],
|
|
61
|
+
setDrawer = _useState2[1];
|
|
62
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_luckDesign.Box, {
|
|
63
|
+
className: _ribbon.default['lc-painter-ribbon'],
|
|
64
|
+
width: _WIDTH_,
|
|
65
|
+
heitht: "100%",
|
|
66
|
+
direction: "column",
|
|
67
|
+
align: "center",
|
|
68
|
+
style: {
|
|
69
|
+
marginRight: drawer !== null && drawer !== void 0 && drawer.fix ? drawer.width : 0
|
|
70
|
+
}
|
|
71
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Tooltip, {
|
|
72
|
+
placement: "right",
|
|
73
|
+
title: (0, _utils.formatMessage)({
|
|
74
|
+
id: 'luckda.lowcode.outline',
|
|
75
|
+
label: _DRAWER_OUTLINE_.title
|
|
76
|
+
})
|
|
77
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Icon, {
|
|
78
|
+
type: "apartment",
|
|
79
|
+
onClick: function onClick() {
|
|
80
|
+
return setDrawer((drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_OUTLINE_.key ? null : _DRAWER_OUTLINE_);
|
|
81
|
+
}
|
|
82
|
+
})), /*#__PURE__*/_react.default.createElement(_antd.Tooltip, {
|
|
83
|
+
placement: "right",
|
|
84
|
+
title: (0, _utils.formatMessage)({
|
|
85
|
+
id: 'luckda.lowcode.components',
|
|
86
|
+
label: _DRAWER_COMPONENTS_.title
|
|
87
|
+
})
|
|
88
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Icon, {
|
|
89
|
+
type: "appstore",
|
|
90
|
+
onClick: function onClick() {
|
|
91
|
+
return setDrawer((drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_COMPONENTS_.key ? null : _DRAWER_COMPONENTS_);
|
|
92
|
+
}
|
|
93
|
+
})), /*#__PURE__*/_react.default.createElement(_antd.Tooltip, {
|
|
94
|
+
placement: "right",
|
|
95
|
+
title: (0, _utils.formatMessage)({
|
|
96
|
+
id: 'luckda.lowcode.i18n',
|
|
97
|
+
label: _DRAWER_I18N_.title
|
|
98
|
+
})
|
|
99
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Icon, {
|
|
100
|
+
type: "global",
|
|
101
|
+
onClick: function onClick() {
|
|
102
|
+
return setDrawer((drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_I18N_.key ? null : _DRAWER_I18N_);
|
|
103
|
+
}
|
|
104
|
+
}))), /*#__PURE__*/_react.default.createElement(_antd.Drawer, (0, _extends2.default)({
|
|
105
|
+
title: drawer ? (0, _utils.formatMessage)({
|
|
106
|
+
id: "luckda.lowcode.".concat(drawer.key),
|
|
107
|
+
label: drawer.title
|
|
108
|
+
}) : '',
|
|
109
|
+
width: (drawer === null || drawer === void 0 ? void 0 : drawer.width) || 0,
|
|
110
|
+
visible: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_OUTLINE_.key,
|
|
111
|
+
onClose: function onClose() {
|
|
112
|
+
return setDrawer(null);
|
|
113
|
+
}
|
|
114
|
+
}, _DRAWER_PROPS, {
|
|
115
|
+
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _DRAWER_PROPS.style), {}, {
|
|
116
|
+
display: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_OUTLINE_.key ? 'block' : 'none'
|
|
117
|
+
})
|
|
118
|
+
}), /*#__PURE__*/_react.default.createElement(_Outline.default, {
|
|
119
|
+
open: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_OUTLINE_.key
|
|
120
|
+
})), /*#__PURE__*/_react.default.createElement(_antd.Drawer, (0, _extends2.default)({
|
|
121
|
+
title: drawer ? (0, _utils.formatMessage)({
|
|
122
|
+
id: "luckda.lowcode.".concat(drawer.key),
|
|
123
|
+
label: drawer.title
|
|
124
|
+
}) : '',
|
|
125
|
+
width: (drawer === null || drawer === void 0 ? void 0 : drawer.width) || 0,
|
|
126
|
+
visible: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_COMPONENTS_.key,
|
|
127
|
+
onClose: function onClose() {
|
|
128
|
+
return setDrawer(null);
|
|
129
|
+
}
|
|
130
|
+
}, _DRAWER_PROPS, {
|
|
131
|
+
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _DRAWER_PROPS.style), {}, {
|
|
132
|
+
display: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_COMPONENTS_.key ? 'block' : 'none'
|
|
133
|
+
})
|
|
134
|
+
}), /*#__PURE__*/_react.default.createElement(_Components.default, null)), /*#__PURE__*/_react.default.createElement(_antd.Drawer, (0, _extends2.default)({
|
|
135
|
+
title: drawer ? (0, _utils.formatMessage)({
|
|
136
|
+
id: "luckda.lowcode.".concat(drawer.key),
|
|
137
|
+
label: drawer.title
|
|
138
|
+
}) : '',
|
|
139
|
+
width: (drawer === null || drawer === void 0 ? void 0 : drawer.width) || 0,
|
|
140
|
+
visible: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_I18N_.key,
|
|
141
|
+
onClose: function onClose() {
|
|
142
|
+
return setDrawer(null);
|
|
143
|
+
}
|
|
144
|
+
}, _DRAWER_PROPS, {
|
|
145
|
+
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _DRAWER_PROPS.style), {}, {
|
|
146
|
+
display: (drawer === null || drawer === void 0 ? void 0 : drawer.key) === _DRAWER_I18N_.key ? 'block' : 'none'
|
|
147
|
+
})
|
|
148
|
+
}), /*#__PURE__*/_react.default.createElement(_I18n.default, null)));
|
|
149
|
+
};
|
|
150
|
+
var _default = exports.default = Ribbon;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = _default;
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
var _lodash = require("lodash");
|
|
10
|
+
var _panelItem = _interopRequireDefault(require("../style/panel-item.less"));
|
|
11
|
+
/**
|
|
12
|
+
* `PanelItem` 组件表示属性面板中的一个属性项。
|
|
13
|
+
* 它展示了一个标签(通常是属性名称)和对应的组件(比如输入框、选择器等)。
|
|
14
|
+
* 这个组件可以用于构建具有多个属性输入的UI,如设置面板或配置界面。
|
|
15
|
+
*
|
|
16
|
+
* @component
|
|
17
|
+
* @example
|
|
18
|
+
* ```jsx
|
|
19
|
+
* <PanelItem
|
|
20
|
+
* label="属性名称"
|
|
21
|
+
* component={<input type="text" />}
|
|
22
|
+
* />
|
|
23
|
+
* ```
|
|
24
|
+
*
|
|
25
|
+
* @param {Object} props 组件接收的参数
|
|
26
|
+
* @param {string} props.label 用于显示的属性名称。
|
|
27
|
+
* @param {React.ReactNode} props.children 与属性名称对应的组件,可以是输入框、下拉菜单等React节点。
|
|
28
|
+
*
|
|
29
|
+
* @returns {React.Element} 返回一个React元素,渲染属性名称和对应的组件。
|
|
30
|
+
*/
|
|
31
|
+
function _default(_ref) {
|
|
32
|
+
var label = _ref.label,
|
|
33
|
+
children = _ref.children;
|
|
34
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
35
|
+
className: _panelItem.default['lc-painter-components-panelitem']
|
|
36
|
+
}, label && !(0, _lodash.startsWith)(label, '#') && /*#__PURE__*/_react.default.createElement("span", {
|
|
37
|
+
className: _panelItem.default['item-label']
|
|
38
|
+
}, label), /*#__PURE__*/_react.default.createElement("span", {
|
|
39
|
+
className: _panelItem.default['item-component']
|
|
40
|
+
}, children));
|
|
41
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = _default;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _antd = require("luck-design/antd");
|
|
11
|
+
var _popConfirm = _interopRequireDefault(require("../style/pop-confirm.less"));
|
|
12
|
+
/**
|
|
13
|
+
* 这个组件是对 luck-design/antd 的 Popconfirm 组件的封装。
|
|
14
|
+
* 它提供了一个带有自定义样式的弹出确认框,用于在用户尝试执行重要操作前提示确认信息。
|
|
15
|
+
* 通过传入的 props 可以自定义 Popconfirm 组件的行为和外观。
|
|
16
|
+
*
|
|
17
|
+
* @param {Object} props - 传递给 Popconfirm 组件的属性。这包括所有标准的 Popconfirm 属性,
|
|
18
|
+
* 以及任何额外的属性,如事件处理器或自定义内容。
|
|
19
|
+
* @returns {ReactNode} 返回一个配置了自定义样式和指定属性的 Popconfirm 组件实例。
|
|
20
|
+
*/
|
|
21
|
+
function _default(props) {
|
|
22
|
+
return /*#__PURE__*/_react.default.createElement(_antd.Popconfirm, (0, _extends2.default)({
|
|
23
|
+
overlayClassName: _popConfirm.default['lc-painter-panel-section-components-popconfirm'],
|
|
24
|
+
icon: null
|
|
25
|
+
}, props));
|
|
26
|
+
}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.PopFormItemRight = exports.PopFormItemLeft = exports.PopFormItem = exports.PopForm = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
var _popForm = _interopRequireDefault(require("../style/pop-form.less"));
|
|
12
|
+
var _excluded = ["children"],
|
|
13
|
+
_excluded2 = ["children"],
|
|
14
|
+
_excluded3 = ["children"],
|
|
15
|
+
_excluded4 = ["children"];
|
|
16
|
+
/**
|
|
17
|
+
* PopForm 是一个为弹出式表单布局提供容器的组件,它使用特定的样式来组织表单内容。
|
|
18
|
+
*
|
|
19
|
+
* @param {Object} props - 组件的 props。
|
|
20
|
+
* @param {ReactNode} props.children - 组件内包含的子元素。
|
|
21
|
+
* @param {Object} rest - 传递给组件的其余属性,这些属性将直接传递给根 div 元素。
|
|
22
|
+
*/
|
|
23
|
+
var PopForm = exports.PopForm = function PopForm(_ref) {
|
|
24
|
+
var children = _ref.children,
|
|
25
|
+
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
26
|
+
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
27
|
+
className: _popForm.default['lc-painter-panel-section-components-popform']
|
|
28
|
+
}, rest), children);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* PopFormItem 是 PopForm 组件的一个子项,用于包装表单的每个独立字段。
|
|
33
|
+
* 它提供了一致的布局和样式封装,用于表单项的展示。
|
|
34
|
+
*
|
|
35
|
+
* @param {Object} props - 组件的 props。
|
|
36
|
+
* @param {ReactNode} props.children - 组件内包含的子元素。
|
|
37
|
+
* @param {Object} rest - 传递给组件的其余属性,这些属性将直接传递给根 div 元素。
|
|
38
|
+
*/
|
|
39
|
+
var PopFormItem = exports.PopFormItem = function PopFormItem(_ref2) {
|
|
40
|
+
var children = _ref2.children,
|
|
41
|
+
rest = (0, _objectWithoutProperties2.default)(_ref2, _excluded2);
|
|
42
|
+
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
43
|
+
className: _popForm.default['item']
|
|
44
|
+
}, rest), children);
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* PopFormItemLeft 是 PopFormItem 的子组件,用于展示表单项的标签或标题部分。
|
|
49
|
+
* 它通常用于放置字段名或说明性文本。
|
|
50
|
+
*
|
|
51
|
+
* @param {Object} props - 组件的 props。
|
|
52
|
+
* @param {ReactNode} props.children - 组件内包含的子元素。
|
|
53
|
+
* @param {Object} rest - 传递给组件的其余属性,这些属性将直接传递给根 div 元素。
|
|
54
|
+
*/
|
|
55
|
+
var PopFormItemLeft = exports.PopFormItemLeft = function PopFormItemLeft(_ref3) {
|
|
56
|
+
var children = _ref3.children,
|
|
57
|
+
rest = (0, _objectWithoutProperties2.default)(_ref3, _excluded3);
|
|
58
|
+
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
59
|
+
className: _popForm.default['left']
|
|
60
|
+
}, rest), children);
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* PopFormItemRight 是 PopFormItem 的子组件,用于包含表单项的输入字段。
|
|
65
|
+
* 它是表单项布局中用于用户输入的部分,可以容纳各种类型的输入控件。
|
|
66
|
+
*
|
|
67
|
+
* @param {Object} props - 组件的 props。
|
|
68
|
+
* @param {ReactNode} props.children - 组件内包含的子元素。
|
|
69
|
+
* @param {Object} rest - 传递给组件的其余属性,这些属性将直接传递给根 div 元素。
|
|
70
|
+
*/
|
|
71
|
+
var PopFormItemRight = exports.PopFormItemRight = function PopFormItemRight(_ref4) {
|
|
72
|
+
var children = _ref4.children,
|
|
73
|
+
rest = (0, _objectWithoutProperties2.default)(_ref4, _excluded4);
|
|
74
|
+
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
75
|
+
className: _popForm.default['right']
|
|
76
|
+
}, rest), children);
|
|
77
|
+
};
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
10
|
+
var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
|
|
11
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
12
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
13
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
14
|
+
var _antd = require("luck-design/antd");
|
|
15
|
+
var _ruleInput = _interopRequireDefault(require("../style/rule-input.less"));
|
|
16
|
+
var _excluded = ["onValueChange", "rules", "value"];
|
|
17
|
+
/**
|
|
18
|
+
* 带校验功能的输入组件。
|
|
19
|
+
*
|
|
20
|
+
* 此组件封装了antd的Input组件,并增加了输入值的校验功能。它允许开发者定义一组校验规则,
|
|
21
|
+
* 以确保用户输入符合特定要求。每条规则由一个校验函数和一个错误信息组成。如果用户的输入
|
|
22
|
+
* 不满足任何一条规则,将展示相应的错误信息提示。
|
|
23
|
+
*
|
|
24
|
+
* @component
|
|
25
|
+
* @example
|
|
26
|
+
* <RuleInput
|
|
27
|
+
* value="示例值"
|
|
28
|
+
* onValueChange={(e, newValue) => console.log('新值:', newValue)}
|
|
29
|
+
* rules={[
|
|
30
|
+
* { func: value => !!value, err: '输入不能为空' },
|
|
31
|
+
* { func: value => /^\d+$/.test(value), err: '只允许输入数字' }
|
|
32
|
+
* ]}
|
|
33
|
+
* />
|
|
34
|
+
*
|
|
35
|
+
* @param {Object} props 组件接收的props
|
|
36
|
+
* @param {string} props.value 输入框当前的值,可以由外部控制以实现受控组件。
|
|
37
|
+
* @param {Function} props.onValueChange 当输入值改变并通过所有校验时,触发的回调函数。
|
|
38
|
+
* 该函数接收原生的事件对象和新的输入值作为参数。
|
|
39
|
+
* @param {Array<{func: (value: string) => boolean, err: string}>} props.rules
|
|
40
|
+
* 定义输入校验规则的数组。每个元素是一个对象,其中`func`属性是一个函数,用于执行校验逻辑,
|
|
41
|
+
* 接收当前输入值作为参数,返回一个布尔值表示校验是否通过;`err`属性是一个字符串,指定当
|
|
42
|
+
* 校验失败时要显示的错误信息。
|
|
43
|
+
* @param {Object} rest 传递给内部Input组件的其他props,如`placeholder`、`disabled`等。
|
|
44
|
+
* @param {React.Ref} ref React ref对象,用于将ref传递给内部的Input DOM元素。
|
|
45
|
+
*
|
|
46
|
+
* @returns React元素,渲染一个带有校验功能的输入框和校验失败时的错误信息提示。
|
|
47
|
+
*/
|
|
48
|
+
var _default = exports.default = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
|
|
49
|
+
var onValueChange = _ref.onValueChange,
|
|
50
|
+
rules = _ref.rules,
|
|
51
|
+
value = _ref.value,
|
|
52
|
+
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
53
|
+
var _useState = (0, _react.useState)(value),
|
|
54
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
55
|
+
inputValue = _useState2[0],
|
|
56
|
+
setInputValue = _useState2[1]; // 托管输入值的状态
|
|
57
|
+
var _useState3 = (0, _react.useState)(null),
|
|
58
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
59
|
+
err = _useState4[0],
|
|
60
|
+
setErr = _useState4[1];
|
|
61
|
+
|
|
62
|
+
// 使用useEffect钩子监听value的变化
|
|
63
|
+
(0, _react.useEffect)(function () {
|
|
64
|
+
setInputValue(value);
|
|
65
|
+
setErr(null);
|
|
66
|
+
}, [value]);
|
|
67
|
+
var handleInputChange = function handleInputChange(e) {
|
|
68
|
+
var value = e.target.value;
|
|
69
|
+
setInputValue(value); // 更新托管的输入值
|
|
70
|
+
|
|
71
|
+
if (value == '') onValueChange(e, value);
|
|
72
|
+
var error = null;
|
|
73
|
+
|
|
74
|
+
// 遍历rules,检查输入值是否满足条件
|
|
75
|
+
var _iterator = (0, _createForOfIteratorHelper2.default)(rules),
|
|
76
|
+
_step;
|
|
77
|
+
try {
|
|
78
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
79
|
+
var rule = _step.value;
|
|
80
|
+
if (!rule.func(value)) {
|
|
81
|
+
error = rule.err;
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
} catch (err) {
|
|
86
|
+
_iterator.e(err);
|
|
87
|
+
} finally {
|
|
88
|
+
_iterator.f();
|
|
89
|
+
}
|
|
90
|
+
if (!error) {
|
|
91
|
+
setErr(null);
|
|
92
|
+
onValueChange(e, value);
|
|
93
|
+
} else {
|
|
94
|
+
setErr(error);
|
|
95
|
+
console.log('err', error);
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
var className = _ruleInput.default['lc-painter-components-ruleinput'];
|
|
99
|
+
if (err) className += ' ' + _ruleInput.default['err'];
|
|
100
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_antd.Tooltip, {
|
|
101
|
+
title: err,
|
|
102
|
+
visible: err
|
|
103
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Input, (0, _extends2.default)({
|
|
104
|
+
className: className,
|
|
105
|
+
size: "small",
|
|
106
|
+
value: inputValue // 绑定输入值
|
|
107
|
+
,
|
|
108
|
+
onChange: handleInputChange
|
|
109
|
+
}, rest, {
|
|
110
|
+
ref: ref
|
|
111
|
+
}))));
|
|
112
|
+
});
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.SortItem = exports.SortBox = void 0;
|
|
9
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _core = require("@dnd-kit/core");
|
|
12
|
+
var _sortable = require("@dnd-kit/sortable");
|
|
13
|
+
var _utilities = require("@dnd-kit/utilities");
|
|
14
|
+
/**
|
|
15
|
+
* SortBox 是一个使用 dnd-kit 实现拖拽排序的组件。
|
|
16
|
+
* 它允许子元素通过拖拽操作来重新排序,并在排序操作完成后通过 onChange 回调传递新的排序结果。
|
|
17
|
+
*
|
|
18
|
+
* @param {Object} props 组件的 props。
|
|
19
|
+
* @param {Array} props.datas 初始排序的数据数组,通常包含用于排序的唯一标识符。
|
|
20
|
+
* @param {ReactNode} props.children 组件的子元素,通常是需要进行排序的元素集合。
|
|
21
|
+
* @param {Function} props.onChange 当排序操作完成时触发的回调函数,参数为重新排序后的数据数组。
|
|
22
|
+
* @param {Function} [props.strategy=verticalListSortingStrategy] 用于排序的策略。默认为垂直列表排序策略。
|
|
23
|
+
*
|
|
24
|
+
* @returns {ReactNode} 返回一个配置了 DndContext 和 SortableContext 的 React 组件结构。
|
|
25
|
+
*/
|
|
26
|
+
var SortBox = exports.SortBox = function SortBox(_ref) {
|
|
27
|
+
var datas = _ref.datas,
|
|
28
|
+
children = _ref.children,
|
|
29
|
+
onChange = _ref.onChange,
|
|
30
|
+
strategy = _ref.strategy;
|
|
31
|
+
var _useState = (0, _react.useState)(datas),
|
|
32
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
33
|
+
items = _useState2[0],
|
|
34
|
+
setItems = _useState2[1];
|
|
35
|
+
var sortStrategy = strategy !== null && strategy !== void 0 ? strategy : _sortable.verticalListSortingStrategy;
|
|
36
|
+
(0, _react.useEffect)(function () {
|
|
37
|
+
setItems(datas);
|
|
38
|
+
}, [datas]);
|
|
39
|
+
function handleDragEnd(event) {
|
|
40
|
+
var active = event.active,
|
|
41
|
+
over = event.over;
|
|
42
|
+
if (active.id !== over.id) {
|
|
43
|
+
setItems(function (items) {
|
|
44
|
+
var oldIndex = items.indexOf(active.id);
|
|
45
|
+
var newIndex = items.indexOf(over.id);
|
|
46
|
+
var newSortItem = (0, _sortable.arrayMove)(items, oldIndex, newIndex);
|
|
47
|
+
if (onChange) onChange(newSortItem);
|
|
48
|
+
return newSortItem;
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return /*#__PURE__*/_react.default.createElement(_core.DndContext, {
|
|
53
|
+
onDragEnd: handleDragEnd
|
|
54
|
+
}, /*#__PURE__*/_react.default.createElement(_sortable.SortableContext, {
|
|
55
|
+
strategy: sortStrategy,
|
|
56
|
+
items: items
|
|
57
|
+
}, children));
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* SortItem 组件是一个使用 dnd-kit 实现的可排序项。它通过 useSortable 钩子来提供拖拽功能,
|
|
62
|
+
* 并将必要的属性和监听器传递给其子元素,使得子元素可拖拽。
|
|
63
|
+
*
|
|
64
|
+
* @param {Object} props - 组件的 props。
|
|
65
|
+
* @param {string} props.id - 该排序项的唯一标识符,用于识别不同的可排序元素。
|
|
66
|
+
* @param {ReactNode} props.children - 该组件的子元素。通常是你希望使之可拖拽的元素。
|
|
67
|
+
* SortItem 会将拖拽相关的 props 注入到这个子元素中。
|
|
68
|
+
*
|
|
69
|
+
* @returns {ReactNode} 返回一个增强后的 React 元素,此元素集成了拖拽功能。
|
|
70
|
+
* 它基于原 children 元素,附加了用于拖拽的属性和样式。
|
|
71
|
+
*/
|
|
72
|
+
var SortItem = exports.SortItem = function SortItem(_ref2) {
|
|
73
|
+
var id = _ref2.id,
|
|
74
|
+
children = _ref2.children;
|
|
75
|
+
var _useSortable = (0, _sortable.useSortable)({
|
|
76
|
+
id: id
|
|
77
|
+
}),
|
|
78
|
+
attributes = _useSortable.attributes,
|
|
79
|
+
listeners = _useSortable.listeners,
|
|
80
|
+
setNodeRef = _useSortable.setNodeRef,
|
|
81
|
+
transform = _useSortable.transform,
|
|
82
|
+
transition = _useSortable.transition,
|
|
83
|
+
setActivatorNodeRef = _useSortable.setActivatorNodeRef;
|
|
84
|
+
var style = {
|
|
85
|
+
transform: _utilities.CSS.Transform.toString(transform),
|
|
86
|
+
transition: transition
|
|
87
|
+
};
|
|
88
|
+
var childWithProps = /*#__PURE__*/_react.default.cloneElement(children, {
|
|
89
|
+
key: id,
|
|
90
|
+
attributes: attributes,
|
|
91
|
+
listeners: listeners,
|
|
92
|
+
setNodeRef: setNodeRef,
|
|
93
|
+
transform: transform,
|
|
94
|
+
transition: transition,
|
|
95
|
+
setActivatorNodeRef: setActivatorNodeRef,
|
|
96
|
+
style: style
|
|
97
|
+
});
|
|
98
|
+
return childWithProps;
|
|
99
|
+
};
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.TabEditorItem = exports.TabEditor = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
var _antd = require("luck-design/antd");
|
|
11
|
+
var _utils = require("@luck-design-biz/base/utils");
|
|
12
|
+
var _tabeditor = _interopRequireDefault(require("../style/tabeditor.less"));
|
|
13
|
+
/**
|
|
14
|
+
* TabEditor 是一个用于管理和展示一组可编辑标签项的容器组件。
|
|
15
|
+
* 它提供了一个添加新标签项的操作按钮,并通过 children 属性接收一组 TabEditorItem 组件。
|
|
16
|
+
*
|
|
17
|
+
* @param {Object} props - 组件接收的属性。
|
|
18
|
+
* @param {ReactNode} props.children - TabEditorItem 组件的实例,表示可编辑的标签项。
|
|
19
|
+
* @param {Function} props.handleAdd - 一个回调函数,当用户点击添加按钮时被触发,用于添加新的标签项。
|
|
20
|
+
* @returns {ReactNode} 渲染一个带有操作按钮和标签项的容器。
|
|
21
|
+
*/
|
|
22
|
+
var TabEditor = exports.TabEditor = function TabEditor(_ref) {
|
|
23
|
+
var children = _ref.children,
|
|
24
|
+
handleAdd = _ref.handleAdd;
|
|
25
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
26
|
+
className: _tabeditor.default['lc-painter-panel-section-components-tabeditor']
|
|
27
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
28
|
+
className: _tabeditor.default['tabs-box']
|
|
29
|
+
}, children), /*#__PURE__*/_react.default.createElement("div", {
|
|
30
|
+
className: _tabeditor.default['tabs-actions']
|
|
31
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
32
|
+
className: _tabeditor.default['tabs-action'],
|
|
33
|
+
onClick: handleAdd
|
|
34
|
+
}, /*#__PURE__*/_react.default.createElement(_antd.Icon, {
|
|
35
|
+
type: "plus-circle"
|
|
36
|
+
}), ' ', (0, _utils.formatMessage)({
|
|
37
|
+
id: 'luckda.lowcode.painter.panel-section.components.tabeditor.add',
|
|
38
|
+
label: '添加一项'
|
|
39
|
+
}))));
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* TabEditorItem 是一个可编辑的标签项组件,用于在 TabEditor 容器内展示。
|
|
44
|
+
* 它支持拖拽排序,并可以通过左侧和右侧的插槽来自定义内容。
|
|
45
|
+
*
|
|
46
|
+
* @param {Object} props - 组件接收的属性。
|
|
47
|
+
* @param {Object} props.item - 表示标签项数据的对象。
|
|
48
|
+
* @param {ReactNode} props.left - 放置在标签项左侧的内容,通常用于展示标签名称或其他信息。
|
|
49
|
+
* @param {ReactNode} props.right - 放置在标签项右侧的内容,通常用于展示操作按钮如编辑或删除。
|
|
50
|
+
* @param {Function} props.setNodeRef - 用于设置拖拽组件根节点的引用。
|
|
51
|
+
* @param {Function} props.setActivatorNodeRef - 用于设置激活拖拽操作的节点引用。
|
|
52
|
+
* @param {Object} props.style - 应用于标签项的样式对象,通常包含拖拽过程中的动态变化样式。
|
|
53
|
+
* @param {Object} props.attributes - 包含与拖拽相关的HTML属性。
|
|
54
|
+
* @param {Object} props.listeners - 包含处理拖拽事件的监听器。
|
|
55
|
+
* @param {CSSProperties} props.transform - 应用于组件的CSS变换属性,用于实现拖拽效果。
|
|
56
|
+
* @param {string} props.transition - 定义拖拽动画的CSS过渡属性。
|
|
57
|
+
* @returns {ReactNode} 渲染一个可编辑的标签项,支持拖拽排序。
|
|
58
|
+
*/
|
|
59
|
+
var TabEditorItem = exports.TabEditorItem = function TabEditorItem(_ref2) {
|
|
60
|
+
var item = _ref2.item,
|
|
61
|
+
left = _ref2.left,
|
|
62
|
+
right = _ref2.right,
|
|
63
|
+
setNodeRef = _ref2.setNodeRef,
|
|
64
|
+
setActivatorNodeRef = _ref2.setActivatorNodeRef,
|
|
65
|
+
style = _ref2.style,
|
|
66
|
+
attributes = _ref2.attributes,
|
|
67
|
+
listeners = _ref2.listeners,
|
|
68
|
+
transform = _ref2.transform,
|
|
69
|
+
transition = _ref2.transition;
|
|
70
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
71
|
+
ref: setNodeRef,
|
|
72
|
+
style: style,
|
|
73
|
+
className: _tabeditor.default['tabitem']
|
|
74
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
75
|
+
className: _tabeditor.default['tabitem-left']
|
|
76
|
+
}, /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
77
|
+
ref: setActivatorNodeRef
|
|
78
|
+
}, attributes, listeners, {
|
|
79
|
+
className: _tabeditor.default['dragicon']
|
|
80
|
+
}), /*#__PURE__*/_react.default.createElement("svg", {
|
|
81
|
+
fill: "currentColor",
|
|
82
|
+
preserveAspectRatio: "xMidYMid meet",
|
|
83
|
+
width: "16",
|
|
84
|
+
height: "12",
|
|
85
|
+
viewBox: "0 0 5 12",
|
|
86
|
+
style: {
|
|
87
|
+
verticalAlign: 'middle'
|
|
88
|
+
}
|
|
89
|
+
}, /*#__PURE__*/_react.default.createElement("path", {
|
|
90
|
+
d: "M0.499972716,6 L1.50002728,6 C1.77615459,6 2,6.22384541 2,6.49997272 C2,6.77610002 1.77615459,6.99994543 1.50002728,6.99994543 L0.499972716,6.99994543 C0.22384541,6.99994543 3.38158422e-17,6.77610002 0,6.49997272 C-3.38158422e-17,6.22384541 0.22384541,6 0.499972716,6 Z M0.499972716,3 L1.50002728,3 C1.77615459,3 2,3.22384541 2,3.49997272 C2,3.77610002 1.77615459,3.99994543 1.50002728,3.99994543 L0.499972716,3.99994543 C0.22384541,3.99994543 3.38158422e-17,3.77610002 0,3.49997272 C-3.38158422e-17,3.22384541 0.22384541,3 0.499972716,3 Z M0.499972716,7.28787148e-18 L1.50002728,5.55666624e-14 C1.77615459,7.07214574e-14 2,0.22384541 2,0.499972716 C2,0.776100022 1.77615459,0.999945432 1.50002728,0.999945432 L0.499972716,0.999945432 C0.22384541,0.999945432 3.38158422e-17,0.776100022 0,0.499972716 C-3.38158422e-17,0.22384541 0.22384541,5.0723721e-17 0.499972716,0 Z M0.5,9.00002729 L1.5,9.00002729 C1.77614237,9.00002729 2,9.22388491 2,9.50002729 C2,9.77616966 1.77614237,10.0000273 1.5,10.0000273 L0.5,10.0000273 C0.223857625,10.0000273 3.38176876e-17,9.77616966 0,9.50002729 C-3.38176876e-17,9.22388491 0.223857625,9.00002729 0.5,9.00002729 Z M0.5,12.0000273 L1.5,12.0000273 C1.77614237,12.0000273 2,12.2238849 2,12.5000273 C2,12.7761697 1.77614237,13.0000273 1.5,13.0000273 L0.5,13.0000273 C0.223857625,13.0000273 3.38176876e-17,12.7761697 0,12.5000273 C-3.38176876e-17,12.2238849 0.223857625,12.0000273 0.5,12.0000273 Z M0.5,15.0000273 L1.5,15.0000273 C1.77614237,15.0000273 2,15.2238849 2,15.5000273 C2,15.7761697 1.77614237,16.0000273 1.5,16.0000273 L0.5,16.0000273 C0.223857625,16.0000273 3.38176876e-17,15.7761697 0,15.5000273 C-3.38176876e-17,15.2238849 0.223857625,15.0000273 0.5,15.0000273 Z M3.49997272,6 L4.50002728,6 C4.77615459,6 5,6.22384541 5,6.49997272 C5,6.77610002 4.77615459,6.99994543 4.50002728,6.99994543 L3.49997272,6.99994543 C3.22384541,6.99994543 3,6.77610002 3,6.49997272 C3,6.22384541 3.22384541,6 3.49997272,6 Z M3.49997272,3 L4.50002728,3 C4.77615459,3 5,3.22384541 5,3.49997272 C5,3.77610002 4.77615459,3.99994543 4.50002728,3.99994543 L3.49997272,3.99994543 C3.22384541,3.99994543 3,3.77610002 3,3.49997272 C3,3.22384541 3.22384541,3 3.49997272,3 Z M3.49997272,7.28787148e-18 L4.50002728,5.55666624e-14 C4.77615459,7.07214574e-14 5,0.22384541 5,0.499972716 C5,0.776100022 4.77615459,0.999945432 4.50002728,0.999945432 L3.49997272,0.999945432 C3.22384541,0.999945432 3,0.776100022 3,0.499972716 C3,0.22384541 3.22384541,5.0723721e-17 3.49997272,0 Z M3.5,9.00002729 L4.5,9.00002729 C4.77614237,9.00002729 5,9.22388491 5,9.50002729 C5,9.77616966 4.77614237,10.0000273 4.5,10.0000273 L3.5,10.0000273 C3.22385763,10.0000273 3,9.77616966 3,9.50002729 C3,9.22388491 3.22385763,9.00002729 3.5,9.00002729 Z M3.5,12.0000273 L4.5,12.0000273 C4.77614237,12.0000273 5,12.2238849 5,12.5000273 C5,12.7761697 4.77614237,13.0000273 4.5,13.0000273 L3.5,13.0000273 C3.22385763,13.0000273 3,12.7761697 3,12.5000273 C3,12.2238849 3.22385763,12.0000273 3.5,12.0000273 Z M3.5,15.0000273 L4.5,15.0000273 C4.77614237,15.0000273 5,15.2238849 5,15.5000273 C5,15.7761697 4.77614237,16.0000273 4.5,16.0000273 L3.5,16.0000273 C3.22385763,16.0000273 3,15.7761697 3,15.5000273 C3,15.2238849 3.22385763,15.0000273 3.5,15.0000273 Z"
|
|
91
|
+
}))), left), /*#__PURE__*/_react.default.createElement("div", {
|
|
92
|
+
className: _tabeditor.default['tabitem-right']
|
|
93
|
+
}, right));
|
|
94
|
+
};
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
10
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
|
|
11
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var monaco = _interopRequireWildcard(require("monaco-editor"));
|
|
14
|
+
var _excluded = ["children", "width", "height", "language", "options"];
|
|
15
|
+
var CodeEditor = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
|
|
16
|
+
var children = _ref.children,
|
|
17
|
+
_ref$width = _ref.width,
|
|
18
|
+
width = _ref$width === void 0 ? '100%' : _ref$width,
|
|
19
|
+
_ref$height = _ref.height,
|
|
20
|
+
height = _ref$height === void 0 ? '100%' : _ref$height,
|
|
21
|
+
_ref$language = _ref.language,
|
|
22
|
+
language = _ref$language === void 0 ? 'javascript' : _ref$language,
|
|
23
|
+
_ref$options = _ref.options,
|
|
24
|
+
options = _ref$options === void 0 ? {} : _ref$options,
|
|
25
|
+
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
26
|
+
var editorRef = (0, _react.useRef)(null);
|
|
27
|
+
var editorInstance = (0, _react.useRef)(null);
|
|
28
|
+
(0, _react.useImperativeHandle)(ref, function () {
|
|
29
|
+
return {
|
|
30
|
+
// 直接暴露 editorInstance
|
|
31
|
+
get editor() {
|
|
32
|
+
return editorInstance.current;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
});
|
|
36
|
+
(0, _react.useEffect)(function () {
|
|
37
|
+
if (editorRef.current) {
|
|
38
|
+
var code = _react.default.Children.toArray(children).join('').trim();
|
|
39
|
+
editorInstance.current = monaco.editor.create(editorRef.current, (0, _objectSpread2.default)({
|
|
40
|
+
value: code,
|
|
41
|
+
language: language
|
|
42
|
+
}, options));
|
|
43
|
+
}
|
|
44
|
+
return function () {
|
|
45
|
+
var _editorInstance$curre;
|
|
46
|
+
return (_editorInstance$curre = editorInstance.current) === null || _editorInstance$curre === void 0 ? void 0 : _editorInstance$curre.dispose();
|
|
47
|
+
};
|
|
48
|
+
}, [children]);
|
|
49
|
+
return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({
|
|
50
|
+
ref: editorRef,
|
|
51
|
+
style: {
|
|
52
|
+
width: width,
|
|
53
|
+
height: height
|
|
54
|
+
}
|
|
55
|
+
}, rest));
|
|
56
|
+
});
|
|
57
|
+
var _default = exports.default = CodeEditor;
|