115 lines
3.5 KiB
Vue
115 lines
3.5 KiB
Vue
<template>
|
||
<doc-alert title="会员手册(功能开启)" url="https://doc.iocoder.cn/member/build/" />
|
||
|
||
<ContentWrap>
|
||
<el-form
|
||
ref="formRef"
|
||
:model="formData"
|
||
:rules="formRules"
|
||
label-width="120px"
|
||
v-loading="formLoading"
|
||
>
|
||
<!-- <el-form-item label="hideId" v-show="false">-->
|
||
<!-- <el-input v-model="formData.id" />-->
|
||
<!-- </el-form-item>-->
|
||
|
||
<el-tabs>
|
||
<el-tab-pane label="付费会员配置">
|
||
<el-form-item label="开启付费会员" prop="openPaidMember">
|
||
<el-radio v-model="formData.openPaidMember" :label="true">开启</el-radio>
|
||
<el-radio v-model="formData.openPaidMember" :label="false">关闭</el-radio>
|
||
<el-text class="w-full" size="small" type="info">
|
||
付费会员开关
|
||
</el-text>
|
||
</el-form-item>
|
||
<el-form-item v-if="formData.openPaidMember === true" label="商品付费会员价" prop="paidMemberPrice">
|
||
<el-radio v-model="formData.paidMemberPrice" :label="true">开启</el-radio>
|
||
<el-radio v-model="formData.paidMemberPrice" :label="false">关闭</el-radio>
|
||
<el-text class="w-full" size="small" type="info">
|
||
商品付费会员价是否展示
|
||
</el-text>
|
||
</el-form-item>
|
||
|
||
</el-tab-pane>
|
||
</el-tabs>
|
||
|
||
<el-form-item>
|
||
<el-button type="primary" @click="onSubmit">提交</el-button>
|
||
</el-form-item>
|
||
</el-form>
|
||
</ContentWrap>
|
||
</template>
|
||
|
||
<script setup lang="ts">
|
||
import { dateFormatter } from '@/utils/formatTime'
|
||
import download from '@/utils/download'
|
||
import * as PadiMemberTypeVoApi from '@/api/member/memberconfig'
|
||
import PaidMemberConfigForm from './PaidMemberConfigForm.vue'
|
||
import * as ConfigApi from "@/api/member/config";
|
||
|
||
/** 付费会员配置 列表 */
|
||
defineOptions({ name: 'PaidMemberConfig' })
|
||
|
||
const message = useMessage() // 消息弹窗
|
||
const { t } = useI18n() // 国际化
|
||
|
||
const loading = ref(true) // 列表的加载中
|
||
|
||
const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||
const formData = ref({
|
||
id: undefined,
|
||
openPaidMember: true,
|
||
paidMemberPrice: true
|
||
})
|
||
|
||
const formRules = reactive({})
|
||
const formRef = ref() // 表单 Ref
|
||
|
||
const onSubmit = async () => {
|
||
// 校验表单
|
||
if (!formRef) return
|
||
const valid = await formRef.value.validate()
|
||
if (!valid) return
|
||
// 提交请求
|
||
formLoading.value = true
|
||
try {
|
||
const data = formData.value as unknown as PadiMemberTypeVoApi.PaidMemberConfigVO
|
||
await PadiMemberTypeVoApi.PaidMemberConfigApi.savePaidMemberConfig(data)
|
||
message.success(t('common.updateSuccess'))
|
||
dialogVisible.value = false
|
||
} finally {
|
||
formLoading.value = false
|
||
}
|
||
}
|
||
|
||
/** 查询付费会员配置 */
|
||
const getPaidMemberConfig = async () =>{
|
||
try {
|
||
const data = await PadiMemberTypeVoApi.PaidMemberConfigApi.getPaidMemberConfig()
|
||
if(data == null){
|
||
return
|
||
}
|
||
formData.value = data
|
||
}finally {
|
||
}
|
||
}
|
||
|
||
|
||
// 使用 watch 来观察 openPaidMember 的变化
|
||
watch(
|
||
() => formData.value.openPaidMember,
|
||
(newVal) => {
|
||
if (!newVal) {
|
||
formData.value.paidMemberPrice = false; // 当 openPaidMember 变为 false 时,重置 paidMemberPriceStatus
|
||
}
|
||
// 注意:这里不需要处理 newVal 为 true 的情况,因为表单项会根据 v-if 指令的条件渲染
|
||
},
|
||
{ immediate: true } // 立即执行一次观察者回调,以确保初始状态正确
|
||
);
|
||
|
||
/** 初始化 **/
|
||
onMounted(() => {
|
||
getPaidMemberConfig()
|
||
})
|
||
</script>
|