Files
tunnel-cloud-front/src/views/system/notice/inform/index.vue
2023-11-06 23:45:22 +08:00

165 lines
4.9 KiB
Vue

<template>
<div>
<el-form :model="queryParams" inline class="query-form" ref="queryInstance">
<el-form-item label="状态" prop="state">
<el-select v-model="queryParams.state" placeholder="请选择状态" clearable filterable>
<el-option label="未读" value="0"/>
<el-option label="已读" value="1"/>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="getList" :icon="Search">搜索</el-button>
<el-button type="primary" @click="handleReset" :icon="Refresh">重置</el-button>
</el-form-item>
</el-form>
<div class="table">
<el-table
:data="list"
row-key="noticeId"
:lazy="true"
v-loading="loading"
>
<el-table-column label="序号" type="index" align="center" width="60"/>
<el-table-column prop="noticeTitle" label="公告标题" align="center"/>
<el-table-column prop="state" label="阅读状态" align="center">
<template #default="scope">
<tag dict-type="read_state" :value="scope.row.state"/>
</template>
</el-table-column>
<el-table-column label="操作" align="center">
<template #default="scope">
<el-button type="text" size="mini" @click="handleViewDetails(scope.row.noticeId)">详情
</el-button>
<popover-delete :name="scope.row.noticeTitle" :type="'通知公告'"
@delete="handleDelete(scope.row.noticeId)"/>
</template>
</el-table-column>
</el-table>
</div>
<paging :current-page="pageInfo.pageNum" :page-size="pageInfo.pageSize" :page-sizes="[10, 20, 30, 40,50]"
:total="total" @changeSize="handleSizeChange" @goPage="handleCurrentChange"/>
<!-- <bell-socket style="display: none" ref="bellSocket"/>-->
<!--详情弹窗-->
<el-dialog v-model="isViewVisited" title="通知公告详情" width="1200px" @close="handleCloseDialog">
<el-form :model="viewForm" label-width="100px">
<el-row>
<el-col :span="24" class="title-block">
<!-- <el-form-item label="公告标题 :" prop="noticeTitle">-->
<el-text class="title">{{ viewForm.noticeTitle }}</el-text>
<!-- </el-form-item>-->
</el-col>
<el-col :span="24">
<!-- <el-form-item label="公告内容 :" prop="noticeContent">-->
<el-text v-if="viewForm.contentType == 'text'">{{ viewForm.noticeContent }}</el-text>
<span v-else v-html="viewForm.noticeContent"></span>
<!-- </el-form-item>-->
</el-col>
</el-row>
</el-form>
</el-dialog>
</div>
</template>
<script setup>
import {ElMessage, ElMessageBox} from "element-plus";
import {getNotifyList, getNotifyDetail,deleteSingleNotify} from "@/api/notice/notify";
import {View, Delete,Search, Refresh} from "@element-plus/icons-vue";
import {useRouter} from "vue-router";
import Paging from "@/components/pagination/index.vue";
const queryParams = reactive({
state: null
})
const router = useRouter()
// const bellSocket = ref()
const loading = ref(true)
const list = ref([])
const total = ref([]);
const isViewVisited = ref(false);
const viewForm = ref();
const notifyId = reactive(router.currentRoute.value.params.queryId)
const pageInfo = reactive({
pageNum: 1,
pageSize: 10
});
onMounted(()=>{
if(notifyId!==undefined){
handleViewDetails(notifyId)
}
})
//重置搜索
const handleReset = () => {
getList()
}
const getList = async () => {
let params = {
cluster: "notice",
...queryParams,
...pageInfo
};
loading.value = true
getNotifyList(params).then(res => {
if (res.code === 1000) {
list.value = res.data.rows;
total.value = res.data.total;
loading.value = false;
} else {
ElMessage.error(res.msg);
}
});
};
//查看详情
const handleViewDetails = (noticeId) => {
getNotifyDetail(noticeId).then(res=>{
// bellSocket.value.searchNotifyList()
isViewVisited.value = true
viewForm.value = res.data
})
}
//关闭详情弹窗
const handleCloseDialog=()=>{
if(notifyId!==undefined){
router.push({path:'/system/notice/inform/index'})
}
isViewVisited.value = false
}
//删除单个消息
const handleDelete = (noticeId) => {
deleteSingleNotify(noticeId).then(res => {
if (res.code === 1000) {
ElMessage.success(res.msg)
getList()
} else {
ElMessage.error(res.msg)
}
})
};
//切换每页显示条数
const handleSizeChange = (val) => {
pageInfo.pageSize = val;
getList();
};
//点击页码进行分页功能
const handleCurrentChange = (val) => {
pageInfo.pageNum = val;
getList();
};
getList()
</script>
<style scoped lang="scss">
.title-block{
text-align: center;
padding-bottom:30px;
.title{
font-size: 28px;
font-weight: bold;
}
}
</style>
<style>
.tox-tinymce-aux {
z-index: 5000 !important;
}
</style>