diff --git a/frontend/src/components/DragItem/index.vue b/frontend/src/components/DragItem/index.vue index 04c86bef7d..e8afd23872 100644 --- a/frontend/src/components/DragItem/index.vue +++ b/frontend/src/components/DragItem/index.vue @@ -132,6 +132,13 @@ export default { return this.index > 0 } }, + watch: { + index(val, old) { + if (val !== old) { + this.sortChange('none') + } + } + }, mounted() { }, created() { diff --git a/frontend/src/views/panel/filter/filterDialog.vue b/frontend/src/views/panel/filter/filterDialog.vue index 0429991a1e..34e93bccf7 100644 --- a/frontend/src/views/panel/filter/filterDialog.vue +++ b/frontend/src/views/panel/filter/filterDialog.vue @@ -181,7 +181,7 @@
- + @@ -297,7 +297,7 @@ export default { datasetParams: [] }, currentElement: null, - allFields: [], + tableFieldsMap: {}, tempTreeDatas: null, showTips: false } @@ -632,7 +632,7 @@ export default { loadField(tableId) { fieldListWithPermission(tableId).then(res => { let datas = res.data - this.allFields = JSON.parse(JSON.stringify(datas)) + this.$set(this.tableFieldsMap, tableId, JSON.parse(JSON.stringify(datas))) if (this.widget && this.widget.filterFieldMethod) { datas = this.widget.filterFieldMethod(datas) } @@ -643,7 +643,7 @@ export default { comLoadField(tableId) { fieldListWithPermission(tableId).then(res => { let datas = res.data - this.allFields = JSON.parse(JSON.stringify(datas)) + this.$set(this.tableFieldsMap, tableId, JSON.parse(JSON.stringify(datas))) if (this.widget && this.widget.filterFieldMethod) { datas = this.widget.filterFieldMethod(datas) } diff --git a/frontend/src/views/panel/filter/filterMain/FilterHead.vue b/frontend/src/views/panel/filter/filterMain/FilterHead.vue index 5b947aa841..21826c658c 100644 --- a/frontend/src/views/panel/filter/filterMain/FilterHead.vue +++ b/frontend/src/views/panel/filter/filterMain/FilterHead.vue @@ -18,8 +18,7 @@ > - - + {{ $t('panel.drag_here') }} @@ -46,9 +45,9 @@ export default { type: Object, default: () => {} }, - allFields: { - type: Array, - default: () => [] + tableFieldsMap: { + type: Object, + default: () => {} }, widget: { type: Object, @@ -63,6 +62,9 @@ export default { computed: { isSortWidget() { return this.widget && this.widget.isSortWidget && this.widget.isSortWidget() + }, + fieldsMap() { + return JSON.parse(JSON.stringify(this.tableFieldsMap)) } }, @@ -74,7 +76,6 @@ export default { }, methods: { onMove(e, originalEvent) { - // this.moveId = e.draggedContext.element.id return true }, end2(e) {}, @@ -88,7 +89,6 @@ export default { }, sortChange(param) { this.element.options.attrs.sort = param - // this.$emit('sort-change', param) } } }