!214 增加部门和菜单的详情,解决个人中心无法上传图片的问题

Merge pull request !214 from clockdotnet/master-vxe
pull/242/MERGE
芋道源码 2023-08-23 16:58:45 +00:00 committed by Gitee
commit a15d777afb
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
6 changed files with 126 additions and 5 deletions

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="user-info-head" @click="open()"> <div class="user-info-head" @click="open()">
<img v-if="sourceValue" :src="sourceValue" alt="avatar" class="img-circle img-lg" /> <img :src="sourceValue" class="img-circle img-lg" />
<el-button v-if="showBtn" :class="`${prefixCls}-upload-btn`" @click="open()"> <el-button v-if="showBtn" :class="`${prefixCls}-upload-btn`" @click="open()">
{{ btnText ? btnText : t('cropper.selectImage') }} {{ btnText ? btnText : t('cropper.selectImage') }}
</el-button> </el-button>

View File

@ -209,3 +209,47 @@ export const yuanToFen = (amount: string | number): number => {
export const fenToYuan = (amount: string | number): number => { export const fenToYuan = (amount: string | number): number => {
return Number((Number(amount) / 100).toFixed(2)) return Number((Number(amount) / 100).toFixed(2))
} }
export const treeFormatter = (ary: any, val: string, valueField = 'value', nameField = 'label') => {
let o = ''
if (ary != null) {
for (const v of ary) {
if (v[valueField] == val) {
o = v[nameField]
if (o) return o
} else if (v.children?.length) {
o = treeFormatter(v.children, val, valueField, nameField)
if (o) return o
}
}
return o
} else {
return val
}
}
/**
*
* @param ary
* @param val
* @param name
* @param returnVal
* @returns
*/
export const commonFormatter = (ary: any, val: string, name: string, returnVal: string) => {
let o = ''
if (ary && val) {
for (const v of ary) {
if (v[name] == val) {
o = v[returnVal]
if (o) return o
} else if (v.children?.length) {
o = commonFormatter(v.children, val, name, returnVal)
if (o) return o
}
}
return o
} else {
return val
}
}

View File

@ -9,7 +9,7 @@ export const rules = reactive({
status: [required], status: [required],
// email: [required], // email: [required],
email: [ email: [
{ required: true, message: t('profile.rules.mail'), trigger: 'blur' }, { message: t('profile.rules.mail'), trigger: 'blur' },
{ {
type: 'email', type: 'email',
message: t('profile.rules.truemail'), message: t('profile.rules.truemail'),

View File

@ -25,6 +25,8 @@
v-hasPermi="['system:dept:update']" v-hasPermi="['system:dept:update']"
@click="handleUpdate(row.id)" @click="handleUpdate(row.id)"
/> />
<!-- 操作详情 -->
<XTextButton preIcon="ep:view" :title="t('action.detail')" @click="handleDetail(row.id)" />
<!-- 操作删除 --> <!-- 操作删除 -->
<XTextButton <XTextButton
preIcon="ep:delete" preIcon="ep:delete"
@ -38,7 +40,12 @@
<!-- 添加或修改菜单对话框 --> <!-- 添加或修改菜单对话框 -->
<XModal id="deptModel" v-model="dialogVisible" :title="dialogTitle"> <XModal id="deptModel" v-model="dialogVisible" :title="dialogTitle">
<!-- 对话框(添加 / 修改) --> <!-- 对话框(添加 / 修改) -->
<Form ref="formRef" :schema="allSchemas.formSchema" :rules="rules"> <Form
v-if="['create', 'update'].includes(actionType)"
ref="formRef"
:schema="allSchemas.formSchema"
:rules="rules"
>
<template #parentId="form"> <template #parentId="form">
<el-tree-select <el-tree-select
node-key="id" node-key="id"
@ -60,6 +67,26 @@
</el-select> </el-select>
</template> </template>
</Form> </Form>
<!-- 对话框(详情) -->
<Descriptions
v-if="actionType === 'detail'"
:schema="allSchemas.detailSchema"
:data="detailData"
ref="formRefDetail"
>
<template #parentId="{ row }">
<el-tag>
{{ dataFormatter(row.parentId) }}
</el-tag>
</template>
<template #leaderUserId="{ row }">
<template v-if="row.leaderUserId !== null">
<el-tag>
{{ userNicknameFormat(row) }}
</el-tag>
</template>
</template>
</Descriptions>
<template #footer> <template #footer>
<!-- 按钮保存 --> <!-- 按钮保存 -->
<XButton <XButton
@ -80,6 +107,7 @@ import type { FormExpose } from '@/components/Form'
import { allSchemas, rules } from './dept.data' import { allSchemas, rules } from './dept.data'
import * as DeptApi from '@/api/system/dept' import * as DeptApi from '@/api/system/dept'
import { getListSimpleUsersApi, UserVO } from '@/api/system/user' import { getListSimpleUsersApi, UserVO } from '@/api/system/user'
import { treeFormatter } from '@/utils'
const { t } = useI18n() // const { t } = useI18n() //
const message = useMessage() // const message = useMessage() //
@ -113,6 +141,11 @@ const getTree = async () => {
dept.children = handleTree(res) dept.children = handleTree(res)
deptOptions.value.push(dept) deptOptions.value.push(dept)
} }
const dataFormatter = (val) => {
return treeFormatter(deptOptions.value, val, 'id', 'name')
}
const [registerTable, { reload, deleteData }] = useXTable({ const [registerTable, { reload, deleteData }] = useXTable({
allSchemas: allSchemas, allSchemas: allSchemas,
treeConfig: treeConfig, treeConfig: treeConfig,
@ -142,6 +175,14 @@ const handleUpdate = async (rowId: number) => {
unref(formRef)?.setValues(res) unref(formRef)?.setValues(res)
} }
const detailData = ref()
const handleDetail = async (rowId: number) => {
setDialogTile('detail')
//
const res = await DeptApi.getDeptApi(rowId)
detailData.value = res
}
// / // /
const submitForm = async () => { const submitForm = async () => {
const elForm = unref(formRef)?.getElFormRef() const elForm = unref(formRef)?.getElFormRef()
@ -171,7 +212,7 @@ const submitForm = async () => {
const userNicknameFormat = (row) => { const userNicknameFormat = (row) => {
if (!row || !row.leaderUserId) { if (!row || !row.leaderUserId) {
return '未设置' return ''
} }
for (const user of userOption.value) { for (const user of userOption.value) {
if (row.leaderUserId === user.id) { if (row.leaderUserId === user.id) {

View File

@ -27,6 +27,8 @@
v-hasPermi="['system:menu:update']" v-hasPermi="['system:menu:update']"
@click="handleUpdate(row.id)" @click="handleUpdate(row.id)"
/> />
<!-- 操作详情 -->
<XTextButton preIcon="ep:view" :title="t('action.detail')" @click="handleDetail(row.id)" />
<!-- 操作删除 --> <!-- 操作删除 -->
<XTextButton <XTextButton
preIcon="ep:delete" preIcon="ep:delete"
@ -46,6 +48,7 @@
:rules="rules" :rules="rules"
label-width="100px" label-width="100px"
label-position="right" label-position="right"
v-if="['create', 'update'].includes(actionType)"
> >
<el-form-item label="上级菜单"> <el-form-item label="上级菜单">
<el-tree-select <el-tree-select
@ -186,6 +189,21 @@
</el-col> </el-col>
</template> </template>
</el-form> </el-form>
<!-- 对话框(详情) -->
<Descriptions
v-if="actionType === 'detail'"
:schema="allSchemas.detailSchema"
:data="detailData"
>
<template #parentId="{ row }">
<template v-if="row.parentId !== ''">
<el-tag>
{{ dataFormatter(row.parentId) }}
</el-tag>
</template>
<template v-else> </template>
</template>
</Descriptions>
<template #footer> <template #footer>
<!-- 按钮保存 --> <!-- 按钮保存 -->
<XButton <XButton
@ -209,6 +227,7 @@ import { SystemMenuTypeEnum, CommonStatusEnum } from '@/utils/constants'
import { handleTree, defaultProps } from '@/utils/tree' import { handleTree, defaultProps } from '@/utils/tree'
import * as MenuApi from '@/api/system/menu' import * as MenuApi from '@/api/system/menu'
import { allSchemas, rules } from './menu.data' import { allSchemas, rules } from './menu.data'
import { treeFormatter } from '@/utils'
const { t } = useI18n() // const { t } = useI18n() //
const message = useMessage() // const message = useMessage() //
@ -265,6 +284,10 @@ const getTree = async () => {
menuOptions.value.push(menu) menuOptions.value.push(menu)
} }
const dataFormatter = (val) => {
return treeFormatter(menuOptions.value, val, 'id', 'name')
}
// ========== / ========== // ========== / ==========
// //
@ -310,6 +333,14 @@ const handleUpdate = async (rowId: number) => {
menuForm.value.alwaysShow = res.alwaysShow !== undefined ? res.alwaysShow : true menuForm.value.alwaysShow = res.alwaysShow !== undefined ? res.alwaysShow : true
} }
let detailData = ref()
const handleDetail = async (rowId: number) => {
await setDialogTile('detail')
//
const res = await MenuApi.getMenuApi(rowId)
detailData.value = res
}
// / // /
const submitForm = async () => { const submitForm = async () => {
actionLoading.value = true actionLoading.value = true

View File

@ -163,7 +163,12 @@
</template> </template>
<template #postIds="{ row }"> <template #postIds="{ row }">
<template v-if="row.postIds !== ''"> <template v-if="row.postIds !== ''">
<el-tag v-for="(post, index) in row.postIds" :key="index" index=""> <el-tag
v-for="(post, index) in row.postIds"
:key="index"
index=""
:style="index !== row.postIds.length - 1 ? 'margin-right: 5px' : ''"
>
<template v-for="postObj in postOptions"> <template v-for="postObj in postOptions">
{{ post === postObj.id ? postObj.name : '' }} {{ post === postObj.id ? postObj.name : '' }}
</template> </template>