vue2-client 1.3.18 → 1.3.20

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 (97) hide show
  1. package/CHANGELOG.md +318 -315
  2. package/index.js +30 -30
  3. package/package.json +76 -76
  4. package/public/defaultLogo.png +0 -0
  5. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  6. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +551 -551
  7. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +777 -777
  8. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +553 -553
  9. package/src/base-client/components/common/CustomColumnsDrawer/index.md +46 -46
  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/Upload/Upload.vue +162 -165
  13. package/src/base-client/components/common/XAddForm/XAddForm.vue +354 -354
  14. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +327 -327
  15. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  16. package/src/base-client/components/common/XForm/XForm.vue +274 -274
  17. package/src/base-client/components/common/XForm/XFormItem.vue +389 -389
  18. package/src/base-client/components/common/XFormTable/index.md +96 -96
  19. package/src/base-client/components/common/XTable/XTable.vue +278 -278
  20. package/src/base-client/components/system/LogDetailsView/LogDetailsView.vue +376 -376
  21. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  22. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  23. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  24. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  25. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  26. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  27. package/src/base-client/plugins/AppData.js +69 -69
  28. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  29. package/src/base-client/plugins/PagedList.js +177 -177
  30. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  31. package/src/base-client/plugins/i18n-extend.js +32 -32
  32. package/src/components/Ellipsis/index.md +38 -38
  33. package/src/components/NumberInfo/index.md +43 -43
  34. package/src/components/STable/README.md +341 -341
  35. package/src/components/STable/index.js +318 -318
  36. package/src/components/Trend/index.md +45 -45
  37. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  38. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  39. package/src/components/exception/ExceptionPage.vue +70 -70
  40. package/src/components/form/FormRow.vue +52 -52
  41. package/src/components/index.js +36 -36
  42. package/src/components/menu/SideMenu.vue +62 -62
  43. package/src/components/menu/menu.js +273 -273
  44. package/src/components/setting/Setting.vue +235 -235
  45. package/src/components/table/StandardTable.vue +141 -141
  46. package/src/components/table/advance/ActionColumns.vue +158 -158
  47. package/src/components/table/advance/SearchArea.vue +355 -355
  48. package/src/components/tool/AStepItem.vue +60 -60
  49. package/src/components/tool/AvatarList.vue +68 -68
  50. package/src/components/tool/Drawer.vue +142 -142
  51. package/src/components/tool/TagSelect.vue +83 -83
  52. package/src/components/transition/PageToggleTransition.vue +97 -97
  53. package/src/config/default/setting.config.js +2 -0
  54. package/src/config/replacer/resolve.config.js +67 -67
  55. package/src/layouts/AdminLayout.vue +174 -174
  56. package/src/layouts/header/AdminHeader.vue +104 -104
  57. package/src/layouts/header/HeaderNotice.vue +167 -167
  58. package/src/layouts/header/HeaderSearch.vue +67 -67
  59. package/src/layouts/header/InstitutionDetail.vue +181 -181
  60. package/src/layouts/tabs/TabsHead.vue +190 -190
  61. package/src/layouts/tabs/TabsView.vue +379 -379
  62. package/src/mock/goods/index.js +108 -108
  63. package/src/pages/CreateQueryPage.vue +65 -65
  64. package/src/pages/login/Login.vue +277 -277
  65. package/src/pages/report/ReportTable.js +124 -124
  66. package/src/pages/report/ReportTableHome.vue +28 -28
  67. package/src/pages/resourceManage/orgListManage.vue +98 -98
  68. package/src/pages/system/dictionary/index.vue +43 -43
  69. package/src/pages/system/file/index.vue +317 -317
  70. package/src/pages/system/queryParams/index.vue +43 -43
  71. package/src/pages/system/ticket/index.vue +489 -461
  72. package/src/pages/system/ticket/submitTicketSuccess.vue +206 -206
  73. package/src/router/async/config.async.js +27 -27
  74. package/src/router/async/router.map.js +56 -56
  75. package/src/router/index.js +27 -27
  76. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  77. package/src/services/api/LogDetailsViewApi.js +10 -10
  78. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  79. package/src/services/api/TicketDetailsViewApi.js +34 -34
  80. package/src/services/api/common.js +58 -58
  81. package/src/services/api/commonTempTable.js +10 -10
  82. package/src/services/api/index.js +17 -17
  83. package/src/services/api/manage.js +8 -8
  84. package/src/store/mutation-types.js +2 -2
  85. package/src/theme/default/nprogress.less +76 -76
  86. package/src/theme/default/style.less +47 -47
  87. package/src/utils/colors.js +103 -103
  88. package/src/utils/excel/Blob.js +180 -180
  89. package/src/utils/excel/Export2Excel.js +141 -141
  90. package/src/utils/formatter.js +68 -68
  91. package/src/utils/i18n.js +80 -80
  92. package/src/utils/request.js +225 -225
  93. package/src/utils/routerUtil.js +364 -364
  94. package/src/utils/theme-color-replacer-extend.js +91 -91
  95. package/src/utils/themeUtil.js +100 -100
  96. package/src/utils/util.js +230 -230
  97. package/vue.config.js +99 -99
@@ -1,551 +1,551 @@
1
- <template>
2
- <a-drawer
3
- :visible="visible"
4
- :width="isMobile ? screenWidth : screenWidth * 0.85"
5
- placement="right"
6
- title="查询配置生成"
7
- @close="onClose"
8
- >
9
- <a-row :gutter="24">
10
- <a-col :lg="12" :md="12" :sm="24" :xl="14" :xs="24">
11
- <a-form-model
12
- ref="businessCreateForm"
13
- :label-col="labelCol"
14
- :model="form"
15
- :rules="rules"
16
- :wrapper-col="wrapperCol"
17
- >
18
- <a-form-model-item label="服务名称" prop="serviceName">
19
- <a-input v-model="form.serviceName" placeholder="查询接口所在的服务名称,默认af-system"/>
20
- </a-form-model-item>
21
- <a-form-model-item label="查询主表名" prop="tableName">
22
- <a-input v-model="form.tableName" placeholder="查询用的主表+别名,用空格隔开,如:t_userfiles u"/>
23
- </a-form-model-item>
24
- <a-form-model-item label="预设关联表" prop="joinArray">
25
- <a-popover placement="right" title="说明">
26
- <template slot="content">
27
- <p>配置你的查询中可能涉及到的所有关联表</p>
28
- <p>比如你的查询中涉及到了t_userinfo表,就需要加入t_userinfo表的关联,和你写SQL的关联一样</p>
29
- <p>请注意,你关联的<span style="color: #ff0000">除主表外的任何表</span>都需要配置</p>
30
- <a-input-group compact style="width: 400px;">
31
- <a-input placeholder="表别名" readOnly style="width: 20%"/>
32
- <a-input placeholder="关联条件" readOnly style="width: 80%"/>
33
- </a-input-group>
34
- <a-input-group compact style="width: 400px;">
35
- <a-input placeholder="表别名" readOnly style="width: 20%" value="ui"/>
36
- <a-input
37
- placeholder="关联条件"
38
- readOnly
39
- style="width: 80%"
40
- value="t_userinfo ui on i.f_userinfo_id = ui.f_userinfo_id"/>
41
- </a-input-group>
42
- </template>
43
- <a-button type="primary" @click="addJoinItem()">增加</a-button>
44
- </a-popover>
45
- <div v-for="(itemObj, index) in joinArray" :key="index">
46
- <a-input-group compact>
47
- <a-input
48
- v-model="itemObj.key"
49
- placeholder="表别名"
50
- style="width: 20%;position: relative;bottom: 1px;"
51
- @change="changeJoinArray()"/>
52
- <a-input v-model="itemObj.value" placeholder="关联条件" style="width: 80%" @change="changeJoinArray()">
53
- <a-icon slot="addonAfter" type="close" @click="removeJoinItem(index)"/>
54
- </a-input>
55
- </a-input-group>
56
- </div>
57
- </a-form-model-item>
58
- <a-form-model-item label="SQL查询表达式" prop="condition">
59
- <a-input v-model="form.condition.value" placeholder="用作SQL查询的固定条件表达式,如:gb.f_meter_type='物联网表',可选"/>
60
- <template v-if="form.condition.value && Object.keys(form.joinArray).length > 0">
61
- <a-alert message="提示:如果SQL查询表达式中用到了关联表,需要勾选用到的关联表别名" type="success"/>
62
- <a-checkbox-group v-model="form.condition.join" :options="conditionJoinArray"/>
63
- </template>
64
- </a-form-model-item>
65
- <a-form-model-item label="排序方式" prop="orderBy">
66
- <a-input v-model="form.orderBy" placeholder="排序字段,用别名+字段名+排序方式(可选)表示,如:u.id desc"/>
67
- </a-form-model-item>
68
- <a-form-model-item label="数据字段" prop="column">
69
- <a-button type="primary" @click="addColumnItem()">增加</a-button>
70
- <div
71
- v-for="(columnItem, index) in form.column"
72
- :key="index"
73
- class="column_item"
74
- draggable="true"
75
- @dragend="handleDragEnd($event, columnItem)"
76
- @dragenter="handleDragEnter($event, columnItem)"
77
- @dragstart="handleDragStart($event, columnItem)"
78
- @dragover.prevent="handleDragOver($event, columnItem)">
79
- <a-row v-if="ending && dragging && columnItem.key === ending.key && dragging.key !== ending.key" class="dragTipsWarp">
80
- <span class="dragTips">拖到此处放置</span>
81
- </a-row>
82
- <a-row :gutter="24">
83
- <a-col :span="20">
84
- <span style="font-weight: bold">{{ columnItem.title }}({{ columnItem.key }})</span>
85
- </a-col>
86
- <!-- 江超说先不要上下移动了 因为可以拖动了-->
87
- <!-- <a-col v-if="index > 0 && form.column.length > 1" :span="2">-->
88
- <!-- <a-icon type="up-square" @click="upColumnItem(columnItem.key,index)"/>-->
89
- <!-- </a-col>-->
90
- <!-- <a-col v-if="(index !== form.column.length - 1) && form.column.length > 1" :span="2">-->
91
- <!-- <a-icon type="down-square" @click="downColumnItem(columnItem.key,index)"/>-->
92
- <!-- </a-col>-->
93
- <a-col :span="2">
94
- <a-icon type="edit" @click="editColumnItem(columnItem.key,index)"/>
95
- </a-col>
96
- <a-col :span="2">
97
- <a-icon type="close" @click="removeColumnItem(columnItem.key,index)"/>
98
- </a-col>
99
- </a-row>
100
- </div>
101
- </a-form-model-item>
102
- <a-form-model-item label="操作按钮配置" prop="buttonState">
103
- <a-checkbox-group v-model="buttonStateData" :options="buttonStateArray"/>
104
- </a-form-model-item>
105
- <a-form-model-item label="自定义查询" prop="customQuery">
106
- <a-input v-model="form.customQuery" placeholder="示例 / 默认值:webmeterapi/commonQueryWithResource"/>
107
- </a-form-model-item>
108
- <a-form-model-item label="自定义保存" prop="customAOM">
109
- <a-input v-model="form.customAoM" placeholder="示例 / 默认值:webmeterapi/commonAddOrModify"/>
110
- </a-form-model-item>
111
- </a-form-model>
112
- <create-query-item ref="queryItem" @getColumn="getColumn" @itemHandle="itemHandle"/>
113
- <a-button type="primary" @click="view">操作</a-button>
114
- </a-col>
115
- <a-col :lg="12" :md="12" :sm="24" :xl="10" :xs="24">
116
- <a-card :bordered="false" size="small" style="overflow: auto" title="预览">
117
- <json-viewer
118
- :copyable="{copyText: '复制', copiedText: '已复制'}"
119
- :expand-depth="parseInt('100')"
120
- :value="result"
121
- style="overflow: auto;max-height: 440px"></json-viewer>
122
- </a-card>
123
- </a-col>
124
- </a-row>
125
- <a-modal
126
- :centered="true"
127
- :destroyOnClose="true"
128
- :visible="modelVisible"
129
- :width="isMobile ? screenWidth : screenWidth * 0.8"
130
- :zIndex="1001"
131
- title="效果预览"
132
- @cancel="onModelClose">
133
- <template slot="footer">
134
- <a-button key="close" @click="onModelClose">
135
- 返回
136
- </a-button>
137
- <a-button key="submit" type="primary" @click="submit">
138
- 保存
139
- </a-button>
140
- </template>
141
- <x-form-table
142
- :queryParamsJson="result"
143
- :view-mode="true">
144
- </x-form-table>
145
- </a-modal>
146
- </a-drawer>
147
- </template>
148
-
149
- <script>
150
- import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
151
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
152
- import JsonViewer from 'vue-json-viewer'
153
- import FileSaver from 'file-saver'
154
- import { mapState } from 'vuex'
155
- import CreateQueryItem from '@vue2-client/base-client/components/common/CreateQuery/CreateQueryItem'
156
-
157
- export default {
158
- name: 'CreateQuery',
159
- components: {
160
- CreateQueryItem,
161
- JsonViewer,
162
- XFormTable,
163
- XFormItem
164
- },
165
- data () {
166
- return {
167
- // 页面宽度
168
- screenWidth: document.documentElement.clientWidth,
169
- // 效果预览模态框是否展示
170
- modelVisible: false,
171
- // 操作按钮状态集合
172
- buttonStateArray: [
173
- { label: '新增', value: 'add' },
174
- { label: '修改', value: 'edit' },
175
- { label: '删除', value: 'delete' },
176
- { label: '导出', value: 'export' }
177
- ],
178
- // 数据模式类型集合值
179
- buttonStateData: ['add', 'edit', 'delete', 'export'],
180
- labelCol: { span: 4 },
181
- wrapperCol: { span: 14 },
182
- form: {
183
- serviceName: '',
184
- tableName: '',
185
- joinArray: {},
186
- condition: {},
187
- orderBy: '',
188
- column: [],
189
- customQuery: undefined,
190
- customAOM: undefined
191
- },
192
- result: {},
193
- itemMap: {},
194
- selectIndex: null,
195
- joinArray: [],
196
- rules: {
197
- tableName: [{ required: true, message: '请输入查询表名', trigger: 'blur' }],
198
- orderBy: [{ required: true, message: '请输入排序方式', trigger: 'blur' }]
199
- },
200
- ending: null,
201
- dragging: null
202
- }
203
- },
204
- mounted () {
205
- this.initView()
206
- },
207
- computed: {
208
- ...mapState('setting', ['isMobile']),
209
- conditionJoinArray: function () {
210
- const result = []
211
- for (const item in this.form.joinArray) {
212
- if (item !== '') {
213
- result.push({
214
- label: item,
215
- value: item
216
- })
217
- }
218
- }
219
- if (result.length === 0) {
220
- result.push({
221
- label: '-',
222
- value: '-'
223
- })
224
- }
225
- return result
226
- },
227
- buttonState: function () {
228
- const result = {
229
- add: false,
230
- edit: false,
231
- delete: false,
232
- export: false
233
- }
234
- for (const item of this.buttonStateData) {
235
- result[item] = true
236
- }
237
- return result
238
- }
239
- },
240
- props: {
241
- visible: {
242
- type: Boolean,
243
- default: false
244
- },
245
- toEditJson: {
246
- type: Object,
247
- default: () => {}
248
- }
249
- },
250
- watch: {
251
- visible (rel) {
252
- if (rel) {
253
- this.initView()
254
- }
255
- if (rel && this.toEditJson) {
256
- // 处理预设关联表
257
- if (this.joinArray.length === 0) {
258
- for (const key in this.toEditJson.joinArray) {
259
- this.joinArray.push({
260
- key: key,
261
- value: this.toEditJson.joinArray[key]
262
- })
263
- }
264
- }
265
- // 处理具体表单项
266
- this.form = Object.assign(
267
- {
268
- tableName: '',
269
- joinArray: {},
270
- condition: {},
271
- orderBy: '',
272
- column: []
273
- }, this.toEditJson
274
- )
275
- for (const columnItem of this.form.column) {
276
- // 数据模式兼容性处理
277
- if (!(columnItem.dataMode || columnItem.dataModeArray)) {
278
- columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
279
- } else if (columnItem.dataMode) {
280
- if (columnItem.dataMode === 'all') {
281
- columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
282
- } else if (columnItem.dataMode === 'form') {
283
- columnItem.dataModeArray = ['queryForm', 'addOrEditForm', 'sqlQueryCondition']
284
- } else if (columnItem.dataMode === 'table') {
285
- columnItem.dataModeArray = ['table', 'sqlQueryItem']
286
- } else if (columnItem.dataMode === 'table_form') {
287
- columnItem.dataModeArray = ['table', 'sqlQueryItem', 'sqlQueryCondition']
288
- } else if (columnItem.dataMode === 'only_form') {
289
- columnItem.dataModeArray = ['queryForm']
290
- } else if (columnItem.dataMode === 'only_table') {
291
- columnItem.dataModeArray = ['table']
292
- } else if (columnItem.dataMode === 'clear') {
293
- columnItem.dataModeArray = ['sqlQueryItem', 'sqlQueryCondition']
294
- } else if (columnItem.dataMode === 'only_add_modify') {
295
- columnItem.dataModeArray = ['addOrEditForm', 'sqlQueryItem']
296
- }
297
- }
298
- delete columnItem.dataMode
299
- // 插槽兼容处理
300
- if (columnItem.slot) {
301
- if (columnItem.slot.value && columnItem.slot.type === 'ellipsis') {
302
- columnItem.slotValue = columnItem.slot.value
303
- } else if (columnItem.slot.keyMap && columnItem.slot.type === 'badge') {
304
- columnItem.slotKeyMap = columnItem.slot.keyMap
305
- } else if (columnItem.slot.actionText && columnItem.slot.type === 'action') {
306
- columnItem.actionText = columnItem.slot.actionText
307
- }
308
- }
309
- // 必选项兼容处理
310
- if (columnItem.rule && columnItem.rule.required && columnItem.rule.required !== 'false') {
311
- columnItem.rule.required = columnItem.rule.required.toString()
312
- } else {
313
- if (!columnItem.rule) {
314
- columnItem.rule = {}
315
- }
316
- columnItem.rule.required = 'false'
317
- }
318
- // 数据源加载方式兼容处理
319
- if (columnItem.lazyLoad && columnItem.lazyLoad !== 'false') {
320
- columnItem.lazyLoad = columnItem.lazyLoad.toString()
321
- } else {
322
- columnItem.lazyLoad = 'false'
323
- }
324
- // 下拉框数据源兼容处理
325
- if ((columnItem.formType === 'select' || columnItem.formType === 'cascader') && columnItem.selectKey) {
326
- // 数据源为logic
327
- if (columnItem.selectKey.toString().startsWith('logic@')) {
328
- columnItem.selectType = 'logic'
329
- } else if (columnItem.selectKey instanceof Array || this.isJSON(columnItem.selectKey)) {
330
- // 数据源为固定json集合
331
- if (columnItem.selectKey instanceof Array) {
332
- columnItem.selectKey = JSON.stringify(columnItem.selectKey)
333
- }
334
- columnItem.selectType = 'fixArray'
335
- } else {
336
- columnItem.selectType = 'key'
337
- }
338
- }
339
- this.itemMap[columnItem.key] = Object.assign({
340
- key: '',
341
- title: '',
342
- slot: {},
343
- rule: {
344
- required: 'false'
345
- },
346
- dataModeArray: []
347
- }, columnItem)
348
- }
349
- // 处理操作按钮配置
350
- if (this.toEditJson.buttonState) {
351
- this.buttonStateData = []
352
- for (const buttonStateKey of Object.keys(this.toEditJson.buttonState)) {
353
- if (this.toEditJson.buttonState[buttonStateKey]) {
354
- this.buttonStateData.push(buttonStateKey)
355
- }
356
- }
357
- } else {
358
- this.buttonStateData = ['add', 'edit', 'delete', 'export']
359
- }
360
- }
361
- }
362
- },
363
- methods: {
364
- // 初始化组件
365
- initView () {
366
- this.joinArray = []
367
- this.result = {}
368
- },
369
- onClose () {
370
- this.$emit('update:visible', false)
371
- },
372
- onModelClose () {
373
- this.modelVisible = false
374
- },
375
- addJoinItem () {
376
- this.joinArray.push({
377
- key: '',
378
- value: ''
379
- })
380
- this.changeJoinArray()
381
- },
382
- removeJoinItem (index) {
383
- this.joinArray.splice(index, 1)
384
- this.changeJoinArray()
385
- },
386
- itemHandle (item, type) {
387
- this.itemMap[item.key] = item
388
- if (type === '新增') {
389
- this.form.column.push(item)
390
- } else {
391
- this.$set(this.form.column, this.selectIndex, item)
392
- }
393
- this.$message.success(`${type}成功`)
394
- this.$refs.queryItem.flashModal(false)
395
- },
396
- getColumn (callback) {
397
- callback(JSON.parse(JSON.stringify(this.form.column)))
398
- },
399
- addColumnItem () {
400
- this.type = '新增'
401
- this.$refs.queryItem.addColumnItemExecute()
402
- },
403
- editColumnItem (key, index) {
404
- if (this.itemMap[key]) {
405
- this.$refs.queryItem.editColumnItemExecute(this.itemMap[key])
406
- this.selectIndex = index
407
- } else {
408
- this.$message.warn('编辑失败')
409
- }
410
- },
411
- removeColumnItem (key, index) {
412
- const _this = this
413
- this.$confirm({
414
- title: '您确定要删除该数据项?',
415
- content: '删除的数据项无法恢复',
416
- okText: '确定',
417
- okType: 'danger',
418
- cancelText: '取消',
419
- onOk () {
420
- delete _this.itemMap[key]
421
- _this.form.column.splice(index, 1)
422
- }
423
- })
424
- },
425
- upColumnItem (key, index) {
426
- const newIndex = index - 1
427
- const itemA = this.form.column[newIndex]
428
- const itemB = this.form.column[index]
429
- this.form.column.splice(index, 1, itemA)
430
- this.form.column.splice(newIndex, 1, itemB)
431
- },
432
- downColumnItem (key, index) {
433
- const newIndex = index + 1
434
- const itemA = this.form.column[newIndex]
435
- const itemB = this.form.column[index]
436
- this.form.column.splice(index, 1, itemA)
437
- this.form.column.splice(newIndex, 1, itemB)
438
- },
439
- changeJoinArray () {
440
- const joinArrayObject = {}
441
- for (const item of this.joinArray) {
442
- joinArrayObject[item.key] = item.value
443
- }
444
- this.form.joinArray = joinArrayObject
445
- },
446
- exportJson () {
447
- const data = JSON.stringify(this.form, null, 2)
448
- const blob = new Blob([data], { type: 'application/json' })
449
- FileSaver.saveAs(blob, `Query.json`)
450
- this.$message.success('导出成功!')
451
- },
452
- viewHandle (then) {
453
- if (this.form.column.length === 0) {
454
- this.$message.error('你没有增加任何数据字段')
455
- return
456
- }
457
- this.result = JSON.parse(JSON.stringify(this.form))
458
- if (this.result.condition && (!this.result.condition.value || this.result.condition.value === '')) {
459
- delete this.result.condition
460
- }
461
- for (const item of this.result.column) {
462
- if (item.selectType === 'fixArray') {
463
- item.selectKey = JSON.parse(item.selectKey)
464
- }
465
- if (item.dataModeArray.length === 5) {
466
- delete item.dataModeArray
467
- }
468
- }
469
- // if (this.buttonStateData.length !== 4) {
470
- this.result.buttonState = this.buttonState
471
- // }
472
- then()
473
- },
474
- view () {
475
- this.$refs.businessCreateForm.validate(valid => {
476
- if (valid) {
477
- this.viewHandle(() => {
478
- this.modelVisible = true
479
- })
480
- }
481
- })
482
- },
483
- submit () {
484
- this.onModelClose()
485
- this.$refs.businessCreateForm.validate(valid => {
486
- if (valid) {
487
- this.viewHandle(() => {
488
- // saveQueryParams
489
- this.$emit('saveQueryParams', this.result)
490
- })
491
- }
492
- })
493
- },
494
- // 判断是否为json字符串
495
- isJSON (str) {
496
- if (typeof str == 'string') {
497
- try {
498
- const obj = JSON.parse(str)
499
- return !!(typeof obj == 'object' && obj)
500
- } catch (e) {
501
- return false
502
- }
503
- }
504
- },
505
- // 拖拽事件
506
- handleDragStart (e, item) {
507
- this.dragging = item
508
- },
509
- handleDragEnd (e, item) {
510
- if (this.ending.key === this.dragging.key) {
511
- return
512
- }
513
- const newItems = [...this.form.column]
514
- const src = newItems.indexOf(this.dragging)
515
- const dst = newItems.indexOf(this.ending)
516
- // newItems.splice(src, 1, ...newItems.splice(dst, 1, newItems[src])) 替换位置
517
- // 挪移位置
518
- newItems.splice(src, 1)
519
- newItems.splice(dst, 0, this.dragging)
520
- this.form.column = newItems
521
- this.$nextTick(() => {
522
- this.dragging = null
523
- this.ending = null
524
- })
525
- },
526
- handleDragOver (e) {
527
- // 首先把div变成可以放置的元素,即重写dragenter/dragover
528
- // e.dataTransfer.dropEffect="move";//在dragenter中针对放置目标来设置!
529
- e.dataTransfer.dropEffect = 'move'
530
- },
531
- handleDragEnter (e, item) {
532
- // 为需要移动的元素设置dragstart事件
533
- e.dataTransfer.effectAllowed = 'move'
534
- this.ending = item
535
- }
536
- }
537
- }
538
- </script>
539
- <style lang="less" scoped>
540
- .column_item :hover {
541
- background-color:rgba(64, 169, 255,0.25);
542
- }
543
- .dragTips{
544
- display:block;
545
- text-align: center;
546
- border:1px dashed rgba(64, 169, 255,0.55);
547
- }
548
- .dragTipsWarp{
549
- padding: .5rem 2rem;
550
- }
551
- </style>
1
+ <template>
2
+ <a-drawer
3
+ :visible="visible"
4
+ :width="isMobile ? screenWidth : screenWidth * 0.85"
5
+ placement="right"
6
+ title="查询配置生成"
7
+ @close="onClose"
8
+ >
9
+ <a-row :gutter="24">
10
+ <a-col :lg="12" :md="12" :sm="24" :xl="14" :xs="24">
11
+ <a-form-model
12
+ ref="businessCreateForm"
13
+ :label-col="labelCol"
14
+ :model="form"
15
+ :rules="rules"
16
+ :wrapper-col="wrapperCol"
17
+ >
18
+ <a-form-model-item label="服务名称" prop="serviceName">
19
+ <a-input v-model="form.serviceName" placeholder="查询接口所在的服务名称,默认af-system"/>
20
+ </a-form-model-item>
21
+ <a-form-model-item label="查询主表名" prop="tableName">
22
+ <a-input v-model="form.tableName" placeholder="查询用的主表+别名,用空格隔开,如:t_userfiles u"/>
23
+ </a-form-model-item>
24
+ <a-form-model-item label="预设关联表" prop="joinArray">
25
+ <a-popover placement="right" title="说明">
26
+ <template slot="content">
27
+ <p>配置你的查询中可能涉及到的所有关联表</p>
28
+ <p>比如你的查询中涉及到了t_userinfo表,就需要加入t_userinfo表的关联,和你写SQL的关联一样</p>
29
+ <p>请注意,你关联的<span style="color: #ff0000">除主表外的任何表</span>都需要配置</p>
30
+ <a-input-group compact style="width: 400px;">
31
+ <a-input placeholder="表别名" readOnly style="width: 20%"/>
32
+ <a-input placeholder="关联条件" readOnly style="width: 80%"/>
33
+ </a-input-group>
34
+ <a-input-group compact style="width: 400px;">
35
+ <a-input placeholder="表别名" readOnly style="width: 20%" value="ui"/>
36
+ <a-input
37
+ placeholder="关联条件"
38
+ readOnly
39
+ style="width: 80%"
40
+ value="t_userinfo ui on i.f_userinfo_id = ui.f_userinfo_id"/>
41
+ </a-input-group>
42
+ </template>
43
+ <a-button type="primary" @click="addJoinItem()">增加</a-button>
44
+ </a-popover>
45
+ <div v-for="(itemObj, index) in joinArray" :key="index">
46
+ <a-input-group compact>
47
+ <a-input
48
+ v-model="itemObj.key"
49
+ placeholder="表别名"
50
+ style="width: 20%;position: relative;bottom: 1px;"
51
+ @change="changeJoinArray()"/>
52
+ <a-input v-model="itemObj.value" placeholder="关联条件" style="width: 80%" @change="changeJoinArray()">
53
+ <a-icon slot="addonAfter" type="close" @click="removeJoinItem(index)"/>
54
+ </a-input>
55
+ </a-input-group>
56
+ </div>
57
+ </a-form-model-item>
58
+ <a-form-model-item label="SQL查询表达式" prop="condition">
59
+ <a-input v-model="form.condition.value" placeholder="用作SQL查询的固定条件表达式,如:gb.f_meter_type='物联网表',可选"/>
60
+ <template v-if="form.condition.value && Object.keys(form.joinArray).length > 0">
61
+ <a-alert message="提示:如果SQL查询表达式中用到了关联表,需要勾选用到的关联表别名" type="success"/>
62
+ <a-checkbox-group v-model="form.condition.join" :options="conditionJoinArray"/>
63
+ </template>
64
+ </a-form-model-item>
65
+ <a-form-model-item label="排序方式" prop="orderBy">
66
+ <a-input v-model="form.orderBy" placeholder="排序字段,用别名+字段名+排序方式(可选)表示,如:u.id desc"/>
67
+ </a-form-model-item>
68
+ <a-form-model-item label="数据字段" prop="column">
69
+ <a-button type="primary" @click="addColumnItem()">增加</a-button>
70
+ <div
71
+ v-for="(columnItem, index) in form.column"
72
+ :key="index"
73
+ class="column_item"
74
+ draggable="true"
75
+ @dragend="handleDragEnd($event, columnItem)"
76
+ @dragenter="handleDragEnter($event, columnItem)"
77
+ @dragstart="handleDragStart($event, columnItem)"
78
+ @dragover.prevent="handleDragOver($event, columnItem)">
79
+ <a-row v-if="ending && dragging && columnItem.key === ending.key && dragging.key !== ending.key" class="dragTipsWarp">
80
+ <span class="dragTips">拖到此处放置</span>
81
+ </a-row>
82
+ <a-row :gutter="24">
83
+ <a-col :span="20">
84
+ <span style="font-weight: bold">{{ columnItem.title }}({{ columnItem.key }})</span>
85
+ </a-col>
86
+ <!-- 江超说先不要上下移动了 因为可以拖动了-->
87
+ <!-- <a-col v-if="index > 0 && form.column.length > 1" :span="2">-->
88
+ <!-- <a-icon type="up-square" @click="upColumnItem(columnItem.key,index)"/>-->
89
+ <!-- </a-col>-->
90
+ <!-- <a-col v-if="(index !== form.column.length - 1) && form.column.length > 1" :span="2">-->
91
+ <!-- <a-icon type="down-square" @click="downColumnItem(columnItem.key,index)"/>-->
92
+ <!-- </a-col>-->
93
+ <a-col :span="2">
94
+ <a-icon type="edit" @click="editColumnItem(columnItem.key,index)"/>
95
+ </a-col>
96
+ <a-col :span="2">
97
+ <a-icon type="close" @click="removeColumnItem(columnItem.key,index)"/>
98
+ </a-col>
99
+ </a-row>
100
+ </div>
101
+ </a-form-model-item>
102
+ <a-form-model-item label="操作按钮配置" prop="buttonState">
103
+ <a-checkbox-group v-model="buttonStateData" :options="buttonStateArray"/>
104
+ </a-form-model-item>
105
+ <a-form-model-item label="自定义查询" prop="customQuery">
106
+ <a-input v-model="form.customQuery" placeholder="示例 / 默认值:webmeterapi/commonQueryWithResource"/>
107
+ </a-form-model-item>
108
+ <a-form-model-item label="自定义保存" prop="customAOM">
109
+ <a-input v-model="form.customAoM" placeholder="示例 / 默认值:webmeterapi/commonAddOrModify"/>
110
+ </a-form-model-item>
111
+ </a-form-model>
112
+ <create-query-item ref="queryItem" @getColumn="getColumn" @itemHandle="itemHandle"/>
113
+ <a-button type="primary" @click="view">操作</a-button>
114
+ </a-col>
115
+ <a-col :lg="12" :md="12" :sm="24" :xl="10" :xs="24">
116
+ <a-card :bordered="false" size="small" style="overflow: auto" title="预览">
117
+ <json-viewer
118
+ :copyable="{copyText: '复制', copiedText: '已复制'}"
119
+ :expand-depth="parseInt('100')"
120
+ :value="result"
121
+ style="overflow: auto;max-height: 440px"></json-viewer>
122
+ </a-card>
123
+ </a-col>
124
+ </a-row>
125
+ <a-modal
126
+ :centered="true"
127
+ :destroyOnClose="true"
128
+ :visible="modelVisible"
129
+ :width="isMobile ? screenWidth : screenWidth * 0.8"
130
+ :zIndex="1001"
131
+ title="效果预览"
132
+ @cancel="onModelClose">
133
+ <template slot="footer">
134
+ <a-button key="close" @click="onModelClose">
135
+ 返回
136
+ </a-button>
137
+ <a-button key="submit" type="primary" @click="submit">
138
+ 保存
139
+ </a-button>
140
+ </template>
141
+ <x-form-table
142
+ :queryParamsJson="result"
143
+ :view-mode="true">
144
+ </x-form-table>
145
+ </a-modal>
146
+ </a-drawer>
147
+ </template>
148
+
149
+ <script>
150
+ import XFormItem from '@vue2-client/base-client/components/common/XForm/XFormItem'
151
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
152
+ import JsonViewer from 'vue-json-viewer'
153
+ import FileSaver from 'file-saver'
154
+ import { mapState } from 'vuex'
155
+ import CreateQueryItem from '@vue2-client/base-client/components/common/CreateQuery/CreateQueryItem'
156
+
157
+ export default {
158
+ name: 'CreateQuery',
159
+ components: {
160
+ CreateQueryItem,
161
+ JsonViewer,
162
+ XFormTable,
163
+ XFormItem
164
+ },
165
+ data () {
166
+ return {
167
+ // 页面宽度
168
+ screenWidth: document.documentElement.clientWidth,
169
+ // 效果预览模态框是否展示
170
+ modelVisible: false,
171
+ // 操作按钮状态集合
172
+ buttonStateArray: [
173
+ { label: '新增', value: 'add' },
174
+ { label: '修改', value: 'edit' },
175
+ { label: '删除', value: 'delete' },
176
+ { label: '导出', value: 'export' }
177
+ ],
178
+ // 数据模式类型集合值
179
+ buttonStateData: ['add', 'edit', 'delete', 'export'],
180
+ labelCol: { span: 4 },
181
+ wrapperCol: { span: 14 },
182
+ form: {
183
+ serviceName: '',
184
+ tableName: '',
185
+ joinArray: {},
186
+ condition: {},
187
+ orderBy: '',
188
+ column: [],
189
+ customQuery: undefined,
190
+ customAOM: undefined
191
+ },
192
+ result: {},
193
+ itemMap: {},
194
+ selectIndex: null,
195
+ joinArray: [],
196
+ rules: {
197
+ tableName: [{ required: true, message: '请输入查询表名', trigger: 'blur' }],
198
+ orderBy: [{ required: true, message: '请输入排序方式', trigger: 'blur' }]
199
+ },
200
+ ending: null,
201
+ dragging: null
202
+ }
203
+ },
204
+ mounted () {
205
+ this.initView()
206
+ },
207
+ computed: {
208
+ ...mapState('setting', ['isMobile']),
209
+ conditionJoinArray: function () {
210
+ const result = []
211
+ for (const item in this.form.joinArray) {
212
+ if (item !== '') {
213
+ result.push({
214
+ label: item,
215
+ value: item
216
+ })
217
+ }
218
+ }
219
+ if (result.length === 0) {
220
+ result.push({
221
+ label: '-',
222
+ value: '-'
223
+ })
224
+ }
225
+ return result
226
+ },
227
+ buttonState: function () {
228
+ const result = {
229
+ add: false,
230
+ edit: false,
231
+ delete: false,
232
+ export: false
233
+ }
234
+ for (const item of this.buttonStateData) {
235
+ result[item] = true
236
+ }
237
+ return result
238
+ }
239
+ },
240
+ props: {
241
+ visible: {
242
+ type: Boolean,
243
+ default: false
244
+ },
245
+ toEditJson: {
246
+ type: Object,
247
+ default: () => {}
248
+ }
249
+ },
250
+ watch: {
251
+ visible (rel) {
252
+ if (rel) {
253
+ this.initView()
254
+ }
255
+ if (rel && this.toEditJson) {
256
+ // 处理预设关联表
257
+ if (this.joinArray.length === 0) {
258
+ for (const key in this.toEditJson.joinArray) {
259
+ this.joinArray.push({
260
+ key: key,
261
+ value: this.toEditJson.joinArray[key]
262
+ })
263
+ }
264
+ }
265
+ // 处理具体表单项
266
+ this.form = Object.assign(
267
+ {
268
+ tableName: '',
269
+ joinArray: {},
270
+ condition: {},
271
+ orderBy: '',
272
+ column: []
273
+ }, this.toEditJson
274
+ )
275
+ for (const columnItem of this.form.column) {
276
+ // 数据模式兼容性处理
277
+ if (!(columnItem.dataMode || columnItem.dataModeArray)) {
278
+ columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
279
+ } else if (columnItem.dataMode) {
280
+ if (columnItem.dataMode === 'all') {
281
+ columnItem.dataModeArray = ['queryForm', 'table', 'addOrEditForm', 'sqlQueryItem', 'sqlQueryCondition']
282
+ } else if (columnItem.dataMode === 'form') {
283
+ columnItem.dataModeArray = ['queryForm', 'addOrEditForm', 'sqlQueryCondition']
284
+ } else if (columnItem.dataMode === 'table') {
285
+ columnItem.dataModeArray = ['table', 'sqlQueryItem']
286
+ } else if (columnItem.dataMode === 'table_form') {
287
+ columnItem.dataModeArray = ['table', 'sqlQueryItem', 'sqlQueryCondition']
288
+ } else if (columnItem.dataMode === 'only_form') {
289
+ columnItem.dataModeArray = ['queryForm']
290
+ } else if (columnItem.dataMode === 'only_table') {
291
+ columnItem.dataModeArray = ['table']
292
+ } else if (columnItem.dataMode === 'clear') {
293
+ columnItem.dataModeArray = ['sqlQueryItem', 'sqlQueryCondition']
294
+ } else if (columnItem.dataMode === 'only_add_modify') {
295
+ columnItem.dataModeArray = ['addOrEditForm', 'sqlQueryItem']
296
+ }
297
+ }
298
+ delete columnItem.dataMode
299
+ // 插槽兼容处理
300
+ if (columnItem.slot) {
301
+ if (columnItem.slot.value && columnItem.slot.type === 'ellipsis') {
302
+ columnItem.slotValue = columnItem.slot.value
303
+ } else if (columnItem.slot.keyMap && columnItem.slot.type === 'badge') {
304
+ columnItem.slotKeyMap = columnItem.slot.keyMap
305
+ } else if (columnItem.slot.actionText && columnItem.slot.type === 'action') {
306
+ columnItem.actionText = columnItem.slot.actionText
307
+ }
308
+ }
309
+ // 必选项兼容处理
310
+ if (columnItem.rule && columnItem.rule.required && columnItem.rule.required !== 'false') {
311
+ columnItem.rule.required = columnItem.rule.required.toString()
312
+ } else {
313
+ if (!columnItem.rule) {
314
+ columnItem.rule = {}
315
+ }
316
+ columnItem.rule.required = 'false'
317
+ }
318
+ // 数据源加载方式兼容处理
319
+ if (columnItem.lazyLoad && columnItem.lazyLoad !== 'false') {
320
+ columnItem.lazyLoad = columnItem.lazyLoad.toString()
321
+ } else {
322
+ columnItem.lazyLoad = 'false'
323
+ }
324
+ // 下拉框数据源兼容处理
325
+ if ((columnItem.formType === 'select' || columnItem.formType === 'cascader') && columnItem.selectKey) {
326
+ // 数据源为logic
327
+ if (columnItem.selectKey.toString().startsWith('logic@')) {
328
+ columnItem.selectType = 'logic'
329
+ } else if (columnItem.selectKey instanceof Array || this.isJSON(columnItem.selectKey)) {
330
+ // 数据源为固定json集合
331
+ if (columnItem.selectKey instanceof Array) {
332
+ columnItem.selectKey = JSON.stringify(columnItem.selectKey)
333
+ }
334
+ columnItem.selectType = 'fixArray'
335
+ } else {
336
+ columnItem.selectType = 'key'
337
+ }
338
+ }
339
+ this.itemMap[columnItem.key] = Object.assign({
340
+ key: '',
341
+ title: '',
342
+ slot: {},
343
+ rule: {
344
+ required: 'false'
345
+ },
346
+ dataModeArray: []
347
+ }, columnItem)
348
+ }
349
+ // 处理操作按钮配置
350
+ if (this.toEditJson.buttonState) {
351
+ this.buttonStateData = []
352
+ for (const buttonStateKey of Object.keys(this.toEditJson.buttonState)) {
353
+ if (this.toEditJson.buttonState[buttonStateKey]) {
354
+ this.buttonStateData.push(buttonStateKey)
355
+ }
356
+ }
357
+ } else {
358
+ this.buttonStateData = ['add', 'edit', 'delete', 'export']
359
+ }
360
+ }
361
+ }
362
+ },
363
+ methods: {
364
+ // 初始化组件
365
+ initView () {
366
+ this.joinArray = []
367
+ this.result = {}
368
+ },
369
+ onClose () {
370
+ this.$emit('update:visible', false)
371
+ },
372
+ onModelClose () {
373
+ this.modelVisible = false
374
+ },
375
+ addJoinItem () {
376
+ this.joinArray.push({
377
+ key: '',
378
+ value: ''
379
+ })
380
+ this.changeJoinArray()
381
+ },
382
+ removeJoinItem (index) {
383
+ this.joinArray.splice(index, 1)
384
+ this.changeJoinArray()
385
+ },
386
+ itemHandle (item, type) {
387
+ this.itemMap[item.key] = item
388
+ if (type === '新增') {
389
+ this.form.column.push(item)
390
+ } else {
391
+ this.$set(this.form.column, this.selectIndex, item)
392
+ }
393
+ this.$message.success(`${type}成功`)
394
+ this.$refs.queryItem.flashModal(false)
395
+ },
396
+ getColumn (callback) {
397
+ callback(JSON.parse(JSON.stringify(this.form.column)))
398
+ },
399
+ addColumnItem () {
400
+ this.type = '新增'
401
+ this.$refs.queryItem.addColumnItemExecute()
402
+ },
403
+ editColumnItem (key, index) {
404
+ if (this.itemMap[key]) {
405
+ this.$refs.queryItem.editColumnItemExecute(this.itemMap[key])
406
+ this.selectIndex = index
407
+ } else {
408
+ this.$message.warn('编辑失败')
409
+ }
410
+ },
411
+ removeColumnItem (key, index) {
412
+ const _this = this
413
+ this.$confirm({
414
+ title: '您确定要删除该数据项?',
415
+ content: '删除的数据项无法恢复',
416
+ okText: '确定',
417
+ okType: 'danger',
418
+ cancelText: '取消',
419
+ onOk () {
420
+ delete _this.itemMap[key]
421
+ _this.form.column.splice(index, 1)
422
+ }
423
+ })
424
+ },
425
+ upColumnItem (key, index) {
426
+ const newIndex = index - 1
427
+ const itemA = this.form.column[newIndex]
428
+ const itemB = this.form.column[index]
429
+ this.form.column.splice(index, 1, itemA)
430
+ this.form.column.splice(newIndex, 1, itemB)
431
+ },
432
+ downColumnItem (key, index) {
433
+ const newIndex = index + 1
434
+ const itemA = this.form.column[newIndex]
435
+ const itemB = this.form.column[index]
436
+ this.form.column.splice(index, 1, itemA)
437
+ this.form.column.splice(newIndex, 1, itemB)
438
+ },
439
+ changeJoinArray () {
440
+ const joinArrayObject = {}
441
+ for (const item of this.joinArray) {
442
+ joinArrayObject[item.key] = item.value
443
+ }
444
+ this.form.joinArray = joinArrayObject
445
+ },
446
+ exportJson () {
447
+ const data = JSON.stringify(this.form, null, 2)
448
+ const blob = new Blob([data], { type: 'application/json' })
449
+ FileSaver.saveAs(blob, `Query.json`)
450
+ this.$message.success('导出成功!')
451
+ },
452
+ viewHandle (then) {
453
+ if (this.form.column.length === 0) {
454
+ this.$message.error('你没有增加任何数据字段')
455
+ return
456
+ }
457
+ this.result = JSON.parse(JSON.stringify(this.form))
458
+ if (this.result.condition && (!this.result.condition.value || this.result.condition.value === '')) {
459
+ delete this.result.condition
460
+ }
461
+ for (const item of this.result.column) {
462
+ if (item.selectType === 'fixArray') {
463
+ item.selectKey = JSON.parse(item.selectKey)
464
+ }
465
+ if (item.dataModeArray.length === 5) {
466
+ delete item.dataModeArray
467
+ }
468
+ }
469
+ // if (this.buttonStateData.length !== 4) {
470
+ this.result.buttonState = this.buttonState
471
+ // }
472
+ then()
473
+ },
474
+ view () {
475
+ this.$refs.businessCreateForm.validate(valid => {
476
+ if (valid) {
477
+ this.viewHandle(() => {
478
+ this.modelVisible = true
479
+ })
480
+ }
481
+ })
482
+ },
483
+ submit () {
484
+ this.onModelClose()
485
+ this.$refs.businessCreateForm.validate(valid => {
486
+ if (valid) {
487
+ this.viewHandle(() => {
488
+ // saveQueryParams
489
+ this.$emit('saveQueryParams', this.result)
490
+ })
491
+ }
492
+ })
493
+ },
494
+ // 判断是否为json字符串
495
+ isJSON (str) {
496
+ if (typeof str == 'string') {
497
+ try {
498
+ const obj = JSON.parse(str)
499
+ return !!(typeof obj == 'object' && obj)
500
+ } catch (e) {
501
+ return false
502
+ }
503
+ }
504
+ },
505
+ // 拖拽事件
506
+ handleDragStart (e, item) {
507
+ this.dragging = item
508
+ },
509
+ handleDragEnd (e, item) {
510
+ if (this.ending.key === this.dragging.key) {
511
+ return
512
+ }
513
+ const newItems = [...this.form.column]
514
+ const src = newItems.indexOf(this.dragging)
515
+ const dst = newItems.indexOf(this.ending)
516
+ // newItems.splice(src, 1, ...newItems.splice(dst, 1, newItems[src])) 替换位置
517
+ // 挪移位置
518
+ newItems.splice(src, 1)
519
+ newItems.splice(dst, 0, this.dragging)
520
+ this.form.column = newItems
521
+ this.$nextTick(() => {
522
+ this.dragging = null
523
+ this.ending = null
524
+ })
525
+ },
526
+ handleDragOver (e) {
527
+ // 首先把div变成可以放置的元素,即重写dragenter/dragover
528
+ // e.dataTransfer.dropEffect="move";//在dragenter中针对放置目标来设置!
529
+ e.dataTransfer.dropEffect = 'move'
530
+ },
531
+ handleDragEnter (e, item) {
532
+ // 为需要移动的元素设置dragstart事件
533
+ e.dataTransfer.effectAllowed = 'move'
534
+ this.ending = item
535
+ }
536
+ }
537
+ }
538
+ </script>
539
+ <style lang="less" scoped>
540
+ .column_item :hover {
541
+ background-color:rgba(64, 169, 255,0.25);
542
+ }
543
+ .dragTips{
544
+ display:block;
545
+ text-align: center;
546
+ border:1px dashed rgba(64, 169, 255,0.55);
547
+ }
548
+ .dragTipsWarp{
549
+ padding: .5rem 2rem;
550
+ }
551
+ </style>