|
|
@@ -1,24 +1,27 @@
|
|
|
package org.dromara.backstage.consumption.service.impl;
|
|
|
|
|
|
+import cn.hutool.core.util.ObjUtil;
|
|
|
import com.baomidou.dynamic.datasource.annotation.DS;
|
|
|
-import org.dromara.common.core.utils.MapstructUtils;
|
|
|
-import org.dromara.common.core.utils.StringUtils;
|
|
|
-import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
-import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
-import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import lombok.RequiredArgsConstructor;
|
|
|
-import org.springframework.stereotype.Service;
|
|
|
-import org.dromara.backstage.consumption.domain.bo.XfUsertotalBo;
|
|
|
-import org.dromara.backstage.consumption.domain.vo.XfUsertotalVo;
|
|
|
-import org.dromara.backstage.consumption.domain.XfUsertotal;
|
|
|
+import org.dromara.backstage.consumption.domain.XfUserTotal;
|
|
|
+import org.dromara.backstage.consumption.domain.bo.XfUserTotalBo;
|
|
|
+import org.dromara.backstage.consumption.domain.vo.XfUserTotalVo;
|
|
|
import org.dromara.backstage.consumption.mapper.XfUsertotalMapper;
|
|
|
-import org.dromara.backstage.consumption.service.IXfUsertotalService;
|
|
|
+import org.dromara.backstage.consumption.service.IXfUserTotalService;
|
|
|
+import org.dromara.common.core.utils.MapstructUtils;
|
|
|
+import org.dromara.common.core.utils.StringUtils;
|
|
|
+import org.dromara.common.mybatis.core.page.PageQuery;
|
|
|
+import org.dromara.common.mybatis.core.page.TableDataInfo;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
|
|
|
+import java.math.BigDecimal;
|
|
|
+import java.util.Collection;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
|
-import java.util.Collection;
|
|
|
|
|
|
/**
|
|
|
* 个人与消费与充值统计Service业务层处理
|
|
|
@@ -29,7 +32,7 @@ import java.util.Collection;
|
|
|
@RequiredArgsConstructor
|
|
|
@Service
|
|
|
@DS("storage")
|
|
|
-public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
+public class XfUserTotalServiceImpl implements IXfUserTotalService {
|
|
|
|
|
|
private final XfUsertotalMapper baseMapper;
|
|
|
|
|
|
@@ -40,7 +43,7 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
* @return 个人与消费与充值统计
|
|
|
*/
|
|
|
@Override
|
|
|
- public XfUsertotalVo queryById(String totalId){
|
|
|
+ public XfUserTotalVo queryById(String totalId) {
|
|
|
return baseMapper.selectVoById(totalId);
|
|
|
}
|
|
|
|
|
|
@@ -52,9 +55,9 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
* @return 个人与消费与充值统计分页列表
|
|
|
*/
|
|
|
@Override
|
|
|
- public TableDataInfo<XfUsertotalVo> queryPageList(XfUsertotalBo bo, PageQuery pageQuery) {
|
|
|
- LambdaQueryWrapper<XfUsertotal> lqw = buildQueryWrapper(bo);
|
|
|
- Page<XfUsertotalVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
|
|
+ public TableDataInfo<XfUserTotalVo> queryPageList(XfUserTotalBo bo, PageQuery pageQuery) {
|
|
|
+ LambdaQueryWrapper<XfUserTotal> lqw = buildQueryWrapper(bo);
|
|
|
+ Page<XfUserTotalVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
|
|
return TableDataInfo.build(result);
|
|
|
}
|
|
|
|
|
|
@@ -65,23 +68,23 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
* @return 个人与消费与充值统计列表
|
|
|
*/
|
|
|
@Override
|
|
|
- public List<XfUsertotalVo> queryList(XfUsertotalBo bo) {
|
|
|
- LambdaQueryWrapper<XfUsertotal> lqw = buildQueryWrapper(bo);
|
|
|
+ public List<XfUserTotalVo> queryList(XfUserTotalBo bo) {
|
|
|
+ LambdaQueryWrapper<XfUserTotal> lqw = buildQueryWrapper(bo);
|
|
|
return baseMapper.selectVoList(lqw);
|
|
|
}
|
|
|
|
|
|
- private LambdaQueryWrapper<XfUsertotal> buildQueryWrapper(XfUsertotalBo bo) {
|
|
|
+ private LambdaQueryWrapper<XfUserTotal> buildQueryWrapper(XfUserTotalBo bo) {
|
|
|
Map<String, Object> params = bo.getParams();
|
|
|
- LambdaQueryWrapper<XfUsertotal> lqw = Wrappers.lambdaQuery();
|
|
|
- lqw.eq(bo.getUserId() != null, XfUsertotal::getUserId, bo.getUserId());
|
|
|
- lqw.eq(StringUtils.isNotBlank(bo.getUserNumb()), XfUsertotal::getUserNumb, bo.getUserNumb());
|
|
|
- lqw.like(StringUtils.isNotBlank(bo.getRealName()), XfUsertotal::getRealName, bo.getRealName());
|
|
|
- lqw.like(StringUtils.isNotBlank(bo.getDeptName()), XfUsertotal::getDeptName, bo.getDeptName());
|
|
|
- lqw.eq(bo.getCardNo() != null, XfUsertotal::getCardNo, bo.getCardNo());
|
|
|
- lqw.eq(StringUtils.isNotBlank(bo.getDateDay()), XfUsertotal::getDateDay, bo.getDateDay());
|
|
|
- lqw.eq(bo.getUseYpe() != null, XfUsertotal::getUseYpe, bo.getUseYpe());
|
|
|
- lqw.eq(bo.getCreditMoney() != null, XfUsertotal::getCreditMoney, bo.getCreditMoney());
|
|
|
- lqw.eq(bo.getConsumeMoney() != null, XfUsertotal::getConsumeMoney, bo.getConsumeMoney());
|
|
|
+ LambdaQueryWrapper<XfUserTotal> lqw = Wrappers.lambdaQuery();
|
|
|
+ lqw.eq(bo.getUserId() != null, XfUserTotal::getUserId, bo.getUserId());
|
|
|
+ lqw.eq(StringUtils.isNotBlank(bo.getUserNumb()), XfUserTotal::getUserNumb, bo.getUserNumb());
|
|
|
+ lqw.like(StringUtils.isNotBlank(bo.getRealName()), XfUserTotal::getRealName, bo.getRealName());
|
|
|
+ lqw.like(StringUtils.isNotBlank(bo.getDeptName()), XfUserTotal::getDeptName, bo.getDeptName());
|
|
|
+ lqw.eq(bo.getCardNo() != null, XfUserTotal::getCardNo, bo.getCardNo());
|
|
|
+ lqw.eq(StringUtils.isNotBlank(bo.getDateDay()), XfUserTotal::getDateDay, bo.getDateDay());
|
|
|
+ lqw.eq(bo.getUseType() != null, XfUserTotal::getUseType, bo.getUseType());
|
|
|
+ lqw.eq(bo.getCreditMoney() != null, XfUserTotal::getCreditMoney, bo.getCreditMoney());
|
|
|
+ lqw.eq(bo.getConsumeMoney() != null, XfUserTotal::getConsumeMoney, bo.getConsumeMoney());
|
|
|
return lqw;
|
|
|
}
|
|
|
|
|
|
@@ -92,8 +95,8 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
* @return 是否新增成功
|
|
|
*/
|
|
|
@Override
|
|
|
- public Boolean insertByBo(XfUsertotalBo bo) {
|
|
|
- XfUsertotal add = MapstructUtils.convert(bo, XfUsertotal.class);
|
|
|
+ public Boolean insertByBo(XfUserTotalBo bo) {
|
|
|
+ XfUserTotal add = MapstructUtils.convert(bo, XfUserTotal.class);
|
|
|
validEntityBeforeSave(add);
|
|
|
boolean flag = baseMapper.insert(add) > 0;
|
|
|
if (flag) {
|
|
|
@@ -109,8 +112,8 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
* @return 是否修改成功
|
|
|
*/
|
|
|
@Override
|
|
|
- public Boolean updateByBo(XfUsertotalBo bo) {
|
|
|
- XfUsertotal update = MapstructUtils.convert(bo, XfUsertotal.class);
|
|
|
+ public Boolean updateByBo(XfUserTotalBo bo) {
|
|
|
+ XfUserTotal update = MapstructUtils.convert(bo, XfUserTotal.class);
|
|
|
validEntityBeforeSave(update);
|
|
|
return baseMapper.updateById(update) > 0;
|
|
|
}
|
|
|
@@ -118,7 +121,7 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
/**
|
|
|
* 保存前的数据校验
|
|
|
*/
|
|
|
- private void validEntityBeforeSave(XfUsertotal entity){
|
|
|
+ private void validEntityBeforeSave(XfUserTotal entity) {
|
|
|
//TODO 做一些数据校验,如唯一约束
|
|
|
}
|
|
|
|
|
|
@@ -131,9 +134,55 @@ public class XfUsertotalServiceImpl implements IXfUsertotalService {
|
|
|
*/
|
|
|
@Override
|
|
|
public Boolean deleteWithValidByIds(Collection<String> ids, Boolean isValid) {
|
|
|
- if(isValid){
|
|
|
+ if (isValid) {
|
|
|
//TODO 做一些业务上的校验,判断是否需要校验
|
|
|
}
|
|
|
return baseMapper.deleteByIds(ids) > 0;
|
|
|
}
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 更新/新增人员日统计表
|
|
|
+ *
|
|
|
+ * @param bo 日统计表实体
|
|
|
+ * @return 更新后的日统计表
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public XfUserTotalVo createOrUpdateUserTotal(XfUserTotalBo bo) {
|
|
|
+ XfUserTotal entity = baseMapper.selectOne(new LambdaQueryWrapper<XfUserTotal>()
|
|
|
+ .eq(XfUserTotal::getUserId, bo.getUserId())
|
|
|
+ .eq(XfUserTotal::getCardNo, bo.getCardNo())
|
|
|
+ .eq(XfUserTotal::getUseType, bo.getUseType())
|
|
|
+ .eq(XfUserTotal::getDateDay, bo.getDateDay()));
|
|
|
+
|
|
|
+ if (ObjUtil.isEmpty(entity)) {
|
|
|
+ entity = MapstructUtils.convert(bo, XfUserTotal.class);
|
|
|
+ boolean flag = baseMapper.insert(entity) > 0;
|
|
|
+ if (flag) {
|
|
|
+ if (entity != null) {
|
|
|
+ return baseMapper.selectVoById(entity.getTotalId());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ return updateTotalCreditValue(entity, bo.getCreditMoney());
|
|
|
+ }
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 更新日统计表中的充值/退款数据
|
|
|
+ *
|
|
|
+ * @param update 需要更新的实体
|
|
|
+ * @param creditValue 充值/退款金额
|
|
|
+ * @return 更新后的日统计表
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public XfUserTotalVo updateTotalCreditValue(XfUserTotal update, BigDecimal creditValue) {
|
|
|
+ boolean result = baseMapper.update(null, new LambdaUpdateWrapper<XfUserTotal>()
|
|
|
+ .set(XfUserTotal::getCreditMoney, update.getCreditMoney().add(creditValue))
|
|
|
+ .eq(XfUserTotal::getTotalId, update.getTotalId())) > 0;
|
|
|
+ if (result) {
|
|
|
+ return queryById(update.getTotalId());
|
|
|
+ }
|
|
|
+ return null;
|
|
|
+ }
|
|
|
}
|