From b6082fe75b377ac9c177736d98f36ae46e7cdb70 Mon Sep 17 00:00:00 2001 From: 罗yu 元桥 <2376770955@qq.com> Date: 星期三, 28 四月 2021 10:20:55 +0800 Subject: [PATCH] Merge branch 'master' into 'test' --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopUserAddressServiceImpl.java | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 102 insertions(+), 0 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..4af6ef2 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,19 @@ package com.panzhihua.service_community.service.impl; +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.common.utlis.StringUtils; 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.beans.BeanUtils; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; /** * @auther lyq @@ -16,4 +24,98 @@ @Service 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