package com.doumee.service.business.impl; import com.doumee.core.constants.Constants; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.DateUtil; import com.doumee.core.utils.Utils; import com.doumee.dao.business.DiscountMemberMapper; import com.doumee.dao.business.RefundMapper; import com.doumee.dao.business.TransactionsMapper; import com.doumee.dao.business.model.DiscountMember; import com.doumee.dao.business.model.Transactions; import com.doumee.service.business.TransactionsService; 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 org.checkerframework.checker.units.qual.A; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.List; import java.util.Objects; /** * 交易流水表Service实现 * @author 江蹄蹄 * @date 2023/09/27 18:08 */ @Service public class TransactionsServiceImpl implements TransactionsService { @Autowired private TransactionsMapper transactionsMapper; @Autowired private DiscountMemberMapper discountMemberMapper; @Autowired private RefundMapper refundMapper; @Override public String create(Transactions transactions) { transactionsMapper.insert(transactions); return transactions.getId(); } @Override public void deleteById(String id) { transactionsMapper.deleteById(id); } @Override public void delete(Transactions transactions) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(transactions); transactionsMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } transactionsMapper.deleteBatchIds(ids); } @Override public void updateById(Transactions transactions) { transactionsMapper.updateById(transactions); } @Override public void updateByIdInBatch(List transactionss) { if (CollectionUtils.isEmpty(transactionss)) { return; } for (Transactions transactions: transactionss) { this.updateById(transactions); } } @Override public Transactions findById(String id) { return transactionsMapper.selectById(id); } @Override public Transactions findOne(Transactions transactions) { QueryWrapper wrapper = new QueryWrapper<>(transactions); return transactionsMapper.selectOne(wrapper.last(" limit 1")); } @Override public List findList(Transactions transactions) { QueryWrapper wrapper = new QueryWrapper<>(transactions); return transactionsMapper.selectList(wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); if (pageWrap.getModel().getId() != null) { queryWrapper.lambda().eq(Transactions::getId, pageWrap.getModel().getId()); } if (pageWrap.getModel().getCreateDate() != null) { queryWrapper.lambda().ge(Transactions::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); queryWrapper.lambda().le(Transactions::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); } if (pageWrap.getModel().getCreator() != null) { queryWrapper.lambda().eq(Transactions::getCreator, pageWrap.getModel().getCreator()); } if (pageWrap.getModel().getEditDate() != null) { queryWrapper.lambda().ge(Transactions::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); queryWrapper.lambda().le(Transactions::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); } if (pageWrap.getModel().getEditor() != null) { queryWrapper.lambda().eq(Transactions::getEditor, pageWrap.getModel().getEditor()); } if (pageWrap.getModel().getIsdeleted() != null) { queryWrapper.lambda().eq(Transactions::getIsdeleted, pageWrap.getModel().getIsdeleted()); } if (pageWrap.getModel().getInfo() != null) { queryWrapper.lambda().eq(Transactions::getInfo, pageWrap.getModel().getInfo()); } if (pageWrap.getModel().getOrderId() != null) { queryWrapper.lambda().eq(Transactions::getOrderId, pageWrap.getModel().getOrderId()); } if (pageWrap.getModel().getMemberId() != null) { queryWrapper.lambda().eq(Transactions::getMemberId, pageWrap.getModel().getMemberId()); } if (pageWrap.getModel().getMoney() != null) { queryWrapper.lambda().eq(Transactions::getMoney, pageWrap.getModel().getMoney()); } if (pageWrap.getModel().getType() != null) { queryWrapper.lambda().eq(Transactions::getType, pageWrap.getModel().getType()); } if (pageWrap.getModel().getPreOrderid() != null) { queryWrapper.lambda().eq(Transactions::getPreOrderid, pageWrap.getModel().getPreOrderid()); } if (pageWrap.getModel().getOnlineOrderid() != null) { queryWrapper.lambda().eq(Transactions::getOnlineOrderid, pageWrap.getModel().getOnlineOrderid()); } if (pageWrap.getModel().getDoneDate() != null) { queryWrapper.lambda().eq(Transactions::getDoneDate, pageWrap.getModel().getDoneDate()); } if (pageWrap.getModel().getTitle() != null) { queryWrapper.lambda().eq(Transactions::getTitle, pageWrap.getModel().getTitle()); } if (pageWrap.getModel().getContent() != null) { queryWrapper.lambda().eq(Transactions::getContent, pageWrap.getModel().getContent()); } if (pageWrap.getModel().getBalance() != null) { queryWrapper.lambda().eq(Transactions::getBalance, pageWrap.getModel().getBalance()); } if (pageWrap.getModel().getObjType() != null) { queryWrapper.lambda().eq(Transactions::getObjType, pageWrap.getModel().getObjType()); } if (pageWrap.getModel().getObjId() != null) { queryWrapper.lambda().eq(Transactions::getObjId, pageWrap.getModel().getObjId()); } for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); } else { queryWrapper.orderByAsc(sortData.getProperty()); } } return PageData.from(transactionsMapper.selectPage(page, queryWrapper)); } @Override public long count(Transactions transactions) { QueryWrapper wrapper = new QueryWrapper<>(transactions); return transactionsMapper.selectCount(wrapper); } @Override public PageData findPageForMini(PageWrap pageWrap,String memberId) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); queryWrapper.lambda().eq(Transactions::getMemberId, memberId); queryWrapper.orderByDesc("create_date"); PageData pageData = PageData.from(transactionsMapper.selectPage(page, queryWrapper)); for (Transactions transactions:pageData.getRecords()) { if(Constants.equalsInteger(transactions.getType(),Constants.TRANSACTIONS_TYPE.DISCOUNT.getKey())){ //购买套餐 处理内容 DiscountMember discountMember = discountMemberMapper.selectById(transactions.getObjId()); if(Objects.nonNull(discountMember)){ transactions.setContent(discountMember.getName() +" 有效期" + DateUtil.dateToString(discountMember.getUseStartDate(),"yyyy-MM-dd") +"-"+DateUtil.dateToString(discountMember.getUseEndDate(),"yyyy-MM-dd")); } }else if(Constants.equalsInteger(transactions.getType(),Constants.TRANSACTIONS_TYPE.PLATFORM_REFUND.getKey())){ DiscountMember discountMember = discountMemberMapper.selectOne( new QueryWrapper().lambda().eq(DiscountMember::getGoodsorderId, transactions.getOrderId()).last("limit 1")); if(Objects.nonNull(discountMember)){ transactions.setContent(discountMember.getName() +" 有效期" + DateUtil.dateToString(discountMember.getUseStartDate(),"yyyy-MM-dd") +"-"+DateUtil.dateToString(discountMember.getUseEndDate(),"yyyy-MM-dd")); } } } return pageData; } }