feat: 在线用户

This commit is contained in:
dap
2024-10-05 13:44:02 +08:00
parent 4ebd4821e2
commit 6e807a3653
4 changed files with 369 additions and 2440 deletions

View File

@@ -1,36 +1,68 @@
<script setup lang="ts">
import { Page } from '@vben/common-ui';
import type { Recordable } from '@vben/types';
import { Card } from 'ant-design-vue';
import { Page, type VbenFormProps } from '@vben/common-ui';
import { useVbenForm } from '#/adapter';
import { Popconfirm } from 'ant-design-vue';
import { querySchema } from './data';
import { useVbenVxeGrid, type VxeGridProps } from '#/adapter';
import { forceLogout, onlineList } from '#/api/monitor/online';
const [QueryForm] = useVbenForm({
// 默认展开
collapsed: false,
// 所有表单项共用,可单独在表单内覆盖
commonConfig: {
// 所有表单项
componentProps: {
class: 'w-full',
import { columns, querySchema } from './data';
const formOptions: VbenFormProps = {
schema: querySchema(),
wrapperClass: 'grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4',
};
const gridOptions: VxeGridProps = {
columns,
height: 'auto',
keepSource: true,
pagerConfig: {},
proxyConfig: {
ajax: {
query: async ({ page }, formValues) => {
return await onlineList({
pageNum: page.currentPage,
pageSize: page.pageSize,
...formValues,
});
},
},
},
schema: querySchema(),
// 是否可展开
showCollapseButton: true,
submitButtonOptions: {
text: '查询',
rowConfig: {
isHover: true,
keyField: 'tokenId',
},
wrapperClass: 'grid-cols-1 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4',
});
round: true,
align: 'center',
showOverflow: true,
};
const [BasicTable, tableApi] = useVbenVxeGrid({ formOptions, gridOptions });
async function handleForceOffline(row: Recordable<any>) {
await forceLogout(row.tokenId);
await tableApi.reload();
}
</script>
<template>
<Page>
<Card>
<QueryForm />
</Card>
<Page :auto-content-height="true">
<BasicTable>
<template #toolbar-actions>
<span class="pl-[7px] text-[16px]">操作日志列表</span>
</template>
<template #action="{ row }">
<Popconfirm
:title="`确认强制下线[${row.userName}]?`"
placement="left"
@confirm="handleForceOffline(row)"
>
<a-button danger size="small" type="link">强制下线</a-button>
</Popconfirm>
</template>
</BasicTable>
</Page>
</template>