From 5a8a90c095280fbd2106869ecd2bad10e01a57a6 Mon Sep 17 00:00:00 2001 From: 101captain <237651143@qq.com> Date: 星期四, 23 十二月 2021 18:10:22 +0800 Subject: [PATCH] 12/23 大屏修改 --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java | 116 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 114 insertions(+), 2 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java index 62d80f9..e32a082 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java @@ -1,11 +1,20 @@ package com.panzhihua.service_community.service.impl; +import org.springframework.beans.BeanUtils; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.panzhihua.common.model.dtos.shop.ComShopAddressDTO; +import com.panzhihua.common.model.dtos.shop.PageComShopAddressDTO; +import com.panzhihua.common.model.vos.R; import com.panzhihua.service_community.dao.ComShopUserAddressDAO; import com.panzhihua.service_community.model.dos.ComShopUserAddressDO; import com.panzhihua.service_community.service.ComShopUserAddressService; + import lombok.extern.slf4j.Slf4j; -import org.springframework.stereotype.Service; /** * @auther lyq @@ -14,6 +23,109 @@ */ @Slf4j @Service -public class ComShopUserAddressServiceImpl extends ServiceImpl<ComShopUserAddressDAO, ComShopUserAddressDO> implements ComShopUserAddressService { +public class ComShopUserAddressServiceImpl extends ServiceImpl<ComShopUserAddressDAO, ComShopUserAddressDO> + implements ComShopUserAddressService { + + /** + * 查询用户收获地址列表 + * + * @param comShopAddressDTO + * 请求参数 + * @return 用户收货地址列表 + */ + @Override + public R shopUserAddressList(PageComShopAddressDTO comShopAddressDTO) { + Page page = new Page<>(comShopAddressDTO.getPageNum(), comShopAddressDTO.getPageSize()); + return R.ok(this.baseMapper.pageUserAddressList(page, comShopAddressDTO.getUserId())); + } + + /** + * 用户添加收货地址 + * + * @param comShopAddressDTO + * 请求参数 + * @return 添加结果 + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R shopAddUserAddress(ComShopAddressDTO comShopAddressDTO) { + ComShopUserAddressDO userAddressDO = new ComShopUserAddressDO(); + BeanUtils.copyProperties(comShopAddressDTO, userAddressDO); + + // 如果新增的地址为默认地址,需要修改原来的默认地址为不默认 + if (userAddressDO.getIsDefault().equals(ComShopUserAddressDO.isDefault.yes)) { + ComShopUserAddressDO oldUserAddressDO = this.baseMapper.selectOne(new QueryWrapper<ComShopUserAddressDO>() + .eq("user_id", comShopAddressDTO.getUserId()).eq("is_default", ComShopUserAddressDO.isDefault.yes)); + if (oldUserAddressDO != null) { + oldUserAddressDO.setIsDefault(ComShopUserAddressDO.isDefault.no); + this.baseMapper.updateById(oldUserAddressDO); + } + } + + if (this.baseMapper.insert(userAddressDO) > 0) { + return R.ok(); + } else { + return R.fail("添加收货地址失败"); + } + } + + /** + * 用户修改收货地址 + * + * @param comShopAddressDTO + * 请求参数 + * @return 修改结果 + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R shopEditUserAddress(ComShopAddressDTO comShopAddressDTO) { + + // 查询用户收货地址 + ComShopUserAddressDO userAddressDO = this.baseMapper.selectById(comShopAddressDTO.getAddressId()); + if (userAddressDO == null) { + return R.fail("未查询到用户收货地址信息"); + } + + BeanUtils.copyProperties(comShopAddressDTO, userAddressDO); + // 如果要修改的地址为默认地址,需要修改原来的默认地址为不默认 + if (comShopAddressDTO.getIsDefault().equals(ComShopUserAddressDO.isDefault.yes)) { + ComShopUserAddressDO oldUserAddressDO = this.baseMapper.selectOne(new QueryWrapper<ComShopUserAddressDO>() + .eq("user_id", comShopAddressDTO.getUserId()).eq("is_default", ComShopUserAddressDO.isDefault.yes)); + if (oldUserAddressDO != null) { + // 判断当前要修改的默认地址是否本来就是默认地址 + if (!oldUserAddressDO.getId().equals(userAddressDO.getId())) { + oldUserAddressDO.setIsDefault(ComShopUserAddressDO.isDefault.no); + this.baseMapper.updateById(oldUserAddressDO); + } + } + } + + if (this.baseMapper.updateById(userAddressDO) > 0) { + return R.ok(); + } else { + return R.fail("添加收货地址失败"); + } + } + + /** + * 用户删除收货地址 + * + * @param addressId + * 收货地址id + * @return 删除结果 + */ + public R shopDelUserAddress(Long addressId) { + // 查询用户收货地址 + ComShopUserAddressDO userAddressDO = this.baseMapper.selectById(addressId); + if (userAddressDO == null) { + return R.fail("未查询到用户收货地址信息"); + } + userAddressDO.setDeleteStatus(1); + if (this.baseMapper.updateById(userAddressDO) > 0) { + return R.ok(); + } else { + return R.fail("删除收货地址失败"); + } + } } -- Gitblit v1.7.1