| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- <template>
- <div class="p-4">
- <BasicTable @register="registerTable" :indexColumnProps="indexColumnProps">
- <template #tableTitle>
- <a-button preIcon="ant-design:plus-outlined" type="primary" @click="handleAdd" style="margin-right: 5px">新增</a-button>
- </template>
- <template #status="{ record, text }">
- <a-tag color="pink" v-if="text == 0">禁用</a-tag>
- <a-tag color="#87d068" v-if="text == 1">正常</a-tag>
- </template>
- <template #action="{ record }">
- <TableAction :actions="getActions(record)" />
- </template>
- </BasicTable>
- <RouteModal @register="registerDrawer" @success="reload" />
- </div>
- </template>
- <script lang="ts" name="monitor-route" setup>
- import { ref } from 'vue';
- import { BasicTable, TableAction } from '/@/components/Table';
- import { useModal } from '/@/components/Modal';
- import { getRouteList, deleteRoute } from './route.api';
- import { columns } from './route.data';
- import RouteModal from './RouteModal.vue';
- import { useMessage } from '/@/hooks/web/useMessage';
- import { useDrawer } from '/@/components/Drawer';
- import { useListPage } from '/@/hooks/system/useListPage';
- const { createMessage } = useMessage();
- const [registerDrawer, { openDrawer }] = useDrawer();
- const checkedKeys = ref<Array<string | number>>([]);
- // 列表页面公共参数、方法
- const { prefixCls, tableContext } = useListPage({
- designScope: 'router-template',
- tableProps: {
- title: '路由列表',
- api: getRouteList,
- useSearchForm: false,
- columns: columns,
- },
- });
- const [registerTable, { reload }, { rowSelection, selectedRowKeys }] = tableContext;
- /**
- * 序号列配置
- */
- const indexColumnProps = {
- dataIndex: 'index',
- width: '15px',
- };
- /**
- * 操作列定义
- * @param record
- */
- function getActions(record) {
- return [
- {
- label: '编辑',
- onClick: handleEdit.bind(null, record),
- },
- {
- label: '删除',
- popConfirm: {
- title: '是否确认删除',
- confirm: handleDelete.bind(null, record),
- },
- },
- ];
- }
- /**
- * 选择事件
- */
- function onSelectChange(selectedRowKeys: (string | number)[]) {
- checkedKeys.value = selectedRowKeys;
- }
- /**
- * 新增事件
- */
- function handleAdd() {
- openDrawer(true, {
- isUpdate: false,
- });
- }
- /**
- * 编辑事件
- */
- function handleEdit(record) {
- openDrawer(true, {
- record,
- isUpdate: true,
- });
- }
- /**
- * 删除事件
- */
- async function handleDelete(record) {
- await deleteRoute({ id: record.id }, reload);
- }
- </script>
|