You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
394 lines
10 KiB
394 lines
10 KiB
<template>
|
|
<main-app :showTree="true">
|
|
<template v-slot:tree>
|
|
<el-tree
|
|
:data="deptOptions"
|
|
:props="defaultProps"
|
|
:expand-on-click-node="false"
|
|
:filter-node-method="filterNode"
|
|
ref="tree"
|
|
node-key="id"
|
|
default-expand-all
|
|
highlight-current
|
|
@node-click="handleNodeClick"
|
|
/>
|
|
</template>
|
|
<template v-slot:tablec>
|
|
<el-button
|
|
type="info"
|
|
plain
|
|
icon="el-icon-upload2"
|
|
size="mini"
|
|
@click="handleImport"
|
|
>导入</el-button
|
|
>
|
|
|
|
<el-button
|
|
type="warning"
|
|
plain
|
|
icon="el-icon-download"
|
|
size="mini"
|
|
@click="handleExport"
|
|
>导出</el-button
|
|
>
|
|
|
|
<el-button type="primary" plain icon="el-icon-plus" size="mini"
|
|
>新增资产</el-button
|
|
>
|
|
</template>
|
|
<template v-slot:search>
|
|
<el-form
|
|
:model="formInline"
|
|
ref="queryForm"
|
|
size="small"
|
|
:inline="true"
|
|
label-width="110px"
|
|
>
|
|
<el-form-item label="所属单位:" prop="dwmc">
|
|
<el-input
|
|
v-model="formInline.dwmc"
|
|
placeholder="请输入所属单位"
|
|
></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="电子邮箱后缀:" prop="dzyxhz">
|
|
<el-input
|
|
v-model="formInline.dzyxhz"
|
|
placeholder="请输入电子邮箱后缀"
|
|
></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="新增时间:" prop="time">
|
|
<el-date-picker
|
|
v-model="time"
|
|
format="yyyy-MM-dd HH:mm:ss"
|
|
value-format="yyyy-MM-dd HH:mm:ss"
|
|
type="datetimerange"
|
|
start-placeholder="开始时间"
|
|
end-placeholder="结束时间"
|
|
placeholder="请选择"
|
|
>
|
|
</el-date-picker>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-button
|
|
type="primary"
|
|
icon="el-icon-search"
|
|
size="mini"
|
|
@click="handleQuery"
|
|
>搜索</el-button
|
|
>
|
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
|
|
>重置</el-button
|
|
>
|
|
</el-form-item>
|
|
</el-form>
|
|
</template>
|
|
<template v-slot:table>
|
|
<el-table
|
|
v-loading="loading"
|
|
:data="tableData"
|
|
:height="tabHeader"
|
|
:row-class-name="tableRowClassName"
|
|
:max-height="tabHeader"
|
|
>
|
|
<el-table-column type="index" width="50" label="序号" align="center" />
|
|
<el-table-column
|
|
label="所属单位"
|
|
prop="ssdw"
|
|
align="center"
|
|
show-overflow-tooltip
|
|
/>
|
|
<el-table-column label="电子邮箱后缀" prop="dzyxhz" align="center" />
|
|
<el-table-column
|
|
label="邮件系统供应商"
|
|
prop="yjxtgys"
|
|
align="center"
|
|
show-overflow-tooltip
|
|
>
|
|
</el-table-column>
|
|
<el-table-column label="新增时间" prop="createTime" align="center" />
|
|
<el-table-column
|
|
label="邮件系统状态"
|
|
prop="status"
|
|
class-name="table-status"
|
|
align="center"
|
|
>
|
|
<template slot-scope="scope">
|
|
<span v-if="scope.row.yjxtzc == 1" style="color: #16b771">
|
|
正常
|
|
</span>
|
|
<span v-if="scope.row.yjxtzc == 2" style="color: #f58a0c">
|
|
关停
|
|
</span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column
|
|
label="操作"
|
|
prop="userId"
|
|
class-name="table-operation"
|
|
align="center"
|
|
>
|
|
<template slot-scope="scope">
|
|
<el-button type="primary" size="mini" plain icon="el-icon-view"
|
|
>查看</el-button
|
|
>
|
|
<el-button
|
|
type="warning"
|
|
size="mini"
|
|
plain
|
|
icon="el-icon-edit-outline"
|
|
>修改</el-button
|
|
>
|
|
<el-button
|
|
type="danger"
|
|
size="mini"
|
|
plain
|
|
icon="el-icon-delete"
|
|
@click="handleDel(scope.row.id)"
|
|
>删除</el-button
|
|
>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<pagination
|
|
prev-text="上页"
|
|
next-text="下页"
|
|
v-show="total > 0"
|
|
:total="total"
|
|
:page-sizes="[10, 20, 40, 80, 100]"
|
|
:page.sync="formInline.current"
|
|
:limit.sync="formInline.size"
|
|
@pagination="getList"
|
|
/>
|
|
<!-- 新增修改,详情 -->
|
|
<emailDialog />
|
|
<!-- 资产导入对话框 -->
|
|
<el-dialog
|
|
:title="upload.title"
|
|
:visible.sync="upload.open"
|
|
width="400px"
|
|
append-to-body
|
|
>
|
|
<el-upload
|
|
ref="upload"
|
|
:limit="1"
|
|
accept=".xlsx, .xls"
|
|
:headers="upload.headers"
|
|
:action="upload.url + '?updateSupport=' + upload.updateSupport"
|
|
:disabled="upload.isUploading"
|
|
:on-progress="handleFileUploadProgress"
|
|
:on-success="handleFileSuccess"
|
|
:auto-upload="false"
|
|
drag
|
|
>
|
|
<i class="el-icon-upload"></i>
|
|
<div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
|
|
<div class="el-upload__tip text-center" slot="tip">
|
|
<!-- <div class="el-upload__tip" slot="tip">
|
|
<el-checkbox v-model="upload.updateSupport" /> 是否更新已经存在的用户数据
|
|
</div> -->
|
|
<span>仅允许导入xls、xlsx格式文件。</span>
|
|
<el-link
|
|
type="primary"
|
|
:underline="false"
|
|
style="font-size: 12px; vertical-align: baseline"
|
|
@click="importTemplate"
|
|
>下载模板</el-link
|
|
>
|
|
</div>
|
|
</el-upload>
|
|
<div slot="footer" class="dialog-footer">
|
|
<el-button type="primary" @click="submitFileForm">确 定</el-button>
|
|
<el-button @click="upload.open = false">取 消</el-button>
|
|
</div>
|
|
</el-dialog>
|
|
</template>
|
|
</main-app>
|
|
</template>
|
|
|
|
<script>
|
|
import { getToken } from "@/utils/auth";
|
|
import emailDialog from "@/views/auditPages/components/assetsManagement/emailDialog.vue";
|
|
import {
|
|
assetEmailList,
|
|
deleteAssetEmail,
|
|
schema,
|
|
} from "@/api/auditPagesApi/index";
|
|
export default {
|
|
dicts: ["zc_xtzt"],
|
|
components: { emailDialog },
|
|
data() {
|
|
return {
|
|
// 部门树选项
|
|
deptOptions: undefined,
|
|
defaultProps: {
|
|
children: "children",
|
|
label: "label",
|
|
},
|
|
formInline: {
|
|
dzyxhz: "",
|
|
dwmc: "",
|
|
startTime: "",
|
|
endTime: "",
|
|
current: 1,
|
|
size: 20,
|
|
},
|
|
time: [],
|
|
total: 0,
|
|
tableData: [],
|
|
loading: false,
|
|
tabHeader: 585,
|
|
// 用户导入参数
|
|
upload: {
|
|
// 是否显示弹出层(用户导入)
|
|
open: false,
|
|
// 弹出层标题(用户导入)
|
|
title: "电子邮件资产导入",
|
|
// 是否禁用上传
|
|
isUploading: false,
|
|
// 是否更新已经存在的用户数据
|
|
updateSupport: 0,
|
|
// 设置上传的请求头部
|
|
headers: { Authorization: "Bearer " + getToken() },
|
|
// 上传的地址
|
|
// url: process.env.VUE_APP_BASE_API + "/tc/assetEmail/importData"
|
|
url: location.origin + "/api/tc/assetEmail/importData",
|
|
},
|
|
};
|
|
},
|
|
created() {
|
|
this.getList();
|
|
this.getDeptTree();
|
|
},
|
|
methods: {
|
|
// 导出
|
|
handleExport() {
|
|
this.download(
|
|
"/tc/assetEmail/export",
|
|
{
|
|
...this.formInline,
|
|
},
|
|
`电子邮件资产${new Date().getTime()}.xlsx`
|
|
);
|
|
},
|
|
//删除
|
|
handleDel(id) {
|
|
this.$modal
|
|
.confirm('是否确认删除用户编号为"' + id + '"的数据项?')
|
|
.then(function () {
|
|
return deleteAssetEmail(id);
|
|
})
|
|
.then(() => {
|
|
this.getList();
|
|
this.$modal.msgSuccess("删除成功");
|
|
})
|
|
.catch(() => {});
|
|
},
|
|
// 修改table背景色
|
|
tableRowClassName({ row, rowIndex }) {
|
|
if (rowIndex % 2 !== 0) {
|
|
return "evenNumber-row";
|
|
}
|
|
return "";
|
|
},
|
|
|
|
/** 查询部门下拉树结构 */
|
|
getDeptTree() {
|
|
schema({ type: 3 }).then((response) => {
|
|
this.deptOptions = response.data;
|
|
});
|
|
},
|
|
|
|
/**
|
|
* 重置
|
|
*/
|
|
resetQuery() {
|
|
this.resetForm("queryForm");
|
|
this.formInline.deptId = undefined;
|
|
this.$refs.tree.setCurrentKey(null);
|
|
this.time = [];
|
|
this.formInline.startTime = "";
|
|
this.formInline.endTime = "";
|
|
this.handleQuery();
|
|
},
|
|
// 筛选节点
|
|
filterNode(value, data) {
|
|
if (!value) return true;
|
|
return data.label.indexOf(value) !== -1;
|
|
},
|
|
// 节点单击事件
|
|
handleNodeClick(data) {
|
|
this.formInline.deptId = data.id;
|
|
this.handleQuery();
|
|
},
|
|
/**
|
|
* 搜索
|
|
*/
|
|
handleQuery() {
|
|
this.formInline.current = 1;
|
|
|
|
if (this.time.length > 0) {
|
|
this.formInline.startTime = this.time[0];
|
|
this.formInline.endTime = this.time[1];
|
|
}
|
|
|
|
this.getList();
|
|
},
|
|
/**
|
|
* 获取列表
|
|
*/
|
|
getList() {
|
|
this.loading = true;
|
|
assetEmailList(this.formInline).then((res) => {
|
|
this.loading = false;
|
|
this.total = res.data.total;
|
|
this.tableData = res.data.records;
|
|
});
|
|
},
|
|
// 导入
|
|
handleImport() {
|
|
this.upload.open = true;
|
|
},
|
|
/** 下载模板操作 */
|
|
importTemplate() {
|
|
this.download(
|
|
"/tc/assetEmail/importTemplate",
|
|
{},
|
|
`电子邮件资产导入模板${new Date().getTime()}.xlsx`
|
|
);
|
|
},
|
|
// 文件上传中处理
|
|
handleFileUploadProgress(event, file, fileList) {
|
|
this.upload.isUploading = true;
|
|
},
|
|
// 文件上传成功处理
|
|
handleFileSuccess(response, file, fileList) {
|
|
this.upload.open = false;
|
|
this.upload.isUploading = false;
|
|
this.$refs.upload.clearFiles();
|
|
this.$alert(
|
|
"<div style='overflow: auto;overflow-x: hidden;max-height: 70vh;padding: 10px 20px 0;'>" +
|
|
response.msg +
|
|
"</div>",
|
|
"导入结果",
|
|
{ dangerouslyUseHTMLString: true }
|
|
);
|
|
this.getList();
|
|
},
|
|
// 提交上传文件
|
|
submitFileForm() {
|
|
this.$refs.upload.submit();
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
::v-deep .el-form-item__content {
|
|
width: 280px;
|
|
.el-select,
|
|
.el-date-editor {
|
|
width: 100%;
|
|
}
|
|
}
|
|
</style>
|