@a2simcode/dui 0.0.3 → 0.0.4

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 ADDED
@@ -0,0 +1,53 @@
1
+ 专有软件许可协议
2
+
3
+ 版权所有 © 2024 苏州极简搭信息技术有限公司。保留所有权利。
4
+
5
+ 本软件及其相关文档("软件")为专有软件,受版权法和国际条约保护。
6
+
7
+ 许可限制:
8
+
9
+ 1. 本软件仅授权给获得明确书面许可的用户使用。
10
+
11
+ 2. 未经版权所有者事先书面同意,您不得:
12
+ - 复制、修改、改编或翻译本软件
13
+ - 对本软件进行反向工程、反编译或反汇编
14
+ - 出租、出借、分发、转让或再许可本软件
15
+ - 删除或修改本软件中的任何版权声明或其他所有权标记
16
+
17
+ 3. 本软件按"现状"提供,不提供任何明示或暗示的保证,包括但不限于适销性、特定用途适用性和非侵权性的保证。
18
+
19
+ 4. 在任何情况下,版权所有者均不对因使用或无法使用本软件而产生的任何索赔、损害或其他责任负责。
20
+
21
+ 5. 本许可协议受中华人民共和国法律管辖。
22
+
23
+ 如需获得使用许可,请联系版权所有者。
24
+
25
+ ---
26
+
27
+ PROPRIETARY SOFTWARE LICENSE
28
+
29
+ Copyright © 2024 Suzhou Jijian-da Information Technology Co., Ltd. All rights reserved.
30
+
31
+ This software and associated documentation files (the "Software") is proprietary
32
+ software protected by copyright laws and international treaties.
33
+
34
+ License Restrictions:
35
+
36
+ 1. This Software is licensed only to users who have obtained explicit written permission.
37
+
38
+ 2. Without prior written consent from the copyright holder, you may not:
39
+ - Copy, modify, adapt, or translate the Software
40
+ - Reverse engineer, decompile, or disassemble the Software
41
+ - Rent, lease, distribute, transfer, or sublicense the Software
42
+ - Remove or modify any copyright notices or other proprietary markings in the Software
43
+
44
+ 3. The Software is provided "as is" without warranty of any kind, express or implied,
45
+ including but not limited to warranties of merchantability, fitness for a particular
46
+ purpose, and non-infringement.
47
+
48
+ 4. In no event shall the copyright holder be liable for any claims, damages, or other
49
+ liability arising from the use or inability to use the Software.
50
+
51
+ 5. This license agreement is governed by the laws of the People's Republic of China.
52
+
53
+ For licensing inquiries, please contact the copyright holder.
@@ -0,0 +1,136 @@
1
+ import { default as formDesignItem } from './src/formDesignItem.vue';
2
+ import { Props as DFormDesignProps } from './src/formDesign.vue';
3
+ declare const DFormDesign: {
4
+ new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins<Readonly<DFormDesignProps> & Readonly<{}>, {
5
+ setTables: (list: import('./src/interface').DbTable[]) => void;
6
+ getSchema: () => {
7
+ ver: string;
8
+ form: Record<string, any>;
9
+ components: import('./src/interface').FormDeisgnSaveComponent[];
10
+ db: Record<string, any>;
11
+ };
12
+ setSchema: (data: Record<string, any>) => void;
13
+ reset: () => void;
14
+ validate: () => boolean;
15
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
16
+ notBindTable: boolean;
17
+ componentToolsList: import('../drag/src/interface').ComponentTool[];
18
+ componentConfigs: Record<string, import('../../components/form/src/interface').FormSchemaConfig[]>;
19
+ componentInit: Function;
20
+ containerAddComponent: Function;
21
+ componentConfigInit: Function;
22
+ componentConfigChange: Function;
23
+ componentConfigValidate: Function;
24
+ }, false, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
25
+ dragContainer: unknown;
26
+ configRef: unknown;
27
+ previewFormLayerRef: unknown;
28
+ previewFormRef: unknown;
29
+ importFormLayerRef: unknown;
30
+ importComponentRef: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{
31
+ componentList: {
32
+ type: import('vue').PropType<Record<string, any>[]>;
33
+ default: () => never[];
34
+ };
35
+ tableList: {
36
+ type: import('vue').PropType<import('./src/interface').DbTable[]>;
37
+ default: () => never[];
38
+ };
39
+ }>> & Readonly<{}>, {
40
+ ok: () => {
41
+ addList: any;
42
+ table: any;
43
+ containerId: any;
44
+ isSubTable: any;
45
+ };
46
+ closed: () => void;
47
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
48
+ componentList: Record<string, any>[];
49
+ tableList: import('./src/interface').DbTable[];
50
+ }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
51
+ formRef: unknown;
52
+ }, any, import('vue').ComponentProvideOptions, {
53
+ P: {};
54
+ B: {};
55
+ D: {};
56
+ C: {};
57
+ M: {};
58
+ Defaults: {};
59
+ }, Readonly<import('vue').ExtractPropTypes<{
60
+ componentList: {
61
+ type: import('vue').PropType<Record<string, any>[]>;
62
+ default: () => never[];
63
+ };
64
+ tableList: {
65
+ type: import('vue').PropType<import('./src/interface').DbTable[]>;
66
+ default: () => never[];
67
+ };
68
+ }>> & Readonly<{}>, {
69
+ ok: () => {
70
+ addList: any;
71
+ table: any;
72
+ containerId: any;
73
+ isSubTable: any;
74
+ };
75
+ closed: () => void;
76
+ }, {}, {}, {}, {
77
+ componentList: Record<string, any>[];
78
+ tableList: import('./src/interface').DbTable[];
79
+ }> | null;
80
+ }, HTMLDivElement, import('vue').ComponentProvideOptions, {
81
+ P: {};
82
+ B: {};
83
+ D: {};
84
+ C: {};
85
+ M: {};
86
+ Defaults: {};
87
+ }, Readonly<DFormDesignProps> & Readonly<{}>, {
88
+ setTables: (list: import('./src/interface').DbTable[]) => void;
89
+ getSchema: () => {
90
+ ver: string;
91
+ form: Record<string, any>;
92
+ components: import('./src/interface').FormDeisgnSaveComponent[];
93
+ db: Record<string, any>;
94
+ };
95
+ setSchema: (data: Record<string, any>) => void;
96
+ reset: () => void;
97
+ validate: () => boolean;
98
+ }, {}, {}, {}, {
99
+ notBindTable: boolean;
100
+ componentToolsList: import('../drag/src/interface').ComponentTool[];
101
+ componentConfigs: Record<string, import('../../components/form/src/interface').FormSchemaConfig[]>;
102
+ componentInit: Function;
103
+ containerAddComponent: Function;
104
+ componentConfigInit: Function;
105
+ componentConfigChange: Function;
106
+ componentConfigValidate: Function;
107
+ }>;
108
+ __isFragment?: never;
109
+ __isTeleport?: never;
110
+ __isSuspense?: never;
111
+ } & import('vue').ComponentOptionsBase<Readonly<DFormDesignProps> & Readonly<{}>, {
112
+ setTables: (list: import('./src/interface').DbTable[]) => void;
113
+ getSchema: () => {
114
+ ver: string;
115
+ form: Record<string, any>;
116
+ components: import('./src/interface').FormDeisgnSaveComponent[];
117
+ db: Record<string, any>;
118
+ };
119
+ setSchema: (data: Record<string, any>) => void;
120
+ reset: () => void;
121
+ validate: () => boolean;
122
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {
123
+ notBindTable: boolean;
124
+ componentToolsList: import('../drag/src/interface').ComponentTool[];
125
+ componentConfigs: Record<string, import('../../components/form/src/interface').FormSchemaConfig[]>;
126
+ componentInit: Function;
127
+ containerAddComponent: Function;
128
+ componentConfigInit: Function;
129
+ componentConfigChange: Function;
130
+ componentConfigValidate: Function;
131
+ }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & {
132
+ install: (app: import('vue').App) => void;
133
+ };
134
+ export default DFormDesign;
135
+ export { formDesignItem };
136
+ export type { DFormDesignProps };
@@ -0,0 +1,91 @@
1
+ import { DbTable, FormDeisgnSaveComponent } from './interface';
2
+ import { ComponentTool } from '../../drag/src/interface';
3
+ import { FormSchemaConfig } from '../../../../packages/components/form/src/interface';
4
+ export interface Props {
5
+ notBindTable?: boolean;
6
+ componentToolsList?: ComponentTool[];
7
+ componentConfigs?: Record<string, FormSchemaConfig[]>;
8
+ componentInit?: Function;
9
+ containerAddComponent?: Function;
10
+ componentConfigInit?: Function;
11
+ componentConfigChange?: Function;
12
+ componentConfigValidate?: Function;
13
+ }
14
+ declare const _default: import('vue').DefineComponent<Props, {
15
+ setTables: (list: DbTable[]) => void;
16
+ getSchema: () => {
17
+ ver: string;
18
+ form: Record<string, any>;
19
+ components: FormDeisgnSaveComponent[];
20
+ db: Record<string, any>;
21
+ };
22
+ setSchema: (data: Record<string, any>) => void;
23
+ reset: () => void;
24
+ validate: () => boolean;
25
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<Props> & Readonly<{}>, {
26
+ notBindTable: boolean;
27
+ componentToolsList: ComponentTool[];
28
+ componentConfigs: Record<string, FormSchemaConfig[]>;
29
+ componentInit: Function;
30
+ containerAddComponent: Function;
31
+ componentConfigInit: Function;
32
+ componentConfigChange: Function;
33
+ componentConfigValidate: Function;
34
+ }, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
35
+ dragContainer: unknown;
36
+ configRef: unknown;
37
+ previewFormLayerRef: unknown;
38
+ previewFormRef: unknown;
39
+ importFormLayerRef: unknown;
40
+ importComponentRef: import('vue').CreateComponentPublicInstanceWithMixins<Readonly<import('vue').ExtractPropTypes<{
41
+ componentList: {
42
+ type: import('vue').PropType<Record<string, any>[]>;
43
+ default: () => never[];
44
+ };
45
+ tableList: {
46
+ type: import('vue').PropType<DbTable[]>;
47
+ default: () => never[];
48
+ };
49
+ }>> & Readonly<{}>, {
50
+ ok: () => {
51
+ addList: any;
52
+ table: any;
53
+ containerId: any;
54
+ isSubTable: any;
55
+ };
56
+ closed: () => void;
57
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {
58
+ componentList: Record<string, any>[];
59
+ tableList: DbTable[];
60
+ }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
61
+ formRef: unknown;
62
+ }, any, import('vue').ComponentProvideOptions, {
63
+ P: {};
64
+ B: {};
65
+ D: {};
66
+ C: {};
67
+ M: {};
68
+ Defaults: {};
69
+ }, Readonly<import('vue').ExtractPropTypes<{
70
+ componentList: {
71
+ type: import('vue').PropType<Record<string, any>[]>;
72
+ default: () => never[];
73
+ };
74
+ tableList: {
75
+ type: import('vue').PropType<DbTable[]>;
76
+ default: () => never[];
77
+ };
78
+ }>> & Readonly<{}>, {
79
+ ok: () => {
80
+ addList: any;
81
+ table: any;
82
+ containerId: any;
83
+ isSubTable: any;
84
+ };
85
+ closed: () => void;
86
+ }, {}, {}, {}, {
87
+ componentList: Record<string, any>[];
88
+ tableList: DbTable[];
89
+ }> | null;
90
+ }, HTMLDivElement>;
91
+ export default _default;
@@ -0,0 +1,43 @@
1
+ import { DesignComponent } from '../../drag/src/interface';
2
+ import { PropType } from 'vue';
3
+ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
4
+ /**
5
+ * @zh 配置项
6
+ */
7
+ componentData: {
8
+ type: PropType<DesignComponent>;
9
+ default: () => {};
10
+ };
11
+ /**
12
+ * @zh 全局配置
13
+ */
14
+ globalConfig: {
15
+ type: ObjectConstructor;
16
+ default: () => {};
17
+ };
18
+ }>, {
19
+ labelWidth: import('vue').ComputedRef<string | undefined>;
20
+ inputConfig: import('vue').ComputedRef<{
21
+ [x: string]: any;
22
+ }>;
23
+ t: (text: string, ...args: string[]) => string;
24
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{
25
+ /**
26
+ * @zh 配置项
27
+ */
28
+ componentData: {
29
+ type: PropType<DesignComponent>;
30
+ default: () => {};
31
+ };
32
+ /**
33
+ * @zh 全局配置
34
+ */
35
+ globalConfig: {
36
+ type: ObjectConstructor;
37
+ default: () => {};
38
+ };
39
+ }>> & Readonly<{}>, {
40
+ componentData: DesignComponent;
41
+ globalConfig: Record<string, any>;
42
+ }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
43
+ export default _default;
@@ -0,0 +1,35 @@
1
+ import { DbTable } from './interface';
2
+ import { PropType } from 'vue';
3
+ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropTypes<{
4
+ componentList: {
5
+ type: PropType<Record<string, any>[]>;
6
+ default: () => never[];
7
+ };
8
+ tableList: {
9
+ type: PropType<DbTable[]>;
10
+ default: () => never[];
11
+ };
12
+ }>, {
13
+ ok: () => {
14
+ addList: any;
15
+ table: any;
16
+ containerId: any;
17
+ isSubTable: any;
18
+ };
19
+ closed: () => void;
20
+ }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<import('vue').ExtractPropTypes<{
21
+ componentList: {
22
+ type: PropType<Record<string, any>[]>;
23
+ default: () => never[];
24
+ };
25
+ tableList: {
26
+ type: PropType<DbTable[]>;
27
+ default: () => never[];
28
+ };
29
+ }>> & Readonly<{}>, {
30
+ componentList: Record<string, any>[];
31
+ tableList: DbTable[];
32
+ }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
33
+ formRef: unknown;
34
+ }, any>;
35
+ export default _default;
@@ -0,0 +1,147 @@
1
+ export interface FormDesignComponents {
2
+ /**
3
+ * @zh 组件集合名称
4
+ */
5
+ name: string;
6
+ /**
7
+ * @zh 组件集
8
+ */
9
+ children: FormDesignComponent[];
10
+ }
11
+ export interface FormDesignComponent {
12
+ /**
13
+ * @zh 组件名
14
+ */
15
+ name: string;
16
+ /**
17
+ * @zh 组件类型
18
+ */
19
+ type: string;
20
+ /**
21
+ * @zh 组件类型
22
+ */
23
+ icon: string;
24
+ /**
25
+ * @zh 组件类型
26
+ */
27
+ dragType?: string;
28
+ /**
29
+ * @zh 组件类型(设计组件)
30
+ */
31
+ componentName?: string;
32
+ /**
33
+ * @zh 组件类型(表单实际运行组件)
34
+ */
35
+ runtimeType?: string;
36
+ /**
37
+ * @zh 是否是输入组件
38
+ */
39
+ isInput?: boolean;
40
+ /**
41
+ * @zh 不绑定数据表
42
+ */
43
+ bindTable?: boolean;
44
+ /**
45
+ * @zh 是否有两个占位提示
46
+ */
47
+ hasTwoPlaceholder?: boolean;
48
+ /**
49
+ * @zh 是否有占位提示
50
+ */
51
+ hasPlaceholder?: boolean;
52
+ /**
53
+ * @zh 是否有span设置
54
+ */
55
+ hasSpan?: boolean;
56
+ /**
57
+ * @zh 是否有标题设置
58
+ */
59
+ hasLabel?: boolean;
60
+ /**
61
+ * @zh 标题项名称
62
+ */
63
+ labelTitle?: string;
64
+ /**
65
+ * @zh 是否有基础设置
66
+ */
67
+ hasBase?: boolean;
68
+ /**
69
+ * @zh 字段类型
70
+ */
71
+ csType?: string;
72
+ /**
73
+ * @zh 字段长度
74
+ */
75
+ fieldLen?: number;
76
+ }
77
+ export interface DbTable {
78
+ /**
79
+ * @zh id
80
+ */
81
+ id: string;
82
+ /**
83
+ * @zh 名称
84
+ */
85
+ name: string;
86
+ /**
87
+ * @zh 说明
88
+ */
89
+ comment: string;
90
+ /**
91
+ * @zh 列
92
+ */
93
+ columns: DbTableColumn[];
94
+ }
95
+ export interface DbTableColumn {
96
+ /**
97
+ * @zh 名称
98
+ */
99
+ name: string;
100
+ /**
101
+ * @zh 类型
102
+ */
103
+ csType: string;
104
+ /**
105
+ * @zh 是否自增
106
+ */
107
+ isIdentity: boolean;
108
+ /**
109
+ * @zh 是否是主键
110
+ */
111
+ isPrimary: boolean;
112
+ /**
113
+ * @zh 是否为空
114
+ */
115
+ isNullable: boolean;
116
+ /**
117
+ * @zh 说明
118
+ */
119
+ coment: string;
120
+ }
121
+ /**
122
+ * @zh 组件保存数据格式
123
+ */
124
+ export interface FormDeisgnSaveComponent {
125
+ id: string;
126
+ name: string;
127
+ type: string;
128
+ runtimeType: string;
129
+ groupId: string;
130
+ config: Record<string, any>;
131
+ containerId: string;
132
+ level: number;
133
+ }
134
+ export interface SchemaRuntimeConfig {
135
+ /**
136
+ * @zh id
137
+ */
138
+ id: string;
139
+ /**
140
+ * @zh 插槽名称
141
+ */
142
+ slot?: string;
143
+ /**
144
+ * @zh 子集
145
+ */
146
+ children: SchemaRuntimeConfig[];
147
+ }
@@ -0,0 +1,21 @@
1
+ import { DesignComponent } from '../../drag/src/interface';
2
+ import { FormDeisgnSaveComponent, FormDesignComponent } from './interface';
3
+ export declare const toFormSchema: (data: {
4
+ ver: string;
5
+ form: Record<string, any>;
6
+ components: FormDeisgnSaveComponent[];
7
+ }) => {
8
+ formConfig: Record<string, any>;
9
+ componentList: SchemaConfig[];
10
+ };
11
+ export declare const toFormDesignSchema: (data: Record<string, any>, componentsMap: Record<string, FormDesignComponent>) => {
12
+ formConfig: Record<string, any>;
13
+ componentList: DesignComponent[];
14
+ componentDic: Record<string, DesignComponent>;
15
+ };
16
+ export declare const toFormSaveSchema: (formConfig: Record<string, any>, componentList: DesignComponent[]) => {
17
+ ver: string;
18
+ form: Record<string, any>;
19
+ components: FormDeisgnSaveComponent[];
20
+ db: Record<string, any>;
21
+ };
@@ -4,7 +4,8 @@ import { default as DFlowDesign } from './flowDesign';
4
4
  import { default as DInputFlow } from './inputFlow';
5
5
  import { default as DLayout } from './layout';
6
6
  import { default as DDraggable } from './draggable';
7
- export { DDrag, dragTool, dragContainer, dragFormList, dragIndexList, DFlowDesign, DInputFlow, DLayout, DDraggable };
7
+ import { default as DFormDesign } from './formDesign';
8
+ export { DDrag, dragTool, dragContainer, dragFormList, dragIndexList, DFlowDesign, DInputFlow, DLayout, DDraggable, DFormDesign };
8
9
  declare const _default: {
9
10
  install: (app: App) => void;
10
11
  };
package/dist/dui.css CHANGED
@@ -1 +1 @@
1
- .d-drag-move{position:fixed;height:24px;line-height:24px;width:64px;background-color:var(--j-color-primary);z-index:999999999999999;color:#fff;text-align:center;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:move;font-size:12px;opacity:.6}.d-drag-component,.d-drag-container,.d-drag-body{position:relative;-webkit-user-select:none;user-select:none}.d-drag-container:after{display:none}.d-drag-container:after,.d-drag-component:after{content:" ";pointer-events:none;height:100%;width:100%;position:absolute;top:0;left:0;border:1px dashed var(--j-color-border)}.d-drag-container.isTopActive>.d-drag-line,.d-drag-component.isTopActive>.d-drag-line,.d-drag-container.isBottomActive>.d-drag-line,.d-drag-component.isBottomActive>.d-drag-line{display:block;content:" ";pointer-events:none;height:100%;width:100%;z-index:100;position:absolute;top:0;left:0;border-top:3px solid var(--j-color-primary)}.d-drag-container.isBottomActive>.d-drag-line,.d-drag-component.isBottomActive>.d-drag-line{border-top:0;border-bottom:3px solid var(--j-color-primary)}.d-drag-container.active:before,.d-drag-component.active:before{display:block;content:" ";pointer-events:none;height:100%;width:100%;z-index:99;background-color:var(--j-color-primary);opacity:.1;position:absolute;top:0;left:0}.d-drag-container:not(.active).hovered:after,.d-drag-component:not(.active).hovered:after{border:1px dashed var(--j-color-primary);display:block}.d-drag-container:not(.active).selected:after,.d-drag-component:not(.active).selected:after{display:block;border:2px solid var(--j-color-primary)}.d-drag-container:not(.active).selected>.d-drag-btns,.d-drag-component:not(.active).selected>.d-drag-btns{display:flex}.d-drag-container.isMoveingInTopLevel .d-drag-container:after,.d-drag-container.isMoveingInTopLevel .d-drag-component:after,.d-drag-container.isMoveingInTopLevel .d-drag-container .d-drag-btns,.d-drag-container.isMoveingInTopLevel .d-drag-component .d-drag-btns{display:none!important}.d-drag-container.isMoveingInTopLevel .d-drag-btns{display:none!important}.d-drag-container.isMoveingInTopLevel:after{display:none!important}.d-drag-btns{position:absolute;right:0;z-index:100;display:none}.d-drag-btns-pname{position:absolute;top:20px;left:0;display:none;padding-top:4px}.d-drag-btns-pname .d-drag-btn{margin-bottom:4px}.d-drag-btns-pname:hover,.d-drag-btns-names:hover .d-drag-btns-pname{display:block}.d-drag-container.isBottomToolBar>.d-drag-btns,.d-drag-component.isBottomToolBar>.d-drag-btns{bottom:-24px}.d-drag-container:not(.isBottomToolBar)>.d-drag-btns,.d-drag-component:not(.isBottomToolBar)>.d-drag-btns{top:-24px}.d-drag-container.isTopLevel>.d-drag-btns{top:4px;padding-right:4px}.d-drag-btn{padding:0 4px!important}.d-drag-mask{position:absolute;top:0;left:0;height:100%;width:100%;z-index:98}.d-drag-tool{position:relative;cursor:grab;-webkit-user-select:none;user-select:none}.d-flow-node-menus{background-color:var(--j-color-bg-container);width:160px;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:4px}.d-flow-node-menus-item{display:flex;align-items:center;border-radius:8px;height:40px;cursor:pointer;width:100%;padding:0 8px}.d-flow-node-menus-item:hover{background-color:var(--j-color-hover)}.d-flow-node-menus-item-name{flex:1;font-size:14px;color:var(--j-color-text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-node-menus-item-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:8px;box-shadow:0 2px 4px #0000001a}.d-flow-step{position:relative;width:172px;height:40px;background-color:var(--j-color-bg-container);border:1px solid transparent;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center}.d-flow-step-name{flex:1;font-size:14px;color:var(--j-color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-step-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 8px;box-shadow:0 2px 4px #0000001a}.d-flow-step-handle-plus{display:none;pointer-events:all;cursor:pointer;color:var(--j-color-primary)}.d-flow-step-target-handle,.d-flow-step-source-handle{border:0!important;width:2px!important;min-width:2px!important;height:8px!important;border-radius:0!important;background-color:transparent!important}.d-flow-step-target-handle:after,.d-flow-step-source-handle:after{content:" ";display:block;position:absolute;top:50%;left:50%;margin-top:-4px;margin-left:-1px;width:2px;height:8px;background-color:var(--j-color-primary)}.d-flow-step-popper{padding:0!important;border:0!important;box-shadow:none!important;background:transparent!important}.d-flow-step-tooltip{background:var(--j-color-bg-container)!important;border:0!important;box-shadow:0 2px 8px #00000026!important}.d-flow-step-dropdown{background:var(--j-color-bg-container)!important;border:0!important;box-shadow:0 2px 8px #00000026!important;border-radius:8px!important}.d-flow-step-dropdown .el-dropdown-menu{background:var(--j-color-bg-container)!important;border-radius:8px!important}.d-flow-step-dropdown .el-dropdown-menu__item{color:var(--j-color-danger)}.d-flow-step-dropdown .el-dropdown-menu__item:not(.is-disabled):focus,.d-flow-step-dropdown .el-dropdown-menu__item:not(.is-disabled):hover{background-color:var(--j-color-hover);color:var(--j-color-danger-hover)}.vue-flow__node.selected .d-flow-step{border-color:var(--j-color-primary)}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd),.vue-flow__node.selected .d-flow-step-source-handle{height:16px!important;width:16px!important;background-color:#fff!important;border-radius:100%!important}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd):after,.vue-flow__node.selected .d-flow-step-source-handle:after{display:none!important}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd) .d-flow-step-handle-plus,.vue-flow__node.selected .d-flow-step-source-handle .d-flow-step-handle-plus{display:block!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd),.vue-flow__node:hover .d-flow-step-source-handle{height:16px!important;width:16px!important;background-color:#fff!important;border-radius:100%!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd):after,.vue-flow__node:hover .d-flow-step-source-handle:after{display:none!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd) .d-flow-step-handle-plus,.vue-flow__node:hover .d-flow-step-source-handle .d-flow-step-handle-plus{display:block!important}.vue-flow__node:hover .d-flow-step-target-handle{height:16px!important;width:16px!important}.d-flow-edge-button{height:16px;width:16px;background-color:#fff;border-radius:100%;cursor:pointer;color:var(--j-color-primary)}.d-flow-edge-button:hover{display:block!important}.vue-flow{position:relative;width:100%;height:100%;overflow:hidden;z-index:0;direction:ltr}.vue-flow__container{position:absolute;height:100%;width:100%;left:0;top:0}.vue-flow__pane{z-index:1}.vue-flow__pane.draggable{cursor:grab}.vue-flow__pane.selection{cursor:pointer}.vue-flow__pane.dragging{cursor:grabbing}.vue-flow__transformationpane{transform-origin:0 0;z-index:2;pointer-events:none}.vue-flow__viewport{z-index:4;overflow:clip}.vue-flow__selection{z-index:6}.vue-flow__edge-labels{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible{outline:none}.vue-flow .vue-flow__edges{pointer-events:none;overflow:visible}.vue-flow__edge-path,.vue-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.vue-flow__edge{pointer-events:visibleStroke;cursor:pointer}.vue-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__edge.animated path.vue-flow__edge-interaction{stroke-dasharray:none;animation:none}.vue-flow__edge.inactive{pointer-events:none}.vue-flow__edge.selected,.vue-flow__edge:focus,.vue-flow__edge:focus-visible{outline:none}.vue-flow__edge.selected .vue-flow__edge-path,.vue-flow__edge:focus .vue-flow__edge-path,.vue-flow__edge:focus-visible .vue-flow__edge-path{stroke:#555}.vue-flow__edge-textwrapper{pointer-events:all}.vue-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__connection{pointer-events:none}.vue-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__connectionline{z-index:1001}.vue-flow__nodes{pointer-events:none;transform-origin:0 0}.vue-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.vue-flow__node.draggable{cursor:grab;pointer-events:all}.vue-flow__node.draggable.dragging{cursor:grabbing}.vue-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.vue-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.vue-flow__nodesselection-rect.dragging{cursor:grabbing}.vue-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px}.vue-flow__handle.connectable{pointer-events:all;cursor:crosshair}.vue-flow__handle-bottom{left:50%;bottom:0;transform:translate(-50%,50%)}.vue-flow__handle-top{left:50%;top:0;transform:translate(-50%,-50%)}.vue-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.vue-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.vue-flow__edgeupdater{cursor:move;pointer-events:all}.vue-flow__panel{position:absolute;z-index:5;margin:15px}.vue-flow__panel.top{top:0}.vue-flow__panel.bottom{bottom:0}.vue-flow__panel.left{left:0}.vue-flow__panel.right{right:0}.vue-flow__panel.center{left:50%;transform:translate(-50%)}@keyframes dashdraw{0%{stroke-dashoffset:10}}:root{--vf-node-bg: #fff;--vf-node-text: #222;--vf-connection-path: #b1b1b7;--vf-handle: #555}.vue-flow__edge.updating .vue-flow__edge-path{stroke:#777}.vue-flow__edge-text{font-size:10px}.vue-flow__edge-textbg{fill:#fff}.vue-flow__connection-path{stroke:var(--vf-connection-path)}.vue-flow__node{cursor:grab}.vue-flow__node.selectable:focus,.vue-flow__node.selectable:focus-visible{outline:none}.vue-flow__node-default,.vue-flow__node-input,.vue-flow__node-output{padding:10px;border-radius:3px;width:150px;font-size:12px;text-align:center;border-width:1px;border-style:solid;color:var(--vf-node-text);background-color:var(--vf-node-bg);border-color:var(--vf-node-color)}.vue-flow__node-default.selected,.vue-flow__node-default.selected:hover,.vue-flow__node-input.selected,.vue-flow__node-input.selected:hover,.vue-flow__node-output.selected,.vue-flow__node-output.selected:hover{box-shadow:0 0 0 .5px var(--vf-box-shadow)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible,.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible,.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid #555}.vue-flow__node-default .vue-flow__handle,.vue-flow__node-input .vue-flow__handle,.vue-flow__node-output .vue-flow__handle{background:var(--vf-handle)}.vue-flow__node-default.selectable:hover,.vue-flow__node-input.selectable:hover,.vue-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.vue-flow__node-input{--vf-node-color: var(--vf-node-color, #0041d0);--vf-handle: var(--vf-node-color, #0041d0);--vf-box-shadow: var(--vf-node-color, #0041d0);background:var(--vf-node-bg);border-color:var(--vf-node-color, #0041d0)}.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible{outline:none;border:1px solid var(--vf-node-color, #0041d0)}.vue-flow__node-default{--vf-handle: var(--vf-node-color, #1a192b);--vf-box-shadow: var(--vf-node-color, #1a192b);background:var(--vf-node-bg);border-color:var(--vf-node-color, #1a192b)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible{outline:none;border:1px solid var(--vf-node-color, #1a192b)}.vue-flow__node-output{--vf-handle: var(--vf-node-color, #ff0072);--vf-box-shadow: var(--vf-node-color, #ff0072);background:var(--vf-node-bg);border-color:var(--vf-node-color, #ff0072)}.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid var(--vf-node-color, #ff0072)}.vue-flow__nodesselection-rect,.vue-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible,.vue-flow__selection:focus,.vue-flow__selection:focus-visible{outline:none}.vue-flow__handle{width:6px;height:6px;background:var(--vf-handle);border:1px solid #fff;border-radius:100%}.vue-flow__controls{box-shadow:0 0 2px 1px #00000014}.vue-flow__controls-button{background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:5px}.vue-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.vue-flow__controls-button:hover{background:#f4f4f4}.vue-flow__controls-button:disabled{pointer-events:none}.vue-flow__controls-button:disabled svg{fill-opacity:.4}.d-flow-design{background-color:var(--j-color-bg);display:flex;height:100%;width:100%}.d-flow-design-canvas{flex:1;width:0;min-width:0}.d-flow-design-right{position:relative;height:100%;background-color:var(--j-color-bg-container);display:flex;flex-direction:column;transition:all .3s;width:320px;border-left:1px solid var(--j-color-border)}.d-flow-design-title{position:relative;height:40px;width:100%;display:flex;align-items:center;border-bottom:1px solid var(--j-color-border);overflow:hidden}.d-flow-design-title-name{flex:1;font-size:14px;color:var(--j-color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-design-title-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 8px;box-shadow:0 2px 4px #0000001a}.d-flow-design-panel{position:relative;height:0;width:100%;flex:1;overflow:auto;overflow-x:hidden}.vue-flow__edge.selected .vue-flow__edge-path,.vue-flow__edge:focus .vue-flow__edge-path,.vue-flow__edge:focus-visible .vue-flow__edge-path{stroke:var(--j-color-primary)!important}.grid-stack{position:relative}.grid-stack-rtl{direction:ltr}.grid-stack-rtl>.grid-stack-item{direction:rtl}.grid-stack-placeholder>.placeholder-content{background-color:#0000001a;margin:0;position:absolute;width:auto;z-index:0!important}.grid-stack>.grid-stack-item{position:absolute;padding:0;top:0;left:0;width:var(--gs-column-width);height:var(--gs-cell-height)}.grid-stack>.grid-stack-item>.grid-stack-item-content{margin:0;position:absolute;width:auto;overflow-x:hidden;overflow-y:auto}.grid-stack>.grid-stack-item.size-to-content:not(.size-to-content-max)>.grid-stack-item-content{overflow-y:hidden}.grid-stack>.grid-stack-item>.grid-stack-item-content,.grid-stack>.grid-stack-placeholder>.placeholder-content{top:var(--gs-item-margin-top);right:var(--gs-item-margin-right);bottom:var(--gs-item-margin-bottom);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-handle{position:absolute;font-size:.1px;display:block;-ms-touch-action:none;touch-action:none}.grid-stack-item.ui-resizable-autohide>.ui-resizable-handle,.grid-stack-item.ui-resizable-disabled>.ui-resizable-handle{display:none}.grid-stack-item>.ui-resizable-ne,.grid-stack-item>.ui-resizable-nw,.grid-stack-item>.ui-resizable-se,.grid-stack-item>.ui-resizable-sw{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%23666" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" viewBox="0 0 20 20"><path d="m10 3 2 2H8l2-2v14l-2-2h4l-2 2"/></svg>');background-repeat:no-repeat;background-position:center}.grid-stack-item>.ui-resizable-ne{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-sw{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-nw{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-se{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-nw{cursor:nw-resize;width:20px;height:20px;top:var(--gs-item-margin-top);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-n{cursor:n-resize;height:10px;top:var(--gs-item-margin-top);left:25px;right:25px}.grid-stack-item>.ui-resizable-ne{cursor:ne-resize;width:20px;height:20px;top:var(--gs-item-margin-top);right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-e{cursor:e-resize;width:10px;top:15px;bottom:15px;right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-se{cursor:se-resize;width:20px;height:20px;bottom:var(--gs-item-margin-bottom);right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-s{cursor:s-resize;height:10px;left:25px;bottom:var(--gs-item-margin-bottom);right:25px}.grid-stack-item>.ui-resizable-sw{cursor:sw-resize;width:20px;height:20px;bottom:var(--gs-item-margin-bottom);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-w{cursor:w-resize;width:10px;top:15px;bottom:15px;left:var(--gs-item-margin-left)}.grid-stack-item.ui-draggable-dragging>.ui-resizable-handle{display:none!important}.grid-stack-item.ui-draggable-dragging{will-change:left,top}.grid-stack-item.ui-resizable-resizing{will-change:width,height}.ui-draggable-dragging,.ui-resizable-resizing{z-index:10000}.ui-draggable-dragging>.grid-stack-item-content,.ui-resizable-resizing>.grid-stack-item-content{box-shadow:1px 4px 6px #0003;opacity:.8}.grid-stack-animate,.grid-stack-animate .grid-stack-item{transition:left .3s,top .3s,height .3s,width .3s}.grid-stack-animate .grid-stack-item.grid-stack-placeholder,.grid-stack-animate .grid-stack-item.ui-draggable-dragging,.grid-stack-animate .grid-stack-item.ui-resizable-resizing{transition:left 0s,top 0s,height 0s,width 0s}.grid-stack>.grid-stack-item[gs-y="0"]{top:0}.grid-stack>.grid-stack-item[gs-x="0"]{left:0}.d-layout{width:100%;height:100%;background-color:var(--j-color-bg)}.d-layout .d-layout-item{background-color:var(--j-color-bg-container);border:1px solid var(--j-color-border);border-radius:4px;padding:8px;box-sizing:border-box}.d-layout .d-layout-item:hover{border-color:var(--j-color-primary)}.d-layout .d-layout-item.ui-draggable-dragging{opacity:.8;z-index:1000}.d-layout .d-layout-item.ui-resizable-resizing{opacity:.8}.d-draggable{position:absolute;padding:8px;cursor:move;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;box-sizing:initial;border:1px dashed transparent}.d-draggable__mask{position:absolute;width:100%;height:100%;border:0;inset:0;z-index:1}.d-draggable--active{cursor:move;border:1px dashed var(--j-color-primary);background-color:var(--j-color-primary-bg)}.d-draggable--pt{border:1px dashed var(--j-color-border);padding:0!important}.d-draggable--active.d-draggable--pt{border:1px dashed transparent;background-color:transparent}.d-draggable--move{opacity:.6;background-color:var(--j-color-primary-bg)}.d-draggable--click{cursor:pointer}.d-draggable__line--left{position:absolute;border-top:1px dashed var(--j-color-primary);width:10000px;height:0;top:-1px;transform:translate(-100%)}.d-draggable__line--top{position:absolute;border-left:1px dashed var(--j-color-primary);width:0;height:10000px;left:-1px;transform:translateY(-100%)}.d-draggable__line--label{top:-8px;left:-8px;position:absolute;padding:5px;transform:translate(-100%,-100%);color:var(--j-color-primary);font-size:16px;white-space:nowrap;cursor:move}.d-draggable__range{position:absolute;width:10px;height:10px;border-radius:100%;z-index:9999;background-color:var(--j-color-primary)}.d-draggable__range--left,.d-draggable__range--right{top:50%;transform:translateY(-50%)}.d-draggable__range--left:hover,.d-draggable__range--right:hover{cursor:ew-resize}.d-draggable__range--left{left:-5px}.d-draggable__range--right{right:-5px}.d-draggable__range--top,.d-draggable__range--bottom{left:50%;transform:translate(-50%)}.d-draggable__range--top:hover,.d-draggable__range--bottom:hover{cursor:ns-resize}.d-draggable__range--top{top:-5px}.d-draggable__range--bottom{bottom:-5px}.d-draggable__range--bottom-right:hover,.d-draggable__range--top-left:hover{cursor:nwse-resize}.d-draggable__range--bottom-left:hover,.d-draggable__range--top-right:hover{cursor:nesw-resize}.d-draggable__range--top-right{top:-5px;right:-5px}.d-draggable__range--top-left{top:-5px;left:-5px}.d-draggable__range--bottom-right{bottom:-5px;right:-5px}.d-draggable__range--bottom-left{bottom:-5px;left:-5px}
1
+ .d-drag-move{position:fixed;height:24px;line-height:24px;width:64px;background-color:var(--j-color-primary);z-index:999999999999999;color:#fff;text-align:center;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:move;font-size:12px;opacity:.6}.d-drag-component,.d-drag-container,.d-drag-body{position:relative;-webkit-user-select:none;user-select:none}.d-drag-container:after{display:none}.d-drag-container:after,.d-drag-component:after{content:" ";pointer-events:none;height:100%;width:100%;position:absolute;top:0;left:0;border:1px dashed var(--j-color-border)}.d-drag-container.isTopActive>.d-drag-line,.d-drag-component.isTopActive>.d-drag-line,.d-drag-container.isBottomActive>.d-drag-line,.d-drag-component.isBottomActive>.d-drag-line{display:block;content:" ";pointer-events:none;height:100%;width:100%;z-index:100;position:absolute;top:0;left:0;border-top:3px solid var(--j-color-primary)}.d-drag-container.isBottomActive>.d-drag-line,.d-drag-component.isBottomActive>.d-drag-line{border-top:0;border-bottom:3px solid var(--j-color-primary)}.d-drag-container.active:before,.d-drag-component.active:before{display:block;content:" ";pointer-events:none;height:100%;width:100%;z-index:99;background-color:var(--j-color-primary);opacity:.1;position:absolute;top:0;left:0}.d-drag-container:not(.active).hovered:after,.d-drag-component:not(.active).hovered:after{border:1px dashed var(--j-color-primary);display:block}.d-drag-container:not(.active).selected:after,.d-drag-component:not(.active).selected:after{display:block;border:2px solid var(--j-color-primary)}.d-drag-container:not(.active).selected>.d-drag-btns,.d-drag-component:not(.active).selected>.d-drag-btns{display:flex}.d-drag-container.isMoveingInTopLevel .d-drag-container:after,.d-drag-container.isMoveingInTopLevel .d-drag-component:after,.d-drag-container.isMoveingInTopLevel .d-drag-container .d-drag-btns,.d-drag-container.isMoveingInTopLevel .d-drag-component .d-drag-btns{display:none!important}.d-drag-container.isMoveingInTopLevel .d-drag-btns{display:none!important}.d-drag-container.isMoveingInTopLevel:after{display:none!important}.d-drag-btns{position:absolute;right:0;z-index:100;display:none}.d-drag-btns-pname{position:absolute;top:20px;left:0;display:none;padding-top:4px}.d-drag-btns-pname .d-drag-btn{margin-bottom:4px}.d-drag-btns-pname:hover,.d-drag-btns-names:hover .d-drag-btns-pname{display:block}.d-drag-container.isBottomToolBar>.d-drag-btns,.d-drag-component.isBottomToolBar>.d-drag-btns{bottom:-24px}.d-drag-container:not(.isBottomToolBar)>.d-drag-btns,.d-drag-component:not(.isBottomToolBar)>.d-drag-btns{top:-24px}.d-drag-container.isTopLevel>.d-drag-btns{top:4px;padding-right:4px}.d-drag-btn{padding:0 4px!important}.d-drag-mask{position:absolute;top:0;left:0;height:100%;width:100%;z-index:98}.d-drag-tool{position:relative;cursor:grab;-webkit-user-select:none;user-select:none}.d-flow-node-menus{background-color:var(--j-color-bg-container);width:160px;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:4px}.d-flow-node-menus-item{display:flex;align-items:center;border-radius:8px;height:40px;cursor:pointer;width:100%;padding:0 8px}.d-flow-node-menus-item:hover{background-color:var(--j-color-hover)}.d-flow-node-menus-item-name{flex:1;font-size:14px;color:var(--j-color-text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-node-menus-item-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:8px;box-shadow:0 2px 4px #0000001a}.d-flow-step{position:relative;width:172px;height:40px;background-color:var(--j-color-bg-container);border:1px solid transparent;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center}.d-flow-step-name{flex:1;font-size:14px;color:var(--j-color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-step-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 8px;box-shadow:0 2px 4px #0000001a}.d-flow-step-handle-plus{display:none;pointer-events:all;cursor:pointer;color:var(--j-color-primary)}.d-flow-step-target-handle,.d-flow-step-source-handle{border:0!important;width:2px!important;min-width:2px!important;height:8px!important;border-radius:0!important;background-color:transparent!important}.d-flow-step-target-handle:after,.d-flow-step-source-handle:after{content:" ";display:block;position:absolute;top:50%;left:50%;margin-top:-4px;margin-left:-1px;width:2px;height:8px;background-color:var(--j-color-primary)}.d-flow-step-popper{padding:0!important;border:0!important;box-shadow:none!important;background:transparent!important}.d-flow-step-tooltip{background:var(--j-color-bg-container)!important;border:0!important;box-shadow:0 2px 8px #00000026!important}.d-flow-step-dropdown{background:var(--j-color-bg-container)!important;border:0!important;box-shadow:0 2px 8px #00000026!important;border-radius:8px!important}.d-flow-step-dropdown .el-dropdown-menu{background:var(--j-color-bg-container)!important;border-radius:8px!important}.d-flow-step-dropdown .el-dropdown-menu__item{color:var(--j-color-danger)}.d-flow-step-dropdown .el-dropdown-menu__item:not(.is-disabled):focus,.d-flow-step-dropdown .el-dropdown-menu__item:not(.is-disabled):hover{background-color:var(--j-color-hover);color:var(--j-color-danger-hover)}.vue-flow__node.selected .d-flow-step{border-color:var(--j-color-primary)}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd),.vue-flow__node.selected .d-flow-step-source-handle{height:16px!important;width:16px!important;background-color:#fff!important;border-radius:100%!important}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd):after,.vue-flow__node.selected .d-flow-step-source-handle:after{display:none!important}.vue-flow__node.selected .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd) .d-flow-step-handle-plus,.vue-flow__node.selected .d-flow-step-source-handle .d-flow-step-handle-plus{display:block!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd),.vue-flow__node:hover .d-flow-step-source-handle{height:16px!important;width:16px!important;background-color:#fff!important;border-radius:100%!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd):after,.vue-flow__node:hover .d-flow-step-source-handle:after{display:none!important}.vue-flow__node:hover .d-flow-step-target-handle:not(.d-flow-step-target-handle-notadd) .d-flow-step-handle-plus,.vue-flow__node:hover .d-flow-step-source-handle .d-flow-step-handle-plus{display:block!important}.vue-flow__node:hover .d-flow-step-target-handle{height:16px!important;width:16px!important}.d-flow-edge-button{height:16px;width:16px;background-color:#fff;border-radius:100%;cursor:pointer;color:var(--j-color-primary)}.d-flow-edge-button:hover{display:block!important}.vue-flow{position:relative;width:100%;height:100%;overflow:hidden;z-index:0;direction:ltr}.vue-flow__container{position:absolute;height:100%;width:100%;left:0;top:0}.vue-flow__pane{z-index:1}.vue-flow__pane.draggable{cursor:grab}.vue-flow__pane.selection{cursor:pointer}.vue-flow__pane.dragging{cursor:grabbing}.vue-flow__transformationpane{transform-origin:0 0;z-index:2;pointer-events:none}.vue-flow__viewport{z-index:4;overflow:clip}.vue-flow__selection{z-index:6}.vue-flow__edge-labels{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible{outline:none}.vue-flow .vue-flow__edges{pointer-events:none;overflow:visible}.vue-flow__edge-path,.vue-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.vue-flow__edge{pointer-events:visibleStroke;cursor:pointer}.vue-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__edge.animated path.vue-flow__edge-interaction{stroke-dasharray:none;animation:none}.vue-flow__edge.inactive{pointer-events:none}.vue-flow__edge.selected,.vue-flow__edge:focus,.vue-flow__edge:focus-visible{outline:none}.vue-flow__edge.selected .vue-flow__edge-path,.vue-flow__edge:focus .vue-flow__edge-path,.vue-flow__edge:focus-visible .vue-flow__edge-path{stroke:#555}.vue-flow__edge-textwrapper{pointer-events:all}.vue-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__connection{pointer-events:none}.vue-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__connectionline{z-index:1001}.vue-flow__nodes{pointer-events:none;transform-origin:0 0}.vue-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.vue-flow__node.draggable{cursor:grab;pointer-events:all}.vue-flow__node.draggable.dragging{cursor:grabbing}.vue-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.vue-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.vue-flow__nodesselection-rect.dragging{cursor:grabbing}.vue-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px}.vue-flow__handle.connectable{pointer-events:all;cursor:crosshair}.vue-flow__handle-bottom{left:50%;bottom:0;transform:translate(-50%,50%)}.vue-flow__handle-top{left:50%;top:0;transform:translate(-50%,-50%)}.vue-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.vue-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.vue-flow__edgeupdater{cursor:move;pointer-events:all}.vue-flow__panel{position:absolute;z-index:5;margin:15px}.vue-flow__panel.top{top:0}.vue-flow__panel.bottom{bottom:0}.vue-flow__panel.left{left:0}.vue-flow__panel.right{right:0}.vue-flow__panel.center{left:50%;transform:translate(-50%)}@keyframes dashdraw{0%{stroke-dashoffset:10}}:root{--vf-node-bg: #fff;--vf-node-text: #222;--vf-connection-path: #b1b1b7;--vf-handle: #555}.vue-flow__edge.updating .vue-flow__edge-path{stroke:#777}.vue-flow__edge-text{font-size:10px}.vue-flow__edge-textbg{fill:#fff}.vue-flow__connection-path{stroke:var(--vf-connection-path)}.vue-flow__node{cursor:grab}.vue-flow__node.selectable:focus,.vue-flow__node.selectable:focus-visible{outline:none}.vue-flow__node-default,.vue-flow__node-input,.vue-flow__node-output{padding:10px;border-radius:3px;width:150px;font-size:12px;text-align:center;border-width:1px;border-style:solid;color:var(--vf-node-text);background-color:var(--vf-node-bg);border-color:var(--vf-node-color)}.vue-flow__node-default.selected,.vue-flow__node-default.selected:hover,.vue-flow__node-input.selected,.vue-flow__node-input.selected:hover,.vue-flow__node-output.selected,.vue-flow__node-output.selected:hover{box-shadow:0 0 0 .5px var(--vf-box-shadow)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible,.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible,.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid #555}.vue-flow__node-default .vue-flow__handle,.vue-flow__node-input .vue-flow__handle,.vue-flow__node-output .vue-flow__handle{background:var(--vf-handle)}.vue-flow__node-default.selectable:hover,.vue-flow__node-input.selectable:hover,.vue-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.vue-flow__node-input{--vf-node-color: var(--vf-node-color, #0041d0);--vf-handle: var(--vf-node-color, #0041d0);--vf-box-shadow: var(--vf-node-color, #0041d0);background:var(--vf-node-bg);border-color:var(--vf-node-color, #0041d0)}.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible{outline:none;border:1px solid var(--vf-node-color, #0041d0)}.vue-flow__node-default{--vf-handle: var(--vf-node-color, #1a192b);--vf-box-shadow: var(--vf-node-color, #1a192b);background:var(--vf-node-bg);border-color:var(--vf-node-color, #1a192b)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible{outline:none;border:1px solid var(--vf-node-color, #1a192b)}.vue-flow__node-output{--vf-handle: var(--vf-node-color, #ff0072);--vf-box-shadow: var(--vf-node-color, #ff0072);background:var(--vf-node-bg);border-color:var(--vf-node-color, #ff0072)}.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid var(--vf-node-color, #ff0072)}.vue-flow__nodesselection-rect,.vue-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible,.vue-flow__selection:focus,.vue-flow__selection:focus-visible{outline:none}.vue-flow__handle{width:6px;height:6px;background:var(--vf-handle);border:1px solid #fff;border-radius:100%}.vue-flow__controls{box-shadow:0 0 2px 1px #00000014}.vue-flow__controls-button{background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:5px}.vue-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.vue-flow__controls-button:hover{background:#f4f4f4}.vue-flow__controls-button:disabled{pointer-events:none}.vue-flow__controls-button:disabled svg{fill-opacity:.4}.d-flow-design{background-color:var(--j-color-bg);display:flex;height:100%;width:100%}.d-flow-design-canvas{flex:1;width:0;min-width:0}.d-flow-design-right{position:relative;height:100%;background-color:var(--j-color-bg-container);display:flex;flex-direction:column;transition:all .3s;width:320px;border-left:1px solid var(--j-color-border)}.d-flow-design-title{position:relative;height:40px;width:100%;display:flex;align-items:center;border-bottom:1px solid var(--j-color-border);overflow:hidden}.d-flow-design-title-name{flex:1;font-size:14px;color:var(--j-color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.d-flow-design-title-icon{width:24px;height:24px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 8px;box-shadow:0 2px 4px #0000001a}.d-flow-design-panel{position:relative;height:0;width:100%;flex:1;overflow:auto;overflow-x:hidden}.vue-flow__edge.selected .vue-flow__edge-path,.vue-flow__edge:focus .vue-flow__edge-path,.vue-flow__edge:focus-visible .vue-flow__edge-path{stroke:var(--j-color-primary)!important}.grid-stack{position:relative}.grid-stack-rtl{direction:ltr}.grid-stack-rtl>.grid-stack-item{direction:rtl}.grid-stack-placeholder>.placeholder-content{background-color:#0000001a;margin:0;position:absolute;width:auto;z-index:0!important}.grid-stack>.grid-stack-item{position:absolute;padding:0;top:0;left:0;width:var(--gs-column-width);height:var(--gs-cell-height)}.grid-stack>.grid-stack-item>.grid-stack-item-content{margin:0;position:absolute;width:auto;overflow-x:hidden;overflow-y:auto}.grid-stack>.grid-stack-item.size-to-content:not(.size-to-content-max)>.grid-stack-item-content{overflow-y:hidden}.grid-stack>.grid-stack-item>.grid-stack-item-content,.grid-stack>.grid-stack-placeholder>.placeholder-content{top:var(--gs-item-margin-top);right:var(--gs-item-margin-right);bottom:var(--gs-item-margin-bottom);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-handle{position:absolute;font-size:.1px;display:block;-ms-touch-action:none;touch-action:none}.grid-stack-item.ui-resizable-autohide>.ui-resizable-handle,.grid-stack-item.ui-resizable-disabled>.ui-resizable-handle{display:none}.grid-stack-item>.ui-resizable-ne,.grid-stack-item>.ui-resizable-nw,.grid-stack-item>.ui-resizable-se,.grid-stack-item>.ui-resizable-sw{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%23666" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" viewBox="0 0 20 20"><path d="m10 3 2 2H8l2-2v14l-2-2h4l-2 2"/></svg>');background-repeat:no-repeat;background-position:center}.grid-stack-item>.ui-resizable-ne{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-sw{transform:rotate(45deg)}.grid-stack-item>.ui-resizable-nw{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-se{transform:rotate(-45deg)}.grid-stack-item>.ui-resizable-nw{cursor:nw-resize;width:20px;height:20px;top:var(--gs-item-margin-top);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-n{cursor:n-resize;height:10px;top:var(--gs-item-margin-top);left:25px;right:25px}.grid-stack-item>.ui-resizable-ne{cursor:ne-resize;width:20px;height:20px;top:var(--gs-item-margin-top);right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-e{cursor:e-resize;width:10px;top:15px;bottom:15px;right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-se{cursor:se-resize;width:20px;height:20px;bottom:var(--gs-item-margin-bottom);right:var(--gs-item-margin-right)}.grid-stack-item>.ui-resizable-s{cursor:s-resize;height:10px;left:25px;bottom:var(--gs-item-margin-bottom);right:25px}.grid-stack-item>.ui-resizable-sw{cursor:sw-resize;width:20px;height:20px;bottom:var(--gs-item-margin-bottom);left:var(--gs-item-margin-left)}.grid-stack-item>.ui-resizable-w{cursor:w-resize;width:10px;top:15px;bottom:15px;left:var(--gs-item-margin-left)}.grid-stack-item.ui-draggable-dragging>.ui-resizable-handle{display:none!important}.grid-stack-item.ui-draggable-dragging{will-change:left,top}.grid-stack-item.ui-resizable-resizing{will-change:width,height}.ui-draggable-dragging,.ui-resizable-resizing{z-index:10000}.ui-draggable-dragging>.grid-stack-item-content,.ui-resizable-resizing>.grid-stack-item-content{box-shadow:1px 4px 6px #0003;opacity:.8}.grid-stack-animate,.grid-stack-animate .grid-stack-item{transition:left .3s,top .3s,height .3s,width .3s}.grid-stack-animate .grid-stack-item.grid-stack-placeholder,.grid-stack-animate .grid-stack-item.ui-draggable-dragging,.grid-stack-animate .grid-stack-item.ui-resizable-resizing{transition:left 0s,top 0s,height 0s,width 0s}.grid-stack>.grid-stack-item[gs-y="0"]{top:0}.grid-stack>.grid-stack-item[gs-x="0"]{left:0}.d-layout{width:100%;height:100%;background-color:var(--j-color-bg)}.d-layout .d-layout-item{background-color:var(--j-color-bg-container);border:1px solid var(--j-color-border);border-radius:4px;padding:8px;box-sizing:border-box}.d-layout .d-layout-item:hover{border-color:var(--j-color-primary)}.d-layout .d-layout-item.ui-draggable-dragging{opacity:.8;z-index:1000}.d-layout .d-layout-item.ui-resizable-resizing{opacity:.8}.d-draggable{position:absolute;padding:8px;cursor:move;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;box-sizing:initial;border:1px dashed transparent}.d-draggable__mask{position:absolute;width:100%;height:100%;border:0;inset:0;z-index:1}.d-draggable--active{cursor:move;border:1px dashed var(--j-color-primary);background-color:var(--j-color-primary-bg)}.d-draggable--pt{border:1px dashed var(--j-color-border);padding:0!important}.d-draggable--active.d-draggable--pt{border:1px dashed transparent;background-color:transparent}.d-draggable--move{opacity:.6;background-color:var(--j-color-primary-bg)}.d-draggable--click{cursor:pointer}.d-draggable__line--left{position:absolute;border-top:1px dashed var(--j-color-primary);width:10000px;height:0;top:-1px;transform:translate(-100%)}.d-draggable__line--top{position:absolute;border-left:1px dashed var(--j-color-primary);width:0;height:10000px;left:-1px;transform:translateY(-100%)}.d-draggable__line--label{top:-8px;left:-8px;position:absolute;padding:5px;transform:translate(-100%,-100%);color:var(--j-color-primary);font-size:16px;white-space:nowrap;cursor:move}.d-draggable__range{position:absolute;width:10px;height:10px;border-radius:100%;z-index:9999;background-color:var(--j-color-primary)}.d-draggable__range--left,.d-draggable__range--right{top:50%;transform:translateY(-50%)}.d-draggable__range--left:hover,.d-draggable__range--right:hover{cursor:ew-resize}.d-draggable__range--left{left:-5px}.d-draggable__range--right{right:-5px}.d-draggable__range--top,.d-draggable__range--bottom{left:50%;transform:translate(-50%)}.d-draggable__range--top:hover,.d-draggable__range--bottom:hover{cursor:ns-resize}.d-draggable__range--top{top:-5px}.d-draggable__range--bottom{bottom:-5px}.d-draggable__range--bottom-right:hover,.d-draggable__range--top-left:hover{cursor:nwse-resize}.d-draggable__range--bottom-left:hover,.d-draggable__range--top-right:hover{cursor:nesw-resize}.d-draggable__range--top-right{top:-5px;right:-5px}.d-draggable__range--top-left{top:-5px;left:-5px}.d-draggable__range--bottom-right{bottom:-5px;right:-5px}.d-draggable__range--bottom-left{bottom:-5px;left:-5px}.d-form-design{display:flex;background-color:var(--j-color-bg);font-size:14px}.d-form-design-left,.d-form-design-right{display:flex;position:relative;flex-direction:column;width:260px;height:100%;background-color:var(--j-color-bg-container)}.d-form-design-left .el-collapse,.d-form-design-right .el-collapse{border-top:0;border-right:0;border-left:0;border-radius:0}.d-form-design-left .el-collapse-item__header,.d-form-design-right .el-collapse-item__header{padding-left:8px}.d-form-design-left{width:260px;border-right:1px solid var(--j-color-border);display:flex;flex-direction:column}.d-form-design-left .d-form-design-component-list{flex:1;overflow-y:auto;padding:12px 8px;display:flex;flex-direction:column;gap:0}.d-form-design-left .d-form-design-component-title{font-weight:700;font-size:13px;color:var(--j-color-text);padding:12px 0 8px}.d-form-design-left .d-form-design-component-title:first-child{padding-top:0}.d-form-design-left .d-form-design-component-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.d-form-design-left .d-form-design-component-tool{display:flex;flex-direction:row;align-items:center;gap:8px;padding:4px 8px;border:1px solid var(--j-color-border);border-radius:4px;cursor:grab;transition:border-color .2s;background:var(--j-color-bg-container);position:relative}.d-form-design-left .d-form-design-component-tool:hover{border:1px dashed var(--j-color-primary)}.d-form-design-left .d-form-design-component-tool-icon{color:var(--j-color-text-3);flex-shrink:0}.d-form-design-left .d-form-design-component-tool:hover .d-form-design-component-tool-icon,.d-form-design-left .d-form-design-component-tool:hover .d-form-design-component-tool-name{color:var(--j-color-primary)}.d-form-design-left .d-form-design-component-tool-name{font-size:12px;color:var(--j-color-text)}.d-form-design-right{width:300px;border-left:1px solid var(--j-color-border)}.d-form-design-right .el-collapse .el-collapse-item__wrap>.el-collapse-item__content{padding:8px 16px 0}.d-form-design-right .el-collapse-item__title{font-weight:700}.d-form-design-right .d-form-design-panel{flex:1;overflow-y:auto;padding-bottom:8px}.d-form-design-right .el-form-item--label-top .el-form-item__label{font-weight:700}.d-form-design .d-form-design-panel-title{padding:0 16px;font-weight:500;border-bottom:1px solid var(--j-color-border);background:var(--j-color-bg-container);height:45px;display:flex;align-items:center}.d-form-design-center{flex:1;display:flex;flex-direction:column;overflow:hidden}.d-form-design-center .d-form-design-toolbar{padding:8px 16px;border-bottom:1px solid var(--j-color-border);display:flex;gap:8px;background:var(--j-color-bg-container)}.d-form-design-center .d-form-design-toolbar .j-button{font-size:12px}.d-form-design-center .d-form-design-container{flex:1;overflow-y:auto;padding:8px;background:var(--j-color-bg)}.d-form-design-center .d-form-design-container .d-form-design-drag-container{min-height:100%;background:var(--j-color-bg-container);padding:8px;display:flex;flex-direction:column}.d-form-design-center .d-form-design-container .d-form-design-drag-container>.d-drag-body{width:100%;flex:1}.d-form-design-center .d-form-design-container .d-form-design-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--j-color-text-3);font-size:14px}