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