tianheng-ui 0.1.35 → 0.1.36

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.
@@ -1,24 +1,6 @@
1
1
  <template>
2
2
  <div class="widgetTools">
3
3
  <div class="left">
4
- <!-- <el-button
5
- v-if="permissions.includes('monitor')"
6
- :class="{ active: client === 'monitor' }"
7
- type="text"
8
- size="medium"
9
- icon="el-icon-monitor"
10
- @click="handleClick('monitor')"
11
- >
12
- </el-button>
13
- <el-button
14
- v-if="permissions.includes('mobile')"
15
- :class="{ active: client === 'mobile' }"
16
- type="text"
17
- size="medium"
18
- icon="el-icon-mobile"
19
- @click="handleClick('mobile')"
20
- >
21
- </el-button> -->
22
4
  <slot> </slot>
23
5
  </div>
24
6
  <div class="right">
@@ -122,7 +104,6 @@
122
104
  <el-button
123
105
  type="text"
124
106
  size="medium"
125
- disabled
126
107
  @click="handleDialogOpen('generateCode')"
127
108
  >
128
109
  生成代码
@@ -157,18 +138,22 @@
157
138
  <th-code-editor v-model="dialog.data" ref="codeEditor"></th-code-editor>
158
139
  </template>
159
140
  <template v-if="dialog.action === 'generateCode'">
160
- <el-tabs value="vue" type="border-card" style="box-shadow: none;">
161
- <el-tab-pane label="Vue Component" name="vue">
141
+ <el-tabs
142
+ style="height:100%;box-shadow: none;"
143
+ value="making"
144
+ type="border-card"
145
+ >
146
+ <el-tab-pane style="height:100%;" label="设计器" name="making">
162
147
  <th-code-editor
163
- v-model="dialog.data.vue"
148
+ v-model="dialog.data.making"
164
149
  language="html"
165
150
  readonly
166
151
  ref="vueCodeEditor"
167
152
  ></th-code-editor>
168
153
  </el-tab-pane>
169
- <el-tab-pane label="HTML" name="html">
154
+ <el-tab-pane style="height:100%;" label="渲染器" name="generate">
170
155
  <th-code-editor
171
- v-model="dialog.data.html"
156
+ v-model="dialog.data.generate"
172
157
  language="html"
173
158
  readonly
174
159
  ref="htmlCodeEditor"
@@ -178,19 +163,19 @@
178
163
  </template>
179
164
  <template v-if="dialog.action === 'previewPc'">
180
165
  <generate-form
166
+ v-if="dialog.show"
181
167
  :config="formData"
182
168
  :value="formValue"
183
169
  :oauthConfig="oauthConfig"
184
- :remote="remoteData"
170
+ :remoteData="remoteData"
185
171
  :slotKeys="slotKeys"
186
- insite="true"
187
172
  @on-change="handleDataChange"
188
173
  @button-submit="handleButtonSubmit"
189
174
  ref="generateForm"
190
175
  >
191
- <template v-for="name in slotKeys" :slot="name">
192
- <slot :name="name" />
193
- </template>
176
+ <div v-for="name in slotKeys" :key="name" :slot="name">
177
+ <div>{{ name }}</div>
178
+ </div>
194
179
  </generate-form>
195
180
  <template slot="footer">
196
181
  <el-button type="primary" @click="handleGetData">获取数据</el-button>
@@ -201,20 +186,20 @@
201
186
  <div class="previewH5">
202
187
  <div class="header"></div>
203
188
  <generate-form
189
+ v-if="dialog.show"
204
190
  class="box"
205
191
  :config="formData"
206
192
  :value="formValue"
207
193
  :oauthConfig="oauthConfig"
208
194
  :remote="remoteData"
209
- :slotKeys="slotKeys"
210
195
  insite="true"
211
196
  @on-change="handleDataChange"
212
197
  @button-submit="handleButtonSubmit"
213
198
  ref="generateForm"
214
199
  >
215
- <template v-for="name in slotKeys" :slot="name">
216
- <slot :name="name" />
217
- </template>
200
+ <div v-for="name in slotKeys" :key="name" :slot="name">
201
+ <div>{{ name }}</div>
202
+ </div>
218
203
  </generate-form>
219
204
  </div>
220
205
  <template slot="footer">
@@ -245,20 +230,18 @@
245
230
  import { deepClone } from "./util/index";
246
231
  import * as XLSX from "xlsx/xlsx.mjs";
247
232
  import request from "./util/request";
248
- import Clipboard from "clipboard";
249
233
  import generateCode from "./util/generateCode.js";
250
234
  import GenerateForm from "./GenerateForm";
251
235
  export default {
252
236
  props: {
253
237
  baseConfig: Object,
254
238
  permissions: Array,
255
- client: String,
256
239
  basicComponents: Array,
257
240
  layoutComponents: Array,
258
241
  formData: Object,
259
242
  formValue: Object,
260
243
  oauthConfig: Object,
261
- slotKeys: Array
244
+ apiOptions: Array
262
245
  },
263
246
  components: { GenerateForm },
264
247
  data() {
@@ -301,7 +284,7 @@ export default {
301
284
  console.log("callback", response, file, fileList);
302
285
  }
303
286
  },
304
- jsonClipboard: null
287
+ slotKeys: ["blank_1681093126000_96387"]
305
288
  };
306
289
  },
307
290
  created() {},
@@ -455,14 +438,6 @@ export default {
455
438
  handleReset() {
456
439
  this.$refs.generateForm.reset();
457
440
  },
458
- initClipboard() {
459
- if (!this.jsonClipboard) {
460
- this.jsonClipboard = new Clipboard(".json-btn");
461
- this.jsonClipboard.on("success", e => {
462
- this.$message.success("复制成功");
463
- });
464
- }
465
- },
466
441
  handleDialogOpen(action) {
467
442
  let data = "";
468
443
  switch (action) {
@@ -471,8 +446,22 @@ export default {
471
446
  break;
472
447
  case "generateCode":
473
448
  data = {
474
- html: generateCode(JSON.stringify(this.formData), "html"),
475
- vue: generateCode(JSON.stringify(this.formData), "vue")
449
+ generate: generateCode(
450
+ {
451
+ formConfig: JSON.stringify(this.formData, null, 2),
452
+ apiOptions: JSON.stringify(this.apiOptions, null, 2),
453
+ oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
454
+ },
455
+ "generate"
456
+ ),
457
+ making: generateCode(
458
+ {
459
+ formConfig: JSON.stringify(this.formData, null, 2),
460
+ apiOptions: JSON.stringify(this.apiOptions, null, 2),
461
+ oauthConfig: JSON.stringify(this.oauthConfig, null, 2)
462
+ },
463
+ "making"
464
+ )
476
465
  };
477
466
  break;
478
467
 
@@ -533,7 +522,7 @@ export default {
533
522
  margin: auto;
534
523
  padding: 0 10px;
535
524
  border-radius: 10px;
536
- background-image: url("../../lib/theme-chalk/images/iPhone13.png");
525
+ background-image: url("");
537
526
  background-size: 100% 100%;
538
527
  overflow: hidden;
539
528
  .header {
@@ -546,3 +535,11 @@ export default {
546
535
  }
547
536
  }
548
537
  </style>
538
+
539
+ <style lang="scss">
540
+ .widgetTools {
541
+ .el-tabs__content {
542
+ height: calc(100% - 40px);
543
+ }
544
+ }
545
+ </style>
@@ -15,7 +15,6 @@
15
15
  :widget="element"
16
16
  :models="models"
17
17
  :config="config"
18
- :remote="remote"
19
18
  :prop="prop ? `${prop}.${element.model}` : element.model"
20
19
  :slotKeys="slotKeys"
21
20
  :componentsData="componentsData"
@@ -34,7 +33,7 @@ import GenerateFormItem from "../../GenerateFormItem.vue";
34
33
  export default {
35
34
  components: { GenerateFormItem },
36
35
  mixins: [itemsComponent],
37
- props: ["models", "remote", "prop", "slotKeys", "componentsData"],
36
+ props: ["models", "prop", "slotKeys", "componentsData"],
38
37
  data() {
39
38
  return {};
40
39
  },
@@ -14,7 +14,6 @@
14
14
  style="flex:1;"
15
15
  :models.sync="column"
16
16
  :widget="element"
17
- :remote="remote"
18
17
  :config="config"
19
18
  :prop="
20
19
  element.type === 'grid'
@@ -62,7 +61,7 @@ import GenerateFormItem from "../../GenerateFormItem.vue";
62
61
  export default {
63
62
  components: { GenerateFormItem },
64
63
  mixins: [itemsComponent],
65
- props: ["models", "remote", "prop", "slotKeys", "componentsData"],
64
+ props: ["models", "prop", "slotKeys", "componentsData"],
66
65
  data() {
67
66
  return {};
68
67
  },
@@ -26,7 +26,6 @@
26
26
  <generate-form-item
27
27
  :models.sync="dataModel[scope.$index]"
28
28
  :widget="element"
29
- :remote="remote"
30
29
  :config="config"
31
30
  :prop="`${prop}.${scope.$index}.${element.model}`"
32
31
  :slotKeys="slotKeys"
@@ -80,7 +79,7 @@ import GenerateFormItem from "../../GenerateFormItem.vue";
80
79
  export default {
81
80
  components: { GenerateFormItem },
82
81
  mixins: [itemsComponent],
83
- props: ["models", "remote", "prop", "slotKeys", "componentsData"],
82
+ props: ["models", "prop", "slotKeys", "componentsData"],
84
83
  data() {
85
84
  return {};
86
85
  },
@@ -16,7 +16,6 @@
16
16
  :widget="element"
17
17
  :models.sync="dataModel[column.value]"
18
18
  :config="config"
19
- :remote="remote"
20
19
  :prop="
21
20
  element.type === 'grid'
22
21
  ? `${prop}.${column.value}`
@@ -39,7 +38,7 @@ import GenerateFormItem from "../../GenerateFormItem.vue";
39
38
  export default {
40
39
  components: { GenerateFormItem },
41
40
  mixins: [itemsComponent],
42
- props: ["models", "remote", "prop", "slotKeys", "componentsData"],
41
+ props: ["models", "prop", "slotKeys", "componentsData"],
43
42
  data() {
44
43
  return {};
45
44
  },
@@ -70,8 +70,12 @@ export default {
70
70
  const info = sessionStorage.getItem("th_oauth_info");
71
71
  let baseUrl = "";
72
72
  if (info) baseUrl = JSON.parse(info).baseUrl;
73
-
74
- return `${baseUrl}${this.widget.options.remoteFunc.api}`;
73
+ const func = this.config.network[this.widget.options.remoteFunc];
74
+ if (!func) {
75
+ this.$message.warning("未知的请求接口,请检查配置信息");
76
+ return "";
77
+ }
78
+ return `${baseUrl}/api/lc/api/${func.url}`;
75
79
  } else {
76
80
  return this.widget.options.action;
77
81
  }
@@ -109,7 +109,7 @@
109
109
  :formData="formConfig"
110
110
  :formValue="widgetValue"
111
111
  :oauthConfig="oauthConfig"
112
- :slotKeys="Object.keys($slots)"
112
+ :apiOptions="apiOptions"
113
113
  @click="handleWidgetToolsChange"
114
114
  >
115
115
  <slot name="action"></slot>
@@ -353,7 +353,7 @@ export default {
353
353
  },
354
354
 
355
355
  handleClear() {
356
- this.formConfig.list = []
356
+ this.formConfig.list = [];
357
357
  this.widgetFormSelect = {};
358
358
  },
359
359
  handleWidgetToolsChange(val, data) {
@@ -41,14 +41,19 @@ function findRemoteFunc(list, funcList, tokenFuncList, blankList) {
41
41
  }
42
42
  }
43
43
 
44
- export default function(data, type = "vue") {
44
+ export default function(config, type = "making") {
45
45
  const funcList = [];
46
46
 
47
47
  const tokenFuncList = [];
48
48
 
49
49
  const blankList = [];
50
50
 
51
- findRemoteFunc(JSON.parse(data).list, funcList, tokenFuncList, blankList);
51
+ findRemoteFunc(
52
+ JSON.parse(config.formConfig).list,
53
+ funcList,
54
+ tokenFuncList,
55
+ blankList
56
+ );
52
57
 
53
58
  let funcTemplate = "";
54
59
 
@@ -56,108 +61,97 @@ export default function(data, type = "vue") {
56
61
 
57
62
  for (let i = 0; i < funcList.length; i++) {
58
63
  funcTemplate += `
59
- ${funcList[i].func} (resolve) {
60
- // ${funcList[i].label} ${funcList[i].model}
61
- // Call callback function once get the data from remote server
62
- // resolve(data)
63
- },
64
+ ${funcList[i].func} (resolve) {
65
+ // ${funcList[i].label} ${funcList[i].model}
66
+ // Call callback function once get the data from remote server
67
+ // resolve(data)
68
+ },
64
69
  `;
65
70
  }
66
71
 
67
72
  for (let i = 0; i < tokenFuncList.length; i++) {
68
73
  funcTemplate += `
69
- ${tokenFuncList[i].func} (resolve) {
70
- // ${tokenFuncList[i].label} ${tokenFuncList[i].model}
71
- // Call callback function once get the token
72
- // resolve(token)
73
- },
74
+ ${tokenFuncList[i].func} (resolve) {
75
+ // ${tokenFuncList[i].label} ${tokenFuncList[i].model}
76
+ // Call callback function once get the token
77
+ // resolve(token)
78
+ },
74
79
  `;
75
80
  }
76
81
 
77
82
  for (let i = 0; i < blankList.length; i++) {
78
83
  blankTemplate += `
79
- <template slot="${blankList[i].name}" slot-scope="scope">
80
- <!-- ${blankList[i].label} -->
81
- <!-- use v-model="scope.model.${blankList[i].name}" to bind data -->
82
- </template>
84
+ <template slot="${blankList[i].name}" slot-scope="scope">
85
+ <!-- ${blankList[i].label} -->
86
+ <!-- use v-model="scope.model.${blankList[i].name}" to bind data -->
87
+ </template>
83
88
  `;
84
89
  }
85
90
 
86
- if (type == "vue") {
91
+ if (type == "making") {
87
92
  return `
88
93
  <template>
89
- <div>
90
- <th-generate-form :data="jsonData" :remote="remoteFuncs" :value="editData" ref="generateForm">
91
- ${blankTemplate}
92
- </th-generate-form>
93
- <el-button type="primary" @click="handleSubmit">提交</el-button>
94
- </div>
94
+ <th-form-making :config="formConfig" :oauthConfig="oauthConfig" :apiOptions="apiOptions" ref="makingForm">
95
+ <div slot="action">
96
+ <el-button type="danger" icon="el-icon-close" size="mini" @click="$router.go(-1)">关闭</el-button>
97
+ <el-button type="primary" icon="el-icon-finished" size="mini" @click="handleSubmit">保存</el-button>
98
+ <el-button type="warning" icon="el-icon-document-copy" size="mini" @click="handleSubmit">另存为</el-button>
99
+ </div>
100
+ ${blankTemplate}
101
+ </th-form-making>
95
102
  </template>
96
103
 
97
104
  <script>
98
105
  export default {
99
106
  data () {
100
107
  return {
101
- jsonData: ${data},
102
- editData: {},
103
- remoteFuncs: {
104
- ${funcTemplate}
105
- }
108
+ formConfig: ${config.formConfig},
109
+ apiOptions: ${config.apiOptions},
110
+ oauthConfig: ${config.oauthConfig},
106
111
  }
107
112
  },
108
113
  methods: {
109
114
  handleSubmit () {
110
- this.$refs.generateForm.getData().then(data => {
111
- // data check success
112
- // data - form data
113
- }).catch(e => {
114
- // data check failed
115
- })
115
+ this.$refs.makingForm.getConfig().then(res => {
116
+ console.log(res);
117
+ });
116
118
  }
117
119
  }
118
120
  }
119
121
  </script>`;
120
122
  } else {
121
- return `<!DOCTYPE html>
122
- <html>
123
- <head>
124
- <meta charset="UTF-8">
125
- <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
126
- <link rel="stylesheet" href="https://unpkg.com/form-making/dist/FormMaking.css">
127
- </head>
128
- <body>
129
- <div id="app">
130
- <th-generate-form :data="jsonData" :remote="remoteFuncs" :value="editData" ref="generateForm">
131
- ${blankTemplate}
132
- </th-generate-form>
133
- <el-button type="primary" @click="handleSubmit">提交</el-button>
134
- </div>
135
- <script src="https://unpkg.com/vue/dist/vue.js"></script>
136
- <script src="https://unpkg.com/element-ui/lib/index.js"></script>
137
- <script src="https://unpkg.com/form-making/dist/FormMaking.umd.js"></script>
138
- <script>
139
- new Vue({
140
- el: '#app',
141
- data: {
142
- jsonData: ${data},
143
- editData: {},
144
- remoteFuncs: {
145
- ${funcTemplate}
146
- }
147
- },
148
- methods: {
149
- handleSubmit () {
150
- this.$refs.generateForm.getData().then(data => {
151
- // data check success
152
- // data - form data
153
- }).catch(e => {
154
- // data check failed
155
- })
156
- }
157
- }
158
- })
159
- </script>
160
- </body>
161
- </html>`;
123
+ return `
124
+ <template>
125
+ <th-form-generate :config="formConfig" :value="formValue" :oauthConfig="oauthConfig" :slotKeys="slotKeys" @change="handleChange" @button-submit="handleSubmit" ref="generateForm">
126
+ ${blankTemplate}
127
+ </th-form-generate>
128
+ </template>
129
+
130
+ <script>
131
+ export default {
132
+ data () {
133
+ return {
134
+ formConfig: ${config.formConfig},
135
+ formValue: {},
136
+ oauthConfig: ${config.oauthConfig},
137
+ slotKeys: ${JSON.stringify(
138
+ blankList.map(item => {
139
+ return item.name;
140
+ })
141
+ )}
142
+ }
143
+ },
144
+ methods: {
145
+ handleChange (val) {
146
+ console.log(val);
147
+ },
148
+ handleSubmit () {
149
+ this.$refs.generateForm.getConfig().then(res => {
150
+ console.log(res);
151
+ });
152
+ }
153
+ }
154
+ }
155
+ </script>`;
162
156
  }
163
157
  }
@@ -1,22 +1,6 @@
1
1
  <template>
2
2
  <div class="widgetTools">
3
3
  <div class="left">
4
- <!-- <el-button
5
- :class="{ active: client === 'monitor' }"
6
- type="text"
7
- size="medium"
8
- icon="el-icon-monitor"
9
- @click="handleClick('monitor')"
10
- >
11
- </el-button>
12
- <el-button
13
- :class="{ active: client === 'mobile' }"
14
- type="text"
15
- size="medium"
16
- icon="el-icon-mobile"
17
- @click="handleClick('mobile')"
18
- >
19
- </el-button> -->
20
4
  <slot> </slot>
21
5
  </div>
22
6
  <div class="right">
@@ -180,7 +164,6 @@ import { deepClone } from "./util";
180
164
  export default {
181
165
  props: {
182
166
  config: Object,
183
- client: String,
184
167
  permissions: Array
185
168
  },
186
169
  data() {