1.提交自动补单代码
parent
c3afd4b83e
commit
6f3f7f9214
@ -0,0 +1,72 @@
|
|||||||
|
package com.glxp.sale.admin.thread;
|
||||||
|
|
||||||
|
import cn.hutool.core.collection.CollUtil;
|
||||||
|
import com.glxp.sale.admin.dao.info.ScheduledDao;
|
||||||
|
import com.glxp.sale.admin.entity.info.ScheduledEntity;
|
||||||
|
import com.glxp.sale.admin.entity.inout.StockOrderEntity;
|
||||||
|
import com.glxp.sale.admin.req.udid.ScheduledRequest;
|
||||||
|
import com.glxp.sale.admin.res.inout.StockOrderResponse;
|
||||||
|
import com.glxp.sale.admin.service.inout.OrderService;
|
||||||
|
import com.glxp.sale.admin.service.inout.StockOrderService;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.scheduling.annotation.EnableScheduling;
|
||||||
|
import org.springframework.scheduling.annotation.SchedulingConfigurer;
|
||||||
|
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
|
||||||
|
import org.springframework.scheduling.support.CronTrigger;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 自动补单定时任务
|
||||||
|
*/
|
||||||
|
@Slf4j
|
||||||
|
@Component
|
||||||
|
@EnableScheduling
|
||||||
|
public class SupplementOrderTask implements SchedulingConfigurer {
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
ScheduledDao scheduledDao;
|
||||||
|
@Resource
|
||||||
|
StockOrderService stockOrderService;
|
||||||
|
@Resource
|
||||||
|
OrderService orderService;
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
|
||||||
|
taskRegistrar.addTriggerTask(() -> process(),
|
||||||
|
triggerContext -> {
|
||||||
|
ScheduledRequest scheduledRequest = new ScheduledRequest();
|
||||||
|
scheduledRequest.setCronName("supplementOrderTask");
|
||||||
|
ScheduledEntity scheduledEntity = scheduledDao.findScheduled(scheduledRequest);
|
||||||
|
String cron = scheduledEntity.getCron();
|
||||||
|
if (cron.isEmpty()) {
|
||||||
|
log.error("cron is null");
|
||||||
|
}
|
||||||
|
return new CronTrigger(cron).nextExecutionTime(triggerContext);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void process() {
|
||||||
|
log.info("开始扫描补单数据");
|
||||||
|
//计数器
|
||||||
|
AtomicInteger counter = new AtomicInteger(0);
|
||||||
|
List<StockOrderEntity> orderEntities = stockOrderService.getSupplementOrderBillNoList();
|
||||||
|
if (CollUtil.isNotEmpty(orderEntities)) {
|
||||||
|
List<StockOrderResponse> stockOrderResponses = orderService.checkSupplementOrder(orderEntities);
|
||||||
|
for (StockOrderResponse stockOrderRespons : stockOrderResponses) {
|
||||||
|
if (stockOrderRespons.isEnableSupplementOrder()) {
|
||||||
|
//此单据可以补单
|
||||||
|
orderService.supplementOrder(stockOrderRespons.getBillNo());
|
||||||
|
counter.addAndGet(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log.info("补单结束,此次补单数量为:{}", counter.get());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue