From f9c24ba3d5eba45afef222dcd72b6383893efc76 Mon Sep 17 00:00:00 2001 From: liukangdong <898885815@qq.com> Date: 星期二, 07 一月 2025 17:23:32 +0800 Subject: [PATCH] Merge branch 'master' of http://139.186.142.91:10010/r/productDev/dmvisit --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java | 150 +++++++++++++++++++++---------------------------- 1 files changed, 65 insertions(+), 85 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java index c184c0e..265e4a9 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java @@ -10,16 +10,17 @@ import com.doumee.core.haikang.model.param.request.ParkReservationDelRequest; import com.doumee.core.haikang.model.param.respose.ParkReservationAddResponse; import com.doumee.core.haikang.service.HKService; -import com.doumee.core.model.LoginUserInfo; -import com.doumee.core.model.PageData; -import com.doumee.core.model.PageWrap; -import com.doumee.core.tms.model.request.TmsLockStatusQueryRequest; -import com.doumee.core.tms.model.response.TmsBaseResponse; -import com.doumee.core.tms.model.response.TmsLockStatusQueryResponse; +import com.doumee.service.business.third.model.LoginUserInfo; +import com.doumee.service.business.third.model.PageData; +import com.doumee.service.business.third.model.PageWrap; +import com.doumee.service.business.third.model.request.TmsLockStatusQueryRequest; +import com.doumee.service.business.third.model.response.TmsBaseResponse; +import com.doumee.service.business.third.model.response.TmsLockStatusQueryResponse; import com.doumee.core.utils.*; import com.doumee.core.wx.wxPlat.WxPlatConstants; import com.doumee.core.wx.wxPlat.WxPlatNotice; import com.doumee.dao.business.*; +import com.doumee.dao.business.dao.MemberMapper; import com.doumee.dao.business.dao.SmsConfigMapper; import com.doumee.dao.business.dao.SmsEmailMapper; import com.doumee.dao.business.join.PlatformJobJoinMapper; @@ -29,6 +30,7 @@ import com.doumee.dao.openapi.request.*; import com.doumee.dao.openapi.response.*; +import com.doumee.dao.system.SystemUserMapper; import com.doumee.dao.system.model.SystemUser; import com.doumee.dao.web.reqeust.*; import com.doumee.dao.web.response.DriverHomeVO; @@ -128,6 +130,8 @@ private MemberMapper memberMapper; @Autowired private WxNoticeConfigMapper wxNoticeConfigMapper; + @Autowired + private SystemUserMapper systemUserMapper; @Override public Integer create(PlatformJob platformJob) { @@ -512,6 +516,14 @@ .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) .eq(PlatformJob::getIsdeleted,Constants.ZERO) .eq(PlatformJob::getDrivierPhone,loginUserInfo.getMobile()) + .and(i->i.like(PlatformJob::getDoneDate,DateUtil.getCurrDate()) + .or().in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey() + ,Constants.PlatformJobStatus.WAIT_CONFIRM.getKey(), + Constants.PlatformJobStatus.WART_SIGN_IN.getKey(), + Constants.PlatformJobStatus.IN_WAIT.getKey(), + Constants.PlatformJobStatus.CALLED.getKey(), + Constants.PlatformJobStatus.WORKING.getKey()) + ) .orderByDesc(PlatformJob::getId) ); for (PlatformJob platformJob:platformJobList) { @@ -522,7 +534,6 @@ } driverHomeVO.setPlatformJobList(platformJobList); - // 鍥尯瀵艰鍥� 鍥剧墖 driverHomeVO.setReservationMap(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.PLATFORM_GUIDEMAP).getCode()); // 棰勭害鎸囧崡 鏂囨湰 @@ -655,11 +666,11 @@ } public void sceneSignIn(SignInDTO signInDTO){ - if( StringUtils.isNotBlank(signInDTO.getQrCodeKey())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } - if(!signInDTO.getQrCodeKey().equals(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode())){ + if(!signInDTO.getQrCodeKey().equals( + systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE_PREFIX).getCode() + systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode())){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"浜岀淮鐮佸凡杩囨湡,璇峰埛鏂伴噸璇�"); } } @@ -732,6 +743,7 @@ ,PlatformJob::getId,lineUpDetailDTO.getJobId()) .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(), Constants.PlatformJobStatus.IN_WAIT.getKey(), + Constants.PlatformJobStatus.WORKING.getKey(), Constants.PlatformJobStatus.CALLED.getKey()) .orderByDesc(PlatformJob::getStatus) .orderByAsc(PlatformJob::getSignDate) @@ -873,20 +885,39 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobCallIn, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobCallIn,platformJob); } - return platformJob; } + + public void sendWxNotice(String objCode,PlatformJob platformJob){ + SystemUser driver = systemUserMapper.selectOne(new QueryWrapper<SystemUser>().lambda() + .eq(SystemUser::getDeleted, Constants.ZERO) + .eq(SystemUser::getType, Constants.ZERO) + .eq(SystemUser::getMobile,platformJob.getDrivierPhone()) + .last(" limit 1 ")); + if (Objects.nonNull(driver) && StringUtils.isNotBlank(driver.getOpenid())) { + PlatformJob p = platformJobJoinMapper.selectJoinOne(PlatformJob.class, + new MPJLambdaWrapper<PlatformJob>() + .selectAll(PlatformJob.class) + .selectAs(Platform::getName,PlatformJob::getPlatformName) + .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) + .eq(PlatformJob::getId,platformJob.getId()) + .last(" limit 1") + ); + + WxPlatNotice wxPlatNotice = new WxPlatNotice(); + wxPlatNotice.sendPlatformJobTemplateNotice(systemDictDataBiz, + wxNoticeConfigMapper, p, + objCode, + systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), + Arrays.asList(driver.getOpenid().split(",")) + ); + } + } + + + private Logger logger = LoggerFactory.getLogger(PlatformJobServiceImpl.class); @@ -1083,17 +1114,8 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� - if(Objects.nonNull(platformJob.getDriverId())){ - Member member = memberMapper.selectById(platformJob.getDriverId()); - if(Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())){ - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper,platformJob, - WxPlatConstants.platformJobContent.platformJobSingIn, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + if(Objects.nonNull(platformJob.getDriverId())){ + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobSingIn,platformJob); } @@ -1228,17 +1250,8 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� - if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobMove, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + if(Objects.nonNull(platformJob.getDriverId())) { + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobMove,platformJob); } platformJob.setPlatformName(oldPlatform.getName()); @@ -1291,16 +1304,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())){ - Member member = memberMapper.selectById(platformJob.getDriverId()); - if(Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())){ - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper,platformJob, - WxPlatConstants.platformJobContent.platformJobOverNum, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobOverNum,platformJob); } platformJob.setPlatformName(platform.getName()); @@ -1352,16 +1356,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobError, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobError,platformJob); } platformJob.setPlatformName(platform.getName()); @@ -1415,16 +1410,7 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobWorking, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobWorking,platformJob); } //骞挎挱 led閫氱煡 platformJob.setPlatformName(platform.getName()); @@ -1434,7 +1420,8 @@ return platformJob; } - + + @Override public PlatformJob getLastWaitJob(String uuid, LoginUserInfo loginUser){ String u = (String) redisTemplate.opsForValue().get(Constants.RedisKeys.BIGSCREEN_UUID); if(!StringUtils.equals(u,uuid)){ @@ -1448,6 +1435,7 @@ .last(" limit 1 ") ); return platformJob; } + @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public PlatformJob finishWork(JobOperateDTO jobOperateDTO){ @@ -1522,16 +1510,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobFinish, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobFinish,platformJob); } //骞挎挱 led閫氱煡 @@ -2123,7 +2102,9 @@ } String u = UUID.randomUUID().toString(); redisTemplate.opsForValue().set(Constants.RedisKeys.BIGSCREEN_UUID,u,3, TimeUnit.MINUTES); - largeScreenDataVO.setQrCode(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode()); + String url = Constants.getWxUrl(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.WX_REDIRECT_URL).getCode(),Constants.WxUrlParams.BISCREEN_CODE,u); + largeScreenDataVO.setQrCode(url); + largeScreenDataVO.setAttention(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_ATTENTION).getCode()); return largeScreenDataVO; } @@ -2230,7 +2211,6 @@ } } - -- Gitblit v1.9.3