package com.doumee.service.business.impl; import com.alibaba.fastjson.JSONArray; import com.doumee.biz.system.SystemDictDataBiz; import com.doumee.core.constants.Constants; 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.CategoryMapper; import com.doumee.dao.business.PricingRuleMapper; import com.doumee.dao.business.model.Category; import com.doumee.dao.business.model.PricingRule; import com.doumee.dao.system.model.SystemUser; import com.doumee.service.business.CategoryService; 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.github.yulichang.base.MPJBaseMapper; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.checkerframework.checker.units.qual.C; 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; /** * 分类信息表Service实现 * @author 江蹄蹄 * @date 2025/07/09 12:00 */ @Service public class CategoryServiceImpl implements CategoryService { @Autowired private CategoryMapper categoryMapper; @Autowired private PricingRuleMapper pricingRuleMapper; @Autowired private SystemDictDataBiz systemDictDataBiz; @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public Integer create(Category category) { if(Objects.isNull(category) || Objects.isNull(category.getType()) || Objects.isNull(category.getName()) || StringUtils.isBlank(category.getDetail()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } validateByType(category); LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); category.setDeleted(Constants.ZERO); category.setCreateTime(new Date()); category.setCreateUser(loginUserInfo.getId()); category.setUpdateTime(new Date()); category.setUpdateUser(loginUserInfo.getId()); categoryMapper.insert(category); return category.getId(); } @Override public void deleteById(Integer id) { categoryMapper.update(new UpdateWrapper().lambda().set(Category::getDeleted,Constants.ONE).eq(Category::getId,id)); // categoryMapper.deleteById(id); } @Override public void delete(Category category) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(category); categoryMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } categoryMapper.deleteBatchIds(ids); } @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public void updateById(Category category) { if(Objects.isNull(category) || Objects.isNull(category.getId()) || Objects.isNull(category.getType()) || Objects.isNull(category.getName()) || StringUtils.isBlank(category.getDetail()) ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } validateByType(category); LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); category.setUpdateTime(new Date()); category.setUpdateUser(loginUserInfo.getId()); categoryMapper.updateById(category); } @Override public void updateStatus(Category category) { if(Objects.isNull(category) || Objects.isNull(category.getId())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); category.setUpdateTime(new Date()); category.setUpdateUser(loginUserInfo.getId()); categoryMapper.updateById(category); } @Override public void updateByIdInBatch(List categorys) { if (CollectionUtils.isEmpty(categorys)) { return; } for (Category category: categorys) { this.updateById(category); } } @Override public Category findById(Integer id) { Category category = categoryMapper.selectById(id); if(Objects.isNull(category)){ throw new BusinessException(ResponseStatus.DATA_EMPTY); } if(StringUtils.isNotBlank(category.getIcon())){ String path = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.CATEGORY_FILES).getCode(); category.setIconFull(path + category.getIcon()); } return category; } @Override public Category findOne(Category category) { QueryWrapper wrapper = new QueryWrapper<>(category); return categoryMapper.selectOne(wrapper); } @Override public List findList(Category category) { QueryWrapper wrapper = new QueryWrapper<>(category); return categoryMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); MPJLambdaWrapper queryWrapper = new MPJLambdaWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); pageWrap.getModel().setDeleted(Constants.ZERO); queryWrapper.selectAll(Category.class) .selectAs(SystemUser::getUsername, Category::getUpdateUserName) .leftJoin(SystemUser.class,SystemUser::getId,Category::getUpdateUser); if (pageWrap.getModel().getId() != null) { queryWrapper.eq(Category::getId, pageWrap.getModel().getId()); } if (pageWrap.getModel().getDeleted() != null) { queryWrapper.eq(Category::getDeleted, pageWrap.getModel().getDeleted()); } if (pageWrap.getModel().getStatus() != null) { queryWrapper.eq(Category::getStatus, pageWrap.getModel().getStatus()); } if (pageWrap.getModel().getCreateUser() != null) { queryWrapper.eq(Category::getCreateUser, pageWrap.getModel().getCreateUser()); } if (pageWrap.getModel().getCreateTime() != null) { queryWrapper.ge(Category::getCreateTime, Utils.Date.getStart(pageWrap.getModel().getCreateTime())); queryWrapper.le(Category::getCreateTime, Utils.Date.getEnd(pageWrap.getModel().getCreateTime())); } if (pageWrap.getModel().getUpdateUser() != null) { queryWrapper.eq(Category::getUpdateUser, pageWrap.getModel().getUpdateUser()); } if (pageWrap.getModel().getUpdateTime() != null) { queryWrapper.ge(Category::getUpdateTime, Utils.Date.getStart(pageWrap.getModel().getUpdateTime())); queryWrapper.le(Category::getUpdateTime, Utils.Date.getEnd(pageWrap.getModel().getUpdateTime())); } if (pageWrap.getModel().getRemark() != null) { queryWrapper.eq(Category::getRemark, pageWrap.getModel().getRemark()); } if (pageWrap.getModel().getName() != null) { queryWrapper.like(Category::getName, pageWrap.getModel().getName()); } if (pageWrap.getModel().getType() != null) { queryWrapper.eq(Category::getType, pageWrap.getModel().getType()); } if (pageWrap.getModel().getDetail() != null) { queryWrapper.eq(Category::getDetail, pageWrap.getModel().getDetail()); } if (pageWrap.getModel().getIcon() != null) { queryWrapper.eq(Category::getIcon, pageWrap.getModel().getIcon()); } queryWrapper.orderByAsc(Category::getSortnum); PageData result =PageData.from(categoryMapper.selectJoinPage(page, Category.class,queryWrapper)); if(result!=null && result.getRecords()!=null){ String path = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.CATEGORY_FILES).getCode(); for(Category cate : result.getRecords()){ try { if(StringUtils.isNotBlank(cate.getIcon())){ cate.setIconFull(path + cate.getIcon()); } }catch (Exception e){ } } } return result; } @Override public long count(Category category) { QueryWrapper wrapper = new QueryWrapper<>(category); return categoryMapper.selectCount(wrapper); } @Override public List getCategoryList(Integer type){ List categoryList = categoryMapper.selectList(new QueryWrapper().lambda().eq(Category::getDeleted,Constants.ZERO).eq(Category::getStatus,Constants.ZERO) .eq(Objects.nonNull(type),Category::getType,type) .orderByAsc(Category::getSortnum) ); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(categoryList)){ String path = systemDictDataBiz.queryByCode(Constants.OSS,Constants.RESOURCE_PATH).getCode() +systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.CATEGORY_FILES).getCode(); for (Category category:categoryList) { if(StringUtils.isNotBlank(category.getIcon())){ category.setIconFull(path + category.getIcon()); } } } return categoryList; } @Override public List getCitySizeList(Integer cityId) { // 1. 查询该城市已配置的异地寄送规则(pricing_rule type=1),获取fieldA(物品尺寸主键) List rules = pricingRuleMapper.selectList(new QueryWrapper().lambda() .eq(PricingRule::getDeleted, Constants.ZERO) .eq(PricingRule::getType, Constants.ONE) .eq(PricingRule::getCityId, cityId)); if (CollectionUtils.isEmpty(rules)) { return java.util.Collections.emptyList(); } List sizeIds = new java.util.ArrayList<>(); for (PricingRule rule : rules) { if (StringUtils.isNotBlank(rule.getFieldA())) { sizeIds.add(Integer.parseInt(rule.getFieldA())); } } if (sizeIds.isEmpty()) { return java.util.Collections.emptyList(); } // 2. 查询对应的物品尺寸(category type=4) List sizeList = categoryMapper.selectList(new QueryWrapper().lambda() .eq(Category::getDeleted, Constants.ZERO) .eq(Category::getStatus, Constants.ZERO) .eq(Category::getType, Constants.FOUR) .in(Category::getId, sizeIds) .orderByAsc(Category::getSortnum)); // 3. 拼接图标全路径 if (!CollectionUtils.isEmpty(sizeList)) { String path = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.RESOURCE_PATH).getCode() + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.CATEGORY_FILES).getCode(); for (Category cate : sizeList) { if (StringUtils.isNotBlank(cate.getIcon())) { cate.setIconFull(path + cate.getIcon()); } } } return sizeList; } private void validateByType(Category category) { if (Constants.equalsInteger(category.getType(), Constants.ONE)) { if (StringUtils.isBlank(category.getOtherField())) { throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "车辆类型必须填写附属字段"); } } else if (Constants.equalsInteger(category.getType(), Constants.TWO)) { if (Objects.isNull(category.getRelationId())) { throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "物品分类必须选择关联物品等级"); } } else if (Constants.equalsInteger(category.getType(), Constants.FOUR)) { if (StringUtils.isBlank(category.getIcon())) { throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), "物品尺寸必须上传图标"); } } } }