提交 fc43849c 作者: 郁骅焌

字典管理修改

上级 23274ff3
......@@ -2,7 +2,7 @@
// @ts-nocheck
// Generated by unplugin-vue-components
// Read more: https://github.com/vuejs/core/pull/3399
export {}
export { }
/* prettier-ignore */
declare module 'vue' {
......@@ -21,7 +21,6 @@ declare module 'vue' {
CarouselVertical: typeof import('./../../../src/views/vab/carousel/vabAutoComponents/CarouselVertical.vue')['default']
CommonProperty: typeof import('./../../../src/views/other/workflow/vabAutoComponents/propertySetting/CommonProperty.vue')['default']
Control: typeof import('./../../../src/views/other/workflow/vabAutoComponents/lFComponents/Control.vue')['default']
copy: typeof import('./../../../src/views/system/roleManagement/vabAutoComponents/RoleManagementEdit2 copy.vue')['default']
DataDialog: typeof import('./../../../src/views/other/workflow/vabAutoComponents/lFComponents/DataDialog.vue')['default']
DataScreenBottom: typeof import('./../../../src/views/index/vabAutoComponents/DataScreenBottom.vue')['default']
DataScreenHeader: typeof import('./../../../src/views/index/vabAutoComponents/DataScreenHeader.vue')['default']
......@@ -36,7 +35,9 @@ declare module 'vue' {
DepartmentManagementEdit: typeof import('./../../../src/views/setting/departmentManagement/vabAutoComponents/DepartmentManagementEdit.vue')['default']
DepartmentManagementEdit2: typeof import('./../../../src/views/system/departmentManagement/vabAutoComponents/DepartmentManagementEdit2.vue')['default']
Develop: typeof import('./../../../src/views/index/vabAutoComponents/Develop.vue')['default']
DictionaryDataManagemenetEdit: typeof import('../../../src/views/system/dictionaryManagement/vabAutoComponents/DictionaryDataManagementEdit.vue')['default']
DictionaryManagementEdit: typeof import('./../../../src/views/setting/dictionaryManagement/vabAutoComponents/DictionaryManagementEdit.vue')['default']
DictionaryManagementEdit2: typeof import('./../../../src/views/system/dictionaryManagement/vabAutoComponents/DictionaryManagementEdit2.vue')['default']
DictTag: typeof import('./../../components/DictTag/index.vue')['default']
DrawerBasicUsage: typeof import('./../../../src/views/vab/drawer/vabAutoComponents/DrawerBasicUsage.vue')['default']
DrawerCustomizationContent: typeof import('./../../../src/views/vab/drawer/vabAutoComponents/DrawerCustomizationContent.vue')['default']
......
import request from '/@/utils/request'
// 查询字典数据列表
export function getList(params?: any) {
return request({
url: '/system/dict/data/list',
method: 'get',
params,
})
}
// 新增字典数据
export const doAdd = (data: any) => {
return request({
url: '/system/dict/data',
method: 'post',
data,
})
}
// 修改字典数据
export const doEdit = (data: any) => {
return request({
url: '/system/dict/data',
method: 'put',
data,
})
}
// 删除字典数据
export const doDelete = (dictCode: any) => {
return request({
url: `/system/dict/data/${dictCode}`,
method: 'delete',
})
}
// 查询字典数据详细
export function getData(dictCode: any) {
return request({
url: `/system/dict/data/${dictCode}`,
method: 'get',
})
}
// 根据字典类型查询字典数据信息
export function getDicts(dictType: any) {
return request({
url: `/system/dict/data/type/${dictType}`,
method: 'get',
})
}
import request from '/@/utils/request'
export function getTree(params?: any) {
// 查询字典类型列表
export function getList(params?: any) {
return request({
url: '/dictionaryManagement/getTree',
url: '/system/dict/type/list',
method: 'get',
params,
})
}
export function getList(params?: any) {
// 新增字典类型
export const doAdd = (data: any) => {
return request({
url: '/dictionaryManagement/getList',
method: 'get',
params,
url: '/system/dict/type',
method: 'post',
data,
})
}
// 修改字典类型
export const doEdit = (data: any) => {
return request({
url: '/dictionaryManagement/doEdit',
method: 'post',
url: '/system/dict/type',
method: 'put',
data,
})
}
export const doDelete = (data: any) => {
// 删除字典类型
export const doDelete = (dictId: any) => {
return request({
url: '/dictionaryManagement/doDelete',
method: 'post',
data,
url: `/system/dict/type/${dictId}`,
method: 'delete',
})
}
// 查询字典类型详细
export function getDictType(dictId: any) {
return request({
url: `/system/dict/type/${dictId}`,
method: 'get',
})
}
// 刷新字典缓存
export function refreshCache() {
return request({
url: '/system/dict/type/refreshCache',
method: 'delete',
})
}
// 获取字典选择框列表
export function optionselect() {
return request({
url: '/system/dict/type/optionselect',
method: 'get',
})
}
......@@ -272,6 +272,19 @@ export const customRoutes: VabRouteRecord[] = [
activeMenu: '/system/roleManagement',
},
},
{
path: 'dictionaryManagement/dictData/:dictId',
component: '/@/views/system/dictionaryManagement/dictData.vue',
name: 'DictData',
meta: {
hidden: true,
icon: 'book-2-line',
title: '字典数据',
noKeepAlive: true,
dynamicNewTab: true,
activeMenu: '/system/dictionaryManagement',
},
},
],
},
]
......
......@@ -14,7 +14,8 @@ const useDictStore = defineStore('dict', {
return this.dict[i].value
}
}
} catch (e) {
} catch (error) {
console.log(error)
return null
}
},
......
<template>
<div class="dictionaryManagement-dictData-container auto-height-container" :class="{ 'fullscreen-container': isFullscreen }">
<vab-query-form>
<vab-query-form-top-panel>
<el-form ref="queryRef" inline label-width="70px" :model="queryForm" @submit.prevent>
<el-form-item label="字典名称" prop="dictType">
<el-select v-model="queryForm.dictType" style="width: 200px">
<el-option v-for="item in typeOptions" :key="item.dictId" :label="item.dictName" :value="item.dictType" />
</el-select>
</el-form-item>
<el-form-item v-show="!fold" label="字典标签" prop="dictLabel">
<el-input
v-model="queryForm.dictLabel"
clearable
placeholder="请输入字典标签"
style="width: 200px"
@keyup.enter="handleQuery"
/>
</el-form-item>
<el-form-item v-show="!fold" label="状态" prop="status">
<el-select v-model="queryForm.status" clearable placeholder="数据状态" style="width: 200px">
<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>
<el-button icon="Search" :loading="listLoading" native-type="submit" type="primary" @click="handleQuery">查询</el-button>
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
<el-button class="hidden-xs-only" text type="primary" @click="handleFold">
<span v-if="fold">展开</span>
<span v-else>合并</span>
<vab-icon class="vab-dropdown" :class="{ 'vab-dropdown-active': fold }" icon="arrow-up-s-line" />
</el-button>
</el-form-item>
</el-form>
</vab-query-form-top-panel>
<vab-query-form-left-panel>
<el-button icon="Plus" type="primary" @click="handleAdd">添加</el-button>
<el-button icon="Delete" type="danger" @click="handleDelete">删除</el-button>
<el-button icon="Upload" plain type="warning" @click="handleExport">导出</el-button>
<el-button icon="Close" plain type="warning" @click="handleClose">关闭</el-button>
</vab-query-form-left-panel>
<vab-query-form-right-panel>
<div class="custom-table-right-tools">
<el-button @click="handleQuery">
<vab-icon icon="refresh-line" />
</el-button>
<el-button @click="clickFullScreen">
<vab-icon :icon="isFullscreen ? 'fullscreen-exit-fill' : 'fullscreen-fill'" />
</el-button>
<el-popover popper-class="custom-table-checkbox">
<template #reference>
<el-button>
<vab-icon icon="settings-line" />
</el-button>
</template>
<vab-draggable v-model="columns" :animation="600" target=".el-checkbox-group">
<el-checkbox-group v-model="checkList">
<el-checkbox
v-for="item in columns"
:key="item.label"
:disabled="item.disableCheck"
:label="item.label"
:value="item.label"
>
{{ item.label }}
</el-checkbox>
</el-checkbox-group>
</vab-draggable>
</el-popover>
</div>
</vab-query-form-right-panel>
</vab-query-form>
<el-table ref="tableRef" v-loading="listLoading" border :data="list" @selection-change="setSelectRows">
<el-table-column align="center" type="selection" width="50" />
<el-table-column
v-for="(item, index) in finallyColumns"
:key="index"
align="center"
:fixed="item.fixed"
:label="item.label"
:min-width="item.minWidth || 160"
:prop="item.prop"
show-overflow-tooltip
:sortable="item.sortable"
>
<template #default="scope">
<span v-if="item.label === '状态'">
<dict-tag :options="sys_normal_disable" :value="scope.row.status" />
</span>
<span v-else>{{ scope.row[item.prop] }}</span>
</template>
</el-table-column>
<el-table-column align="center" fixed="right" label="操作" min-width="160">
<template #default="scope">
<el-button icon="Edit" link type="primary" @click="handleUpdate(scope.row)">修改</el-button>
<el-button icon="Delete" link type="primary" @click="handleDelete(scope.row)">删除</el-button>
</template>
</el-table-column>
<template #empty>
<el-empty class="vab-data-empty" description="暂无数据" />
</template>
</el-table>
<vab-pagination
:current-page="queryForm.pageNum"
:page-size="queryForm.pageSize"
:total="total"
@current-change="handleCurrentChange"
@size-change="handleSizeChange"
/>
<dictionary-data-management-edit ref="editRef" :dict-type="queryForm.dictType" @fetch-data="fetchData" />
</div>
</template>
<script lang="ts" setup>
import type { TableInstance } from 'element-plus'
import { VueDraggable as VabDraggable } from 'vue-draggable-plus'
import { doDelete, getList } from '/@/api/dictionaryDataManagement'
import { optionselect as getDictOptionselect, getDictType } from '/@/api/dictionaryManagement'
import useDictStore from '/@/store/modules/dict'
import { useTabsStore } from '/@/store/modules/tabs'
defineOptions({
name: 'DictData',
})
const route = useRoute()
const router = useRouter()
const tabStore = useTabsStore()
const { delVisitedRoute } = tabStore
const { proxy } = getCurrentInstance() as any
const { sys_normal_disable } = proxy.useDict('sys_normal_disable')
const { exit, enter, isFullscreen: _isFullscreen } = useFullscreen()
const isFullscreen = ref<boolean>(false)
const fold = ref<boolean>(true)
const tableRef = ref<TableInstance>()
const editRef = ref<any>(null)
const list = ref<any>([])
const listLoading = ref<boolean>(true)
const total = ref<number>(0)
const selectRows = ref<any>([])
const checkList = ref<any>([])
const queryForm = reactive<any>({
pageNum: 1,
pageSize: 10,
dictType: undefined,
dictLabel: undefined,
status: undefined,
})
const defaultDictType = ref('')
const typeOptions = ref<any>([])
const columns = ref<any>([
{ label: '字典编码', prop: 'dictCode', minWidth: 160, checked: true },
{ label: '字典标签', prop: 'dictLabel', minWidth: 160, checked: true },
{ label: '字典键值', prop: 'dictValue', minWidth: 160, checked: true },
{ label: '字典排序', prop: 'dictSort', minWidth: 120, checked: true },
{ label: '状态', prop: 'status', minWidth: 120, checked: true },
{ label: '备注', prop: 'remark', minWidth: 160, checked: true },
{ label: '创建时间', prop: 'createTime', minWidth: 160, checked: true },
])
const finallyColumns = computed(() => columns.value.filter((item: any) => checkList.value.includes(item.label)))
watch(
_isFullscreen,
() => {
if (_isFullscreen.value) isFullscreen.value = true
else isFullscreen.value = false
},
{ immediate: true }
)
onActivated(() => {
tableRef.value?.doLayout()
})
onBeforeMount(() => {
columns.value.forEach((item: any) => {
if (item.checked) checkList.value.push(item.label)
})
getTypeList()
getTypes(route.params && route.params.dictId)
})
/** 查询字典类型详细 */
function getTypes(dictId: any) {
getDictType(dictId).then((response: any) => {
queryForm.dictType = response.data.dictType
defaultDictType.value = response.data.dictType
fetchData()
})
}
/** 查询字典类型列表 */
function getTypeList() {
getDictOptionselect().then((response: any) => {
typeOptions.value = response.data
})
}
/** 点击全屏 */
const clickFullScreen = () => {
isFullscreen.value = !isFullscreen.value
isFullscreen.value ? enter() : exit()
}
/** 搜索条件折叠 */
const handleFold = () => {
fold.value = !fold.value
}
/** 查询字典数据列表 */
const fetchData = async () => {
listLoading.value = true
const pp = Object.assign({}, queryForm)
const { rows, total: _total } = (await getList(pp)) as any
list.value = rows
total.value = _total
listLoading.value = false
}
/** 搜索按钮操作 */
function handleQuery() {
queryForm.pageNum = 1
fetchData()
}
/** 重置按钮操作 */
function resetQuery() {
proxy.resetForm('queryRef')
queryForm.dictType = defaultDictType.value
handleQuery()
}
const handleSizeChange = (value: number) => {
queryForm.pageNum = 1
queryForm.pageSize = value
fetchData()
}
const handleCurrentChange = (value: number) => {
queryForm.pageNum = value
fetchData()
}
const setSelectRows = (value: string) => {
selectRows.value = value
}
/** 新增按钮操作 */
const handleAdd = () => {
editRef.value.showEdit()
}
/** 修改按钮操作 */
function handleUpdate(row: any) {
editRef.value.showEdit(row)
}
/** 删除按钮操作 */
const handleDelete = (row: any = {}) => {
if (row.dictCode) {
$baseConfirm(`您确定要删除字典标签为“${row.dictLabel}”的数据项吗`, null, async () => {
const { msg }: any = await doDelete(row.dictCode)
$baseMessage(msg, 'success', 'hey')
await fetchData()
})
} else {
if (selectRows.value.length > 0) {
const ids = selectRows.value.map((item: { dictCode: any }) => item.dictCode)
$baseConfirm('您确定要删除选中项吗', null, async () => {
const { msg }: any = await doDelete(ids)
$baseMessage(msg, 'success', 'hey')
await fetchData()
useDictStore().removeDict(queryForm.dictType)
})
} else {
$baseMessage('您未选中任何行', 'warning', 'hey')
}
}
}
/** 导出按钮操作 */
function handleExport() {
proxy.download(
'system/dict/data/export',
{
...queryForm,
},
`dict_data_${Date.now()}.xlsx`
)
}
/** 关闭按钮操作 */
async function handleClose() {
await delVisitedRoute(route.path)
router.push({ name: 'DictionaryManagement' })
}
</script>
<template>
<div class="dictionary-management-container auto-height-container" :class="{ 'fullscreen-container': isFullscreen }">
<vab-query-form>
<vab-query-form-top-panel>
<el-form ref="queryRef" inline label-width="70px" :model="queryForm" @submit.prevent>
<el-form-item label="字典名称" prop="dictName">
<el-input v-model="queryForm.dictName" clearable placeholder="请输入字典名称" style="width: 240px" @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item v-show="!fold" label="字典类型" prop="dictType">
<el-input v-model="queryForm.dictType" clearable placeholder="请输入字典类型" style="width: 240px" @keyup.enter="handleQuery" />
</el-form-item>
<el-form-item v-show="!fold" label="状态" prop="status">
<el-select v-model="queryForm.status" clearable placeholder="字典状态" 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 v-show="!fold" label="创建时间" prop="dateRange" style="width: 308px">
<el-date-picker
v-model="queryForm.dateRange"
end-placeholder="结束日期"
range-separator="-"
start-placeholder="开始日期"
type="daterange"
value-format="YYYY-MM-DD"
/>
</el-form-item>
<el-form-item>
<el-button icon="Search" :loading="listLoading" native-type="submit" type="primary" @click="handleQuery">查询</el-button>
<el-button icon="Refresh" @click="resetQuery">重置</el-button>
<el-button class="hidden-xs-only" text type="primary" @click="handleFold">
<span v-if="fold">展开</span>
<span v-else>合并</span>
<vab-icon class="vab-dropdown" :class="{ 'vab-dropdown-active': fold }" icon="arrow-up-s-line" />
</el-button>
</el-form-item>
</el-form>
</vab-query-form-top-panel>
<vab-query-form-left-panel>
<el-button icon="Plus" type="primary" @click="handleAdd">添加</el-button>
<el-button icon="Delete" type="danger" @click="handleDelete">删除</el-button>
<el-button icon="Upload" plain type="warning" @click="handleExport">导出</el-button>
<el-button icon="Refresh" plain type="danger" @click="handleRefreshCache">刷新缓存</el-button>
</vab-query-form-left-panel>
<vab-query-form-right-panel>
<div class="custom-table-right-tools">
<el-button @click="handleQuery">
<vab-icon icon="refresh-line" />
</el-button>
<el-button @click="clickFullScreen">
<vab-icon :icon="isFullscreen ? 'fullscreen-exit-fill' : 'fullscreen-fill'" />
</el-button>
<el-popover popper-class="custom-table-checkbox">
<template #reference>
<el-button>
<vab-icon icon="settings-line" />
</el-button>
</template>
<vab-draggable v-model="columns" :animation="600" target=".el-checkbox-group">
<el-checkbox-group v-model="checkList">
<el-checkbox
v-for="item in columns"
:key="item.label"
:disabled="item.disableCheck"
:label="item.label"
:value="item.label"
>
{{ item.label }}
</el-checkbox>
</el-checkbox-group>
</vab-draggable>
</el-popover>
</div>
</vab-query-form-right-panel>
</vab-query-form>
<el-table ref="tableRef" v-loading="listLoading" border :data="list" @selection-change="setSelectRows">
<el-table-column align="center" type="selection" width="50" />
<el-table-column
v-for="(item, index) in finallyColumns"
:key="index"
align="center"
:fixed="item.fixed"
:label="item.label"
:min-width="item.minWidth || 160"
:prop="item.prop"
show-overflow-tooltip
:sortable="item.sortable"
>
<template #default="scope">
<span v-if="item.label === '状态'">
<dict-tag :options="sys_normal_disable" :value="scope.row.status" />
</span>
<span v-else-if="item.label === '字典类型'">
<router-link class="link-type" :to="'/system/dictionaryManagement/dictData/' + scope.row.dictId">
<span>{{ scope.row.dictType }}</span>
</router-link>
</span>
<span v-else>{{ scope.row[item.prop] }}</span>
</template>
</el-table-column>
<el-table-column align="center" fixed="right" label="操作" min-width="160">
<template #default="scope">
<el-button icon="Edit" link type="primary" @click="handleUpdate(scope.row)">修改</el-button>
<el-button icon="Delete" link type="primary" @click="handleDelete(scope.row)">删除</el-button>
</template>
</el-table-column>
<template #empty>
<el-empty class="vab-data-empty" description="暂无数据" />
</template>
</el-table>
<vab-pagination
:current-page="queryForm.pageNum"
:page-size="queryForm.pageSize"
:total="total"
@current-change="handleCurrentChange"
@size-change="handleSizeChange"
/>
<dictionary-management-edit2 ref="editRef" @fetch-data="fetchData" />
</div>
</template>
<script lang="ts" setup>
import type { TableInstance } from 'element-plus'
import { VueDraggable as VabDraggable } from 'vue-draggable-plus'
import { doDelete, getList, refreshCache } from '/@/api/dictionaryManagement'
import useDictStore from '/@/store/modules/dict'
defineOptions({
name: 'DictionaryManagement',
})
const { proxy } = getCurrentInstance() as any
const { sys_normal_disable } = proxy.useDict('sys_normal_disable')
const { exit, enter, isFullscreen: _isFullscreen } = useFullscreen()
const isFullscreen = ref<boolean>(false)
const fold = ref<boolean>(true)
const tableRef = ref<TableInstance>()
const editRef = ref<any>(null)
const list = ref<any>([])
const listLoading = ref<boolean>(true)
const total = ref<number>(0)
const selectRows = ref<any>([])
const checkList = ref<any>([])
const queryForm = reactive<any>({
pageNum: 1,
pageSize: 10,
dictName: undefined,
dictType: undefined,
status: undefined,
dateRange: [],
})
const columns = ref<any>([
{ label: '字典编号', prop: 'dictId', minWidth: 120, checked: true },
{ label: '字典名称', prop: 'dictName', minWidth: 160, checked: true },
{ label: '字典类型', prop: 'dictType', minWidth: 160, checked: true },
{ label: '状态', prop: 'status', minWidth: 120, checked: true },
{ label: '备注', prop: 'remark', minWidth: 160, checked: true },
{ label: '创建时间', prop: 'createTime', minWidth: 160, checked: true },
])
const finallyColumns = computed(() => columns.value.filter((item: any) => checkList.value.includes(item.label)))
watch(
_isFullscreen,
() => {
if (_isFullscreen.value) isFullscreen.value = true
else isFullscreen.value = false
},
{ immediate: true }
)
onActivated(() => {
tableRef.value?.doLayout()
})
onBeforeMount(() => {
columns.value.forEach((item: any) => {
if (item.checked) checkList.value.push(item.label)
})
fetchData()
})
/** 点击全屏 */
const clickFullScreen = () => {
isFullscreen.value = !isFullscreen.value
isFullscreen.value ? enter() : exit()
}
/** 搜索条件折叠 */
const handleFold = () => {
fold.value = !fold.value
}
/** 查询字典列表 */
const fetchData = async () => {
listLoading.value = true
const pp = Object.assign({}, proxy.addDateRange(queryForm, queryForm.dateRange))
delete pp.dateRange
const { rows, total: _total } = (await getList(pp)) as any
list.value = rows
total.value = _total
listLoading.value = false
}
/** 搜索按钮操作 */
function handleQuery() {
queryForm.pageNum = 1
fetchData()
}
/** 重置按钮操作 */
function resetQuery() {
proxy.resetForm('queryRef')
handleQuery()
}
const handleSizeChange = (value: number) => {
queryForm.pageNum = 1
queryForm.pageSize = value
fetchData()
}
const handleCurrentChange = (value: number) => {
queryForm.pageNum = value
fetchData()
}
const setSelectRows = (value: string) => {
selectRows.value = value
}
/** 新增按钮操作 */
const handleAdd = () => {
editRef.value.showEdit()
}
/** 修改按钮操作 */
function handleUpdate(row: any) {
editRef.value.showEdit(row)
}
/** 删除按钮操作 */
const handleDelete = (row: any = {}) => {
if (row.dictId) {
$baseConfirm(`您确定要删除字典名称为“${row.dictName}”的数据项吗`, null, async () => {
const { msg }: any = await doDelete(row.dictId)
$baseMessage(msg, 'success', 'hey')
await fetchData()
})
} else {
if (selectRows.value.length > 0) {
const ids = selectRows.value.map((item: { dictId: any }) => item.dictId)
$baseConfirm('您确定要删除选中项吗', null, async () => {
const { msg }: any = await doDelete(ids)
$baseMessage(msg, 'success', 'hey')
await fetchData()
})
} else {
$baseMessage('您未选中任何行', 'warning', 'hey')
}
}
}
/** 导出按钮操作 */
function handleExport() {
proxy.download(
'system/dict/type/export',
{
...queryForm,
},
`dict_${Date.now()}.xlsx`
)
}
/** 刷新缓存按钮操作 */
function handleRefreshCache() {
refreshCache().then(() => {
$baseMessage('刷新成功', 'success', 'hey')
useDictStore().cleanDict()
})
}
</script>
<style lang="scss" scoped>
.link-type,
.link-type:focus {
color: #337ab7;
cursor: pointer;
&:hover {
color: rgb(32, 160, 255);
}
}
</style>
<template>
<vab-dialog v-model="dialogFormVisible" append-to-body :title="title" width="500px" @close="close">
<el-form ref="formRef" label-width="80px" :model="form" :rules="rules">
<el-form-item label="字典类型">
<el-input v-model="form.dictType" :disabled="true" />
</el-form-item>
<el-form-item label="数据标签" prop="dictLabel">
<el-input v-model="form.dictLabel" placeholder="请输入数据标签" />
</el-form-item>
<el-form-item label="数据键值" prop="dictValue">
<el-input v-model="form.dictValue" placeholder="请输入数据键值" />
</el-form-item>
<el-form-item label="样式属性" prop="cssClass">
<el-input v-model="form.cssClass" placeholder="请输入样式属性" />
</el-form-item>
<el-form-item label="显示排序" prop="dictSort">
<el-input-number v-model="form.dictSort" controls-position="right" :min="0" />
</el-form-item>
<el-form-item label="回显样式" prop="listClass">
<el-select v-model="form.listClass">
<el-option v-for="item in listClassOptions" :key="item.value" :label="item.label + '(' + item.value + ')'" :value="item.value" />
</el-select>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio v-for="dict in sys_normal_disable" :key="dict.value" :value="dict.value">{{ dict.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入内容" type="textarea" />
</el-form-item>
</el-form>
<template #footer>
<el-button type="primary" @click="save">确 定</el-button>
<el-button @click="cancel">取 消</el-button>
</template>
</vab-dialog>
</template>
<script lang="ts" setup>
import type { FormInstance } from 'element-plus'
import { doAdd, doEdit, getData } from '/@/api/dictionaryDataManagement'
import useDictStore from '/@/store/modules/dict'
defineOptions({
name: 'DictionaryDataManagementEdit',
})
const { proxy } = getCurrentInstance() as any
const { sys_normal_disable } = proxy.useDict('sys_normal_disable')
const emit = defineEmits(['fetch-data'])
const props = defineProps({
dictType: {
type: String,
default: '',
},
})
// 数据标签回显样式
const listClassOptions = ref([
{ value: 'default', label: '默认' },
{ value: 'primary', label: '主要' },
{ value: 'success', label: '成功' },
{ value: 'info', label: '信息' },
{ value: 'warning', label: '警告' },
{ value: 'danger', label: '危险' },
])
const formRef = ref<FormInstance>()
const form = ref<any>({
dictCode: undefined,
dictLabel: undefined,
dictValue: undefined,
cssClass: undefined,
listClass: 'default',
dictSort: 0,
status: '0',
remark: undefined,
})
const rules = reactive<any>({
dictLabel: [{ required: true, message: '数据标签不能为空', trigger: 'blur' }],
dictValue: [{ required: true, message: '数据键值不能为空', trigger: 'blur' }],
dictSort: [{ required: true, message: '数据顺序不能为空', trigger: 'blur' }],
})
const title = ref<string>('')
const dialogFormVisible = ref<boolean>(false)
const showEdit = (row?: any) => {
reset()
if (row && row.dictCode) {
title.value = '编辑'
getData(row.dictCode).then((response: any) => {
form.value = response.data
dialogFormVisible.value = true
})
} else {
title.value = '添加'
form.value.dictType = props.dictType
dialogFormVisible.value = true
}
}
/** 表单重置 */
function reset() {
form.value = {
dictCode: undefined,
dictLabel: undefined,
dictValue: undefined,
cssClass: undefined,
listClass: 'default',
dictSort: 0,
status: '0',
remark: undefined,
}
proxy.resetForm('formRef')
}
const close = () => {
formRef.value?.clearValidate()
formRef.value?.resetFields()
emit('fetch-data')
}
const cancel = () => {
close()
dialogFormVisible.value = false
}
const save = () => {
formRef.value?.validate(async (valid: any) => {
if (valid) {
if (form.value.dictCode) {
await doEdit(form.value)
useDictStore().removeDict(props.dictType)
await $baseMessage('修改成功', 'success', 'hey')
} else {
await doAdd(form.value)
useDictStore().removeDict(props.dictType)
await $baseMessage('添加成功', 'success', 'hey')
}
cancel()
}
})
}
defineExpose({
showEdit,
})
</script>
<template>
<vab-dialog v-model="dialogFormVisible" append-to-body :title="title" width="500px" @close="close">
<el-form ref="formRef" label-width="80px" :model="form" :rules="rules">
<el-form-item label="字典名称" prop="dictName">
<el-input v-model="form.dictName" placeholder="请输入字典名称" />
</el-form-item>
<el-form-item label="字典类型" prop="dictType">
<el-input v-model="form.dictType" placeholder="请输入字典类型" />
</el-form-item>
<el-form-item label="状态" prop="status">
<el-radio-group v-model="form.status">
<el-radio v-for="dict in sys_normal_disable" :key="dict.value" :value="dict.value">{{ dict.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入内容" type="textarea" />
</el-form-item>
</el-form>
<template #footer>
<el-button type="primary" @click="save">确 定</el-button>
<el-button @click="cancel">取 消</el-button>
</template>
</vab-dialog>
</template>
<script lang="ts" setup>
import type { FormInstance } from 'element-plus'
import { doAdd, doEdit, getDictType } from '/@/api/dictionaryManagement'
defineOptions({
name: 'DictionaryManagementEdit2',
})
const { proxy } = getCurrentInstance() as any
const { sys_normal_disable } = proxy.useDict('sys_normal_disable')
const emit = defineEmits(['fetch-data'])
const formRef = ref<FormInstance>()
const form = ref<any>({
dictId: undefined,
dictName: undefined,
dictType: undefined,
status: '0',
remark: undefined,
})
const rules = reactive<any>({
dictName: [{ required: true, message: '字典名称不能为空', trigger: 'blur' }],
dictType: [{ required: true, message: '字典类型不能为空', trigger: 'blur' }],
})
const title = ref<string>('')
const dialogFormVisible = ref<boolean>(false)
const showEdit = (row?: any) => {
reset()
if (row && row.dictId) {
title.value = '编辑'
getDictType(row.dictId).then((response: any) => {
form.value = response.data
dialogFormVisible.value = true
})
} else {
title.value = '添加'
dialogFormVisible.value = true
}
}
/** 表单重置 */
function reset() {
form.value = {
dictId: undefined,
dictName: undefined,
dictType: undefined,
status: '0',
remark: undefined,
}
proxy.resetForm('formRef')
}
const close = () => {
formRef.value?.clearValidate()
formRef.value?.resetFields()
emit('fetch-data')
}
const cancel = () => {
close()
dialogFormVisible.value = false
}
const save = () => {
formRef.value?.validate(async (valid: any) => {
if (valid) {
if (form.value.dictId) {
await doEdit(form.value)
await $baseMessage('修改成功', 'success', 'hey')
} else {
await doAdd(form.value)
await $baseMessage('添加成功', 'success', 'hey')
}
cancel()
}
})
}
defineExpose({
showEdit,
})
</script>
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论