From 5da53ab90d6152de28b8475cd9ccaa00abba45e8 Mon Sep 17 00:00:00 2001 From: zepengdev <lzpsmith@outlook.com> Date: Thu, 26 Jun 2025 22:45:18 +0800 Subject: [PATCH] fix: 优化店铺添加,预检查店铺名称,返回添加的店铺信息 --- oying-system/src/main/java/com/oying/modules/pc/store/service/impl/StoreServiceImpl.java | 211 ++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 179 insertions(+), 32 deletions(-) diff --git a/oying-system/src/main/java/com/oying/modules/pc/store/service/impl/StoreServiceImpl.java b/oying-system/src/main/java/com/oying/modules/pc/store/service/impl/StoreServiceImpl.java index 69597a5..8531306 100644 --- a/oying-system/src/main/java/com/oying/modules/pc/store/service/impl/StoreServiceImpl.java +++ b/oying-system/src/main/java/com/oying/modules/pc/store/service/impl/StoreServiceImpl.java @@ -1,24 +1,45 @@ package com.oying.modules.pc.store.service.impl; +import cn.hutool.core.collection.CollectionUtil; +import cn.hutool.core.collection.ListUtil; +import cn.hutool.core.util.ObjUtil; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.oying.exception.BadRequestException; +import com.oying.exception.EntityNotFoundException; +import com.oying.modules.pc.common.ValueUpdate; +import com.oying.modules.pc.store.converter.StoreAssembler; +import com.oying.modules.pc.store.converter.StoreQualificationAssembler; import com.oying.modules.pc.store.domain.Store; +import com.oying.modules.pc.store.domain.StoreQualification; +import com.oying.modules.pc.store.domain.StoreUser; +import com.oying.modules.pc.store.domain.dto.StoreCreateRequest; +import com.oying.modules.pc.store.domain.dto.StoreQualificationCreateRequest; import com.oying.modules.pc.store.domain.dto.StoreQueryCriteria; +import com.oying.modules.pc.store.domain.dto.StoreUpdateRequest; import com.oying.modules.pc.store.mapper.StoreMapper; +import com.oying.modules.pc.store.mapper.StoreUserMapper; +import com.oying.modules.pc.store.service.StoreQualificationService; import com.oying.modules.pc.store.service.StoreService; +import com.oying.service.BucketStorageService; import com.oying.utils.PageResult; import com.oying.utils.PageUtil; import com.oying.utils.SecurityUtils; +import com.oying.utils.StringUtils; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import java.math.BigDecimal; import java.time.LocalTime; -import java.time.ZonedDateTime; +import java.util.ArrayList; import java.util.List; +import java.util.Objects; import java.util.Optional; +import java.util.stream.Collectors; /** * 店铺Service业务层处理 @@ -32,6 +53,9 @@ public class StoreServiceImpl extends ServiceImpl<StoreMapper, Store> implements StoreService { private final StoreMapper storeMapper; + private final StoreUserMapper storeUserMapper; + private final StoreQualificationService qualificationService; + private final BucketStorageService bucketStorageService; @Override public PageResult<Store> queryByPage(StoreQueryCriteria criteria) { @@ -50,94 +74,143 @@ } @Override - public boolean create(Store store) { - // store.setStoreId(StoreIdGenerator.getId()); - return save(store); + public List<Store> queryUserStores(Long userId) { + return storeMapper.queryUserStores(userId); } @Override - public boolean updateLogo(Long storeId, String logo) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId).set(Store::getLogoImageId, logo); + @Transactional(rollbackFor = Exception.class) + public Store create(StoreCreateRequest request) { + // 检查店铺名称是否存在 + if (this.existsStoreName(request.getStoreName())) { + throw new BadRequestException("店铺名称已存在"); + } + // 创建店铺 + Store store = StoreAssembler.to(request); + storeMapper.insert(store); + this.processQualificationCreate(store, request.getQualificationList()); + this.bindUser(store.getStoreId()); + return store; + } + + @Override + @Transactional(rollbackFor = Exception.class) + public boolean update(StoreUpdateRequest request) { + Store existingStore = this.findOrThrow(request); + this.processImagesUpdate(request, existingStore); + this.processQualificationUpdate(request); + existingStore.copy(StoreAssembler.to(request)); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(existingStore.getStoreId(), existingStore.getVersion()); + return this.update(existingStore, wrapper); + } + + @Override + @Transactional(rollbackFor = Exception.class) + public boolean updateLogo(Long storeId, String logo, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) + .set(Store::getLogoImageId, logo); return update(wrapper); } @Override - public boolean updateName(Long storeId, String storeName) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateName(Long storeId, String storeName, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getStoreName, storeName); return update(wrapper); } @Override - public boolean updateDescription(Long storeId, String description) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateDescription(Long storeId, String description, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getDescription, description); return update(wrapper); } @Override - public boolean updateContactPhone(Long storeId, String contactPhone) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateContactPhone(Long storeId, String contactPhone, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getContactPhone, contactPhone); return update(wrapper); } @Override - public boolean updateAddress(Long storeId, String address) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateAddress(Long storeId, String address, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getAddress, address); return update(wrapper); } @Override - public boolean updateLocation(Long storeId, Double longitude, Double latitude) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateLocation(Long storeId, Double longitude, Double latitude, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getLongitude, longitude) .set(Store::getLatitude, latitude); return update(wrapper); } @Override - public boolean updateRadius(Long storeId, Integer radius) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateRadius(Long storeId, Integer radius, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getRadius, radius); return update(wrapper); } @Override - public boolean updatePlatformCategory(Long storeId, Long platformCategory) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updatePlatformCategory(Long storeId, Long platformCategory, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getPlatformCategoryId, platformCategory); return update(wrapper); } @Override - public boolean updateBusinessHours(Long storeId, LocalTime openTime, LocalTime endTime) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateBusinessHours(Long storeId, LocalTime openTime, LocalTime endTime, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getOpenTime, openTime) .set(Store::getCloseTime, endTime); return update(wrapper); } @Override - public boolean updateDeliveryMinimum(Long storeId, BigDecimal deliveryMinimum) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateDeliveryMinimum(Long storeId, BigDecimal deliveryMinimum, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getDeliveryMinimum, deliveryMinimum); return update(wrapper); } @Override - public boolean updateDeliveryFee(Long storeId, BigDecimal deliveryFee) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateDeliveryFee(Long storeId, BigDecimal deliveryFee, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getDeliveryFee, deliveryFee); return update(wrapper); } @Override - public boolean updateStatus(Long storeId, Integer status) { - LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId) + public boolean updateStatus(Long storeId, Integer status, Long version) { + Store existingStore = this.findOrThrow(storeId, version); + LambdaUpdateWrapper<Store> wrapper = this.createLambdaUpdateWrapper(storeId, existingStore.getVersion()) .set(Store::getStatus, status); return update(wrapper); + } + + @Override + public boolean existsStoreName(String storeName) { + if (StringUtils.isEmpty(storeName)) { + return true; + } + LambdaQueryWrapper<Store> wrapper = new LambdaQueryWrapper<Store>() + .eq(Store::getStoreName, storeName); + return storeMapper.selectCount(wrapper) > 0; } @Override @@ -149,9 +222,83 @@ return Optional.ofNullable(store).map(i -> merchantId.equals(i.getMerchantId())).orElse(false); } - private LambdaUpdateWrapper<Store> createLambdaUpdateWrapper(Long storeId) { - return new LambdaUpdateWrapper<Store>() - .eq(Store::getStoreId, storeId) - .set(Store::getUpdateBy, SecurityUtils.getCurrentUserId()); + private void processQualificationCreate(Store store, List<StoreQualificationCreateRequest> qualificationRequests) { + if (CollectionUtil.isNotEmpty(qualificationRequests)) { + List<StoreQualification> storeQualificationList = qualificationRequests.stream().map(i -> { + i.setStoreId(store.getStoreId()); + return StoreQualificationAssembler.to(i); + }).collect(Collectors.toList()); + storeQualificationList.forEach(i -> i.setStoreId(store.getStoreId())); + qualificationService.batchCreate(storeQualificationList); + } + } + + private void bindUser(Long storeId) { + StoreUser storeUser = new StoreUser(); + storeUser.setStoreId(storeId); + storeUser.setUserId(SecurityUtils.getCurrentUserId()); + storeUser.setRoleType(""); + storeUser.setPermissions(""); + storeUserMapper.insert(storeUser); + } + + private LambdaUpdateWrapper<Store> createLambdaUpdateWrapper(Long storeId, Long version) { + Objects.requireNonNull(storeId, String.format("方法 '%s' 调用失败:参数 'storeId'(店铺ID)不能为 null", "createLambdaUpdateWrapper")); + LambdaUpdateWrapper<Store> updateWrapper = new LambdaUpdateWrapper<>(); + updateWrapper.eq(Store::getStoreId, storeId); + if (ObjUtil.isNotEmpty(version)) { + updateWrapper.eq(Store::getVersion, version); + updateWrapper.set(Store::getVersion, version + 1); + } + updateWrapper.set(Store::getUpdateBy, SecurityUtils.getCurrentUserId()); + return updateWrapper; + } + + private Store findOrThrow(StoreUpdateRequest request) { + return this.findOrThrow(request.getStoreId(), request.getVersion()); + } + + private Store findOrThrow(Long storeId, Long version) { + Objects.requireNonNull(storeId, String.format("方法 '%s' 调用失败:参数 'storeId'(店铺ID)不能为 null", "findOrThrow")); + LambdaQueryWrapper<Store> wrapper = new LambdaQueryWrapper<>(); + wrapper.eq(Store::getStoreId, storeId); + if (ObjUtil.isNotEmpty(version)) { + wrapper.eq(Store::getVersion, version); + } + Store existingStore = storeMapper.selectOne(wrapper); + if (ObjUtil.isEmpty(existingStore)) { + throw new EntityNotFoundException(Store.class, "storeId", storeId.toString()); + } + return existingStore; + } + + private List<Long> getDeleteImageIds(List<ValueUpdate<Long>> imageValues) { + List<Long> deleteImageIds = new ArrayList<>(); + for (ValueUpdate<Long> imageValue : imageValues) { + if (imageValue.isChangeAndOldValueNotEmpty()) { + deleteImageIds.add(imageValue.getOldValue()); + } + } + return deleteImageIds; + } + + private void processImagesUpdate(StoreUpdateRequest request, Store existingStore) { + List<ValueUpdate<Long>> imageValues = ListUtil.toList( + new ValueUpdate<>(request.getLogoImageId(), existingStore.getLogoImageId()), + new ValueUpdate<>(request.getCoverImageId(), existingStore.getCoverImageId()) + ); + bucketStorageService.deleteAll(this.getDeleteImageIds(imageValues)); + } + + private void processQualificationUpdate(StoreUpdateRequest request) { + if (CollectionUtil.isNotEmpty(request.getDeletedQualificationIds())) { + qualificationService.deleteAll(request.getDeletedQualificationIds()); + } + if (CollectionUtil.isNotEmpty(request.getUpdatedQualifications())) { + qualificationService.batchUpdate(request.getUpdatedQualifications()); + } + if (CollectionUtil.isNotEmpty(request.getNewQualifications())) { + qualificationService.batchCreate(request.getNewQualifications()); + } } } -- Gitblit v1.9.3