Files
xzlz_JczWeb/src/views/backOfficeSystem/systemConfig/system-config-list/index.vue
2025-06-02 20:25:19 +08:00

388 lines
9.8 KiB
Vue

<template>
<div>
<div class="titleBox">
<div class="title">系统配置</div>
<div class="btnBox">
<el-button type="primary" @click="addConfig">
<el-icon><CirclePlus /></el-icon>
<span>新增</span>
</el-button>
</div>
</div>
<div class="searchBox" ref="searchBox">
<el-form :model="listQuery" :inline="true">
<el-form-item label="配置名称">
<el-input
placeholder="请输入配置名称"
v-model="listQuery.configName"
clearable
></el-input>
</el-form-item>
<el-form-item label="配置键">
<el-input
placeholder="请输入配置键"
v-model="listQuery.configKey"
clearable
></el-input>
</el-form-item>
<el-form-item>
<el-button @click="handleFilter"> 查询 </el-button>
<el-button @click="reset()"> 重置 </el-button>
</el-form-item>
</el-form>
</div>
<div class="tabBox">
<el-table
:data="tableData"
border
style="width: 100%"
:height="tableHeight"
:key="keyCount"
>
<el-table-column
sortable
prop="pzmc"
show-overflow-tooltip
label="配置名称"
>
</el-table-column>
<el-table-column
sortable
prop="pzj"
show-overflow-tooltip
label="配置键"
>
</el-table-column>
<el-table-column
sortable
prop="pzz"
show-overflow-tooltip
label="配置值"
>
</el-table-column>
<el-table-column
sortable
prop="xtZhxgrxm"
show-overflow-tooltip
label="修改人姓名"
>
</el-table-column>
<el-table-column sortable prop="bz" show-overflow-tooltip label="备注">
</el-table-column>
<el-table-column sortable prop="xtCjsj" label="采集时间">
<template #default="{ row }">
{{ $filters.dateFilter(row.xtCjsj) }}
</template>
</el-table-column>
<el-table-column label="操作" fixed="right" width="160">
<template #default="{ row }">
<el-button @click="updateDict(row)" size="small">修改</el-button>
<el-popconfirm
confirm-button-text=""
cancel-button-text=""
icon-color="red"
title="确定要删除?"
@confirm="delConfig(row)"
>
<template #reference>
<el-button type="danger" size="small">删除</el-button>
</template>
</el-popconfirm>
</template>
</el-table-column>
</el-table>
<div class="fenye" :style="{ top: tableHeight + 'px' }">
<el-pagination
class="pagination"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="listQuery.page"
:page-sizes="[10, 20, 50, 100]"
:page-size="listQuery.size"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
>
</el-pagination>
</div>
</div>
<div v-if="dialogFormVisible" class="dialog">
<div class="head_box">
<span class="title">{{ isEdit ? "修改" : "新增" }}</span>
<div>
<!-- 修改 -->
<el-button
v-if="isEdit"
type="primary"
size="small"
@click="onSave"
:loading="buttonLoading"
>保存</el-button
>
<!-- 新增 -->
<el-button
v-else
type="primary"
size="small"
@click="onAdd"
:loading="buttonLoading"
>保存</el-button
>
<el-button size="small" @click="closeDialog">关闭</el-button>
</div>
</div>
<el-form
ref="formRef"
class="mosty-from-wrap"
:inline="true"
label-position="top"
:model="dialogForm"
:rules="rules"
>
<el-form-item
class="one"
label="配置名称"
prop="pzmc"
label-width="140px"
>
<el-input
v-model="dialogForm.pzmc"
show-word-limit
maxlength="50"
autocomplete="off"
></el-input>
</el-form-item>
<el-form-item class="one" label="配置键" prop="pzj" label-width="140px">
<el-input
v-model="dialogForm.pzj"
show-word-limit
maxlength="50"
autocomplete="off"
></el-input>
</el-form-item>
<el-form-item
class="one"
label="配置值"
prop="pzz"
required
label-width="140px"
>
<el-input
v-model="dialogForm.pzz"
show-word-limit
maxlength="50"
autocomplete="off"
></el-input>
</el-form-item>
<!-- <el-form-item class="one" prop="xtZxbz" label="状态">
<el-select
style="width: 100%"
v-model="dialogForm.xtZxbz"
placeholder="请选择配置状态"
>
<el-option label="正常" :value="0"></el-option>
<el-option label="注销" :value="1"></el-option>
</el-select>
</el-form-item> -->
<el-form-item class="one" label="备注" label-width="140px">
<el-input
v-model="dialogForm.bz"
:autosize="{ minRows: 2, maxRows: 4 }"
type="textarea"
show-word-limit
maxlength="200"
></el-input>
</el-form-item>
</el-form>
</div>
</div>
</template>
<script setup>
import { ElMessage } from "element-plus";
import { ref, reactive, onMounted, onUnmounted, getCurrentInstance } from "vue";
import {
getSysConfigList,
addSysConfig,
updateSysConfig,
deleteSysConfig
} from "@/api/user-manage";
const { proxy } = getCurrentInstance();
const keyCount = ref(0); //tabel组件刷新值
const searchBox = ref(null); // 搜索盒子
const tableHeight = ref(); // 表格高度
const formRef = ref(null);
const rules = ref({
pzmc: [{ required: true, message: "请填写配置名称", trigger: "blur" }],
pzj: [{ required: true, message: "请填写配置键", trigger: "blur" }],
pzz: [{ required: true, message: "请填写配置值", trigger: "blur" }],
xtZxbz: [{ required: true, message: "请选择配置状态", trigger: "blur" }],
});
//查询参数
const total = ref(0);
const page = ref(1);
const size = ref(20);
const currentRow = ref({});
const listQuery = ref({
page: 1,
size: 20,
dictName: "",
dictCode: "",
xtZxbz: ""
});
const isEdit = ref(true);
const dialogForm = ref({});
const buttonLoading = ref(false);
// 数据相关
const tableData = ref([]);
const dialogFormVisible = ref(false);
const formLabelWidth = "140px";
// 获取数据的方法
const getListData = async () => {
const params = listQuery.value;
params.current = params.page;
const res = await getSysConfigList(params);
tableData.value = res?.records;
total.value = Number(res.total);
};
const reset = () => {
listQuery.value = {
page: 1,
size: 20,
configName: "",
configKey: ""
};
getListData();
};
const handleFilter = () => {
listQuery.value.page = 1;
getListData();
};
getListData();
// 分页相关
/**
* size 改变触发
*/
const handleSizeChange = (currentSize) => {
listQuery.value.size = currentSize;
getListData();
};
/**
* 页码改变触发
*/
const handleCurrentChange = (currentPage) => {
listQuery.value.page = currentPage;
getListData();
};
/**修改字典 */
const updateDict = (row) => {
isEdit.value = true;
dialogForm.value = { ...row };
dialogFormVisible.value = true;
};
const addConfig = (row) => {
isEdit.value = false;
dialogForm.value = {};
dialogFormVisible.value = true;
};
const onSave = () => {
formRef.value.validate((valid) => {
if (!valid) {
ElMessage.error("请完成必填项!");
return false;
}
buttonLoading.value = true;
updateSysConfig({
...dialogForm.value
})
.then((res) => {
dialogFormVisible.value = false;
ElMessage.success("修改成功");
handleFilter();
})
.finally(() => {
buttonLoading.value = false;
});
});
};
const onAdd = () => {
formRef.value.validate((valid) => {
if (!valid) {
ElMessage.error("请完成必填项!");
return false;
}
buttonLoading.value = true;
addSysConfig({
...dialogForm.value
})
.then((res) => {
dialogFormVisible.value = false;
ElMessage.success("新增成功");
handleFilter();
})
.finally(() => {
buttonLoading.value = false;
});
});
};
const delConfig = (row) => {
deleteSysConfig({
id: Number(row.id)
}).then((res) => {
ElMessage.success("删除成功");
handleFilter();
});
};
const closeDialog = () => {
dialogForm.value = {};
dialogFormVisible.value = false;
};
// 表格高度计算
const tabHeightFn = () => {
tableHeight.value = window.innerHeight - searchBox.value.offsetHeight - 240;
};
onMounted(() => {
tabHeightFn();
window.onresize = function () {
tabHeightFn();
};
proxy.mittBus.on("mittFn", (data) => {
keyCount.value = data;
});
});
onUnmounted(() => {
proxy.mittBus.off("mittFn");
});
</script>
<style lang="scss" scoped>
@import "~@/assets/css/layout.scss";
@import "~@/assets/css/element-plus.scss";
.user-manage-container {
.table-header-wrap {
margin-bottom: 22px;
}
::v-deep .avatar {
width: 60px;
height: 60px;
border-radius: 50%;
}
::v-deep .el-tag {
margin-right: 6px;
}
.pagination {
margin-top: 20px;
}
}
</style>