会员详情,修改会员积分
							parent
							
								
									940a102546
								
							
						
					
					
						commit
						4b7e57e67d
					
				|  | @ -41,3 +41,13 @@ export const updateUser = async (data: UserVO) => { | |||
| export const updateUserLevel = async (data: any) => { | ||||
|   return await request.put({ url: `/member/user/update-level`, data }) | ||||
| } | ||||
| 
 | ||||
| // 修改会员用户积分
 | ||||
| export const updateUserPoint = async (data: any) => { | ||||
|   return await request.put({ url: `/member/user/update-point`, data }) | ||||
| } | ||||
| 
 | ||||
| // 修改会员用户余额
 | ||||
| export const updateUserBalance = async (data: any) => { | ||||
|   return await request.put({ url: `/member/user/update-balance`, data }) | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,128 @@ | |||
| <template> | ||||
|   <Dialog title="修改用户积分" v-model="dialogVisible" width="600"> | ||||
|     <el-form | ||||
|       ref="formRef" | ||||
|       :model="formData" | ||||
|       :rules="formRules" | ||||
|       label-width="100px" | ||||
|       v-loading="formLoading" | ||||
|     > | ||||
|       <el-form-item label="用户编号" prop="id"> | ||||
|         <el-input v-model="formData.id" class="!w-240px" disabled /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="用户昵称" prop="nickname"> | ||||
|         <el-input v-model="formData.nickname" class="!w-240px" disabled /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="变动前积分" prop="point"> | ||||
|         <el-input-number v-model="formData.point" class="!w-240px" disabled /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="变动类型" prop="changeType"> | ||||
|         <el-radio-group v-model="formData.changeType"> | ||||
|           <el-radio :label="1">增加</el-radio> | ||||
|           <el-radio :label="-1">减少</el-radio> | ||||
|         </el-radio-group> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="变动积分" prop="changePoint"> | ||||
|         <el-input-number v-model="formData.changePoint" class="!w-240px" :min="0" :precision="0" /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="变动后积分"> | ||||
|         <el-input-number v-model="pointResult" class="!w-240px" disabled /> | ||||
|       </el-form-item> | ||||
|     </el-form> | ||||
|     <template #footer> | ||||
|       <el-button @click="submitForm" type="primary" :disabled="formLoading">确 定</el-button> | ||||
|       <el-button @click="dialogVisible = false">取 消</el-button> | ||||
|     </template> | ||||
|   </Dialog> | ||||
| </template> | ||||
| <script setup lang="ts"> | ||||
| import * as UserApi from '@/api/member/user' | ||||
| 
 | ||||
| /** 修改用户积分表单 */ | ||||
| defineOptions({ name: 'UpdatePointForm' }) | ||||
| 
 | ||||
| const { t } = useI18n() // 国际化 | ||||
| const message = useMessage() // 消息弹窗 | ||||
| 
 | ||||
| const dialogVisible = ref(false) // 弹窗的是否展示 | ||||
| const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用 | ||||
| const formData = ref({ | ||||
|   id: undefined, | ||||
|   nickname: undefined, | ||||
|   point: 0, | ||||
|   changePoint: 0, | ||||
|   changeType: 1 | ||||
| }) | ||||
| const formRules = reactive({ | ||||
|   changePoint: [{ required: true, message: '变动积分不能为空', trigger: 'blur' }] | ||||
| }) | ||||
| const formRef = ref() // 表单 Ref | ||||
| 
 | ||||
| /** 打开弹窗 */ | ||||
| const open = async (id?: number) => { | ||||
|   dialogVisible.value = true | ||||
|   resetForm() | ||||
|   // 修改时,设置数据 | ||||
|   if (id) { | ||||
|     formLoading.value = true | ||||
|     try { | ||||
|       formData.value = await UserApi.getUser(id) | ||||
|       formData.value.changeType = 1 // 默认增加积分 | ||||
|       formData.value.changePoint = 0 // 变动积分默认0 | ||||
|     } finally { | ||||
|       formLoading.value = false | ||||
|     } | ||||
|   } | ||||
| } | ||||
| defineExpose({ open }) // 提供 open 方法,用于打开弹窗 | ||||
| 
 | ||||
| /** 提交表单 */ | ||||
| const emit = defineEmits(['success']) // 定义 success 事件,用于操作成功后的回调 | ||||
| const submitForm = async () => { | ||||
|   // 校验表单 | ||||
|   if (!formRef) return | ||||
|   const valid = await formRef.value.validate() | ||||
|   if (!valid) return | ||||
| 
 | ||||
|   if (formData.value.changePoint < 1) { | ||||
|     message.error('变动积分不能小于 1') | ||||
|     return | ||||
|   } | ||||
|   if (pointResult.value < 0) { | ||||
|     message.error('变动后的积分不能小于 0') | ||||
|     return | ||||
|   } | ||||
| 
 | ||||
|   // 提交请求 | ||||
|   formLoading.value = true | ||||
|   try { | ||||
|     await UserApi.updateUserPoint({ | ||||
|       id: formData.value.id, | ||||
|       point: formData.value.changePoint * formData.value.changeType | ||||
|     }) | ||||
| 
 | ||||
|     message.success(t('common.updateSuccess')) | ||||
|     dialogVisible.value = false | ||||
|     // 发送操作成功的事件 | ||||
|     emit('success') | ||||
|   } finally { | ||||
|     formLoading.value = false | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /** 重置表单 */ | ||||
| const resetForm = () => { | ||||
|   formData.value = { | ||||
|     id: undefined, | ||||
|     nickname: undefined, | ||||
|     levelId: undefined, | ||||
|     reason: undefined | ||||
|   } | ||||
|   formRef.value?.resetFields() | ||||
| } | ||||
| 
 | ||||
| /** 变动后的积分 */ | ||||
| const pointResult = computed( | ||||
|   () => formData.value.point + formData.value.changePoint * formData.value.changeType | ||||
| ) | ||||
| </script> | ||||
|  | @ -1,14 +0,0 @@ | |||
| <script lang="ts"> | ||||
| import { defineComponent } from 'vue' | ||||
| 
 | ||||
| export default defineComponent({ | ||||
|   name: 'GrowthList' | ||||
| }) | ||||
| </script> | ||||
| 
 | ||||
| <!-- TODO @梦:可以读取 member_experience_log 表 --> | ||||
| <template> | ||||
|   <div>成长值列表</div> | ||||
| </template> | ||||
| 
 | ||||
| <style scoped lang="scss"></style> | ||||
|  | @ -117,28 +117,56 @@ | |||
|         :formatter="dateFormatter" | ||||
|         width="180px" | ||||
|       /> | ||||
|       <el-table-column label="操作" align="center" width="180px" fixed="right"> | ||||
|       <el-table-column | ||||
|         label="操作" | ||||
|         align="center" | ||||
|         width="100px" | ||||
|         fixed="right" | ||||
|         :show-overflow-tooltip="false" | ||||
|       > | ||||
|         <template #default="scope"> | ||||
|           <el-button link type="primary" @click="openDetail(scope.row.id)">详情</el-button> | ||||
|           <el-button | ||||
|             link | ||||
|             type="primary" | ||||
|             @click="openForm('update', scope.row.id)" | ||||
|             v-hasPermi="['member:user:update']" | ||||
|           > | ||||
|             编辑 | ||||
|           </el-button> | ||||
|           <!-- todo @jason:增加一个【修改余额】 --> | ||||
|           <!-- todo @疯狂:增加一个【修改积分】,表单是:radio 增加/减少;input 具体的变化积分 --> | ||||
|           <!-- todo 放到更多菜单中 --> | ||||
|           <el-button | ||||
|             link | ||||
|             type="primary" | ||||
|             @click="updateLevelFormRef.open(scope.row.id)" | ||||
|             v-hasPermi="['member:user:update-level']" | ||||
|           > | ||||
|             修改等级 | ||||
|           </el-button> | ||||
|           <div class="flex items-center justify-center"> | ||||
|             <el-button link type="primary" @click="openDetail(scope.row.id)">详情</el-button> | ||||
|             <el-dropdown | ||||
|               @command="(command) => handleCommand(command, scope.row)" | ||||
|               v-hasPermi="[ | ||||
|                 'member:user:update', | ||||
|                 'member:user:update-level', | ||||
|                 'member:user:update-point', | ||||
|                 'member:user:update-balance' | ||||
|               ]" | ||||
|             > | ||||
|               <el-button type="primary" link><Icon icon="ep:d-arrow-right" /> 更多</el-button> | ||||
|               <template #dropdown> | ||||
|                 <el-dropdown-menu> | ||||
|                   <el-dropdown-item | ||||
|                     command="handleUpdate" | ||||
|                     v-if="checkPermi(['member:user:update'])" | ||||
|                   > | ||||
|                     编辑 | ||||
|                   </el-dropdown-item> | ||||
|                   <el-dropdown-item | ||||
|                     command="handleUpdateLevel" | ||||
|                     v-if="checkPermi(['member:user:update-level'])" | ||||
|                   > | ||||
|                     修改等级 | ||||
|                   </el-dropdown-item> | ||||
|                   <el-dropdown-item | ||||
|                     command="handleUpdatePoint" | ||||
|                     v-if="checkPermi(['member:user:update-point'])" | ||||
|                   > | ||||
|                     修改积分 | ||||
|                   </el-dropdown-item> | ||||
|                   <el-dropdown-item | ||||
|                     command="handleUpdateBlance" | ||||
|                     v-if="checkPermi(['member:user:update-balance'])" | ||||
|                   > | ||||
|                     修改余额(WIP) | ||||
|                   </el-dropdown-item> | ||||
|                 </el-dropdown-menu> | ||||
|               </template> | ||||
|             </el-dropdown> | ||||
|           </div> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|     </el-table> | ||||
|  | @ -155,6 +183,8 @@ | |||
|   <UserForm ref="formRef" @success="getList" /> | ||||
|   <!-- 修改用户等级弹窗 --> | ||||
|   <UpdateLevelForm ref="updateLevelFormRef" @success="getList" /> | ||||
|   <!-- 修改用户积分弹窗 --> | ||||
|   <UpdatePointForm ref="updatePointFormRef" @success="getList" /> | ||||
|   <!-- 发送优惠券弹窗 --> | ||||
|   <CouponSendForm ref="couponSendFormRef" /> | ||||
| </template> | ||||
|  | @ -166,8 +196,10 @@ import UserForm from './UserForm.vue' | |||
| import MemberTagSelect from '@/views/member/tag/components/MemberTagSelect.vue' | ||||
| import MemberLevelSelect from '@/views/member/level/components/MemberLevelSelect.vue' | ||||
| import MemberGroupSelect from '@/views/member/group/components/MemberGroupSelect.vue' | ||||
| import UpdateLevelForm from '@/views/member/user/UpdateLevelForm.vue' | ||||
| import UpdateLevelForm from './UpdateLevelForm.vue' | ||||
| import UpdatePointForm from './UpdatePointForm.vue' | ||||
| import CouponSendForm from '@/views/mall/promotion/coupon/components/CouponSendForm.vue' | ||||
| import { checkPermi } from '@/utils/permission' | ||||
| 
 | ||||
| defineOptions({ name: 'MemberUser' }) | ||||
| 
 | ||||
|  | @ -189,6 +221,7 @@ const queryParams = reactive({ | |||
| }) | ||||
| const queryFormRef = ref() // 搜索的表单 | ||||
| const updateLevelFormRef = ref() // 修改会员等级表单 | ||||
| const updatePointFormRef = ref() // 修改会员积分表单 | ||||
| const selectedIds = ref<number[]>([]) // 表格的选中 ID 数组 | ||||
| 
 | ||||
| /** 查询列表 */ | ||||
|  | @ -242,6 +275,26 @@ const openCoupon = () => { | |||
|   couponSendFormRef.value.open(selectedIds.value) | ||||
| } | ||||
| 
 | ||||
| /** 操作分发 */ | ||||
| const handleCommand = (command: string, row: UserApi.UserVO) => { | ||||
|   switch (command) { | ||||
|     case 'handleUpdate': | ||||
|       openForm('update', row.id) | ||||
|       break | ||||
|     case 'handleUpdateLevel': | ||||
|       updateLevelFormRef.value.open(row.id) | ||||
|       break | ||||
|     case 'handleUpdatePoint': | ||||
|       updatePointFormRef.value.open(row.id) | ||||
|       break | ||||
|     case 'handleUpdateBlance': | ||||
|       // todo @jason:增加一个【修改余额】 | ||||
|       break | ||||
|     default: | ||||
|       break | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /** 初始化 **/ | ||||
| onMounted(() => { | ||||
|   getList() | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 owen
						owen