cloud-web-corejs 1.0.18 → 1.0.19

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 (186) hide show
  1. package/package.json +2 -1
  2. package/src/components/jsonImport/index.js +3 -1
  3. package/src/components/jsonImport/mixins.js +16 -16
  4. package/src/components/xform/form-designer/form-widget/dialog/importDialogMixin.js +1 -1
  5. package/src/layout/components/Sidebar/default.vue +10 -4
  6. package/src/router/modules/customer.js +8 -8
  7. package/src/utils/aes.js +1 -0
  8. package/src/views/bd/setting/bd_attach_setting/dialog.vue +4 -4
  9. package/src/views/bd/setting/bd_attach_setting/edit.vue +3 -3
  10. package/src/views/bd/setting/bd_attach_setting/list.vue +3 -3
  11. package/src/views/bd/setting/form_script/dialog.vue +14 -12
  12. package/src/views/bd/setting/form_script/edit.vue +5 -4
  13. package/src/views/bd/setting/form_script/edit1.vue +3 -3
  14. package/src/views/bd/setting/form_script/form_list.vue +3 -3
  15. package/src/views/bd/setting/form_script/list.vue +4 -4
  16. package/src/views/bd/setting/form_script/list1.vue +4 -4
  17. package/src/views/bd/setting/form_script/list2.vue +1 -1
  18. package/src/views/bd/setting/form_template/dialog.vue +24 -17
  19. package/src/views/bd/setting/form_template/edit.vue +3 -3
  20. package/src/views/bd/setting/form_template/editWfObjConfigDialog.vue +1 -1
  21. package/src/views/bd/setting/form_template/ftHistoryDialog.vue +5 -5
  22. package/src/views/bd/setting/form_template/itemEdit.vue +3 -3
  23. package/src/views/bd/setting/form_template/itemList.vue +3 -3
  24. package/src/views/bd/setting/form_template/list.vue +4 -4
  25. package/src/views/bd/setting/form_template/preformDialog.vue +2 -2
  26. package/src/views/bd/setting/menu_kind/authDialog.vue +2 -2
  27. package/src/views/bd/setting/menu_kind/dialog.vue +23 -16
  28. package/src/views/bd/setting/menu_kind/list.vue +3 -3
  29. package/src/views/bd/setting/table_model/dialog.vue +4 -4
  30. package/src/views/bd/setting/table_model/edit.vue +1123 -1123
  31. package/src/views/bd/setting/table_model/list.vue +4 -4
  32. package/src/views/bd/setting/table_model/zdDialog.vue +4 -4
  33. package/src/views/mobile/user/area/dialog.vue +3 -2
  34. package/src/views/mobile/user/user/dialog.vue +3 -2
  35. package/src/views/support/export_template/edit.vue +4 -4
  36. package/src/views/support/export_template/list.vue +12 -12
  37. package/src/views/user/access_log/edit.vue +2 -2
  38. package/src/views/user/access_log/list.vue +8 -8
  39. package/src/views/user/access_log/statistics_list.vue +16 -11
  40. package/src/views/user/api_request/edit.vue +7 -4
  41. package/src/views/user/api_request/list.vue +7 -5
  42. package/src/views/user/area/dialog.vue +4 -4
  43. package/src/views/user/area_attribute/configDialog.vue +319 -319
  44. package/src/views/user/area_attribute/edit.vue +2 -2
  45. package/src/views/user/area_attribute/list.vue +1 -1
  46. package/src/views/user/attachment/uploadDialog.vue +11 -11
  47. package/src/views/user/bill_setting/edit.vue +6 -5
  48. package/src/views/user/bill_setting/h5_ModifyDialog.vue +5 -3
  49. package/src/views/user/bill_setting/h5_view.vue +4 -4
  50. package/src/views/user/bill_setting/itemViewDialog.vue +1 -1
  51. package/src/views/user/bill_setting/list.vue +5 -4
  52. package/src/views/user/bill_setting/queryDialog.vue +3 -3
  53. package/src/views/user/bill_setting/render.vue +6 -6
  54. package/src/views/user/bill_setting/template2.json +44 -11
  55. package/src/views/user/bill_setting/userDialog.vue +4 -4
  56. package/src/views/user/code_rules/edit.vue +3 -3
  57. package/src/views/user/code_rules/list.vue +3 -3
  58. package/src/views/user/commMenu/index.vue +2 -2
  59. package/src/views/user/common_attribute/edit.vue +3 -3
  60. package/src/views/user/common_attribute/itemEdit.vue +3 -3
  61. package/src/views/user/common_attribute/list.vue +3 -3
  62. package/src/views/user/common_script/edit.vue +5 -4
  63. package/src/views/user/common_script/list.vue +14 -13
  64. package/src/views/user/company_info/dialog.vue +138 -131
  65. package/src/views/user/company_info/edit.vue +2 -2
  66. package/src/views/user/company_info/view.vue +1 -1
  67. package/src/views/user/country/dialog.vue +6 -6
  68. package/src/views/user/country/edit.vue +8 -7
  69. package/src/views/user/country/list.vue +170 -160
  70. package/src/views/user/data_type_setting/dialog.vue +10 -7
  71. package/src/views/user/data_type_setting/editDialog.vue +12 -11
  72. package/src/views/user/ea/eagroup/eaobj_list.vue +331 -310
  73. package/src/views/user/ea/eagroup/edit.vue +492 -475
  74. package/src/views/user/ea/eaobj/edit.vue +153 -148
  75. package/src/views/user/ea/eaobj/list.vue +147 -135
  76. package/src/views/user/error-page/401.vue +42 -34
  77. package/src/views/user/error-page/404.vue +19 -3
  78. package/src/views/user/extend_datasource/dialog.vue +124 -116
  79. package/src/views/user/extend_datasource/edit.vue +5 -4
  80. package/src/views/user/extend_datasource/list.vue +3 -3
  81. package/src/views/user/fieldTranslation/editDialog.vue +2 -2
  82. package/src/views/user/fieldTranslation/list.vue +4 -3
  83. package/src/views/user/field_values_invisible/edit.vue +85 -83
  84. package/src/views/user/field_values_invisible/list.vue +32 -21
  85. package/src/views/user/file_type/edit.vue +3 -3
  86. package/src/views/user/file_type/list.vue +7 -4
  87. package/src/views/user/file_type/userEdit.vue +188 -188
  88. package/src/views/user/file_view_area/edit.vue +3 -3
  89. package/src/views/user/file_view_area/itemEdit.vue +168 -165
  90. package/src/views/user/file_view_area/list.vue +3 -3
  91. package/src/views/user/file_view_ins/list.vue +55 -36
  92. package/src/views/user/file_view_ins/propertiesDialog.vue +218 -218
  93. package/src/views/user/form/form_ins_list/edit.vue +421 -421
  94. package/src/views/user/form/form_template/dialog.vue +24 -17
  95. package/src/views/user/form/form_template/edit.vue +7 -4
  96. package/src/views/user/form/form_template/itemEdit.vue +3 -3
  97. package/src/views/user/form/form_template/itemList.vue +3 -3
  98. package/src/views/user/form/form_template/list.vue +5 -4
  99. package/src/views/user/form/form_template_field/dialog.vue +11 -8
  100. package/src/views/user/form/form_type/dialog.vue +134 -127
  101. package/src/views/user/form/form_type/edit.vue +4 -4
  102. package/src/views/user/form/form_type/editDialog.vue +10 -9
  103. package/src/views/user/form/form_type/list.vue +128 -118
  104. package/src/views/user/form/report_requestaccess/dialog.vue +106 -99
  105. package/src/views/user/form/report_requestaccess/edit.vue +272 -234
  106. package/src/views/user/form/report_requestaccess/list.vue +29 -18
  107. package/src/views/user/form/vform/designer.vue +164 -164
  108. package/src/views/user/form/vform/formFieldMapping.js +151 -169
  109. package/src/views/user/form/vform/out_render.vue +3 -2
  110. package/src/views/user/form/vform/render.vue +2 -2
  111. package/src/views/user/form/view/edit.vue +7 -7
  112. package/src/views/user/form/view/list.vue +2 -2
  113. package/src/views/user/home/distributor.vue +374 -118
  114. package/src/views/user/home/index.vue +1 -1
  115. package/src/views/user/language_setting/edit.vue +167 -166
  116. package/src/views/user/language_setting/list.vue +3 -3
  117. package/src/views/user/ledger_library/list.vue +2 -2
  118. package/src/views/user/ledger_library/private_list.vue +3 -3
  119. package/src/views/user/login/auth-redirect.vue +1 -1
  120. package/src/views/user/login/index.vue +1 -1
  121. package/src/views/user/login/indexMixin.js +4 -1
  122. package/src/views/user/menu/list.vue +3 -3
  123. package/src/views/user/mobile_menu/list.vue +2 -2
  124. package/src/views/user/notify_message/dialog.vue +8 -6
  125. package/src/views/user/notify_message/list.vue +4 -3
  126. package/src/views/user/notify_template/edit.vue +185 -185
  127. package/src/views/user/notify_template/list.vue +4 -4
  128. package/src/views/user/oplog/edit.vue +108 -103
  129. package/src/views/user/oplog/list.vue +3 -3
  130. package/src/views/user/outLink/form_view.vue +144 -143
  131. package/src/views/user/outLink/index.vue +7 -5
  132. package/src/views/user/outLink/view.vue +119 -117
  133. package/src/views/user/position/dialog.vue +145 -138
  134. package/src/views/user/position/edit.vue +4 -4
  135. package/src/views/user/position/list.vue +170 -160
  136. package/src/views/user/project_tag/dialog.vue +5 -5
  137. package/src/views/user/project_tag/edit.vue +3 -3
  138. package/src/views/user/project_tag/list.vue +3 -3
  139. package/src/views/user/push_setting/edit.vue +7 -4
  140. package/src/views/user/push_setting/list.vue +44 -34
  141. package/src/views/user/redirect/index.vue +4 -4
  142. package/src/views/user/role/dialog.vue +10 -7
  143. package/src/views/user/role/edit.vue +427 -427
  144. package/src/views/user/role/list.vue +125 -114
  145. package/src/views/user/sale_org/dialog.vue +3 -3
  146. package/src/views/user/sale_org/list.vue +11 -11
  147. package/src/views/user/sale_org/moveDialog.vue +2 -2
  148. package/src/views/user/sale_org_net/list.vue +9 -9
  149. package/src/views/user/system_notice/edit.vue +184 -184
  150. package/src/views/user/system_notice/list.vue +156 -145
  151. package/src/views/user/system_parameter/edit.vue +140 -137
  152. package/src/views/user/system_parameter/list.vue +131 -120
  153. package/src/views/user/user/dialog.vue +31 -24
  154. package/src/views/user/user/edit.vue +1021 -1019
  155. package/src/views/user/user/form_edit.vue +481 -483
  156. package/src/views/user/user/form_list.vue +5 -5
  157. package/src/views/user/user/info.vue +271 -256
  158. package/src/views/user/user/infoContent.vue +12 -11
  159. package/src/views/user/user/infoEdit.vue +111 -92
  160. package/src/views/user/user/inner_list.vue +1 -1
  161. package/src/views/user/user/list.vue +55 -50
  162. package/src/views/user/user/list2.vue +1 -1
  163. package/src/views/user/user/modifyPasswordDialog.vue +3 -3
  164. package/src/views/user/user/out_list.vue +1 -1
  165. package/src/views/user/wf/formCustDialog/list.vue +13 -15
  166. package/src/views/user/wf/iframe/index.vue +12 -12
  167. package/src/views/user/wf/iframe/index2.vue +2 -2
  168. package/src/views/user/wf/wf_auto_submit_data/edit.vue +1 -1
  169. package/src/views/user/wf/wf_auto_submit_data/edith.vue +1 -1
  170. package/src/views/user/wf/wf_auto_submit_data/list.vue +8 -6
  171. package/src/views/user/wf/wf_diy_attribute/edit.vue +5 -5
  172. package/src/views/user/wf/wf_manage/list.vue +5 -4
  173. package/src/views/user/wf/wf_obj_config/activiti_wf.vue +11 -10
  174. package/src/views/user/wf/wf_obj_config/dialog.vue +10 -7
  175. package/src/views/user/wf/wf_obj_config/edit.vue +7 -4
  176. package/src/views/user/wf/wf_obj_config/edit_form.vue +70 -63
  177. package/src/views/user/wf/wf_obj_config/itemEdit.vue +3 -3
  178. package/src/views/user/wf/wf_obj_config/itemEdit_form.vue +3 -3
  179. package/src/views/user/wf/wf_obj_config/list.vue +4 -4
  180. package/src/views/user/wf/wf_obj_config/list_form.vue +22 -22
  181. package/src/views/user/wf/wf_param/edit.vue +4 -4
  182. package/src/views/user/wf/wf_work_calendar/components/calendar.vue +27 -13
  183. package/src/views/user/wf/wf_work_calendar/components/calendar2.vue +25 -10
  184. package/src/views/user/wf/wf_work_calendar/configDialog.vue +8 -5
  185. package/src/views/user/wf/wf_work_calendar/date.js +10 -10
  186. package/src/views/user/wf/wf_work_calendar/list.vue +9 -4
@@ -1,319 +1,319 @@
1
- <template>
2
- <el-dialog
3
- :title="title"
4
- :append-to-body="true"
5
- :modal-append-to-body="falseValue"
6
- :close-on-click-modal="falseValue"
7
- :visible.sync="showDialog"
8
- :modal="falseValue"
9
- custom-class="dialog-style list-dialog"
10
- width="1000px"
11
- @close="dialogClose"
12
- v-el-drag-dialog
13
- v-el-dialog-center
14
- >
15
- <div id="containt">
16
- <div class="detail-wrap">
17
- <el-form ref="editForm" :model="formData">
18
- <div class="d-header clearfix">
19
- <div class="fl">
20
- <i class="el-icon-info"/>
21
- {{ title }}
22
- </div>
23
- <div class="fr">
24
- <!-- <el-button type="primary" plain class="button-sty" @click="getCheckedKeys" icon="el-icon-refresh-right">
25
- 重置
26
- </el-button>-->
27
- <el-button type="primary" class="button-sty" icon="el-icon-check" @click="saveData">保存</el-button>
28
- </div>
29
- </div>
30
- <baseTabs>
31
- <baseTabPane label="基本信息">
32
- <template #default>
33
- <table class="table-detail">
34
- <tbody>
35
- <tr>
36
- <th>
37
- <em class="f-red">*</em>
38
- 属性名
39
- </th>
40
- <td>
41
- <el-radio-group v-model="formData.type">
42
- <el-radio label="attribute01">偏远地区</el-radio>
43
- </el-radio-group>
44
- </td>
45
- </tr>
46
- <tr>
47
- <th>
48
- <em class="f-red">*</em>
49
- 属性值
50
- </th>
51
- <td>
52
- <template v-if="formData.type=='attribute01'">
53
- <el-form-item prop="attribute01" :rules="[{ required: true, trigger: 'blur' }]">
54
- <el-radio-group v-model="formData.attribute01">
55
- <el-radio :label="1">是</el-radio>
56
- <el-radio :label="0">否</el-radio>
57
- </el-radio-group>
58
- </el-form-item>
59
- </template>
60
- </td>
61
- </tr>
62
- </tbody>
63
- </table>
64
- </template>
65
- </baseTabPane>
66
- <baseTabPane label="地区信息" v-if="modifyModel==1">
67
- <template #default>
68
- <el-tree
69
- :props="defaultProps"
70
- :load="loadNode"
71
- node-key="id"
72
- ref="tree"
73
- highlight-current
74
- lazy
75
- :expand-on-click-node="false"
76
- class="tree-checkbox t-check2"
77
- icon-class="el-icon-arrow-down"
78
- show-checkbox
79
- :check-on-click-node="true"
80
- @check-change="handleCheckChange"
81
- :check-strictly="true"
82
- :default-checked-keys="defaultCheckedKeys"
83
- >
84
- <span class="custom-tree-node" slot-scope="{ node, data }">
85
- <span>{{ node.label }}</span>
86
- <span v-if="node.level==1" @click.stop>
87
- ( <el-checkbox v-model="data.checked" :indeterminate="data.indeterminate" @change="(val)=>{
88
- changeCheckAll(node,val)
89
- }">全选</el-checkbox> )
90
- </span>
91
- </span>
92
- </el-tree>
93
- </template>
94
- </baseTabPane>
95
- </baseTabs>
96
- </el-form>
97
- </div>
98
- </div>
99
- </el-dialog>
100
- </template>
101
-
102
- <script>
103
- export default {
104
- name: 'formDataInfo',
105
- components: {},
106
- props: {
107
- modifyModel: {
108
- type: Number,
109
- default: () => 1//1 新增 2 修改
110
- },
111
- checkRows: {
112
- type: Array,
113
- default: () => []//1 新增 2 修改
114
- }
115
- },
116
- created() {
117
- this.title = this.modifyModel == 1 ? "批量新增地区属性" : "批量修改地区属性";
118
- },
119
- mounted() {
120
-
121
- },
122
- data() {
123
- return {
124
- showDialog: true,
125
- falseValue: false,
126
- dataId: '',
127
- hBtn: true,
128
- formData: {type: "attribute01", attribute01: null},
129
- vxeOption: {},
130
- companyInfoOption: {},
131
- formDataRoleOption: {},
132
- showContent: true,
133
-
134
- defaultProps: {
135
- label: 'name', //这里是树结构中需显示的数据(即接口返回的需展示在页面上的参数)
136
- children: [],
137
- isLeaf: 'leaf'
138
- },
139
- expandAll: false,
140
- defaultExpandedNodes: [],
141
- defaultCheckedKeys: [],
142
- maxGrade: 1,
143
- title: ""
144
- };
145
- },
146
- methods: {
147
- saveData() {
148
- let modifyModel = this.modifyModel;
149
- let checkedDatas = [];
150
- if (modifyModel == 1) {
151
- checkedDatas = this.getCheckedDatas();
152
- if (!checkedDatas.length) {
153
- this.$message({
154
- message: "请选择地区",
155
- type: 'error',
156
- duration: 2000
157
- });
158
- return
159
- }
160
- } else {
161
- checkedDatas = this.$baseLodash.cloneDeep(this.checkRows);
162
- }
163
- this.$refs.editForm.$baseValidate(valid => {
164
- if (valid) {
165
- this.$baseConfirm('您确定要保存吗?').then(() => {
166
- var url = USER_PREFIX + '/area_attribute/save';
167
-
168
- let requests = [];
169
- let field = this.formData.type;
170
- let value = this.formData[field];
171
-
172
- checkedDatas.forEach(item => {
173
- let reqData;
174
- if (modifyModel == 1) {
175
- reqData = {
176
- name: item.name,
177
- fullName: item.fullName,
178
- areaId: item.id
179
- }
180
- } else {
181
- reqData = reqData = {
182
- name: item.name,
183
- fullName: item.fullName,
184
- areaId: item.areaId
185
- };
186
- }
187
- reqData[field] = value;
188
- reqData.attributeName = field;
189
- requests.push(this.$http({
190
- url: url,
191
- method: `post`,
192
- data: reqData,
193
- isLoading: true,
194
- success: res => {
195
-
196
- }
197
- }));
198
- })
199
- if (requests.length) {
200
- Promise.all(requests)
201
- .then(responses => {
202
- // 所有请求都成功了
203
- // 处理你的数据
204
- /*responses.forEach(response => {
205
- console.log(response.data);
206
- });*/
207
- this.$message({
208
- message: 'success',
209
- type: 'success',
210
- duration: 2000,
211
- onClose: t => {
212
-
213
- }
214
- });
215
- this.confirm();
216
- })
217
- .catch(error => {
218
- // 至少一个请求失败了
219
- console.error('An error occurred:', error);
220
- });
221
- }
222
- });
223
- }
224
- });
225
- },
226
- dialogClose() {
227
- this.showDialog = false
228
- this.$emit('update:visiable', false);
229
- },
230
- confirm() {
231
- this.dialogClose();
232
- this.$emit('confirm');
233
- },
234
- handleNodeClick(data, node, v) {
235
-
236
- },
237
- handleCheckChange(data, checked, indeterminate) {
238
- console.log(data, checked, indeterminate);
239
- let node = this.$refs.tree.getNode(data.id + '');
240
- if (node.level == 1 && !node.childNodes.length) {
241
- node.expand();
242
- }
243
- if (node.level == 2) {
244
- let parentNode = node.parent;
245
- let parentData = parentNode.data;
246
- let pNodes = parentNode.childNodes;
247
- let pNodeSize = pNodes.length;
248
- let checkedKeys = this.$refs.tree.getCheckedKeys();
249
- let pCheckNodes = pNodes.filter(pNode => {
250
- return checkedKeys.includes(pNode.data.id)
251
- });
252
- let pCheckNodeSize = pCheckNodes.length;
253
- if (pCheckNodeSize) {
254
- if (pCheckNodeSize < pNodeSize) {
255
- parentData.checked = false;
256
- parentData.indeterminate = true;
257
- } else {
258
- parentData.checked = true;
259
- parentData.indeterminate = false;
260
- }
261
- } else {
262
- parentData.checked = false;
263
- parentData.indeterminate = false;
264
- }
265
- }
266
- },
267
- getCheckedDatas() {
268
- let checkDatas = this.$refs.tree.getCheckedNodes(false, true);
269
- return checkDatas;
270
- },
271
- loadNode(node, resolve) {
272
- this.getTreeData(node, resolve)
273
- },
274
- getTreeData(node, resolve) {
275
- let data = node.data;
276
- // this.defaultExpandedNodes = [];
277
- let id = data && data.id ? data.id : null;
278
- let url = USER_PREFIX + '/area/getChildren';
279
- let maxGrade = this.maxGrade;
280
- let currentGrade = 0;
281
- if (data && data.id) {
282
- currentGrade = data.grade + 1;
283
- }
284
- this.$http({
285
- url: url,
286
- method: 'post',
287
- data: {
288
- id: id
289
- },
290
- success: res => {
291
- let rows = res.objx || [];
292
- rows.forEach(item => {
293
- item.grade = currentGrade;
294
- item.leaf = currentGrade >= maxGrade;
295
- item.checked = false;
296
- item.indeterminate = false;
297
- if (id && data.checked) {
298
- this.defaultCheckedKeys.push(item.id);//展开第二级节点
299
- }
300
-
301
- });
302
- resolve(rows)
303
- }
304
- });
305
-
306
- },
307
- changeCheckAll(node, val) {
308
- let childNodes = node.childNodes
309
- let $tree = this.$refs.tree;
310
- if (childNodes.length) {
311
- childNodes.forEach(childNode => {
312
- this.$refs.tree.setChecked(childNode.data, val)
313
- })
314
- }
315
- node.expand();
316
- }
317
- }
318
- };
319
- </script>
1
+ <template>
2
+ <el-dialog
3
+ :title="title"
4
+ :append-to-body="true"
5
+ :modal-append-to-body="falseValue"
6
+ :close-on-click-modal="falseValue"
7
+ :visible.sync="showDialog"
8
+ :modal="falseValue"
9
+ custom-class="dialog-style list-dialog"
10
+ width="1000px"
11
+ @close="dialogClose"
12
+ v-el-drag-dialog
13
+ v-el-dialog-center
14
+ >
15
+ <div id="containt">
16
+ <div class="detail-wrap">
17
+ <el-form ref="editForm" :model="formData">
18
+ <div class="d-header clearfix">
19
+ <div class="fl">
20
+ <i class="el-icon-info"/>
21
+ {{ title }}
22
+ </div>
23
+ <div class="fr">
24
+ <!-- <el-button type="primary" plain class="button-sty" @click="getCheckedKeys" icon="el-icon-refresh-right">
25
+ 重置
26
+ </el-button>-->
27
+ <el-button type="primary" class="button-sty" icon="el-icon-check" @click="saveData">{{$t1('保存')}}</el-button>
28
+ </div>
29
+ </div>
30
+ <baseTabs>
31
+ <baseTabPane :label="$t1('基本信息')">
32
+ <template #default>
33
+ <table class="table-detail">
34
+ <tbody>
35
+ <tr>
36
+ <th>
37
+ <em class="f-red">*</em>
38
+ 属性名
39
+ </th>
40
+ <td>
41
+ <el-radio-group v-model="formData.type">
42
+ <el-radio label="attribute01">偏远地区</el-radio>
43
+ </el-radio-group>
44
+ </td>
45
+ </tr>
46
+ <tr>
47
+ <th>
48
+ <em class="f-red">*</em>
49
+ 属性值
50
+ </th>
51
+ <td>
52
+ <template v-if="formData.type=='attribute01'">
53
+ <el-form-item prop="attribute01" :rules="[{ required: true, trigger: 'blur' }]">
54
+ <el-radio-group v-model="formData.attribute01">
55
+ <el-radio :label="1">是</el-radio>
56
+ <el-radio :label="0">否</el-radio>
57
+ </el-radio-group>
58
+ </el-form-item>
59
+ </template>
60
+ </td>
61
+ </tr>
62
+ </tbody>
63
+ </table>
64
+ </template>
65
+ </baseTabPane>
66
+ <baseTabPane label="地区信息" v-if="modifyModel==1">
67
+ <template #default>
68
+ <el-tree
69
+ :props="defaultProps"
70
+ :load="loadNode"
71
+ node-key="id"
72
+ ref="tree"
73
+ highlight-current
74
+ lazy
75
+ :expand-on-click-node="false"
76
+ class="tree-checkbox t-check2"
77
+ icon-class="el-icon-arrow-down"
78
+ show-checkbox
79
+ :check-on-click-node="true"
80
+ @check-change="handleCheckChange"
81
+ :check-strictly="true"
82
+ :default-checked-keys="defaultCheckedKeys"
83
+ >
84
+ <span class="custom-tree-node" slot-scope="{ node, data }">
85
+ <span>{{ node.label }}</span>
86
+ <span v-if="node.level==1" @click.stop>
87
+ ( <el-checkbox v-model="data.checked" :indeterminate="data.indeterminate" @change="(val)=>{
88
+ changeCheckAll(node,val)
89
+ }">全选</el-checkbox> )
90
+ </span>
91
+ </span>
92
+ </el-tree>
93
+ </template>
94
+ </baseTabPane>
95
+ </baseTabs>
96
+ </el-form>
97
+ </div>
98
+ </div>
99
+ </el-dialog>
100
+ </template>
101
+
102
+ <script>
103
+ export default {
104
+ name: 'formDataInfo',
105
+ components: {},
106
+ props: {
107
+ modifyModel: {
108
+ type: Number,
109
+ default: () => 1//1 新增 2 修改
110
+ },
111
+ checkRows: {
112
+ type: Array,
113
+ default: () => []//1 新增 2 修改
114
+ }
115
+ },
116
+ created() {
117
+ this.title = this.modifyModel == 1 ? "批量新增地区属性" : "批量修改地区属性";
118
+ },
119
+ mounted() {
120
+
121
+ },
122
+ data() {
123
+ return {
124
+ showDialog: true,
125
+ falseValue: false,
126
+ dataId: '',
127
+ hBtn: true,
128
+ formData: {type: "attribute01", attribute01: null},
129
+ vxeOption: {},
130
+ companyInfoOption: {},
131
+ formDataRoleOption: {},
132
+ showContent: true,
133
+
134
+ defaultProps: {
135
+ label: 'name', //这里是树结构中需显示的数据(即接口返回的需展示在页面上的参数)
136
+ children: [],
137
+ isLeaf: 'leaf'
138
+ },
139
+ expandAll: false,
140
+ defaultExpandedNodes: [],
141
+ defaultCheckedKeys: [],
142
+ maxGrade: 1,
143
+ title: ""
144
+ };
145
+ },
146
+ methods: {
147
+ saveData() {
148
+ let modifyModel = this.modifyModel;
149
+ let checkedDatas = [];
150
+ if (modifyModel == 1) {
151
+ checkedDatas = this.getCheckedDatas();
152
+ if (!checkedDatas.length) {
153
+ this.$message({
154
+ message: "请选择地区",
155
+ type: 'error',
156
+ duration: 2000
157
+ });
158
+ return
159
+ }
160
+ } else {
161
+ checkedDatas = this.$baseLodash.cloneDeep(this.checkRows);
162
+ }
163
+ this.$refs.editForm.$baseValidate(valid => {
164
+ if (valid) {
165
+ this.$baseConfirm('您确定要保存吗?').then(() => {
166
+ var url = USER_PREFIX + '/area_attribute/save';
167
+
168
+ let requests = [];
169
+ let field = this.formData.type;
170
+ let value = this.formData[field];
171
+
172
+ checkedDatas.forEach(item => {
173
+ let reqData;
174
+ if (modifyModel == 1) {
175
+ reqData = {
176
+ name: item.name,
177
+ fullName: item.fullName,
178
+ areaId: item.id
179
+ }
180
+ } else {
181
+ reqData = reqData = {
182
+ name: item.name,
183
+ fullName: item.fullName,
184
+ areaId: item.areaId
185
+ };
186
+ }
187
+ reqData[field] = value;
188
+ reqData.attributeName = field;
189
+ requests.push(this.$http({
190
+ url: url,
191
+ method: `post`,
192
+ data: reqData,
193
+ isLoading: true,
194
+ success: res => {
195
+
196
+ }
197
+ }));
198
+ })
199
+ if (requests.length) {
200
+ Promise.all(requests)
201
+ .then(responses => {
202
+ // 所有请求都成功了
203
+ // 处理你的数据
204
+ /*responses.forEach(response => {
205
+ console.log(response.data);
206
+ });*/
207
+ this.$message({
208
+ message: 'success',
209
+ type: 'success',
210
+ duration: 2000,
211
+ onClose: t => {
212
+
213
+ }
214
+ });
215
+ this.confirm();
216
+ })
217
+ .catch(error => {
218
+ // 至少一个请求失败了
219
+ console.error('An error occurred:', error);
220
+ });
221
+ }
222
+ });
223
+ }
224
+ });
225
+ },
226
+ dialogClose() {
227
+ this.showDialog = false
228
+ this.$emit('update:visiable', false);
229
+ },
230
+ confirm() {
231
+ this.dialogClose();
232
+ this.$emit('confirm');
233
+ },
234
+ handleNodeClick(data, node, v) {
235
+
236
+ },
237
+ handleCheckChange(data, checked, indeterminate) {
238
+ console.log(data, checked, indeterminate);
239
+ let node = this.$refs.tree.getNode(data.id + '');
240
+ if (node.level == 1 && !node.childNodes.length) {
241
+ node.expand();
242
+ }
243
+ if (node.level == 2) {
244
+ let parentNode = node.parent;
245
+ let parentData = parentNode.data;
246
+ let pNodes = parentNode.childNodes;
247
+ let pNodeSize = pNodes.length;
248
+ let checkedKeys = this.$refs.tree.getCheckedKeys();
249
+ let pCheckNodes = pNodes.filter(pNode => {
250
+ return checkedKeys.includes(pNode.data.id)
251
+ });
252
+ let pCheckNodeSize = pCheckNodes.length;
253
+ if (pCheckNodeSize) {
254
+ if (pCheckNodeSize < pNodeSize) {
255
+ parentData.checked = false;
256
+ parentData.indeterminate = true;
257
+ } else {
258
+ parentData.checked = true;
259
+ parentData.indeterminate = false;
260
+ }
261
+ } else {
262
+ parentData.checked = false;
263
+ parentData.indeterminate = false;
264
+ }
265
+ }
266
+ },
267
+ getCheckedDatas() {
268
+ let checkDatas = this.$refs.tree.getCheckedNodes(false, true);
269
+ return checkDatas;
270
+ },
271
+ loadNode(node, resolve) {
272
+ this.getTreeData(node, resolve)
273
+ },
274
+ getTreeData(node, resolve) {
275
+ let data = node.data;
276
+ // this.defaultExpandedNodes = [];
277
+ let id = data && data.id ? data.id : null;
278
+ let url = USER_PREFIX + '/area/getChildren';
279
+ let maxGrade = this.maxGrade;
280
+ let currentGrade = 0;
281
+ if (data && data.id) {
282
+ currentGrade = data.grade + 1;
283
+ }
284
+ this.$http({
285
+ url: url,
286
+ method: 'post',
287
+ data: {
288
+ id: id
289
+ },
290
+ success: res => {
291
+ let rows = res.objx || [];
292
+ rows.forEach(item => {
293
+ item.grade = currentGrade;
294
+ item.leaf = currentGrade >= maxGrade;
295
+ item.checked = false;
296
+ item.indeterminate = false;
297
+ if (id && data.checked) {
298
+ this.defaultCheckedKeys.push(item.id);//展开第二级节点
299
+ }
300
+
301
+ });
302
+ resolve(rows)
303
+ }
304
+ });
305
+
306
+ },
307
+ changeCheckAll(node, val) {
308
+ let childNodes = node.childNodes
309
+ let $tree = this.$refs.tree;
310
+ if (childNodes.length) {
311
+ childNodes.forEach(childNode => {
312
+ this.$refs.tree.setChecked(childNode.data, val)
313
+ })
314
+ }
315
+ node.expand();
316
+ }
317
+ }
318
+ };
319
+ </script>
@@ -7,9 +7,9 @@
7
7
  设置地区属性(请勾选需要设置的‘{{ attributeName }}’)
8
8
  </div>
9
9
  <div class="fr">
10
- <el-button type="primary" plain class="button-sty" @click="$baseReload()" icon="el-icon-refresh-right">重置
10
+ <el-button type="primary" plain class="button-sty" @click="$baseReload()" icon="el-icon-refresh-right">{{$t1('重置')}}
11
11
  </el-button>
12
- <el-button type="primary" class="button-sty" icon="el-icon-check" @click="saveData">保存</el-button>
12
+ <el-button type="primary" class="button-sty" icon="el-icon-check" @click="saveData">{{$t1('保存')}}</el-button>
13
13
  </div>
14
14
  </div>
15
15
  <baseTabs :showNav="false">
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <div id="containt">
3
3
  <el-tabs v-model="activeName" class="tab-box">
4
- <el-tab-pane label="列表" name="second">
4
+ <el-tab-pane :label="$t1('列表')" name="second">
5
5
  <div class="tree-box fl">
6
6
  <div class="tit"><b>属性名</b></div>
7
7
  <el-tree