feat: sensitiveword

This commit is contained in:
xingyu4j 2022-11-22 13:34:17 +08:00
parent 407ac853cb
commit 5da9ae25fe
4 changed files with 137 additions and 157 deletions

View File

@ -1,8 +1,27 @@
import request from '@/config/axios' import request from '@/config/axios'
import type { SensitiveWordVO } from './types'
export type SensitiveWordVO = {
id: number
name: string
status: number
description: string
tags: string
type: number
createTime: string
}
export interface SensitiveWordPageReqVO extends PageParam {
name?: string
status?: number
}
export interface SensitiveWordExportReqVO {
name?: string
status?: number
}
// 查询敏感词列表 // 查询敏感词列表
export const getSensitiveWordPageApi = (params) => { export const getSensitiveWordPageApi = (params: SensitiveWordPageReqVO) => {
return request.get({ url: '/system/sensitive-word/page', params }) return request.get({ url: '/system/sensitive-word/page', params })
} }
@ -27,7 +46,7 @@ export const deleteSensitiveWordApi = (id: number) => {
} }
// 导出敏感词 // 导出敏感词
export const exportSensitiveWordApi = (params) => { export const exportSensitiveWordApi = (params: SensitiveWordExportReqVO) => {
return request.download({ url: '/system/sensitive-word/export-excel', params }) return request.download({ url: '/system/sensitive-word/export-excel', params })
} }

View File

@ -1,9 +0,0 @@
export type SensitiveWordVO = {
id: number
name: string
status: number
description: string
tags: string
type: number
createTime: string
}

View File

@ -1,40 +1,24 @@
<template> <template>
<!-- 搜索工作区 -->
<ContentWrap> <ContentWrap>
<Search :schema="allSchemas.searchSchema" @search="setSearchParams" @reset="setSearchParams" />
</ContentWrap>
<ContentWrap>
<!-- 操作工具栏 -->
<div class="mb-10px">
<XButton
type="primary"
preIcon="ep:zoom-in"
:title="t('action.add')"
v-hasPermi="['system:sensitive-word:create']"
@click="handleCreate()"
/>
<XButton
type="warning"
preIcon="ep:download"
:title="t('action.export')"
v-hasPermi="['system:sensitive-word:export']"
@click="exportList('敏感词数据.xls')"
/>
</div>
<!-- 列表 --> <!-- 列表 -->
<Table <vxe-grid ref="xGrid" v-bind="gridOptions" class="xtable-scrollbar">
:columns="allSchemas.tableColumns" <template #toolbar_buttons>
:selection="false" <XButton
:data="tableObject.tableList" type="primary"
:loading="tableObject.loading" preIcon="ep:zoom-in"
:pagination="{ :title="t('action.add')"
total: tableObject.total v-hasPermi="['system:sensitive-word:create']"
}" @click="handleCreate()"
v-model:pageSize="tableObject.pageSize" />
v-model:currentPage="tableObject.currentPage" <XButton
@register="register" type="warning"
> preIcon="ep:download"
<template #tags="{ row }"> :title="t('action.export')"
v-hasPermi="['system:sensitive-word:export']"
@click="handleExport()"
/>
</template>
<template #tags_default="{ row }">
<el-tag <el-tag
:disable-transitions="true" :disable-transitions="true"
:key="index" :key="index"
@ -44,13 +28,7 @@
{{ tag }} {{ tag }}
</el-tag> </el-tag>
</template> </template>
<template #status="{ row }"> <template #actionbtns_default="{ row }">
<DictTag :type="DICT_TYPE.COMMON_STATUS" :value="row.status" />
</template>
<template #createTime="{ row }">
<span>{{ dayjs(row.createTime).format('YYYY-MM-DD HH:mm:ss') }}</span>
</template>
<template #action="{ row }">
<!-- 操作修改 --> <!-- 操作修改 -->
<XTextButton <XTextButton
preIcon="ep:edit" preIcon="ep:edit"
@ -63,17 +41,17 @@
preIcon="ep:view" preIcon="ep:view"
:title="t('action.detail')" :title="t('action.detail')"
v-hasPermi="['system:sensitive-word:update']" v-hasPermi="['system:sensitive-word:update']"
@click="handleDetail(row)" @click="handleDetail(row.id)"
/> />
<!-- 操作删除 --> <!-- 操作删除 -->
<XTextButton <XTextButton
preIcon="ep:delete" preIcon="ep:delete"
:title="t('action.del')" :title="t('action.del')"
v-hasPermi="['system:sensitive-word:delete']" v-hasPermi="['system:sensitive-word:delete']"
@click="delList(row.id, false)" @click="handleDelete(row.id)"
/> />
</template> </template>
</Table> </vxe-grid>
</ContentWrap> </ContentWrap>
<XModal v-model="dialogVisible" :title="dialogTitle"> <XModal v-model="dialogVisible" :title="dialogTitle">
@ -94,7 +72,7 @@
<Descriptions <Descriptions
v-if="actionType === 'detail'" v-if="actionType === 'detail'"
:schema="allSchemas.detailSchema" :schema="allSchemas.detailSchema"
:data="detailRef" :data="detailData"
/> />
<!-- 操作按钮 --> <!-- 操作按钮 -->
<template #footer> <template #footer>
@ -113,24 +91,33 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { onMounted, ref, unref } from 'vue' import { onMounted, ref, unref } from 'vue'
import dayjs from 'dayjs'
import { ElMessage, ElTag, ElSelect, ElOption } from 'element-plus'
import { DICT_TYPE } from '@/utils/dict'
import { useTable } from '@/hooks/web/useTable'
import { useI18n } from '@/hooks/web/useI18n' import { useI18n } from '@/hooks/web/useI18n'
import { useMessage } from '@/hooks/web/useMessage'
import { useVxeGrid } from '@/hooks/web/useVxeGrid'
import { VxeGridInstance } from 'vxe-table'
import { FormExpose } from '@/components/Form' import { FormExpose } from '@/components/Form'
import type { SensitiveWordVO } from '@/api/system/sensitiveWord/types' import { ElTag, ElSelect, ElOption } from 'element-plus'
import { rules, allSchemas } from './sensitiveWord.data'
import * as SensitiveWordApi from '@/api/system/sensitiveWord' import * as SensitiveWordApi from '@/api/system/sensitiveWord'
const { t } = useI18n() // import { rules, allSchemas } from './sensitiveWord.data'
// ========== ========== const { t } = useI18n() //
const { register, tableObject, methods } = useTable<SensitiveWordVO>({ const message = useMessage() //
getListApi: SensitiveWordApi.getSensitiveWordPageApi, //
delListApi: SensitiveWordApi.deleteSensitiveWordApi, const xGrid = ref<VxeGridInstance>() // Grid Ref
exportListApi: SensitiveWordApi.exportSensitiveWordApi const { gridOptions, getList, deleteData, exportList } =
}) useVxeGrid<SensitiveWordApi.SensitiveWordVO>({
const { getList, setSearchParams, delList, exportList } = methods allSchemas: allSchemas,
getListApi: SensitiveWordApi.getSensitiveWordPageApi,
deleteApi: SensitiveWordApi.deleteSensitiveWordApi,
exportListApi: SensitiveWordApi.exportSensitiveWordApi
})
const actionLoading = ref(false) //
const actionType = ref('') //
const dialogVisible = ref(false) //
const dialogTitle = ref('edit') //
const formRef = ref<FormExpose>() // Ref
const detailData = ref() // Ref
const tags = ref()
// //
const tagsOptions = ref() const tagsOptions = ref()
@ -138,13 +125,7 @@ const getTags = async () => {
const res = await SensitiveWordApi.getSensitiveWordTagsApi() const res = await SensitiveWordApi.getSensitiveWordTagsApi()
tagsOptions.value = res tagsOptions.value = res
} }
// ========== CRUD ==========
const actionLoading = ref(false) //
const actionType = ref('') //
const dialogVisible = ref(false) //
const dialogTitle = ref('edit') //
const formRef = ref<FormExpose>() // Ref
const tags = ref()
// //
const setDialogTile = (type: string) => { const setDialogTile = (type: string) => {
dialogTitle.value = t('action.' + type) dialogTitle.value = t('action.' + type)
@ -158,6 +139,11 @@ const handleCreate = () => {
setDialogTile('create') setDialogTile('create')
} }
//
const handleExport = async () => {
await exportList(xGrid, '敏感词数据.xls')
}
// //
const handleUpdate = async (rowId: number) => { const handleUpdate = async (rowId: number) => {
setDialogTile('update') setDialogTile('update')
@ -167,6 +153,18 @@ const handleUpdate = async (rowId: number) => {
unref(formRef)?.setValues(res) unref(formRef)?.setValues(res)
} }
//
const handleDetail = async (rowId: number) => {
setDialogTile('detail')
const res = await SensitiveWordApi.getSensitiveWordApi(rowId)
detailData.value = res
}
//
const handleDelete = async (rowId: number) => {
await deleteData(xGrid, rowId)
}
// //
const submitForm = async () => { const submitForm = async () => {
const elForm = unref(formRef)?.getElFormRef() const elForm = unref(formRef)?.getElFormRef()
@ -176,38 +174,27 @@ const submitForm = async () => {
actionLoading.value = true actionLoading.value = true
// //
try { try {
const data = unref(formRef)?.formModel as SensitiveWordVO const data = unref(formRef)?.formModel as SensitiveWordApi.SensitiveWordVO
data.tags = tags.value data.tags = tags.value
if (actionType.value === 'create') { if (actionType.value === 'create') {
await SensitiveWordApi.createSensitiveWordApi(data) await SensitiveWordApi.createSensitiveWordApi(data)
ElMessage.success(t('common.createSuccess')) message.success(t('common.createSuccess'))
} else { } else {
await SensitiveWordApi.updateSensitiveWordApi(data) await SensitiveWordApi.updateSensitiveWordApi(data)
ElMessage.success(t('common.updateSuccess')) message.success(t('common.updateSuccess'))
} }
//
dialogVisible.value = false dialogVisible.value = false
await getList()
} finally { } finally {
actionLoading.value = false actionLoading.value = false
//
await getList(xGrid)
} }
} }
}) })
} }
// ========== ==========
const detailRef = ref() // Ref
//
const handleDetail = async (row: SensitiveWordVO) => {
//
detailRef.value = row
setDialogTile('detail')
}
// ========== ========== // ========== ==========
onMounted(async () => { onMounted(async () => {
await getTags() await getTags()
await getList()
}) })
</script> </script>

View File

@ -1,8 +1,8 @@
import { reactive } from 'vue' import { reactive } from 'vue'
import { useI18n } from '@/hooks/web/useI18n' import { useI18n } from '@/hooks/web/useI18n'
import { required } from '@/utils/formRules' import { required } from '@/utils/formRules'
import { CrudSchema, useCrudSchemas } from '@/hooks/web/useCrudSchemas'
import { DICT_TYPE } from '@/utils/dict' import { DICT_TYPE } from '@/utils/dict'
import { VxeCrudSchema, useVxeCrudSchemas } from '@/hooks/web/useVxeCrudSchemas'
const { t } = useI18n() // 国际化 const { t } = useI18n() // 国际化
// 表单校验 // 表单校验
@ -12,69 +12,52 @@ export const rules = reactive({
}) })
// CrudSchema // CrudSchema
const crudSchemas = reactive<CrudSchema[]>([ const crudSchemas = reactive<VxeCrudSchema>({
{ primaryKey: 'id',
label: t('common.index'), primaryType: 'seq',
field: 'id', action: true,
type: 'index', columns: [
form: { {
show: false title: '敏感词',
field: 'name',
isSearch: true
}, },
detail: { {
show: false title: '标签',
} field: 'tags',
}, table: {
{ slots: {
label: '敏感词', default: 'tags_default'
field: 'name', }
search: {
show: true
}
},
{
label: '标签',
field: 'tags'
},
{
label: t('common.status'),
field: 'status',
dictType: DICT_TYPE.COMMON_STATUS,
dictClass: 'number',
search: {
show: true
}
},
{
label: '描述',
field: 'description',
form: {
component: 'Input',
componentProps: {
type: 'textarea',
rows: 4
},
colProps: {
span: 24
} }
}
},
{
label: t('common.createTime'),
field: 'createTime',
form: {
show: false
}
},
{
label: t('table.action'),
field: 'action',
width: '240px',
form: {
show: false
}, },
detail: { {
show: false title: t('common.status'),
field: 'status',
dictType: DICT_TYPE.COMMON_STATUS,
dictClass: 'number',
isSearch: true
},
{
title: '描述',
field: 'description',
form: {
component: 'Input',
componentProps: {
type: 'textarea',
rows: 4
},
colProps: {
span: 24
}
}
},
{
title: t('common.createTime'),
field: 'createTime',
formatter: 'formatDate',
isForm: false
} }
} ]
]) })
export const { allSchemas } = useCrudSchemas(crudSchemas) export const { allSchemas } = useVxeCrudSchemas(crudSchemas)