tianheng-ui 0.1.77 → 0.1.79

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/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
+ }