add
zongzhibin
2024-11-24 46e6fa47d1fd07ab5803fb7732095c2d680b38f6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
<template>
    <div class="sys-config-container">
        <el-card shadow="hover" :body-style="{ paddingBottom: '0' }">
            <TableSearch :search="tb.tableData.search" @search="onSearch" />
        </el-card>
        <el-card class="full-table" shadow="hover" style="margin-top: 5px">
            <Table ref="tableRef" v-bind="tb.tableData" :getData="getData" :exportChangeData="exportChangeData" @sortHeader="onSortHeader" @selectionChange="tableSelection" border>
                <template #command>
                    <el-button type="primary" icon="ele-Plus" @click="openAddConfig" v-auth="'sysConfig:add'"> 新增 </el-button>
 
                    <el-button v-if="state.selectlist.length > 0" type="danger" icon="ele-Delete" @click="bacthDelete" v-auth="'sysConfig:batchDelete'"> 批量删除 </el-button>
                </template>
                <template #sysFlag="scope">
                    <el-tag v-if="scope.row.sysFlag === 1"> 是 </el-tag>
                    <el-tag type="danger" v-else> 否 </el-tag>
                </template>
                <template #remark="scope">
                    <ModifyRecord :data="scope.row" />
                </template>
                <template #action="scope">
                    <el-button icon="ele-Edit" size="small" text type="primary" @click="openEditConfig(scope.row)" v-auth="'sysConfig:update'"> 编辑 </el-button>
                    <el-button icon="ele-Delete" size="small" text type="danger" @click="delConfig(scope.row)" v-auth="'sysConfig:delete'"> 删除 </el-button>
                </template>
            </Table>
        </el-card>
 
        <EditConfig ref="editConfigRef" :title="state.editConfigTitle" :groupList="state.groupList" @updateData="updateData" />
    </div>
</template>
 
<script lang="ts" setup name="sysConfig">
import { onMounted, onUnmounted, reactive, ref, defineAsyncComponent, nextTick } from 'vue';
import { ElMessageBox, ElMessage } from 'element-plus';
import EditConfig from '/@/views/system/config/component/editConfig.vue';
import ModifyRecord from '/@/components/table/modifyRecord.vue';
 
import { getAPI } from '/@/utils/axios-utils';
import { SysConfigApi } from '/@/api-services/api';
import { auth } from '/@/utils/authFunction';
 
// 引入组件
const Table = defineAsyncComponent(() => import('/@/components/table/index.vue'));
const TableSearch = defineAsyncComponent(() => import('/@/components/table/search.vue'));
const editConfigRef = ref<InstanceType<typeof EditConfig>>();
const tableRef = ref<RefType>();
 
const state = reactive({
    editConfigTitle: '',
    selectlist: [] as EmptyObjectType[],
    groupList: [] as Array<String>,
});
 
const tb = reactive<TableDemoState>({
    tableData: {
        // 表头内容(必传,注意格式)
        columns: [
            { prop: 'name', minWidth: 150, label: '配置名称', headerAlign: 'center', sortable: 'custom', isCheck: true, hideCheck: true },
            { prop: 'code', minWidth: 150, label: '配置编号', headerAlign: 'center', toolTip: true, sortable: 'custom', isCheck: true },
            { prop: 'value', minWidth: 150, label: '属性值', headerAlign: 'center', isCheck: true },
            { prop: 'sysFlag', width: 100, label: '内置参数', align: 'center', isCheck: true },
            { prop: 'groupCode', width: 120, label: '分组编号', align: 'center', sortable: 'custom', isCheck: true },
            { prop: 'orderNo', width: 80, label: '排序', align: 'center', sortable: 'custom', isCheck: true },
            { prop: 'remark', width: 100, label: '修改记录', align: 'center', headerAlign: 'center', showOverflowTooltip: true, isCheck: true },
            { prop: 'action', width: 140, label: '操作', type: 'action', align: 'center', isCheck: true, fixed: 'right', hideCheck: true },
        ],
        // 配置项(必传)
        config: {
            isStripe: true, // 是否显示表格斑马纹
            isBorder: false, // 是否显示表格边框
            isSerialNo: true, // 是否显示表格序号
            isSelection: true, // 是否勾选表格多选
            showSelection: auth('sysConfig:batchDelete'), //是否显示表格多选
            pageSize: 200, // 每页条数
            hideExport: false, //是否隐藏导出按钮
            exportFileName: '系统参数', //导出报表的文件名,不填写取应用名称
        },
        // 搜索表单,动态生成(传空数组时,将不显示搜索,type有3种类型:input,date,select)
        search: [
            { label: '配置名称', prop: 'name', placeholder: '搜索配置名称', required: false, type: 'input' },
            { label: '配置编号', prop: 'code', placeholder: '搜索配置编号', required: false, type: 'input' },
            // { label: '创建时间', prop: 'time', placeholder: '请选择', required: false, type: 'date' },
        ],
        param: {},
        defaultSort: {
            prop: 'orderNo',
            order: 'ascending',
        },
    },
});
const getData = (param: any) => {
    return getAPI(SysConfigApi)
        .apiSysConfigPagePost(param)
        .then((res) => {
            return res.data;
        });
};
const exportChangeData = (data: Array<EmptyObjectType>) => {
    data.forEach((item) => {
        item.sysFlag = item.sysFlag == 1 ? '是' : '否';
    });
    return data;
};
// 拖动显示列排序回调
const onSortHeader = (data: object[]) => {
    tb.tableData.columns = data;
};
// 搜索点击时表单回调
const onSearch = (data: EmptyObjectType) => {
    tb.tableData.param = Object.assign({}, tb.tableData.param, { ...data });
    nextTick(() => {
        tableRef.value.pageReset();
    });
};
 
const getGroupList = async () => {
    const res = await getAPI(SysConfigApi).apiSysConfigGroupListGet();
    const groupSearch = {
        label: '分组编号',
        prop: 'groupCode',
        placeholder: '请选择',
        required: false,
        type: 'select',
        options: [],
    } as TableSearchType;
    state.groupList = res.data.result ?? [];
    res.data.result?.forEach((item) => {
        groupSearch.options?.push({ label: item, value: item });
    });
    let group = tb.tableData.search.filter((item) => {
        return item.prop == 'groupCode';
    });
    if (group.length == 0) {
        tb.tableData.search.push(groupSearch);
    } else {
        group[0] = groupSearch;
    }
};
 
//表格多选事件
const tableSelection = (data: EmptyObjectType[]) => {
    state.selectlist = data;
};
 
onMounted(async () => {
    getGroupList();
});
 
// 更新数据
const updateData = () => {
    tableRef.value.handleList();
    getGroupList();
};
 
// 打开新增页面
const openAddConfig = () => {
    state.editConfigTitle = '添加配置';
    editConfigRef.value?.openDialog({ sysFlag: 2, orderNo: 100 });
};
 
// 打开编辑页面
const openEditConfig = (row: any) => {
    state.editConfigTitle = '编辑配置';
    editConfigRef.value?.openDialog(row);
};
 
// 删除
const delConfig = (row: any) => {
    ElMessageBox.confirm(`确定删除配置:【${row.name}】?`, '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning',
    })
        .then(async () => {
            await getAPI(SysConfigApi).apiSysConfigDeletePost({ id: row.id });
            tableRef.value.handleList();
            ElMessage.success('删除成功');
        })
        .catch(() => {});
};
 
//批量删除
const bacthDelete = () => {
    if (state.selectlist.length == 0) return false;
    ElMessageBox.confirm(`确定批量删除【${state.selectlist[0].name}】等${state.selectlist.length}个配置?`, '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning',
    })
        .then(async () => {
            const ids = state.selectlist.map((item) => {
                return item.id;
            });
            var res = await getAPI(SysConfigApi).apiSysConfigBatchDeletePost(ids);
            tableRef.value.pageReset();
            ElMessage.success('删除成功');
        })
        .catch(() => {});
};
</script>