tianheng-ui 0.1.35 → 0.1.37

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.35",
4
+ "version": "0.1.37",
5
5
  "author": "shu lang <403732931@qq.com>",
6
6
  "license": "MIT",
7
7
  "private": false,
@@ -13,7 +13,7 @@
13
13
  <el-form-item prop="fieldsType" required>
14
14
  <el-tooltip
15
15
  slot="label"
16
- effect="dark"
16
+ effect="light"
17
17
  content="字段的配置方式"
18
18
  placement="top"
19
19
  >
@@ -31,7 +31,7 @@
31
31
  >
32
32
  <el-tooltip
33
33
  slot="label"
34
- effect="dark"
34
+ effect="light"
35
35
  content="使用接口的出参配置可选字段"
36
36
  placement="top"
37
37
  >
@@ -83,7 +83,7 @@
83
83
  <el-form-item>
84
84
  <el-tooltip
85
85
  slot="label"
86
- effect="dark"
86
+ effect="light"
87
87
  content="一般用于编辑和详情的数据回显"
88
88
  placement="top"
89
89
  >
@@ -1,24 +1,23 @@
1
1
  <template>
2
- <div v-if="formJson.config">
2
+ <div v-if="formConfig.config">
3
3
  <el-form
4
4
  class="generateForm"
5
- :class="{ isHideLabel: formJson.config.hideLabel }"
6
- :style="{ width: formJson.config.width }"
7
- :label-suffix="formJson.config.labelSuffix"
8
- :size="formJson.config.size"
5
+ :class="{ isHideLabel: formConfig.config.hideLabel }"
6
+ :style="{ width: formConfig.config.width }"
7
+ :label-suffix="formConfig.config.labelSuffix"
8
+ :size="formConfig.config.size"
9
9
  :model="models"
10
- :label-position="formJson.config.labelPosition"
11
- :label-width="formJson.config.labelWidth + 'px'"
10
+ :label-position="formConfig.config.labelPosition"
11
+ :label-width="formConfig.config.labelWidth + 'px'"
12
12
  ref="generateForm"
13
13
  >
14
14
  <genetate-form-item
15
- v-for="item in formJson.list"
15
+ v-for="item in formConfig.list"
16
16
  :key="item.key"
17
17
  :models.sync="models"
18
18
  :widget="item"
19
19
  :slotKeys="slotKeys"
20
- :remote="remoteData"
21
- :config="formJson.config"
20
+ :config="formConfig.config"
22
21
  :prop="item.type === 'grid' ? '' : item.model"
23
22
  :componentsData="componentsData"
24
23
  @input-change="onInputChange"
@@ -32,21 +31,20 @@
32
31
  <!-- <van-form
33
32
  v-else
34
33
  class="generateForm"
35
- :class="{ 'form-hideLabel': formJson.config.hideLabel }"
34
+ :class="{ 'form-hideLabel': formConfig.config.hideLabel }"
36
35
  :style="{ width: formWidth }"
37
36
  style="margin: 0 auto;"
38
- :label-align="formJson.config.labelPosition"
39
- :label-width="formJson.config.labelWidth + 'px'"
37
+ :label-align="formConfig.config.labelPosition"
38
+ :label-width="formConfig.config.labelWidth + 'px'"
40
39
  ref="generateForm"
41
40
  >
42
41
  <genetate-form-item-h5
43
- v-for="item in formJson.list"
42
+ v-for="item in formConfig.list"
44
43
  :key="item.key"
45
44
  :models.sync="models"
46
45
  :widget="item"
47
46
  :slotKeys="slotKeys"
48
- :remote="remoteData"
49
- :config="formJson.config"
47
+ :config="formConfig.config"
50
48
  :prop="item.type === 'grid' ? '' : item.model"
51
49
  :componentsData="componentsData"
52
50
  @input-change="onInputChange"
@@ -61,6 +59,7 @@
61
59
 
62
60
  <script>
63
61
  import * as Axios from "lib/theme-chalk/js/axios";
62
+ import { deepClone } from "./util/index";
64
63
  import GenetateFormItem from "./GenerateFormItem";
65
64
 
66
65
  export default {
@@ -79,12 +78,6 @@ export default {
79
78
  return {};
80
79
  }
81
80
  },
82
- remoteData: {
83
- type: Object,
84
- default: () => {
85
- return {};
86
- }
87
- },
88
81
  value: {
89
82
  type: Object,
90
83
  default: () => {
@@ -96,19 +89,20 @@ export default {
96
89
  default: () => {
97
90
  return [];
98
91
  }
99
- },
92
+ }
100
93
  },
101
94
  data() {
102
95
  return {
103
- formJson: this.config,
96
+ formConfig: this.config,
104
97
  models: {},
98
+ query: {},
105
99
  componentsData: [],
106
100
  axios: null
107
101
  };
108
102
  },
109
103
  computed: {
110
104
  formWidth() {
111
- if (this.formJson.config.width) return this.formJson.config.width;
105
+ if (this.formConfig.config.width) return this.formConfig.config.width;
112
106
 
113
107
  return "";
114
108
  }
@@ -117,7 +111,7 @@ export default {
117
111
  config(val) {
118
112
  this.setConfig(val);
119
113
  },
120
- formJson: {
114
+ formConfig: {
121
115
  handler(val) {
122
116
  this.$emit("update:config", val);
123
117
  },
@@ -131,9 +125,10 @@ export default {
131
125
  }
132
126
  },
133
127
  created() {
128
+ this.query = this.$route.query || {};
134
129
  localStorage.setItem("_TH_OauthConfig", JSON.stringify(this.oauthConfig));
135
130
  this.axios = Axios.init(this.oauthConfig);
136
- this.generateModle(this.formJson.list);
131
+ this.generateModle(this.formConfig.list);
137
132
  },
138
133
  mounted() {},
139
134
  methods: {
@@ -222,13 +217,23 @@ export default {
222
217
  hendleRemoteData(item) {
223
218
  if (!item.options.remote) return;
224
219
  if (item.type === "upload" || item.type === "button") return;
220
+ const func = this.formConfig.config.network[item.options.remoteFunc];
221
+ if (!func) return this.$message.warning("未知的请求接口,请检查配置信息");
222
+
223
+ const remoteFunc = deepClone(func);
224
+ for (let key of Object.keys(remoteFunc.params)) {
225
+ remoteFunc.params[key] = this.models[key] || this.query[key] || null;
226
+ }
227
+ if (remoteFunc.needPage) {
228
+ remoteFunc.params.pageNum = 1;
229
+ remoteFunc.params.pageSize = 20;
230
+ }
225
231
 
226
- const remoteFunc = item.options.remoteFunc;
227
232
  this.axios({
228
- url: remoteFunc.url,
233
+ url: `/api/lc/api/${remoteFunc.url}`,
229
234
  method: remoteFunc.method,
230
235
  headers: remoteFunc.headers,
231
- data: { ...remoteFunc.params }
236
+ data: remoteFunc.params
232
237
  }).then(res => {
233
238
  const resultData = res.data.records ? res.data.records : res.data;
234
239
  item.options.remoteOptions = resultData.map(element => {
@@ -240,7 +245,7 @@ export default {
240
245
  });
241
246
  });
242
247
  },
243
- handleButtonSubmit(val){
248
+ handleButtonSubmit(val) {
244
249
  this.$emit("button-submit", val);
245
250
  },
246
251
  getData() {
@@ -258,11 +263,11 @@ export default {
258
263
  this.$refs.generateForm.resetFields();
259
264
  },
260
265
  onInputChange(value, field) {
261
- this.$emit("on-change", field, value, this.models);
266
+ this.$emit("change", field, value, this.models);
262
267
  },
263
268
  setConfig(json) {
264
- this.formJson = json;
265
- this.generateModle(this.formJson.list);
269
+ this.formConfig = json;
270
+ this.generateModle(this.formConfig.list);
266
271
  }
267
272
  }
268
273
  };
@@ -24,148 +24,15 @@
24
24
  :widget="widget"
25
25
  :config="config"
26
26
  :models="models"
27
- :remote="remote"
28
27
  :prop="prop"
29
28
  :slotKeys="slotKeys"
30
29
  :componentsData="componentsData"
31
30
  @button-submit="handleButtonSubmit"
32
- ></component>
33
-
34
- <!-- <template v-if="widget.type == 'input'">
35
-
36
-
37
-
38
- <template v-if="widget.type == 'tableH5'">
39
- <div class="tableH5">
40
- <div
41
- v-for="(column, columnIndex) in dataModel"
42
- class="tableH5-item"
43
- :key="`table_h5_${columnIndex}`"
44
- >
45
- <div
46
- v-for="(element, elementIndex) in widget.list"
47
- :key="`table_h5_${columnIndex}_${element.key}`"
48
- >
49
- <generate-form-item
50
- style="flex:1;"
51
- :models.sync="column"
52
- :widget="element"
53
- :remote="remote"
54
- :config="config"
55
- :prop="
56
- element.type === 'grid'
57
- ? `${prop}.${columnIndex}`
58
- : `${prop}.${columnIndex}.${element.model}`
59
- "
60
- :slotKeys="slotKeys"
61
- :componentsData="componentsData"
62
- >
63
- <template v-for="name in slotKeys" :slot="name">
64
- <slot :name="name" />
65
- </template>
66
- </generate-form-item>
67
- <div
68
- v-if="
69
- widget.options.isDelete &&
70
- elementIndex === 0 &&
71
- columnIndex >= widget.options.deleteIndex
72
- "
73
- class="actions"
74
- >
75
- <el-button
76
- type="danger"
77
- @click.native.prevent="handleTableDelete(columnIndex)"
78
- >{{ widget.options.deleteButtonText }}</el-button
79
- >
80
- </div>
81
- </div>
82
- </div>
83
-
84
- <div v-if="widget.options.isAdd" style="text-align: center;">
85
- <el-button
86
- type="text"
87
- :disabled="widget.options.disabled"
88
- @click="handleTableAdd"
89
- >{{ widget.options.addButtonText }}</el-button
90
- >
91
- </div>
92
- </div>
93
- </template>
94
-
95
- <template v-if="widget.type == 'grid'">
96
- <th-row
97
- :gutter="widget.options.gutter ? widget.options.gutter : 0"
98
- :justify="widget.options.justify"
99
- :align="widget.options.align"
100
- >
101
- <th-col
102
- v-for="(column, columnIndex) in widget.options.columns"
103
- :key="columnIndex"
104
- :span="column.span"
105
- >
106
- <generate-form-item
107
- v-for="element in column.list"
108
- :key="element.key"
109
- :widget="element"
110
- :models="models"
111
- :config="config"
112
- :remote="remote"
113
- :prop="prop ? `${prop}.${element.model}` : element.model"
114
- :slotKeys="slotKeys"
115
- :componentsData="componentsData"
116
- >
117
- <template v-for="name in slotKeys" :slot="name">
118
- <slot :name="name" />
119
- </template>
120
- </generate-form-item>
121
- </th-col>
122
- </th-row>
123
- </template>
124
-
125
- <template v-if="widget.type == 'tabs'">
126
- <el-tabs
127
- v-model="widget.options.defaultValue"
128
- :type="widget.options.type"
129
- :tab-position="widget.options.tabPosition"
130
- >
131
- <el-tab-pane
132
- v-for="(column, columnIndex) in widget.options.columns"
133
- :key="`tabs_${columnIndex}`"
134
- :label="column.label"
135
- :name="column.value"
136
- >
137
- <generate-form-item
138
- v-for="element in column.list"
139
- :key="`tabs_${columnIndex}_${element.key}`"
140
- :widget="element"
141
- :models.sync="dataModel[column.value]"
142
- :config="config"
143
- :remote="remote"
144
- :prop="
145
- element.type === 'grid'
146
- ? `${prop}.${column.value}`
147
- : `${prop}.${column.value}.${element.model}`
148
- "
149
- :slotKeys="slotKeys"
150
- :componentsData="componentsData"
151
- >
152
- <template v-for="name in slotKeys" :slot="name">
153
- <slot :name="name" />
154
- </template>
155
- </generate-form-item>
156
- </el-tab-pane>
157
- </el-tabs>
158
- </template>
159
-
160
- <template v-if="widget.type == 'divider'">
161
- <el-divider :content-position="widget.options.contentPosition">
162
- {{ widget.options.defaultValue }}
163
- </el-divider>
164
- </template>
165
-
166
- <el-dialog :visible.sync="dialogVisible" append-to-body>
167
- <img width="100%" :src="dialogImageUrl" alt="" />
168
- </el-dialog> -->
31
+ >
32
+ <template v-for="name in slotKeys" :slot="name">
33
+ <slot :name="name" />
34
+ </template>
35
+ </component>
169
36
  </el-form-item>
170
37
  </template>
171
38
 
@@ -177,22 +44,12 @@ import FmUpload from "./Upload";
177
44
 
178
45
  export default {
179
46
  name: "generate-form-item",
180
- props: [
181
- "widget",
182
- "models",
183
- "remote",
184
- "prop",
185
- "slotKeys",
186
- "config",
187
- "componentsData"
188
- ],
47
+ props: ["widget", "models", "prop", "slotKeys", "config", "componentsData"],
189
48
  components: { FmUpload, VueEditor },
190
49
  data() {
191
50
  return {
192
51
  compsData: deepClone(compsData),
193
- dataModel: this.models[this.widget.model],
194
- dialogVisible: false,
195
- dialogImageUrl: ""
52
+ dataModel: this.models[this.widget.model]
196
53
  };
197
54
  },
198
55
  watch: {
@@ -221,24 +78,6 @@ export default {
221
78
  return `${this.widget.options.labelWidth}px`;
222
79
 
223
80
  return "";
224
- },
225
- uploadUrl() {
226
- if (this.widget.options.remote) {
227
- const info = sessionStorage.getItem("th_oauth_info");
228
- let baseUrl = "";
229
- if (info) baseUrl = JSON.parse(info).baseUrl;
230
-
231
- return `${baseUrl}/${this.widget.options.remoteFunc.url}`;
232
- } else {
233
- return this.widget.options.action;
234
- }
235
- },
236
- imagePreviewList() {
237
- const list = [];
238
- this.widget.options.defaultValue.forEach(item => {
239
- list.push(item.url);
240
- });
241
- return list;
242
81
  }
243
82
  },
244
83
  created() {
@@ -271,12 +110,6 @@ export default {
271
110
  this.dataModel[0] = vals;
272
111
  this.widget.options.endTimePickerOptions.minTime = vals;
273
112
  },
274
- handlePictureCardPreview(file, listType) {
275
- if (listType === "picture-card") {
276
- this.dialogImageUrl = file.url;
277
- this.dialogVisible = true;
278
- }
279
- },
280
113
  handleRemove(file, fileList) {
281
114
  this.dataModel = {
282
115
  data: fileList,
@@ -13,7 +13,7 @@
13
13
  <el-form-item>
14
14
  <el-tooltip
15
15
  slot="label"
16
- effect="dark"
16
+ effect="light"
17
17
  content="切换组件会导致该组件配置信息重置,请谨慎使用!"
18
18
  placement="top"
19
19
  >
@@ -34,21 +34,16 @@
34
34
  </el-option>
35
35
  </el-select>
36
36
  </el-form-item>
37
- <el-form-item required>
37
+ <el-form-item required v-if="config.fieldsType === 'fieldsApi'">
38
38
  <el-tooltip
39
39
  slot="label"
40
- effect="dark"
40
+ effect="light"
41
41
  content="组件关联数据表中的唯一字段"
42
42
  placement="top"
43
43
  >
44
- <span style="color: #409EFF;">组件字段</span>
44
+ <span style="color: #409EFF;">字段标识</span>
45
45
  </el-tooltip>
46
- <el-input
47
- v-if="config.fieldsType === 'custom'"
48
- v-model="data.model"
49
- ></el-input>
50
46
  <el-select
51
- v-else
52
47
  v-model="data.model"
53
48
  style="width:100%;"
54
49
  placeholder="请选择字段"
@@ -62,14 +57,14 @@
62
57
  </el-option>
63
58
  </el-select>
64
59
  </el-form-item>
65
- <el-form-item v-if="config.fieldsType === 'fieldsApi'">
60
+ <el-form-item>
66
61
  <el-tooltip
67
62
  slot="label"
68
- effect="dark"
63
+ effect="light"
69
64
  content="表单提交时的入参名,对应数据表中的字段,非必要不修改!"
70
65
  placement="top"
71
66
  >
72
- <span style="color: #409EFF;">字段标识</span>
67
+ <span style="color: #409EFF;">组件字段</span>
73
68
  </el-tooltip>
74
69
  <el-input v-model="data.model"></el-input>
75
70
  </el-form-item>
@@ -1,9 +1,9 @@
1
1
  <template>
2
2
  <div class="widget-form-container" ref="formContainer">
3
3
  <th-empty
4
- class="form-empty"
5
4
  v-if="data.list.length == 0"
6
- :image="require('../../lib/theme-chalk/images/notData.png')"
5
+ class="form-empty"
6
+ image=""
7
7
  description="从左侧拖拽来添加字段"
8
8
  ></th-empty>
9
9
  <el-form