【系统设置】 修复# 消息通知-短信通知:点击设置按钮后页面无反应

dev1.0
kaeery 2025-03-21 15:48:22 +08:00
parent da34a60c9b
commit 10a9d8f354
3 changed files with 29 additions and 48 deletions

View File

@ -421,6 +421,20 @@ export const constantRoutes: Array<RouteRecordRaw> = [
} }
} }
] ]
},
{
path: '/setting/notice',
component: LAYOUT,
children: [
{
path: 'edit',
component: () => import('@/views/message/notice/edit.vue'),
meta: {
title: '设置',
activeMenu: '/setting/message/notice'
}
}
]
} }
] ]

View File

@ -3,18 +3,12 @@
<el-card class="!border-none" shadow="never"> <el-card class="!border-none" shadow="never">
<el-page-header :content="$route.meta.title" @back="$router.back()" /> <el-page-header :content="$route.meta.title" @back="$router.back()" />
</el-card> </el-card>
<el-form <el-form ref="formRef" :model="formData" label-width="120px" :rules="rules" v-loading="loading">
ref="formRef"
:model="formData"
label-width="120px"
:rules="rules"
v-loading="loading"
>
<el-card class="!border-none mt-4" shadow="never"> <el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">通知名称</div> <div class="font-medium mb-7">通知名称</div>
<el-form-item label="通知名称" prop="name"> {{ formData.name }} </el-form-item> <el-form-item label="通知名称" prop="name">{{ formData.name }}</el-form-item>
<el-form-item label="通知类型" prop="name"> {{ formData.type }} </el-form-item> <el-form-item label="通知类型" prop="name">{{ formData.type }}</el-form-item>
<el-form-item label="通知业务" prop="name"> {{ formData.remarks }} </el-form-item> <el-form-item label="通知业务" prop="name">{{ formData.remarks }}</el-form-item>
</el-card> </el-card>
<el-card class="!border-none mt-4" shadow="never"> <el-card class="!border-none mt-4" shadow="never">
<div class="font-medium mb-7">短信通知</div> <div class="font-medium mb-7">短信通知</div>
@ -26,20 +20,13 @@
</el-form-item> </el-form-item>
<el-form-item label="模板ID" prop="smsNotice.templateId"> <el-form-item label="模板ID" prop="smsNotice.templateId">
<div class="w-80"> <div class="w-80">
<el-input <el-input v-model="formData.smsNotice.templateId" placeholder="请输入模板ID" />
v-model="formData.smsNotice.templateId"
placeholder="请输入模板ID"
/>
</div> </div>
</el-form-item> </el-form-item>
<el-form-item label="短信内容" prop="smsNotice.content"> <el-form-item label="短信内容" prop="smsNotice.content">
<div class="flex-1"> <div class="flex-1">
<div class="w-full max-w-[320px]"> <div class="w-full max-w-[320px]">
<el-input <el-input type="textarea" :autosize="{ minRows: 6, maxRows: 6 }" v-model="formData.smsNotice.content" />
type="textarea"
:autosize="{ minRows: 6, maxRows: 6 }"
v-model="formData.smsNotice.content"
/>
</div> </div>
<div class="form-tips"> <div class="form-tips">
<!-- <div v-for="(item, index) in formData.smsNotice.tips" :key="index"> --> <!-- <div v-for="(item, index) in formData.smsNotice.tips" :key="index"> -->
@ -103,7 +90,7 @@ const getDetails = async () => {
const data = await noticeDetail({ const data = await noticeDetail({
id: route.query.id id: route.query.id
}) })
Object.keys(data).forEach((key) => { Object.keys(data).forEach(key => {
//@ts-ignore //@ts-ignore
formData[key] = data[key] formData[key] = data[key]
}) })
@ -114,7 +101,7 @@ const handleSave = async () => {
await formRef.value?.validate() await formRef.value?.validate()
await setNoticeConfig(formData) await setNoticeConfig(formData)
feedback.msgSuccess('操作成功') feedback.msgSuccess('操作成功')
removeTab() // removeTab()
router.back() router.back()
} }

View File

@ -1,22 +1,11 @@
<template> <template>
<div> <div>
<el-card class="!border-none" shadow="never"> <el-card class="!border-none" shadow="never">
<el-alert <el-alert type="warning" title="温馨提示:平台配置在各个场景下的通知发送方式和内容模板" :closable="false" show-icon></el-alert>
type="warning"
title="温馨提示:平台配置在各个场景下的通知发送方式和内容模板"
:closable="false"
show-icon
></el-alert>
</el-card> </el-card>
<el-card class="!border-none mt-4" shadow="never"> <el-card class="!border-none mt-4" shadow="never">
<el-tabs v-model="tabsActive" @tab-change="getLists"> <el-tabs v-model="tabsActive" @tab-change="getLists">
<el-tab-pane <el-tab-pane v-for="(item, index) in tabsMap" :key="index" :label="item.name" :name="item.type" lazy></el-tab-pane>
v-for="(item, index) in tabsMap"
:key="index"
:label="item.name"
:name="item.type"
lazy
></el-tab-pane>
</el-tabs> </el-tabs>
<el-table size="large" :data="state.lists" v-loading="state.loading"> <el-table size="large" :data="state.lists" v-loading="state.loading">
<el-table-column label="通知场景" prop="name" min-width="120" /> <el-table-column label="通知场景" prop="name" min-width="120" />
@ -29,18 +18,7 @@
</el-table-column> </el-table-column>
<el-table-column label="操作" min-width="80" fixed="right"> <el-table-column label="操作" min-width="80" fixed="right">
<template #default="{ row }"> <template #default="{ row }">
<el-button v-perms="['setting:notice:detail']" type="primary" link> <el-button v-perms="['setting:notice:detail']" type="primary" link @click="handleSetting(row.id)"></el-button>
<router-link
:to="{
path: getRoutePath('setting:notice:detail'),
query: {
id: row.id
}
}"
>
设置
</router-link>
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -49,7 +27,6 @@
</template> </template>
<script lang="ts" setup name="notice"> <script lang="ts" setup name="notice">
import { noticeLists } from '@/api/message' import { noticeLists } from '@/api/message'
import { getRoutePath } from '@/router'
enum NoticeEnums { enum NoticeEnums {
USER = 1, USER = 1,
@ -91,7 +68,10 @@ const getLists = async () => {
state.loading = false state.loading = false
} }
} }
const router = useRouter()
const handleSetting = (id: number) => {
router.push({ path: '/setting/notice/edit', query: { id } })
}
onActivated(() => { onActivated(() => {
getLists() getLists()
}) })