修复用户产线和工厂区域分页
This commit is contained in:
@@ -25,11 +25,12 @@
|
||||
:loading="loading"
|
||||
:toolbar-buttons="toolbarButtons"
|
||||
:row-buttons="rowButtons"
|
||||
:pagination="null"
|
||||
:pagination="pagination"
|
||||
:table-attrs="tableAttrs"
|
||||
help-url="/help/factory-area"
|
||||
:help-text="$t(ckey('help'))"
|
||||
auto-height
|
||||
@page-change="onPageChange"
|
||||
@selection-change="onSelect"
|
||||
>
|
||||
</page-table>
|
||||
@@ -82,6 +83,7 @@ export default {
|
||||
editId: '',
|
||||
handleType: 'create',
|
||||
search: { code: '', name: '' },
|
||||
pagination: { current: 1, size: 10, total: 0 },
|
||||
tableAttrs: { defaultExpandAll: true, treeProps: { children: 'children', hasChildren: 'hasChildren' } },
|
||||
formData: { code: '', name: '', parent_id: '', remark: '' },
|
||||
rules: {
|
||||
@@ -138,11 +140,22 @@ export default {
|
||||
return ''
|
||||
},
|
||||
normalizeResponse (res) {
|
||||
const data = res && res.data !== undefined ? res.data : res
|
||||
if (Array.isArray(data)) return { list: data, total: data.length }
|
||||
if (data && Array.isArray(data.list)) return { list: data.list, total: Number(data.count || data.total || data.list.length) }
|
||||
if (data && Array.isArray(data.data)) return { list: data.data, total: Number(data.count || data.total || data.data.length) }
|
||||
if (data && data.data && Array.isArray(data.data.data)) return { list: data.data.data, total: Number(data.data.count || data.data.total || data.data.data.length) }
|
||||
const getTotal = (source, fallback) => {
|
||||
if (!source) return fallback
|
||||
const total = source.count ?? source.total ?? source.total_count ?? source.record_count
|
||||
const value = Number(total)
|
||||
return Number.isNaN(value) ? fallback : value
|
||||
}
|
||||
const containers = [res, res && res.data, res && res.data && res.data.data].filter(Boolean)
|
||||
for (const item of containers) {
|
||||
if (Array.isArray(item)) {
|
||||
return { list: item, total: getTotal(res, item.length) }
|
||||
}
|
||||
const list = item.data || item.list || item.rows || item.records || item.items
|
||||
if (Array.isArray(list)) {
|
||||
return { list, total: getTotal(item, getTotal(res, list.length)) }
|
||||
}
|
||||
}
|
||||
return { list: [], total: 0 }
|
||||
},
|
||||
normalizeNode (row, level = 0) {
|
||||
@@ -185,19 +198,31 @@ export default {
|
||||
async fetchData () {
|
||||
this.loading = true
|
||||
try {
|
||||
const res = await getFactoryAreaList({ ...this.search, page_no: 1, page_size: 10000 })
|
||||
const res = await getFactoryAreaList({
|
||||
...this.search,
|
||||
page_no: this.pagination.current,
|
||||
page_size: this.pagination.size
|
||||
})
|
||||
const data = this.normalizeResponse(res)
|
||||
this.rawAreaData = data.list
|
||||
this.tableData = this.buildTree(data.list)
|
||||
this.pagination.total = data.total
|
||||
} finally {
|
||||
this.loading = false
|
||||
}
|
||||
},
|
||||
onSearch () {
|
||||
this.pagination.current = 1
|
||||
this.fetchData()
|
||||
},
|
||||
onReset () {
|
||||
this.search = { code: '', name: '' }
|
||||
this.pagination.current = 1
|
||||
this.fetchData()
|
||||
},
|
||||
onPageChange (page) {
|
||||
this.pagination.current = page.current
|
||||
this.pagination.size = page.size
|
||||
this.fetchData()
|
||||
},
|
||||
onSelect (rows) {
|
||||
@@ -251,6 +276,7 @@ export default {
|
||||
const ok = await this.confirmAction(this.key('confirm_delete'), () => deleteFactoryArea({ id: [this.getId(row)] }))
|
||||
if (!ok) return
|
||||
this.$message.success(this.$t(this.key('operation_success')))
|
||||
this.pagination.current = Math.min(this.pagination.current, Math.ceil((this.pagination.total - 1) / this.pagination.size) || 1)
|
||||
this.fetchData()
|
||||
},
|
||||
async handleExport () {
|
||||
|
||||
@@ -176,11 +176,22 @@ export default {
|
||||
},
|
||||
methods: {
|
||||
normalizeResponse (res) {
|
||||
const data = res && res.data !== undefined ? res.data : res
|
||||
if (Array.isArray(data)) return { list: data, total: data.length }
|
||||
if (data && Array.isArray(data.list)) return { list: data.list, total: Number(data.count || data.total || data.list.length) }
|
||||
if (data && Array.isArray(data.data)) return { list: data.data, total: Number(data.count || data.total || data.data.length) }
|
||||
if (data && data.data && Array.isArray(data.data.data)) return { list: data.data.data, total: Number(data.data.count || data.data.total || data.data.data.length) }
|
||||
const getTotal = (source, fallback) => {
|
||||
if (!source) return fallback
|
||||
const total = source.count ?? source.total ?? source.total_count ?? source.record_count
|
||||
const value = Number(total)
|
||||
return Number.isNaN(value) ? fallback : value
|
||||
}
|
||||
const containers = [res, res && res.data, res && res.data && res.data.data].filter(Boolean)
|
||||
for (const item of containers) {
|
||||
if (Array.isArray(item)) {
|
||||
return { list: item, total: getTotal(res, item.length) }
|
||||
}
|
||||
const list = item.data || item.list || item.rows || item.records || item.items
|
||||
if (Array.isArray(list)) {
|
||||
return { list, total: getTotal(item, getTotal(res, list.length)) }
|
||||
}
|
||||
}
|
||||
return { list: [], total: 0 }
|
||||
},
|
||||
async initAreaOptions () {
|
||||
|
||||
@@ -319,11 +319,22 @@ export default {
|
||||
} catch { /* 忽略 */ }
|
||||
},
|
||||
normalizeResponse (res) {
|
||||
const data = res && res.data !== undefined ? res.data : res
|
||||
if (Array.isArray(data)) return { list: data, total: data.length }
|
||||
if (data && Array.isArray(data.list)) return { list: data.list, total: Number(data.count || data.total || data.list.length) }
|
||||
if (data && Array.isArray(data.data)) return { list: data.data, total: Number(data.count || data.total || data.data.length) }
|
||||
if (data && data.data && Array.isArray(data.data.data)) return { list: data.data.data, total: Number(data.data.count || data.data.total || data.data.data.length) }
|
||||
const getTotal = (source, fallback) => {
|
||||
if (!source) return fallback
|
||||
const total = source.count ?? source.total ?? source.total_count ?? source.record_count
|
||||
const value = Number(total)
|
||||
return Number.isNaN(value) ? fallback : value
|
||||
}
|
||||
const containers = [res, res && res.data, res && res.data && res.data.data].filter(Boolean)
|
||||
for (const item of containers) {
|
||||
if (Array.isArray(item)) {
|
||||
return { list: item, total: getTotal(res, item.length) }
|
||||
}
|
||||
const list = item.data || item.list || item.rows || item.records || item.items
|
||||
if (Array.isArray(list)) {
|
||||
return { list, total: getTotal(item, getTotal(res, list.length)) }
|
||||
}
|
||||
}
|
||||
return { list: [], total: 0 }
|
||||
},
|
||||
async fetchData () {
|
||||
|
||||
Reference in New Issue
Block a user