From c313a253b1fcdc75b6be5db575fc2b29fb407021 Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期三, 15 四月 2026 20:05:04 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
server/services/src/main/java/com/doumee/service/business/impl/AddrServiceImpl.java | 171 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 171 insertions(+), 0 deletions(-)
diff --git a/server/services/src/main/java/com/doumee/service/business/impl/AddrServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/AddrServiceImpl.java
new file mode 100644
index 0000000..c9e5dbc
--- /dev/null
+++ b/server/services/src/main/java/com/doumee/service/business/impl/AddrServiceImpl.java
@@ -0,0 +1,171 @@
+package com.doumee.service.business.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.doumee.core.constants.Constants;
+import com.doumee.core.constants.ResponseStatus;
+import com.doumee.core.exception.BusinessException;
+import com.doumee.core.model.LoginUserInfo;
+import com.doumee.core.model.PageData;
+import com.doumee.core.model.PageWrap;
+import com.doumee.core.utils.Utils;
+import com.doumee.dao.business.AddrMapper;
+import com.doumee.dao.business.model.Addr;
+import com.doumee.service.business.AddrService;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.shiro.SecurityUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.CollectionUtils;
+
+import java.util.Date;
+import java.util.List;
+import java.util.Objects;
+
+/**
+ * 鍦板潃绨縎ervice瀹炵幇
+ * @author rk
+ * @date 2026/04/15
+ */
+@Service
+public class AddrServiceImpl implements AddrService {
+
+ @Autowired
+ private AddrMapper addrMapper;
+
+ @Override
+ @Transactional(rollbackFor = {Exception.class, BusinessException.class})
+ public Integer create(Addr addr) {
+ LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ addr.setDeleted(Constants.ZERO);
+ addr.setCreateTime(new Date());
+ addr.setCreateUser(loginUserInfo.getId());
+ addr.setUpdateTime(new Date());
+ addr.setUpdateUser(loginUserInfo.getId());
+ addrMapper.insert(addr);
+ return addr.getId();
+ }
+
+ @Override
+ public void deleteById(Integer id) {
+ addrMapper.update(new UpdateWrapper<Addr>().lambda()
+ .set(Addr::getDeleted, Constants.ONE)
+ .eq(Addr::getId, id));
+ }
+
+ @Override
+ public void delete(Addr addr) {
+ UpdateWrapper<Addr> deleteWrapper = new UpdateWrapper<>(addr);
+ addrMapper.delete(deleteWrapper);
+ }
+
+ @Override
+ public void deleteByIdInBatch(List<Integer> ids) {
+ if (CollectionUtils.isEmpty(ids)) {
+ return;
+ }
+ for (Integer id : ids) {
+ this.deleteById(id);
+ }
+ }
+
+ @Override
+ @Transactional(rollbackFor = {Exception.class, BusinessException.class})
+ public void updateById(Addr addr) {
+ if (Objects.isNull(addr) || Objects.isNull(addr.getId())) {
+ throw new BusinessException(ResponseStatus.BAD_REQUEST);
+ }
+ LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ addr.setUpdateTime(new Date());
+ addr.setUpdateUser(loginUserInfo.getId());
+ addrMapper.updateById(addr);
+ }
+
+ @Override
+ public void updateStatus(Addr addr) {
+ if (Objects.isNull(addr) || Objects.isNull(addr.getId())) {
+ throw new BusinessException(ResponseStatus.BAD_REQUEST);
+ }
+ LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+ addr.setUpdateTime(new Date());
+ addr.setUpdateUser(loginUserInfo.getId());
+ addrMapper.updateById(addr);
+ }
+
+ @Override
+ public void updateByIdInBatch(List<Addr> addrs) {
+ if (CollectionUtils.isEmpty(addrs)) {
+ return;
+ }
+ for (Addr addr : addrs) {
+ this.updateById(addr);
+ }
+ }
+
+ @Override
+ public Addr findById(Integer id) {
+ Addr addr = addrMapper.selectById(id);
+ if (Objects.isNull(addr)) {
+ throw new BusinessException(ResponseStatus.DATA_EMPTY);
+ }
+ return addr;
+ }
+
+ @Override
+ public Addr findOne(Addr addr) {
+ QueryWrapper<Addr> wrapper = new QueryWrapper<>(addr);
+ return addrMapper.selectOne(wrapper);
+ }
+
+ @Override
+ public List<Addr> findList(Addr addr) {
+ QueryWrapper<Addr> wrapper = new QueryWrapper<>(addr);
+ return addrMapper.selectList(wrapper);
+ }
+
+ @Override
+ public PageData<Addr> findPage(PageWrap<Addr> pageWrap) {
+ IPage<Addr> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
+ QueryWrapper<Addr> queryWrapper = new QueryWrapper<>();
+ Utils.MP.blankToNull(pageWrap.getModel());
+ pageWrap.getModel().setDeleted(Constants.ZERO);
+ if (pageWrap.getModel().getDeleted() != null) {
+ queryWrapper.lambda().eq(Addr::getDeleted, pageWrap.getModel().getDeleted());
+ }
+ if (pageWrap.getModel().getMemberId() != null) {
+ queryWrapper.lambda().eq(Addr::getMemberId, pageWrap.getModel().getMemberId());
+ }
+ if (pageWrap.getModel().getIsDefault() != null) {
+ queryWrapper.lambda().eq(Addr::getIsDefault, pageWrap.getModel().getIsDefault());
+ }
+ if (StringUtils.isNotBlank(pageWrap.getModel().getName())) {
+ queryWrapper.lambda().like(Addr::getName, pageWrap.getModel().getName());
+ }
+ if (StringUtils.isNotBlank(pageWrap.getModel().getPhone())) {
+ queryWrapper.lambda().like(Addr::getPhone, pageWrap.getModel().getPhone());
+ }
+ if (StringUtils.isNotBlank(pageWrap.getModel().getAddr())) {
+ queryWrapper.lambda().like(Addr::getAddr, pageWrap.getModel().getAddr());
+ }
+ if (pageWrap.getModel().getAreaId() != null) {
+ queryWrapper.lambda().eq(Addr::getAreaId, pageWrap.getModel().getAreaId());
+ }
+ for (PageWrap.SortData sortData : pageWrap.getSorts()) {
+ if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
+ queryWrapper.orderByDesc(sortData.getProperty());
+ } else {
+ queryWrapper.orderByAsc(sortData.getProperty());
+ }
+ }
+ return PageData.from(addrMapper.selectPage(page, queryWrapper));
+ }
+
+ @Override
+ public long count(Addr addr) {
+ QueryWrapper<Addr> wrapper = new QueryWrapper<>(addr);
+ return addrMapper.selectCount(wrapper);
+ }
+}
--
Gitblit v1.9.3