This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
cyber-narrator-cn-ui/src/views/system/Plugin.vue

114 lines
3.5 KiB
Vue
Raw Normal View History

<template>
2024-01-26 17:35:01 +08:00
<div style="height: 100%;" class="plugin-management">
<cn-data-list
ref="dataList"
:tableId="tableId"
v-model:custom-table-title="tools.customTableTitle"
:api="url"
:from="fromRoute.plugin"
:layout="['columnCustomize']"
@search="search"
>
<template #default>
<loading :loading="loading"></loading>
<plugin-table
ref="dataTable"
:api="url"
:isNoData="isNoData"
:custom-table-title="tools.customTableTitle"
:height="mainTableHeight"
:table-data="tableData"
@delete="del"
@edit="edit"
@orderBy="tableDataSort"
@reload="getTableData"
@selectionChange="selectionChange"
/>
</template>
<template #pagination>
<pagination ref="pagination" :page-obj="pageObj" :table-id="tableId" @pageNo='pageNo' @pageSize='pageSize'></pagination>
</template>
</cn-data-list>
</div>
</template>
<script>
import cnDataList from '@/components/table/CnDataList'
import dataListMixin from '@/mixins/data-list'
import pluginTable from '@/components/table/system/PluginTable'
import { api } from '@/utils/api'
import { pluginBasicInfo } from '@/utils/constants'
import axios from 'axios'
export default {
name: 'Plugin',
mixins: [dataListMixin],
components: {
cnDataList,
pluginTable
},
data () {
return {
url: api.pluginList,
blankObject: { // 空白对象
id: '',
name: '',
remark: '',
type: '',
schedule: '',
status: 1
},
tableId: 'pluginTable'
}
},
methods: {
getTableData (params, isAll, isClearType) {
if (isAll) {
this.searchLabel = null
} else if (isClearType) {
this.searchLabel.type = ''// 换新接口需要修改的属性名称
}
if (params) {
this.searchLabel = { ...this.searchLabel, ...params }
}
// this.searchLabel = { ...this.searchLabel, ...this.pageObj }
this.searchLabel = { ...this.searchLabel, jobGroup: 3, pageSize: -1 }
this.isNoData = false
this.toggleLoading(true)
delete this.searchLabel.total
let listUrl = this.url
if (this.listUrl) {
listUrl = this.listUrl
}
// this.searchLabel.category = 'ai_tagging'
axios.get(listUrl, { params: this.searchLabel }).then(response => {
if (response.status === 200) {
const filterDataList = []
for (let i = 0; i < response.data.data.list.length; i++) {
response.data.data.list[i].triggerStatus = response.data.data.list[i].triggerStatus + ''
const basicInfo = pluginBasicInfo.find(plugin => plugin.id === response.data.data.list[i].id)
if (basicInfo) {
filterDataList.push(response.data.data.list[i])
}
}
this.tableData = filterDataList
} else {
console.error(response.data)
this.isNoData = true
if (response.data.message) {
this.$message.error(response.data.message)
} else {
this.$message.error(this.$t('tip.somethingWentWrong'))
}
}
}).finally(() => {
this.toggleLoading(false)
this.isNoData = !this.tableData || this.tableData.length === 0
})
}
},
unmounted () {
this.isNoData = false
}
}
</script>