235 lines
8.1 KiB
Vue
Raw Normal View History

2025-04-19 19:22:39 +08:00
<template>
<div class="app-container">
<!-- <el-form :model="queryParams" ref="queryRef" v-show="showSearch" :inline="true" label-width="68px">
<el-form-item label="角色名称" prop="roleName">
<el-input
v-model="queryParams.roleName"
placeholder="请输入角色名称"
clearable
style="width: 240px"
@keyup.enter="handleQuery"
/>
</el-form-item>
<el-form-item label="权限字符" prop="roleKey">
<el-input
v-model="queryParams.roleKey"
placeholder="请输入权限字符"
clearable
style="width: 240px"
@keyup.enter="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-select
v-model="queryParams.status"
placeholder="角色状态"
clearable
style="width: 240px"
>
<el-option
v-for="dict in sys_normal_disable"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="创建时间" style="width: 308px">
<el-date-picker
v-model="dateRange"
value-format="YYYY-MM-DD"
type="daterange"
range-separator="-"
start-placeholder="开始日期"
end-placeholder="结束日期"
></el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="Plus"
@click="handleAdd"
v-hasPermi="['system:role:add']"
>新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="success"
plain
icon="Edit"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['system:role:edit']"
>修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="danger"
plain
icon="Delete"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['system:role:remove']"
>删除</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="Download"
@click="handleExport"
v-hasPermi="['system:role:export']"
>导出</el-button>
</el-col>
<right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>
</el-row> -->
<!-- 表格数据 -->
<el-table v-loading="loading" :data="applyList" @selection-change="handleSelectionChange">
<!-- <el-table-column type="selection" width="55" align="center" /> -->
<el-table-column label="活动ID" prop="activityId" />
2025-05-13 21:00:16 +08:00
<el-table-column label="活动名称" prop="activityName" :show-overflow-tooltip="true" width="320"/>
<el-table-column label="状态" prop="actStatus" :show-overflow-tooltip="true">
2025-04-19 19:22:39 +08:00
<template #default="scope">
2025-05-13 21:00:16 +08:00
<el-tag :type="scope.row.actStatus === 3 ? 'success' : 'danger'">
{{ scope.row.actStatus === 3 ? '报名中' : '报名结束' }}
2025-04-19 19:22:39 +08:00
</el-tag>
</template>
</el-table-column>
2025-05-13 21:00:16 +08:00
<el-table-column label="排序" prop="sort" width="100"/>
<el-table-column label="自动提报" align="center" key="enableAutoApply">
2025-04-19 19:22:39 +08:00
<template #default="scope">
2025-05-13 21:00:16 +08:00
<el-switch v-model="scope.row.enableAutoApply" @change="handleStatusChange(scope.row)"></el-switch>
<!-- {{ scope.row.memberStatus }} -->
</template>
</el-table-column>
<el-table-column label="操作" prop="sortOrder">
<template #default="scope">
<el-button type="primary" link @click="handleEditSort(scope.row)" style="margin-left:20px;"
:disabled="scope.row.actStatus !== 3">编辑</el-button>
2025-04-19 19:22:39 +08:00
</template>
</el-table-column>
</el-table>
<pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum"
v-model:limit="queryParams.pageSize" @pagination="handlePaginationChange" />
<el-dialog title="修改排序" v-model="sortDialogVisible" width="500px" append-to-body>
<el-form>
<el-form-item label="排序值">
<el-input-number v-model="newSortOrder" :min="0" />
</el-form-item>
</el-form>
<template #footer>
<div class="dialog-footer">
<el-button type="primary" @click="setOrderSortFn"> </el-button>
<el-button @click="sortDialogVisible = false"> </el-button>
</div>
</template>
</el-dialog>
</div>
</template>
<script setup name="Role">
import { listRole } from "@/api/system/role";
2025-05-13 21:00:16 +08:00
import { getApplyList, setOrderSort, setAutoApply } from "@/api/system/apply";
2025-04-19 19:22:39 +08:00
import { onMounted } from "vue";
const router = useRouter();
const { proxy } = getCurrentInstance();
2025-05-14 20:01:29 +08:00
// const { sys_normal_disable } = proxy.useDict("sys_normal_disable");
2025-04-19 19:22:39 +08:00
const applyList = ref([]);
const roleList = ref([]);
const loading = ref(true);
const total = ref(0);
const dateRange = ref([]);
const queryParams = ref({
pageNum: 1,
pageSize: 20
});
onMounted(() => {
getActivityListFn(queryParams.value);
});
//获取团长活动
function getActivityListFn(params) {
loading.value = true;
getApplyList(params).then(res => {
2025-05-13 21:00:16 +08:00
console.log(res);
applyList.value = res.data.records.map(item => {
item._isInit = true;
return item;
});
// 数据加载完成后延迟将_isInit设为false
setTimeout(() => {
applyList.value.forEach(item => {
item._isInit = false;
});
}, 0);
2025-04-19 19:22:39 +08:00
total.value = res.data.total;
loading.value = false;
});
}
function handlePaginationChange({ page, limit }) {
queryParams.value.pageNum = page;
queryParams.value.pageSize = limit;
getActivityListFn(queryParams.value);
}
const sortDialogVisible = ref(false);
const currentSortItem = ref(null);
const newSortOrder = ref(0);
function handleEditSort(row) {
currentSortItem.value = row;
2025-05-13 21:00:16 +08:00
newSortOrder.value = row.sort;
2025-04-19 19:22:39 +08:00
sortDialogVisible.value = true;
}
2025-05-13 21:00:16 +08:00
/** 自动提报状态修改 */
function handleStatusChange(row) {
if (row._isInit) return;
console.log('用户状态修改', row.id, row.memberStatus)
const params = {
activityId: row.activityId,
enableAutoApply: row.enableAutoApply
}
setAutoApply(params).then(res => {
if (res.code === 0) {
proxy.$modal.msgSuccess('修改成功');
} else {
proxy.$modal.msgError('修改失败,请重试');
}
}).catch(error => {
console.error('请求失败', error);
proxy.$modal.msgError('设置失败');
row.enableAutoApply = !row.enableAutoApply
});
};
2025-04-19 19:22:39 +08:00
function setOrderSortFn() {
const params = {
2025-05-13 21:00:16 +08:00
activityId: currentSortItem.value.activityId,
sort: newSortOrder.value
2025-04-19 19:22:39 +08:00
}
setOrderSort(params).then(res => {
// 更新本地列表中的排序值
2025-05-13 21:00:16 +08:00
const index = applyList.value.findIndex(item => item.activityId === currentSortItem.value.activityId);
2025-04-19 19:22:39 +08:00
if (index !== -1) {
2025-05-13 21:00:16 +08:00
applyList.value[index].sort = newSortOrder.value;
2025-04-19 19:22:39 +08:00
}
sortDialogVisible.value = false;
proxy.$modal.msgSuccess('修改成功');
});
}
</script>