2023-02-11 00:44:00 +08:00
|
|
|
|
<template>
|
|
|
|
|
<ContentWrap>
|
|
|
|
|
<!-- 列表 -->
|
|
|
|
|
<XTable @register="registerTable">
|
|
|
|
|
<template #toolbar_buttons>
|
|
|
|
|
<!-- 操作:新增 -->
|
|
|
|
|
<XButton
|
|
|
|
|
type="primary"
|
|
|
|
|
preIcon="ep:zoom-in"
|
|
|
|
|
:title="t('action.add')"
|
|
|
|
|
v-hasPermi="['system:post:create']"
|
|
|
|
|
@click="openModal('create')"
|
|
|
|
|
/>
|
|
|
|
|
<!-- 操作:导出 -->
|
|
|
|
|
<XButton
|
2023-02-11 15:54:44 +08:00
|
|
|
|
type="primary"
|
|
|
|
|
plain
|
2023-02-11 00:44:00 +08:00
|
|
|
|
preIcon="ep:download"
|
|
|
|
|
:title="t('action.export')"
|
|
|
|
|
v-hasPermi="['system:post:export']"
|
|
|
|
|
@click="exportList('岗位列表.xls')"
|
|
|
|
|
/>
|
|
|
|
|
</template>
|
|
|
|
|
<template #actionbtns_default="{ row }">
|
|
|
|
|
<!-- 操作:修改 -->
|
|
|
|
|
<XTextButton
|
|
|
|
|
preIcon="ep:edit"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
:title="t('action.edit')"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
v-hasPermi="['system:post:update']"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
@click="openModal('update', row?.id)"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
/>
|
|
|
|
|
<!-- 操作:详情 -->
|
|
|
|
|
<XTextButton
|
|
|
|
|
preIcon="ep:view"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
:title="t('action.detail')"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
v-hasPermi="['system:post:query']"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
@click="openModal('detail', row?.id)"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
/>
|
|
|
|
|
<!-- 操作:删除 -->
|
|
|
|
|
<XTextButton
|
|
|
|
|
preIcon="ep:delete"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
:title="t('action.delete')"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
v-hasPermi="['system:post:delete']"
|
2023-02-11 15:54:44 +08:00
|
|
|
|
@click="deleteData(row?.id)"
|
2023-02-11 00:44:00 +08:00
|
|
|
|
/>
|
|
|
|
|
</template>
|
|
|
|
|
</XTable>
|
|
|
|
|
</ContentWrap>
|
2023-02-11 15:54:44 +08:00
|
|
|
|
<!-- 表单弹窗:添加/修改/详情 -->
|
2023-02-11 00:44:00 +08:00
|
|
|
|
<PostForm ref="modalRef" @success="reload()" />
|
|
|
|
|
</template>
|
|
|
|
|
<script setup lang="ts" name="Post">
|
|
|
|
|
import * as PostApi from '@/api/system/post'
|
|
|
|
|
import { allSchemas } from './post.data'
|
2023-02-11 15:54:44 +08:00
|
|
|
|
import PostForm from './form.vue'
|
2023-02-11 00:44:00 +08:00
|
|
|
|
const { t } = useI18n() // 国际化
|
|
|
|
|
|
|
|
|
|
// 列表相关的变量
|
|
|
|
|
const [registerTable, { reload, deleteData, exportList }] = useXTable({
|
2023-02-11 15:54:44 +08:00
|
|
|
|
allSchemas: allSchemas, // 列表配置
|
|
|
|
|
getListApi: PostApi.getPostPageApi, // 加载列表的 API
|
|
|
|
|
deleteApi: PostApi.deletePostApi, // 删除数据的 API
|
|
|
|
|
exportListApi: PostApi.exportPostApi // 导出数据的 API
|
2023-02-11 00:44:00 +08:00
|
|
|
|
})
|
2023-02-11 15:54:44 +08:00
|
|
|
|
|
2023-02-11 00:44:00 +08:00
|
|
|
|
// 表单相关的变量
|
|
|
|
|
const modalRef = ref()
|
2023-02-11 16:32:10 +08:00
|
|
|
|
const openModal = (type: string, id?: number) => {
|
|
|
|
|
modalRef.value.openModal(type, id)
|
2023-02-11 00:44:00 +08:00
|
|
|
|
}
|
|
|
|
|
</script>
|