@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.
Files changed (66) hide show
  1. package/README.md +201 -0
  2. package/babel.config.js +5 -0
  3. package/dist/lib/VFormDesigner.common-report.html +53 -0
  4. package/dist/lib/VFormDesigner.common.js +123773 -0
  5. package/dist/lib/VFormDesigner.common.js.map +1 -0
  6. package/dist/lib/VFormDesigner.css +1 -0
  7. package/dist/lib/VFormDesigner.umd-report.html +53 -0
  8. package/dist/lib/VFormDesigner.umd.js +123783 -0
  9. package/dist/lib/VFormDesigner.umd.js.map +1 -0
  10. package/dist/lib/VFormDesigner.umd.min-report.html +53 -0
  11. package/dist/lib/VFormDesigner.umd.min.js +222 -0
  12. package/dist/lib/demo.html +10 -0
  13. package/dist/lib/img/indicator-card-header.7291bcc9.png +0 -0
  14. package/dist/lib/img/lan_navigator.53090c9d.png +0 -0
  15. package/dist/lib/img/layout-header-bg-canglan.b1d97e4e.png +0 -0
  16. package/dist/lib/img/layout-header-bg-cuiwei.67019b6d.png +0 -0
  17. package/dist/lib/img/lv_navigator.f07fb393.png +0 -0
  18. package/index_template/index_dev.html +19 -0
  19. package/index_template/index_prod.html +28 -0
  20. package/install-render.js +29 -0
  21. package/install.js +41 -0
  22. package/jsconfig.json +10 -0
  23. package/license.txt +8 -0
  24. package/package.json +10 -4
  25. package/public/favicon.ico +0 -0
  26. package/public/index.html +19 -0
  27. package/src/App.vue +45 -0
  28. package/src/components/form-designer/designer.js +1 -0
  29. package/src/components/form-designer/form-widget/field-widget/organ-select-widget.vue +254 -0
  30. package/src/components/form-designer/form-widget/field-widget/relation-form-widget.vue +397 -0
  31. package/src/components/form-designer/form-widget/field-widget/sub-form-widget.vue +660 -0
  32. package/src/components/form-designer/form-widget/field-widget/user-select-widget.vue +333 -0
  33. package/src/components/form-designer/form-widget/index.vue +1 -1
  34. package/src/components/form-designer/index.vue +14 -12
  35. package/src/components/form-designer/setting-panel/form-setting.vue +59 -60
  36. package/src/components/form-designer/setting-panel/index.vue +2 -0
  37. package/src/components/form-designer/setting-panel/property-editor/allowMultiple-editor.vue +24 -0
  38. package/src/components/form-designer/setting-panel/property-editor/border-editor.vue +1 -1
  39. package/src/components/form-designer/setting-panel/property-editor/buttonStyle-editor.vue +1 -1
  40. package/src/components/form-designer/setting-panel/property-editor/clearable-editor.vue +1 -1
  41. package/src/components/form-designer/setting-panel/property-editor/displayFields-editor.vue +91 -0
  42. package/src/components/form-designer/setting-panel/property-editor/displayStyle-editor.vue +1 -1
  43. package/src/components/form-designer/setting-panel/property-editor/field-relation-form/relation-form-defaultValue-editor.vue +18 -0
  44. package/src/components/form-designer/setting-panel/property-editor/filterable-editor.vue +1 -1
  45. package/src/components/form-designer/setting-panel/property-editor/multipleLimit-editor.vue +1 -1
  46. package/src/components/form-designer/setting-panel/property-editor/name-editor.vue +2 -2
  47. package/src/components/form-designer/setting-panel/property-editor/operList-editor.vue +64 -0
  48. package/src/components/form-designer/setting-panel/property-editor/placeholder-editor.vue +1 -1
  49. package/src/components/form-designer/setting-panel/property-editor/relationForm-editor.vue +74 -0
  50. package/src/components/form-designer/setting-panel/property-editor/relationItems-editor.vue +91 -0
  51. package/src/components/form-designer/setting-panel/property-editor/relationType-editor.vue +67 -0
  52. package/src/components/form-designer/setting-panel/property-editor/rootOrgan-editor.vue +248 -0
  53. package/src/components/form-designer/setting-panel/property-editor/size-editor.vue +5 -5
  54. package/src/components/form-designer/setting-panel/property-editor/subFormId-editor.vue +74 -0
  55. package/src/components/form-designer/setting-panel/propertyRegister.js +144 -133
  56. package/src/components/form-designer/toolbar-panel/index.vue +11 -10
  57. package/src/components/form-designer/widget-panel/index.vue +11 -11
  58. package/src/components/form-designer/widget-panel/widgetsConfig.js +425 -297
  59. package/src/extension/extension-loader.js +1 -1
  60. package/src/icons/svg/relation-form-field.svg +1 -0
  61. package/src/lang/en-US.js +39 -0
  62. package/src/lang/zh-CN.js +42 -3
  63. package/src/main.js +29 -0
  64. package/src/utils/config.js +1 -1
  65. package/src/utils/util.js +35 -1
  66. 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
- {label: 'default', value: ''},
26
- {label: 'large', value: 'large'},
27
- {label: 'medium', value: 'medium'},
28
- {label: 'small', value: 'small'},
29
- {label: 'mini', value: 'mini'},
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>