tianheng-ui 0.1.77 → 0.1.79

Sign up to get free protection for your applications and to get access to all the features.
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "tianheng-ui",
3
3
  "description": "A Vue.js project",
4
- "version": "0.1.77",
4
+ "version": "0.1.79",
5
5
  "author": "shu lang <403732931@qq.com>",
6
6
  "license": "MIT",
7
7
  "private": false,
@@ -181,7 +181,7 @@
181
181
  <el-tooltip
182
182
  slot="label"
183
183
  effect="light"
184
- content="使用接口的出参配置可选字段"
184
+ content="使用该接口的出参配置可选字段"
185
185
  placement="top"
186
186
  >
187
187
  <span style="color: #409EFF;">字段接口</span>
@@ -217,7 +217,7 @@
217
217
  <el-tooltip
218
218
  slot="label"
219
219
  effect="light"
220
- content="开启后,选择数据接口会触发 remote-params 回调,用于从服务器查询字段"
220
+ content="开启后,选择数据接口会触发 remote-params 回调,用于从服务器获取字段"
221
221
  placement="top"
222
222
  >
223
223
  <span style="color: #409EFF;">远程字段</span>
@@ -3,14 +3,94 @@
3
3
  <el-steps :active="step" finish-status="success" simple>
4
4
  <el-step title="表单配置" icon="el-icon-s-operation" description="">
5
5
  </el-step>
6
- <el-step title="按钮配置" icon="el-icon-set-up" description=""></el-step>
6
+ <el-step
7
+ title="选择初始模板"
8
+ icon="el-icon-set-up"
9
+ description=""
10
+ ></el-step>
11
+ <!-- <el-step
12
+ title="选择初始模板"
13
+ icon="el-icon-set-up"
14
+ description=""
15
+ ></el-step> -->
7
16
  </el-steps>
8
17
  <div class="content">
9
- <div v-show="step === 0">
10
- <div>你好</div>
11
- <div>让我们来了解一些基本信息</div>
12
- </div>
13
- <div v-show="step === 1"></div>
18
+ <el-form :model="config" label-width="80px" size="small">
19
+ <div v-show="step === 0">
20
+ <el-form-item>
21
+ <el-tooltip
22
+ slot="label"
23
+ effect="light"
24
+ content="字段的配置方式"
25
+ placement="top"
26
+ >
27
+ <span style="color: #409EFF;">字段类型</span>
28
+ </el-tooltip>
29
+ <el-radio-group v-model="config.config.fields.type">
30
+ <el-radio-button label="custom">自定义</el-radio-button>
31
+ <el-radio-button label="api">接口导入</el-radio-button>
32
+ </el-radio-group>
33
+ </el-form-item>
34
+ <el-form-item v-if="config.config.fields.type === 'api'">
35
+ <el-tooltip
36
+ slot="label"
37
+ effect="light"
38
+ content="使用该接口的出参配置可选字段"
39
+ placement="top"
40
+ >
41
+ <span style="color: #409EFF;">字段接口</span>
42
+ </el-tooltip>
43
+ <el-select
44
+ v-model="config.config.fields.api"
45
+ style="width:100%"
46
+ clearable
47
+ placeholder="请选择"
48
+ no-data-text="暂无接口,请前往【接口模块】创建"
49
+ filterable
50
+ >
51
+ <el-option
52
+ v-for="item in apiOptions"
53
+ :key="item.id"
54
+ :label="item.name"
55
+ :value="item.id"
56
+ >
57
+ </el-option>
58
+ </el-select>
59
+ </el-form-item>
60
+ <el-form-item label="表单名称">
61
+ <el-input
62
+ v-model="config.config.title"
63
+ placeholder="请输入"
64
+ ></el-input>
65
+ </el-form-item>
66
+ <el-form-item>
67
+ <el-tooltip
68
+ slot="label"
69
+ effect="light"
70
+ content="开启后,选择数据接口会触发 remote-params 回调,用于从服务器获取字段"
71
+ placement="top"
72
+ >
73
+ <span style="color: #409EFF;">远程字段</span>
74
+ </el-tooltip>
75
+ <el-switch v-model="config.config.fields.remote"> </el-switch>
76
+ </el-form-item>
77
+ </div>
78
+ <div v-show="step === 1" class="formTemplates">
79
+ <div
80
+ :class="
81
+ `formTemplates-item th-border th-hover_boxShadow_light ${
82
+ formTemplateActive === index ? 'th-active' : ''
83
+ }`
84
+ "
85
+ v-for="(item, index) in formTemplates"
86
+ :key="index"
87
+ @click="handleFormTemplateClick(index)"
88
+ >
89
+ <img :src="item.img" alt="" />
90
+ <div>{{ item.name }}</div>
91
+ </div>
92
+ </div>
93
+ </el-form>
14
94
  </div>
15
95
  <div class="footer">
16
96
  <div></div>
@@ -23,31 +103,43 @@
23
103
  @click="handleBack"
24
104
  >上一步</el-button
25
105
  >
26
- <el-button type="primary" size="small" @click="handleNext"
27
- >下一步<i class="el-icon-right el-icon--right"></i
28
- ></el-button>
106
+ <el-button
107
+ v-if="step !== 1"
108
+ type="primary"
109
+ size="small"
110
+ @click="handleNext"
111
+ >
112
+ 下一步<i class="el-icon-right el-icon--right"></i>
113
+ </el-button>
114
+ <el-button v-else type="success" size="small" @click="handleSave">
115
+ 完&nbsp;&nbsp;&nbsp;成<i class="el-icon-finished el-icon--right"></i>
116
+ </el-button>
29
117
  </div>
30
118
  </div>
31
119
  </div>
32
120
  </template>
33
121
 
34
122
  <script>
123
+ import EmptyTemplateJson from "./assets/templates/empty.json";
124
+ import GeneralTemplateJson from "./assets/templates/general.json";
125
+ import PersonalDetailsTemplateJson from "./assets/templates/personalDetails.json";
126
+ import TableTemplateJson from "./assets/templates/table.json";
127
+ import { deepClone } from "./util";
35
128
  export default {
36
- props: { visible: { type: Boolean, default: true } },
129
+ props: { config: Object, apiOptions: Array },
37
130
  data() {
38
131
  return {
39
- show: this.visible,
40
- step: 0
132
+ step: 0,
133
+ formTemplates: [
134
+ EmptyTemplateJson,
135
+ GeneralTemplateJson,
136
+ PersonalDetailsTemplateJson,
137
+ TableTemplateJson
138
+ ],
139
+ formTemplateActive: null
41
140
  };
42
141
  },
43
- watch: {
44
- visible(val) {
45
- this.show = val;
46
- },
47
- show(val) {
48
- this.$emit("update:visible", val);
49
- }
50
- },
142
+ computed: {},
51
143
  created() {},
52
144
  mounted() {},
53
145
  methods: {
@@ -57,8 +149,15 @@ export default {
57
149
  handleNext() {
58
150
  this.step++;
59
151
  },
60
- handleClose() {
61
- this.show = !this.show;
152
+ handleSave() {
153
+ if (this.formTemplateActive !== null) {
154
+ const list = this.formTemplates[this.formTemplateActive].data.list;
155
+ this.config.list = deepClone(list);
156
+ }
157
+ this.$emit("save");
158
+ },
159
+ handleFormTemplateClick(index) {
160
+ this.formTemplateActive = index;
62
161
  }
63
162
  }
64
163
  };
@@ -70,7 +169,13 @@ export default {
70
169
  height: 100%;
71
170
 
72
171
  .content {
73
- height: calc(100% - 50px);
172
+ height: calc(100% - 96px);
173
+ padding-top: 10px;
174
+ overflow-y: scroll;
175
+
176
+ .tools-item {
177
+ margin-bottom: 10px;
178
+ }
74
179
  }
75
180
  .footer {
76
181
  height: 50px;
@@ -78,9 +183,57 @@ export default {
78
183
  align-items: center;
79
184
  justify-content: space-between;
80
185
  box-sizing: border-box;
186
+ background-color: white;
81
187
 
82
188
  .stepView {
83
189
  }
84
190
  }
191
+ .fields-item {
192
+ span {
193
+ padding: 0px 8px 2px 8px;
194
+ border-radius: 4px;
195
+ }
196
+ span:nth-child(1) {
197
+ color: #1890ff;
198
+ background-color: #e8f4ff;
199
+ }
200
+ span:nth-child(2) {
201
+ color: #13ce66;
202
+ background-color: #e7faf0;
203
+ }
204
+ span:nth-child(3) {
205
+ color: #909399;
206
+ background-color: #f4f4f5;
207
+ }
208
+ }
209
+ .formTemplates {
210
+ .formTemplates-item {
211
+ display: inline-block;
212
+ margin: 10px;
213
+ padding: 10px;
214
+ width: 230px;
215
+ border-radius: 4px;
216
+ transition: 0.25s;
217
+ box-sizing: border-box;
218
+
219
+ img {
220
+ width: 100%;
221
+ height: 230px;
222
+ object-fit: contain;
223
+ }
224
+ }
225
+ }
226
+ }
227
+ </style>
228
+
229
+ <style lang="scss">
230
+ .widgetGuide {
231
+ .el-transfer {
232
+ display: flex;
233
+ align-items: center;
234
+ }
235
+ .el-transfer-panel {
236
+ flex: 1;
237
+ }
85
238
  }
86
239
  </style>
@@ -74,7 +74,6 @@
74
74
  <el-button
75
75
  type="text"
76
76
  size="medium"
77
- disabled
78
77
  @click="handleDialogOpen('importTemplate')"
79
78
  >导入模板
80
79
  </el-button>
@@ -120,7 +119,8 @@
120
119
  :showFooter="
121
120
  dialog.action === 'previewPc' ||
122
121
  dialog.action === 'previewH5' ||
123
- dialog.action === 'importJson'
122
+ dialog.action === 'importJson' ||
123
+ dialog.action === 'importTemplate'
124
124
  "
125
125
  @on-close="handleDialogClose"
126
126
  @on-affirm="handleDialogAffirm"
@@ -133,7 +133,21 @@
133
133
  ></el-alert>
134
134
  <th-code-editor v-model="dialog.data" ref="codeEditor"></th-code-editor>
135
135
  </template>
136
- <template v-if="dialog.action === 'importTemplate'"> </template>
136
+ <div v-if="dialog.action === 'importTemplate'" class="formTemplates">
137
+ <div
138
+ :class="
139
+ `formTemplates-item th-border th-hover_boxShadow_light ${
140
+ formTemplateActive === index ? 'th-active' : ''
141
+ }`
142
+ "
143
+ v-for="(item, index) in formTemplates"
144
+ :key="index"
145
+ @click="handleFormTemplateClick(index)"
146
+ >
147
+ <img :src="item.img" alt="" />
148
+ <div>{{ item.name }}</div>
149
+ </div>
150
+ </div>
137
151
  <template v-if="dialog.action === 'generateJson'">
138
152
  <th-code-editor v-model="dialog.data" ref="codeEditor"></th-code-editor>
139
153
  </template>
@@ -164,7 +178,7 @@
164
178
  <template v-if="dialog.action === 'previewPc'">
165
179
  <generate-form
166
180
  v-if="dialog.show"
167
- :config="formData"
181
+ :config="formConfig"
168
182
  :oauthConfig="oauthConfig"
169
183
  :slotKeys="slotKeys"
170
184
  @change="handleDataChange"
@@ -188,7 +202,7 @@
188
202
  <generate-form
189
203
  v-if="dialog.show"
190
204
  class="box"
191
- :config="formData"
205
+ :config="formConfig"
192
206
  :oauthConfig="oauthConfig"
193
207
  @change="handleDataChange"
194
208
  @button-submit="handleButtonSubmit"
@@ -230,13 +244,17 @@ import { deepClone } from "./util/index";
230
244
  import * as XLSX from "xlsx/xlsx.mjs";
231
245
  import generateCode from "./util/generateCode.js";
232
246
  import GenerateForm from "./GenerateForm";
247
+ import EmptyTemplateJson from "./assets/templates/empty.json";
248
+ import GeneralTemplateJson from "./assets/templates/general.json";
249
+ import PersonalDetailsTemplateJson from "./assets/templates/personalDetails.json";
250
+ import TableTemplateJson from "./assets/templates/table.json";
233
251
  export default {
234
252
  props: {
235
253
  baseConfig: Object,
236
254
  permissions: Array,
237
255
  basicComponents: Array,
238
256
  layoutComponents: Array,
239
- formData: Object,
257
+ formConfig: Object,
240
258
  oauthConfig: Object,
241
259
  apiOptions: Array
242
260
  },
@@ -249,7 +267,6 @@ export default {
249
267
  data: null
250
268
  },
251
269
  dialogResultData: { show: false, data: null },
252
-
253
270
  dialogTitles: {
254
271
  previewPc: "预览-电脑端",
255
272
  previewH5: "预览-移动端",
@@ -258,7 +275,14 @@ export default {
258
275
  generateJson: "生成JSON",
259
276
  generateCode: "生成代码"
260
277
  },
261
- slotKeys: ["blank_1681093126000_96387"]
278
+ formTemplates: [
279
+ EmptyTemplateJson,
280
+ GeneralTemplateJson,
281
+ PersonalDetailsTemplateJson,
282
+ TableTemplateJson
283
+ ],
284
+ formTemplateActive: null,
285
+ slotKeys: []
262
286
  };
263
287
  },
264
288
  created() {},
@@ -418,13 +442,13 @@ export default {
418
442
  let data = "";
419
443
  switch (action) {
420
444
  case "generateJson":
421
- data = JSON.stringify(this.formData, null, 2);
445
+ data = JSON.stringify(this.formConfig, null, 2);
422
446
  break;
423
447
  case "generateCode":
424
448
  data = {
425
449
  generate: generateCode(
426
450
  {
427
- formConfig: JSON.stringify(this.formData, null, 2),
451
+ formConfig: JSON.stringify(this.formConfig, null, 2),
428
452
  apiOptions: JSON.stringify(this.apiOptions, null, 2),
429
453
  oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
430
454
  },
@@ -432,7 +456,7 @@ export default {
432
456
  ),
433
457
  making: generateCode(
434
458
  {
435
- formConfig: JSON.stringify(this.formData, null, 2),
459
+ formConfig: JSON.stringify(this.formConfig, null, 2),
436
460
  apiOptions: JSON.stringify(this.apiOptions, null, 2),
437
461
  oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
438
462
  },
@@ -440,6 +464,9 @@ export default {
440
464
  )
441
465
  };
442
466
  break;
467
+ case "importTemplate":
468
+ this.formTemplateActive = null;
469
+ break;
443
470
 
444
471
  default:
445
472
  break;
@@ -453,6 +480,14 @@ export default {
453
480
  if (this.dialog.action === "importJson") {
454
481
  this.handleClick("import-json", JSON.parse(this.dialog.data));
455
482
  }
483
+ if (
484
+ this.dialog.action === "importTemplate" &&
485
+ this.formTemplateActive !== null
486
+ ) {
487
+ const list = this.formTemplates[this.formTemplateActive].data.list;
488
+ this.formConfig.list = deepClone(list);
489
+ this.$emit("importTemplate");
490
+ }
456
491
  this.handleDialogClose();
457
492
  },
458
493
  handleDialogFullscreen() {
@@ -472,8 +507,8 @@ export default {
472
507
  },
473
508
  handleNetworkConfig() {
474
509
  const fieldsApi = {
475
- fields: this.formData.config.fields.api,
476
- mounted: this.formData.config.mounted.api
510
+ fields: this.formConfig.config.fields.api,
511
+ mounted: this.formConfig.config.mounted.api
477
512
  };
478
513
  const initList = list => {
479
514
  for (const item of list) {
@@ -490,13 +525,16 @@ export default {
490
525
  }
491
526
  }
492
527
  };
493
- initList(this.formData.list);
528
+ initList(this.formConfig.list);
494
529
  const apis = Object.values(fieldsApi);
495
530
  const network = {};
496
531
  this.apiOptions.map(item => {
497
532
  if (apis.includes(item.id)) network[item.id] = item;
498
533
  });
499
- this.formData.config.network = network;
534
+ this.formConfig.config.network = network;
535
+ },
536
+ handleFormTemplateClick(index) {
537
+ this.formTemplateActive = index;
500
538
  }
501
539
  }
502
540
  };
@@ -520,6 +558,23 @@ export default {
520
558
  justify-content: right;
521
559
  }
522
560
 
561
+ .formTemplates {
562
+ .formTemplates-item {
563
+ display: inline-block;
564
+ margin: 10px;
565
+ padding: 10px;
566
+ width: 230px;
567
+ border-radius: 4px;
568
+ transition: 0.25s;
569
+
570
+ img {
571
+ width: 100%;
572
+ height: 230px;
573
+ object-fit: contain;
574
+ }
575
+ }
576
+ }
577
+
523
578
  .previewH5 {
524
579
  width: 300px;
525
580
  height: 649px;
@@ -0,0 +1,39 @@
1
+ {
2
+ "name": "空白表单",
3
+ "data": {
4
+ "list": [],
5
+ "config": {
6
+ "fields": {
7
+ "type": "api",
8
+ "api": "",
9
+ "remote": true
10
+ },
11
+ "ui": "element",
12
+ "title": "",
13
+ "width": "",
14
+ "labelWidth": 100,
15
+ "labelPosition": "right",
16
+ "labelSuffix": ":",
17
+ "size": "small",
18
+ "disabled": false,
19
+ "hideLabel": false,
20
+ "mounted": {
21
+ "api": ""
22
+ },
23
+ "eventScript": [
24
+ {
25
+ "id": "mounted",
26
+ "label": "mounted",
27
+ "value": ""
28
+ },
29
+ {
30
+ "id": "refresh",
31
+ "label": "refresh",
32
+ "value": ""
33
+ }
34
+ ],
35
+ "network": {}
36
+ }
37
+ },
38
+ "img": ""
39
+ }