@lambo-design/variant-form 2.2.9-beta.0 → 2.2.9-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +201 -0
- package/babel.config.js +5 -0
- package/dist/lib/VFormDesigner.common-report.html +53 -0
- package/dist/lib/VFormDesigner.common.js +123773 -0
- package/dist/lib/VFormDesigner.common.js.map +1 -0
- package/dist/lib/VFormDesigner.css +1 -0
- package/dist/lib/VFormDesigner.umd-report.html +53 -0
- package/dist/lib/VFormDesigner.umd.js +123783 -0
- package/dist/lib/VFormDesigner.umd.js.map +1 -0
- package/dist/lib/VFormDesigner.umd.min-report.html +53 -0
- package/dist/lib/VFormDesigner.umd.min.js +222 -0
- package/dist/lib/demo.html +10 -0
- package/dist/lib/img/indicator-card-header.7291bcc9.png +0 -0
- package/dist/lib/img/lan_navigator.53090c9d.png +0 -0
- package/dist/lib/img/layout-header-bg-canglan.b1d97e4e.png +0 -0
- package/dist/lib/img/layout-header-bg-cuiwei.67019b6d.png +0 -0
- package/dist/lib/img/lv_navigator.f07fb393.png +0 -0
- package/index_template/index_dev.html +19 -0
- package/index_template/index_prod.html +28 -0
- package/install-render.js +29 -0
- package/install.js +41 -0
- package/jsconfig.json +10 -0
- package/license.txt +8 -0
- package/package.json +10 -4
- package/public/favicon.ico +0 -0
- package/public/index.html +19 -0
- package/src/App.vue +45 -0
- package/src/components/form-designer/designer.js +1 -0
- package/src/components/form-designer/form-widget/field-widget/organ-select-widget.vue +254 -0
- package/src/components/form-designer/form-widget/field-widget/relation-form-widget.vue +397 -0
- package/src/components/form-designer/form-widget/field-widget/sub-form-widget.vue +660 -0
- package/src/components/form-designer/form-widget/field-widget/user-select-widget.vue +333 -0
- package/src/components/form-designer/form-widget/index.vue +1 -1
- package/src/components/form-designer/index.vue +14 -12
- package/src/components/form-designer/setting-panel/form-setting.vue +59 -60
- package/src/components/form-designer/setting-panel/index.vue +2 -0
- package/src/components/form-designer/setting-panel/property-editor/allowMultiple-editor.vue +24 -0
- package/src/components/form-designer/setting-panel/property-editor/border-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/buttonStyle-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/clearable-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/displayFields-editor.vue +91 -0
- package/src/components/form-designer/setting-panel/property-editor/displayStyle-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/field-relation-form/relation-form-defaultValue-editor.vue +18 -0
- package/src/components/form-designer/setting-panel/property-editor/filterable-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/multipleLimit-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/name-editor.vue +2 -2
- package/src/components/form-designer/setting-panel/property-editor/operList-editor.vue +64 -0
- package/src/components/form-designer/setting-panel/property-editor/placeholder-editor.vue +1 -1
- package/src/components/form-designer/setting-panel/property-editor/relationForm-editor.vue +74 -0
- package/src/components/form-designer/setting-panel/property-editor/relationItems-editor.vue +91 -0
- package/src/components/form-designer/setting-panel/property-editor/relationType-editor.vue +67 -0
- package/src/components/form-designer/setting-panel/property-editor/rootOrgan-editor.vue +248 -0
- package/src/components/form-designer/setting-panel/property-editor/size-editor.vue +5 -5
- package/src/components/form-designer/setting-panel/property-editor/subFormId-editor.vue +74 -0
- package/src/components/form-designer/setting-panel/propertyRegister.js +144 -133
- package/src/components/form-designer/toolbar-panel/index.vue +11 -10
- package/src/components/form-designer/widget-panel/index.vue +11 -11
- package/src/components/form-designer/widget-panel/widgetsConfig.js +425 -297
- package/src/extension/extension-loader.js +1 -1
- package/src/icons/svg/relation-form-field.svg +1 -0
- package/src/lang/en-US.js +39 -0
- package/src/lang/zh-CN.js +42 -3
- package/src/main.js +29 -0
- package/src/utils/config.js +1 -1
- package/src/utils/util.js +35 -1
- package/vue.config.js +93 -0
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-form-item prop="name" :rules="rootOrganRequiredRule">
|
|
3
|
+
<span slot="label">{{ i18nt('designer.setting.rootOrgan') }}</span>
|
|
4
|
+
<el-input
|
|
5
|
+
placeholder="请选择根组织"
|
|
6
|
+
style="width: 100%"
|
|
7
|
+
v-model="optionModel.rootOrgan"
|
|
8
|
+
@click="handleClickCustomEvent"
|
|
9
|
+
@focus="handleClickCustomEvent">
|
|
10
|
+
<i slot="suffix" class="el-input__icon el-icon-s-grid" @click="handleClickCustomEvent"></i>
|
|
11
|
+
</el-input>
|
|
12
|
+
<el-dialog title="组织" :visible.sync="dialogVisible" class="organ-dialog">
|
|
13
|
+
<el-form label-width="120px">
|
|
14
|
+
<el-row>
|
|
15
|
+
<el-col :span="12" v-if="userCenterType === 'sc'">
|
|
16
|
+
<el-form-item label="管理单元:">
|
|
17
|
+
<el-select size="default" v-model="optionModel.manageUnitId" @change="manageUnitIdChange">
|
|
18
|
+
<el-option
|
|
19
|
+
v-for="item in manageUnitIdOptions"
|
|
20
|
+
:key="item.manageUnitId"
|
|
21
|
+
:label="item.manageUnitName"
|
|
22
|
+
:value="item.manageUnitId">
|
|
23
|
+
</el-option>
|
|
24
|
+
</el-select>
|
|
25
|
+
</el-form-item>
|
|
26
|
+
</el-col>
|
|
27
|
+
<el-col :span="12">
|
|
28
|
+
<el-form-item label="组织树类型:">
|
|
29
|
+
<el-select size="default" v-model="optionModel.organTreeType" @change="organTreeTypeChange">
|
|
30
|
+
<el-option
|
|
31
|
+
v-for="item in organTreeTypeOptions"
|
|
32
|
+
:key="item.typeId"
|
|
33
|
+
:label="item.typeName"
|
|
34
|
+
:value="item.typeId">
|
|
35
|
+
</el-option>
|
|
36
|
+
</el-select>
|
|
37
|
+
</el-form-item>
|
|
38
|
+
</el-col>
|
|
39
|
+
</el-row>
|
|
40
|
+
</el-form>
|
|
41
|
+
<el-tree
|
|
42
|
+
v-loading="loading"
|
|
43
|
+
lazy
|
|
44
|
+
:load="loadNode"
|
|
45
|
+
:data="treeDataList"
|
|
46
|
+
:props="defaultProps"
|
|
47
|
+
:highlight-current="true"
|
|
48
|
+
@node-click="handleNodeClick"
|
|
49
|
+
style="margin-top: 10px; height: 90%; overflow: auto">
|
|
50
|
+
</el-tree>
|
|
51
|
+
<div slot="footer" class="dialog-footer">
|
|
52
|
+
<el-button type="primary" @click="closeDialog">取 消</el-button>
|
|
53
|
+
<el-button type="primary" @click="onOk">确 定</el-button>
|
|
54
|
+
</div>
|
|
55
|
+
</el-dialog>
|
|
56
|
+
</el-form-item>
|
|
57
|
+
</template>
|
|
58
|
+
|
|
59
|
+
<script>
|
|
60
|
+
import i18n from "@/utils/i18n";
|
|
61
|
+
import ajax from "@lambo-design/shared/utils/ajax";
|
|
62
|
+
|
|
63
|
+
export default {
|
|
64
|
+
name: "rootOrgan-editor",
|
|
65
|
+
mixins: [i18n],
|
|
66
|
+
props: {
|
|
67
|
+
designer: Object,
|
|
68
|
+
selectedWidget: Object,
|
|
69
|
+
optionModel: Object,
|
|
70
|
+
},
|
|
71
|
+
inject: ['serverFieldList', 'getDesignerConfig'],
|
|
72
|
+
data() {
|
|
73
|
+
return {
|
|
74
|
+
serverContext: '/dida-manage-server',
|
|
75
|
+
organTreeTypeOptions: [],
|
|
76
|
+
manageUnitIdOptions: [],
|
|
77
|
+
treeDataList: [],
|
|
78
|
+
loading: false,
|
|
79
|
+
userCenterType: 'x1',
|
|
80
|
+
dialogVisible: false,
|
|
81
|
+
selectedRootOrgan: '',
|
|
82
|
+
defaultProps: {
|
|
83
|
+
children: 'children',
|
|
84
|
+
label: 'bizOrganName',
|
|
85
|
+
isLeaf: (data) => {
|
|
86
|
+
return data.isLeaf === 'true';
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
rootOrganRequiredRule: [{ required: true, message: 'root organ required' }],
|
|
90
|
+
};
|
|
91
|
+
},
|
|
92
|
+
computed: {
|
|
93
|
+
noFieldList() {
|
|
94
|
+
return !this.serverFieldList || this.serverFieldList.length <= 0;
|
|
95
|
+
},
|
|
96
|
+
widgetNameReadonly() {
|
|
97
|
+
return !!this.getDesignerConfig().widgetNameReadonly;
|
|
98
|
+
},
|
|
99
|
+
},
|
|
100
|
+
mounted() {
|
|
101
|
+
// 初始化用户中心类型
|
|
102
|
+
this.initData();
|
|
103
|
+
},
|
|
104
|
+
methods: {
|
|
105
|
+
initData() {
|
|
106
|
+
ajax.get(this.serverContext + '/uc/adaptor/getUserCenterType').then((resp) => {
|
|
107
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
108
|
+
if (resp.data.data === 'sc') {
|
|
109
|
+
this.userCenterType = 'sc';
|
|
110
|
+
this.getManageUnit()
|
|
111
|
+
}
|
|
112
|
+
// 根据用户中心放置组织树类型默认值
|
|
113
|
+
this.optionModel.organTreeType = this.userCenterType === 'sc' ? 'default' : '00'
|
|
114
|
+
this.getOrganTreeType()
|
|
115
|
+
this.getOrgRootTree(this.optionModel.organTreeType);
|
|
116
|
+
}
|
|
117
|
+
}).catch((err) => {
|
|
118
|
+
console.error(err);
|
|
119
|
+
this.$Message.error('获取用户中心类型失败')
|
|
120
|
+
});
|
|
121
|
+
},
|
|
122
|
+
|
|
123
|
+
getOrganTreeType() {
|
|
124
|
+
return ajax.get(this.serverContext + '/manage/organ/getOrganTypes').then((resp) => {
|
|
125
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
126
|
+
this.organTreeTypeOptions = resp.data.data || [];
|
|
127
|
+
const defaultOrganTreeType = {
|
|
128
|
+
typeCode: this.userCenterType === 'sc' ? 'default' : '00',
|
|
129
|
+
typeId: this.userCenterType === 'sc' ? 'default' : '00',
|
|
130
|
+
typeName: '默认组织树'
|
|
131
|
+
};
|
|
132
|
+
this.organTreeTypeOptions.unshift(defaultOrganTreeType);
|
|
133
|
+
}
|
|
134
|
+
}).catch((err) => {
|
|
135
|
+
console.error('获取组织树类型失败:', err);
|
|
136
|
+
throw err;
|
|
137
|
+
});
|
|
138
|
+
},
|
|
139
|
+
|
|
140
|
+
getManageUnit() {
|
|
141
|
+
return ajax.get(this.serverContext + '/manage/organ/getManageUnitId').then((resp) => {
|
|
142
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
143
|
+
this.manageUnitIdOptions = resp.data.data || [];
|
|
144
|
+
}
|
|
145
|
+
}).catch((err) => {
|
|
146
|
+
console.error('获取管理单元失败:', err);
|
|
147
|
+
});
|
|
148
|
+
},
|
|
149
|
+
|
|
150
|
+
getOrgRootTree(treeTypeId) {
|
|
151
|
+
this.treeDataList = [];
|
|
152
|
+
this.loading = true;
|
|
153
|
+
const params = {
|
|
154
|
+
treeTypeId: treeTypeId || (this.userCenterType === 'sc' ? 'default' : '00'),
|
|
155
|
+
manageUnitId: this.userCenterType === 'sc' ? this.optionModel.manageUnitId : ''
|
|
156
|
+
};
|
|
157
|
+
ajax.get(this.serverContext + '/manage/organ/getOrganRootTree', { params }).then((resp) => {
|
|
158
|
+
this.loading = false;
|
|
159
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
160
|
+
this.treeDataList = resp.data.data || [];
|
|
161
|
+
}
|
|
162
|
+
}).catch((err) => {
|
|
163
|
+
this.loading = false;
|
|
164
|
+
console.error('获取根组织树失败:', err);
|
|
165
|
+
});
|
|
166
|
+
},
|
|
167
|
+
|
|
168
|
+
organTreeTypeChange(treeTypeId) {
|
|
169
|
+
this.getOrgRootTree(treeTypeId);
|
|
170
|
+
},
|
|
171
|
+
|
|
172
|
+
manageUnitIdChange() {
|
|
173
|
+
this.getOrgRootTree(this.optionModel.organTreeType);
|
|
174
|
+
},
|
|
175
|
+
|
|
176
|
+
async loadNode(node, resolve) {
|
|
177
|
+
if (node){
|
|
178
|
+
// if (node.level === 0 && this.treeDataList.length > 0) {
|
|
179
|
+
// return resolve(this.treeDataList);
|
|
180
|
+
// }
|
|
181
|
+
const params = {
|
|
182
|
+
parentId: node.data.bizOrganId,
|
|
183
|
+
organTreeType: this.optionModel.organTreeType || (this.userCenterType === 'sc' ? 'default' : '00'),
|
|
184
|
+
manageUnitId: this.optionModel.manageUnitId
|
|
185
|
+
};
|
|
186
|
+
try {
|
|
187
|
+
const resp = await ajax.get(this.serverContext + '/manage/organ/getOrgChildren', { params });
|
|
188
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
189
|
+
resolve(resp.data.data || []);
|
|
190
|
+
} else {
|
|
191
|
+
resolve([]);
|
|
192
|
+
}
|
|
193
|
+
} catch (err) {
|
|
194
|
+
console.error(err);
|
|
195
|
+
resolve([]);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
},
|
|
199
|
+
|
|
200
|
+
handleNodeClick(data) {
|
|
201
|
+
this.selectedRootOrgan = data.bizOrganId;
|
|
202
|
+
},
|
|
203
|
+
|
|
204
|
+
handleClickCustomEvent(event) {
|
|
205
|
+
this.$nextTick(() => {
|
|
206
|
+
this.getOrgRootTree(this.optionModel.organTreeType);
|
|
207
|
+
this.dialogVisible = true;
|
|
208
|
+
});
|
|
209
|
+
},
|
|
210
|
+
|
|
211
|
+
onOk() {
|
|
212
|
+
if (!this.optionModel.rootOrgan && !this.selectedRootOrgan){
|
|
213
|
+
this.$Message.error('请选择根组织');
|
|
214
|
+
return;
|
|
215
|
+
}
|
|
216
|
+
this.dialogVisible = false;
|
|
217
|
+
this.optionModel.rootOrgan = this.selectedRootOrgan || this.optionModel.rootOrgan;
|
|
218
|
+
},
|
|
219
|
+
closeDialog() {
|
|
220
|
+
this.dialogVisible = false;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
</script>
|
|
225
|
+
|
|
226
|
+
<style lang="scss" scoped>
|
|
227
|
+
.organ-dialog {
|
|
228
|
+
display: flex;
|
|
229
|
+
flex-direction: column;
|
|
230
|
+
::v-deep .el-dialog {
|
|
231
|
+
max-height: 80vh;
|
|
232
|
+
display: flex;
|
|
233
|
+
flex-direction: column;
|
|
234
|
+
overflow: hidden;
|
|
235
|
+
|
|
236
|
+
.el-dialog__body {
|
|
237
|
+
flex: 1;
|
|
238
|
+
overflow: hidden;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
.dialog-footer {
|
|
243
|
+
padding: 10px 20px;
|
|
244
|
+
text-align: right;
|
|
245
|
+
border-top: 1px solid #eee;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
</style>
|
|
@@ -22,11 +22,11 @@
|
|
|
22
22
|
data() {
|
|
23
23
|
return {
|
|
24
24
|
widgetSizes: [
|
|
25
|
-
{
|
|
26
|
-
{
|
|
27
|
-
{
|
|
28
|
-
{
|
|
29
|
-
{
|
|
25
|
+
{value: '', label: this.i18nt('designer.setting.sizeDefault')},
|
|
26
|
+
{value: 'large', label: this.i18nt('designer.setting.sizeLarge')},
|
|
27
|
+
// {value: 'medium', label: this.i18nt('designer.setting.sizeMedium')},
|
|
28
|
+
{value: 'small', label: this.i18nt('designer.setting.sizeSmall')},
|
|
29
|
+
// {value: 'mini', label: this.i18nt('designer.setting.sizeMini')},
|
|
30
30
|
],
|
|
31
31
|
}
|
|
32
32
|
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-form-item :label="i18nt('designer.setting.subFormId')">
|
|
3
|
+
<el-select v-model="optionModel.subFormId">
|
|
4
|
+
<el-option v-for="item in relationForms" :key="item.formId" :label="item.formName" :value="item.formId">
|
|
5
|
+
</el-option>
|
|
6
|
+
</el-select>
|
|
7
|
+
</el-form-item>
|
|
8
|
+
</template>
|
|
9
|
+
|
|
10
|
+
<script>
|
|
11
|
+
import i18n from "@/utils/i18n"
|
|
12
|
+
// import axios from "axios"
|
|
13
|
+
import ajax from "@lambo-design/shared/utils/ajax";
|
|
14
|
+
|
|
15
|
+
export default {
|
|
16
|
+
name: "subFormId-editor",
|
|
17
|
+
mixins: [i18n],
|
|
18
|
+
props: {
|
|
19
|
+
designer: Object,
|
|
20
|
+
selectedWidget: Object,
|
|
21
|
+
optionModel: Object,
|
|
22
|
+
},
|
|
23
|
+
inject: ['getDesignerConfig'],
|
|
24
|
+
data() {
|
|
25
|
+
return {
|
|
26
|
+
relationForms: [],
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
created() {
|
|
31
|
+
this.initRelationForms();
|
|
32
|
+
},
|
|
33
|
+
mounted() {
|
|
34
|
+
},
|
|
35
|
+
methods: {
|
|
36
|
+
initRelationForms() {
|
|
37
|
+
let projectId = this.getDesignerConfig().projectId;
|
|
38
|
+
let formId = this.getDesignerConfig().formId;
|
|
39
|
+
if(!projectId || !formId) {
|
|
40
|
+
console.log("get designer config projectId & formId is null", projectId, formId);
|
|
41
|
+
projectId = 'ZhaoyxTP';
|
|
42
|
+
formId = 'ZhaoyxTF';
|
|
43
|
+
}
|
|
44
|
+
if(projectId && formId) {
|
|
45
|
+
let url = "/dida-manage-server/manage/form-materialization-table-relation/listOthers?projectId="+projectId+"&formId="+formId;
|
|
46
|
+
ajax.get(url)
|
|
47
|
+
.then(resp => {
|
|
48
|
+
if (resp.data && (resp.data.code == 1 || resp.data.code == 200)) {
|
|
49
|
+
this.relationForms = resp.data.data;
|
|
50
|
+
} else {
|
|
51
|
+
this.relationForms = [];
|
|
52
|
+
// this.$Message.error('查询表单列表失败');
|
|
53
|
+
console.error(resp.data.message);
|
|
54
|
+
}
|
|
55
|
+
})
|
|
56
|
+
.catch(err => {
|
|
57
|
+
this.relationForms = [];
|
|
58
|
+
// this.$Message.error('获取表单列表失败');
|
|
59
|
+
console.error(err);
|
|
60
|
+
});
|
|
61
|
+
} else {
|
|
62
|
+
this.relationForms = [];
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
watch:{
|
|
67
|
+
// deep:true
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
</script>
|
|
71
|
+
|
|
72
|
+
<style scoped>
|
|
73
|
+
|
|
74
|
+
</style>
|