vue2-client 1.5.13 → 1.5.14

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 (112) hide show
  1. package/CHANGELOG.md +511 -504
  2. package/index.js +30 -30
  3. package/package.json +78 -78
  4. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  5. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +667 -667
  6. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +713 -713
  7. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +457 -457
  8. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +508 -508
  9. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +140 -140
  10. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  11. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  12. package/src/base-client/components/common/XAddForm/XAddForm.vue +316 -316
  13. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +277 -277
  14. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  15. package/src/base-client/components/common/XForm/XForm.vue +185 -185
  16. package/src/base-client/components/common/XForm/XFormItem.vue +502 -485
  17. package/src/base-client/components/common/XForm/index.md +177 -177
  18. package/src/base-client/components/common/XFormTable/XFormTable.vue +324 -324
  19. package/src/base-client/components/common/XFormTable/index.md +96 -96
  20. package/src/base-client/components/common/XTable/XTable.vue +505 -505
  21. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +109 -109
  22. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  23. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  24. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  25. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  26. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  27. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  28. package/src/base-client/plugins/AppData.js +70 -70
  29. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  30. package/src/base-client/plugins/PagedList.js +177 -177
  31. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  32. package/src/base-client/plugins/i18n-extend.js +32 -32
  33. package/src/components/Ellipsis/Ellipsis.vue +65 -65
  34. package/src/components/Ellipsis/index.md +38 -38
  35. package/src/components/NumberInfo/index.md +43 -43
  36. package/src/components/STable/README.md +341 -341
  37. package/src/components/STable/index.js +318 -318
  38. package/src/components/Trend/index.md +45 -45
  39. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  40. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  41. package/src/components/exception/ExceptionPage.vue +70 -70
  42. package/src/components/form/FormRow.vue +52 -52
  43. package/src/components/index.js +36 -36
  44. package/src/components/menu/SideMenu.vue +62 -62
  45. package/src/components/menu/menu.js +273 -273
  46. package/src/components/page/header/index.less +40 -40
  47. package/src/components/setting/Setting.vue +235 -235
  48. package/src/components/table/StandardTable.vue +141 -141
  49. package/src/components/table/advance/ActionColumns.vue +158 -158
  50. package/src/components/table/advance/SearchArea.vue +355 -355
  51. package/src/components/tool/AStepItem.vue +60 -60
  52. package/src/components/tool/AvatarList.vue +68 -68
  53. package/src/components/tool/Drawer.vue +142 -142
  54. package/src/components/tool/TagSelect.vue +83 -83
  55. package/src/components/transition/PageToggleTransition.vue +97 -97
  56. package/src/config/CreateQueryConfig.js +307 -307
  57. package/src/config/default/admin.config.js +18 -18
  58. package/src/config/default/setting.config.js +44 -44
  59. package/src/config/replacer/resolve.config.js +67 -67
  60. package/src/layouts/AdminLayout.vue +174 -174
  61. package/src/layouts/CommonLayout.vue +42 -42
  62. package/src/layouts/ComponentLayoutOne.vue +47 -47
  63. package/src/layouts/PageLayout.vue +151 -151
  64. package/src/layouts/SinglePageView.vue +111 -111
  65. package/src/layouts/footer/PageFooter.vue +49 -49
  66. package/src/layouts/header/AdminHeader.vue +104 -104
  67. package/src/layouts/header/HeaderAvatar.vue +61 -61
  68. package/src/layouts/header/HeaderNotice.vue +176 -176
  69. package/src/layouts/header/HeaderSearch.vue +67 -67
  70. package/src/layouts/header/InstitutionDetail.vue +181 -181
  71. package/src/layouts/header/index.less +92 -92
  72. package/src/layouts/tabs/TabsHead.vue +190 -190
  73. package/src/layouts/tabs/TabsView.vue +379 -379
  74. package/src/mock/goods/index.js +108 -108
  75. package/src/pages/exception/404.vue +25 -25
  76. package/src/pages/login/Login.vue +363 -363
  77. package/src/pages/report/ReportTable.js +124 -124
  78. package/src/pages/report/ReportTableHome.vue +28 -28
  79. package/src/pages/resourceManage/orgListManage.vue +98 -98
  80. package/src/pages/system/dictionary/index.vue +43 -43
  81. package/src/pages/system/file/index.vue +317 -317
  82. package/src/pages/system/monitor/loginInfor/index.vue +36 -36
  83. package/src/pages/system/monitor/operLog/index.vue +36 -36
  84. package/src/pages/system/queryParams/index.vue +43 -43
  85. package/src/router/async/config.async.js +27 -27
  86. package/src/router/async/router.map.js +68 -68
  87. package/src/router/guards.js +113 -113
  88. package/src/router/index.js +27 -27
  89. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  90. package/src/services/api/LogDetailsViewApi.js +10 -10
  91. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  92. package/src/services/api/TicketDetailsViewApi.js +34 -34
  93. package/src/services/api/cas.js +79 -79
  94. package/src/services/api/commonTempTable.js +10 -10
  95. package/src/services/api/index.js +17 -17
  96. package/src/services/api/logininfor/index.js +6 -6
  97. package/src/services/api/manage.js +8 -8
  98. package/src/services/apiService.js +13 -13
  99. package/src/services/user.js +53 -53
  100. package/src/store/modules/index.js +4 -4
  101. package/src/theme/default/nprogress.less +76 -76
  102. package/src/theme/default/style.less +47 -47
  103. package/src/utils/colors.js +107 -107
  104. package/src/utils/excel/Blob.js +180 -180
  105. package/src/utils/excel/Export2Excel.js +141 -141
  106. package/src/utils/formatter.js +68 -68
  107. package/src/utils/i18n.js +80 -80
  108. package/src/utils/indexedDB.js +145 -145
  109. package/src/utils/theme-color-replacer-extend.js +91 -91
  110. package/src/utils/themeUtil.js +100 -100
  111. package/src/utils/util.js +230 -230
  112. package/vue.config.js +106 -106
@@ -1,275 +1,275 @@
1
- <template>
2
- <a-drawer
3
- title="设备类型配置生成"
4
- placement="right"
5
- :width="isMobile ? screenWidth : screenWidth * 0.85"
6
- :visible="visible"
7
- @close="onClose"
8
- >
9
- <a-row :gutter="24">
10
- <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
11
- <div class="page-header-index-wide">
12
- <a-card :bordered="false">
13
- <div slot="title">
14
- <div v-show="changeflag" >
15
- <a-button v-show="treeData.length === 0" @click="showModal('eventAddRoot')">添加根节点</a-button>
16
- <a-divider v-show="treeData.length === 0" type="vertical" />
17
- <a-button v-show="treeData.length > 0" @click="showModal('eventAddSame')">添加同级</a-button>
18
- <a-divider v-show="treeData.length > 0" type="vertical" />
19
- <a-button v-show="treeData.length > 0" @click="showModal('eventAddSub')">添加下级</a-button>
20
- <a-divider v-show="treeData.length > 0" type="vertical" />
21
- <a-button v-show="treeData.length > 0" @click="showModal('eventModify')">修改</a-button>
22
- <a-divider v-show="treeData.length > 0" type="vertical" />
23
- <a-button v-show="treeData.length > 0" @click="eventDelete">删除</a-button>
24
- </div>
25
- </div>
26
- <a-tree
27
- :tree-data="treeData"
28
- @select="onEventTreeNodeSelected"
29
- :defaultExpandAll="true"
30
- :selectedKeys.sync="selectKeys"
31
- showLine >
32
- <template slot="custom" slot-scope="item">
33
- <div style="position: relative;float:left;">
34
- {{ item.title }}
35
- </div>
36
- <div v-show="item.visibleModel" style="position: absolute;height:25px;top: 3%;left:3.8%" >
37
- <a-input-group compact>
38
- <a-input type="text" style="width: 30%" placeholder="名称" ref="myInput" v-model="nowchangetitle" />
39
- <a-input type="text" style="width: 30%" placeholder="值" ref="myInput" v-model="nowchangevalue" />
40
- <a-button
41
- @click="handleOk(item)"
42
- type="link">
43
- 保存
44
- </a-button>
45
- <a-divider type="vertical" />
46
- <a-button
47
- @click="handleCancel(item)"
48
- type="link"
49
- >取消</a-button>
50
- </a-input-group>
51
- </div>
52
- </template>
53
- </a-tree>
54
- </a-card>
55
- </div>
56
- </a-col>
57
- <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
58
- <a-card :bordered="false" title="预览" size="small" style="overflow: auto">
59
- <json-viewer :copyable="{copyText: '复制', copiedText: '已复制'}" :value="treeData" :expand-depth="parseInt('100')" style="overflow: auto;max-height: 440px"></json-viewer>
60
- </a-card>
61
- </a-col>
62
- </a-row>
63
- </a-drawer>
64
- </template>
65
-
66
- <script>
67
-
68
- import { mapState } from 'vuex'
69
- import JsonViewer from 'vue-json-viewer'
70
-
71
- export default {
72
- name: 'LogDetailsView',
73
- data () {
74
- return {
75
- // 页面宽度
76
- screenWidth: document.documentElement.clientWidth,
77
- selectKeys: [],
78
- treeData: [],
79
- eventSelectedNode: null,
80
- // 当前操作类型
81
- operate: '',
82
- // 新建节点中的值
83
- nowchangetitle: '',
84
- // 新建节点中的值
85
- nowchangevalue: '',
86
- // 操作按钮显示控制
87
- changeflag: true
88
- }
89
- },
90
- props: {
91
- visible: {
92
- type: Boolean,
93
- default: () => {
94
- return false
95
- }
96
- }
97
- },
98
- components: {
99
- JsonViewer
100
- },
101
- methods: {
102
- showModal (operate) {
103
- if (!this.eventSelectedNode && this.treeData.length > 0) {
104
- this.$message.warning('请选择节点后进行操作')
105
- return
106
- }
107
- if (operate === 'eventAddSame' && this.eventSelectedNode && !this.eventSelectedNode.$parent.dataRef && this.treeData.length > 0) {
108
- this.$message.warning('不能给根节点添加同级')
109
- return
110
- }
111
- this.changeflag = false
112
- this.operate = operate
113
- switch (this.operate) {
114
- case 'eventAddRoot':
115
- this.eventAddRoot()
116
- break
117
- case 'eventAddSame':
118
- this.eventAddSame()
119
- break
120
- case 'eventAddSub':
121
- this.eventAddSub()
122
- break
123
- case 'eventModify':
124
- this.nowchangetitle = this.eventSelectedNode.dataRef.title
125
- this.nowchangevalue = this.eventSelectedNode.dataRef.value
126
- this.setvisibleModel(true, 'visibleModel')
127
- break
128
- default:
129
- this.$message.warning('未获取到操作指令')
130
- }
131
- },
132
- handleOk (item) {
133
- if (this.operate === 'eventModify') {
134
- this.eventModify()
135
- } else {
136
- this.eventSelectedNode.dataRef.title = this.nowchangetitle
137
- this.eventSelectedNode.dataRef.value = this.nowchangevalue
138
- }
139
- this.setvisibleModel(false, 'visibleModel')
140
- this.clearnodename()
141
- },
142
- setvisibleModel (flag, value) {
143
- const dataRef = this.eventSelectedNode.dataRef
144
- this.$set(dataRef, value, flag)
145
- },
146
- handleCancel (item) {
147
- if (this.operate === 'eventModify') {
148
- this.setvisibleModel(false, 'visibleModel')
149
- } else if (this.operate === 'eventAddRoot') {
150
- this.treeData = []
151
- } else {
152
- this.searchitem(item, this.treeData)
153
- }
154
- this.clearnodename()
155
- },
156
- searchitem (option, arr, type = 'delete') {
157
- // 递归删除树中某个节点
158
- for (let s = 0; s < arr.length; s++) {
159
- if (arr[s].key === option.key) {
160
- if (type === 'delete') {
161
- arr.splice(s, 1)
162
- }
163
- break
164
- } else if (arr[s].children && arr[s].children.length > 0) { // 递归条件
165
- this.searchitem(option, arr[s].children)
166
- } else {
167
-
168
- }
169
- }
170
- },
171
- clearnodename () {
172
- this.operate = ''
173
- this.nowchangetitle = ''
174
- this.nowchangevalue = ''
175
- this.changeflag = true
176
- },
177
- onClose () {
178
- this.$emit('update:visible', false)
179
- },
180
- onEventTreeNodeSelected (seleteKeys, e) {
181
- if (e.selected) {
182
- this.eventSelectedNode = e.node
183
- return
184
- }
185
- this.eventSelectedNode = null
186
- },
187
- eventAddRoot () {
188
- this.$set(this.treeData, 'children', [])
189
- this.treeData.push({
190
- title: '',
191
- value: '',
192
- key: new Date().getTime(),
193
- scopedSlots: { title: 'custom' },
194
- visibleModel: true
195
- })
196
- },
197
- eventAddSame () {
198
- // 查找父级
199
- const dataRef = this.eventSelectedNode.$parent.dataRef
200
- if (!dataRef.children) {
201
- this.$set(dataRef, 'children', [])
202
- }
203
- dataRef.children.push({
204
- title: '',
205
- value: '',
206
- key: new Date().getTime(),
207
- scopedSlots: { title: 'custom' },
208
- visibleModel: true
209
- })
210
- },
211
- eventAddSub () {
212
- const dataRef = this.eventSelectedNode.dataRef
213
- if (!dataRef.children) {
214
- this.$set(dataRef, 'children', [])
215
- }
216
- this.eventSelectedNode.vcTree.$data._expandedKeys.push(dataRef.key)
217
- dataRef.children.push({
218
- title: '',
219
- value: '',
220
- key: new Date().getTime(),
221
- scopedSlots: { title: 'custom' },
222
- children: [],
223
- visibleModel: true
224
- })
225
- },
226
- eventModify () {
227
- const dataRef = this.eventSelectedNode.dataRef
228
- // this.$set(dataRef, 'children', [])
229
- dataRef.title = this.nowchangetitle
230
- dataRef.value = this.nowchangevalue
231
- },
232
- eventDelete () {
233
- if (!this.eventSelectedNode.$parent.dataRef) {
234
- this.treeData = []
235
- return
236
- }
237
- const parentDataRef = this.eventSelectedNode.$parent.dataRef
238
- // 判断是否是顶层
239
- const children = parentDataRef.children
240
- const currentDataRef = this.eventSelectedNode.dataRef
241
- const index = children.indexOf(currentDataRef)
242
- children.splice(index, 1)
243
- },
244
- onSelect (selectedKeys, info) {
245
- console.log('selected', selectedKeys, info)
246
- }
247
- },
248
- computed: {
249
- ...mapState('setting', ['isMobile'])
250
- }
251
- }
252
- </script>
253
- <style lang="less" scoped>
254
- .ant-tree-title {
255
- width: 100%;
256
- }
257
- .title {
258
- float: left;
259
- }
260
- .ant-card-body {
261
- :global {
262
- .ant-tree {
263
- line-height: 3;
264
- li {
265
- position: relative;
266
- }
267
- }
268
- }
269
- }
270
- .ant-card-body .but_type {
271
- float: right;
272
- position: absolute;
273
- right: 40px;
274
- }
275
- </style>
1
+ <template>
2
+ <a-drawer
3
+ title="设备类型配置生成"
4
+ placement="right"
5
+ :width="isMobile ? screenWidth : screenWidth * 0.85"
6
+ :visible="visible"
7
+ @close="onClose"
8
+ >
9
+ <a-row :gutter="24">
10
+ <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
11
+ <div class="page-header-index-wide">
12
+ <a-card :bordered="false">
13
+ <div slot="title">
14
+ <div v-show="changeflag" >
15
+ <a-button v-show="treeData.length === 0" @click="showModal('eventAddRoot')">添加根节点</a-button>
16
+ <a-divider v-show="treeData.length === 0" type="vertical" />
17
+ <a-button v-show="treeData.length > 0" @click="showModal('eventAddSame')">添加同级</a-button>
18
+ <a-divider v-show="treeData.length > 0" type="vertical" />
19
+ <a-button v-show="treeData.length > 0" @click="showModal('eventAddSub')">添加下级</a-button>
20
+ <a-divider v-show="treeData.length > 0" type="vertical" />
21
+ <a-button v-show="treeData.length > 0" @click="showModal('eventModify')">修改</a-button>
22
+ <a-divider v-show="treeData.length > 0" type="vertical" />
23
+ <a-button v-show="treeData.length > 0" @click="eventDelete">删除</a-button>
24
+ </div>
25
+ </div>
26
+ <a-tree
27
+ :tree-data="treeData"
28
+ @select="onEventTreeNodeSelected"
29
+ :defaultExpandAll="true"
30
+ :selectedKeys.sync="selectKeys"
31
+ showLine >
32
+ <template slot="custom" slot-scope="item">
33
+ <div style="position: relative;float:left;">
34
+ {{ item.title }}
35
+ </div>
36
+ <div v-show="item.visibleModel" style="position: absolute;height:25px;top: 3%;left:3.8%" >
37
+ <a-input-group compact>
38
+ <a-input type="text" style="width: 30%" placeholder="名称" ref="myInput" v-model="nowchangetitle" />
39
+ <a-input type="text" style="width: 30%" placeholder="值" ref="myInput" v-model="nowchangevalue" />
40
+ <a-button
41
+ @click="handleOk(item)"
42
+ type="link">
43
+ 保存
44
+ </a-button>
45
+ <a-divider type="vertical" />
46
+ <a-button
47
+ @click="handleCancel(item)"
48
+ type="link"
49
+ >取消</a-button>
50
+ </a-input-group>
51
+ </div>
52
+ </template>
53
+ </a-tree>
54
+ </a-card>
55
+ </div>
56
+ </a-col>
57
+ <a-col :xl="12" :lg="12" :md="12" :sm="24" :xs="24">
58
+ <a-card :bordered="false" title="预览" size="small" style="overflow: auto">
59
+ <json-viewer :copyable="{copyText: '复制', copiedText: '已复制'}" :value="treeData" :expand-depth="parseInt('100')" style="overflow: auto;max-height: 440px"></json-viewer>
60
+ </a-card>
61
+ </a-col>
62
+ </a-row>
63
+ </a-drawer>
64
+ </template>
65
+
66
+ <script>
67
+
68
+ import { mapState } from 'vuex'
69
+ import JsonViewer from 'vue-json-viewer'
70
+
71
+ export default {
72
+ name: 'LogDetailsView',
73
+ data () {
74
+ return {
75
+ // 页面宽度
76
+ screenWidth: document.documentElement.clientWidth,
77
+ selectKeys: [],
78
+ treeData: [],
79
+ eventSelectedNode: null,
80
+ // 当前操作类型
81
+ operate: '',
82
+ // 新建节点中的值
83
+ nowchangetitle: '',
84
+ // 新建节点中的值
85
+ nowchangevalue: '',
86
+ // 操作按钮显示控制
87
+ changeflag: true
88
+ }
89
+ },
90
+ props: {
91
+ visible: {
92
+ type: Boolean,
93
+ default: () => {
94
+ return false
95
+ }
96
+ }
97
+ },
98
+ components: {
99
+ JsonViewer
100
+ },
101
+ methods: {
102
+ showModal (operate) {
103
+ if (!this.eventSelectedNode && this.treeData.length > 0) {
104
+ this.$message.warning('请选择节点后进行操作')
105
+ return
106
+ }
107
+ if (operate === 'eventAddSame' && this.eventSelectedNode && !this.eventSelectedNode.$parent.dataRef && this.treeData.length > 0) {
108
+ this.$message.warning('不能给根节点添加同级')
109
+ return
110
+ }
111
+ this.changeflag = false
112
+ this.operate = operate
113
+ switch (this.operate) {
114
+ case 'eventAddRoot':
115
+ this.eventAddRoot()
116
+ break
117
+ case 'eventAddSame':
118
+ this.eventAddSame()
119
+ break
120
+ case 'eventAddSub':
121
+ this.eventAddSub()
122
+ break
123
+ case 'eventModify':
124
+ this.nowchangetitle = this.eventSelectedNode.dataRef.title
125
+ this.nowchangevalue = this.eventSelectedNode.dataRef.value
126
+ this.setvisibleModel(true, 'visibleModel')
127
+ break
128
+ default:
129
+ this.$message.warning('未获取到操作指令')
130
+ }
131
+ },
132
+ handleOk (item) {
133
+ if (this.operate === 'eventModify') {
134
+ this.eventModify()
135
+ } else {
136
+ this.eventSelectedNode.dataRef.title = this.nowchangetitle
137
+ this.eventSelectedNode.dataRef.value = this.nowchangevalue
138
+ }
139
+ this.setvisibleModel(false, 'visibleModel')
140
+ this.clearnodename()
141
+ },
142
+ setvisibleModel (flag, value) {
143
+ const dataRef = this.eventSelectedNode.dataRef
144
+ this.$set(dataRef, value, flag)
145
+ },
146
+ handleCancel (item) {
147
+ if (this.operate === 'eventModify') {
148
+ this.setvisibleModel(false, 'visibleModel')
149
+ } else if (this.operate === 'eventAddRoot') {
150
+ this.treeData = []
151
+ } else {
152
+ this.searchitem(item, this.treeData)
153
+ }
154
+ this.clearnodename()
155
+ },
156
+ searchitem (option, arr, type = 'delete') {
157
+ // 递归删除树中某个节点
158
+ for (let s = 0; s < arr.length; s++) {
159
+ if (arr[s].key === option.key) {
160
+ if (type === 'delete') {
161
+ arr.splice(s, 1)
162
+ }
163
+ break
164
+ } else if (arr[s].children && arr[s].children.length > 0) { // 递归条件
165
+ this.searchitem(option, arr[s].children)
166
+ } else {
167
+
168
+ }
169
+ }
170
+ },
171
+ clearnodename () {
172
+ this.operate = ''
173
+ this.nowchangetitle = ''
174
+ this.nowchangevalue = ''
175
+ this.changeflag = true
176
+ },
177
+ onClose () {
178
+ this.$emit('update:visible', false)
179
+ },
180
+ onEventTreeNodeSelected (seleteKeys, e) {
181
+ if (e.selected) {
182
+ this.eventSelectedNode = e.node
183
+ return
184
+ }
185
+ this.eventSelectedNode = null
186
+ },
187
+ eventAddRoot () {
188
+ this.$set(this.treeData, 'children', [])
189
+ this.treeData.push({
190
+ title: '',
191
+ value: '',
192
+ key: new Date().getTime(),
193
+ scopedSlots: { title: 'custom' },
194
+ visibleModel: true
195
+ })
196
+ },
197
+ eventAddSame () {
198
+ // 查找父级
199
+ const dataRef = this.eventSelectedNode.$parent.dataRef
200
+ if (!dataRef.children) {
201
+ this.$set(dataRef, 'children', [])
202
+ }
203
+ dataRef.children.push({
204
+ title: '',
205
+ value: '',
206
+ key: new Date().getTime(),
207
+ scopedSlots: { title: 'custom' },
208
+ visibleModel: true
209
+ })
210
+ },
211
+ eventAddSub () {
212
+ const dataRef = this.eventSelectedNode.dataRef
213
+ if (!dataRef.children) {
214
+ this.$set(dataRef, 'children', [])
215
+ }
216
+ this.eventSelectedNode.vcTree.$data._expandedKeys.push(dataRef.key)
217
+ dataRef.children.push({
218
+ title: '',
219
+ value: '',
220
+ key: new Date().getTime(),
221
+ scopedSlots: { title: 'custom' },
222
+ children: [],
223
+ visibleModel: true
224
+ })
225
+ },
226
+ eventModify () {
227
+ const dataRef = this.eventSelectedNode.dataRef
228
+ // this.$set(dataRef, 'children', [])
229
+ dataRef.title = this.nowchangetitle
230
+ dataRef.value = this.nowchangevalue
231
+ },
232
+ eventDelete () {
233
+ if (!this.eventSelectedNode.$parent.dataRef) {
234
+ this.treeData = []
235
+ return
236
+ }
237
+ const parentDataRef = this.eventSelectedNode.$parent.dataRef
238
+ // 判断是否是顶层
239
+ const children = parentDataRef.children
240
+ const currentDataRef = this.eventSelectedNode.dataRef
241
+ const index = children.indexOf(currentDataRef)
242
+ children.splice(index, 1)
243
+ },
244
+ onSelect (selectedKeys, info) {
245
+ console.log('selected', selectedKeys, info)
246
+ }
247
+ },
248
+ computed: {
249
+ ...mapState('setting', ['isMobile'])
250
+ }
251
+ }
252
+ </script>
253
+ <style lang="less" scoped>
254
+ .ant-tree-title {
255
+ width: 100%;
256
+ }
257
+ .title {
258
+ float: left;
259
+ }
260
+ .ant-card-body {
261
+ :global {
262
+ .ant-tree {
263
+ line-height: 3;
264
+ li {
265
+ position: relative;
266
+ }
267
+ }
268
+ }
269
+ }
270
+ .ant-card-body .but_type {
271
+ float: right;
272
+ position: absolute;
273
+ right: 40px;
274
+ }
275
+ </style>