From 56e8e3d9616813874a5c83c1770ba9fc761dd3d0 Mon Sep 17 00:00:00 2001 From: Administrator <1144154118@qq.com> Date: 星期六, 19 八月 2023 10:12:57 +0800 Subject: [PATCH] 巡检打卡前 --- ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java | 285 +++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 216 insertions(+), 69 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java index d4c769c..7b88c1c 100644 --- a/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/app/patrolplan/service/impl/ArdAppPatrolpointRecordServiceImpl.java @@ -59,73 +59,6 @@ @Resource private ArdAlarmpointsWellMapper wellMapper; - /** - * 鏌ヨapp宸℃璁″垝璁板綍 - * - * @param id app宸℃璁″垝璁板綍涓婚敭 - * @return app宸℃璁″垝璁板綍 - */ - @Override - public ArdAppPatrolpointRecord selectArdAppPatrolpointRecordById(String id) { - return ardAppPatrolpointRecordMapper.selectArdAppPatrolpointRecordById(id); - } - - /** - * 鏌ヨapp宸℃璁″垝璁板綍鍒楄〃 - * - * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍 - * @return app宸℃璁″垝璁板綍 - */ - @Override - public List<ArdAppPatrolpointRecord> selectArdAppPatrolpointRecordList(ArdAppPatrolpointRecord ardAppPatrolpointRecord) { - return ardAppPatrolpointRecordMapper.selectArdAppPatrolpointRecordList(ardAppPatrolpointRecord); - } - - /** - * 鏂板app宸℃璁″垝璁板綍 - * - * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍 - * @return 缁撴灉 - */ - @Override - public int insertArdAppPatrolpointRecord(ArdAppPatrolpointRecord ardAppPatrolpointRecord) { - ardAppPatrolpointRecord.setUserId(SecurityUtils.getUserId()); - return ardAppPatrolpointRecordMapper.insertArdAppPatrolpointRecord(ardAppPatrolpointRecord); - } - - /** - * 淇敼app宸℃璁″垝璁板綍 - * - * @param ardAppPatrolpointRecord app宸℃璁″垝璁板綍 - * @return 缁撴灉 - */ - @Override - public int updateArdAppPatrolpointRecord(ArdAppPatrolpointRecord ardAppPatrolpointRecord) { - return ardAppPatrolpointRecordMapper.updateArdAppPatrolpointRecord(ardAppPatrolpointRecord); - } - - /** - * 鎵归噺鍒犻櫎app宸℃璁″垝璁板綍 - * - * @param ids 闇�瑕佸垹闄ょ殑app宸℃璁″垝璁板綍涓婚敭 - * @return 缁撴灉 - */ - @Override - public int deleteArdAppPatrolpointRecordByIds(String[] ids) { - return ardAppPatrolpointRecordMapper.deleteArdAppPatrolpointRecordByIds(ids); - } - - /** - * 鍒犻櫎app宸℃璁″垝璁板綍淇℃伅 - * - * @param id app宸℃璁″垝璁板綍涓婚敭 - * @return 缁撴灉 - */ - @Override - public int deleteArdAppPatrolpointRecordById(String id) { - return ardAppPatrolpointRecordMapper.deleteArdAppPatrolpointRecordById(id); - } - @Override public Results record(ArdAppPatrolpointRecord ardAppPatrolpointRecord) { String id = IdUtils.simpleUUID(); @@ -366,10 +299,20 @@ String userId = recordSoloParam.getUserId(); String planName = recordSoloParam.getPlanName(); String userName = recordSoloParam.getUserName(); + //鏍规嵁璁″垝ID鑾峰彇鍒跺畾浜篒D + ArdAppPatrolplan ardAppPatrolplan = patrolplanMapper.selectById(planId); + //鏍规嵁濮撳悕ID鏌ヨ璁″垝鍒跺畾浜虹殑濮撳悕 + String planUserId = ardAppPatrolplan.getUserId(); + SysUser sysUser = sysUserMapper.selectById(planUserId); + String nikeName = sysUser.getNickName(); QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("plan_id", planId).eq("user_id",userId).like("record_time", toDay); //褰撳墠璁″垝閫変腑鏃堕棿閲屾鐢ㄦ埛鐨勬墦鍗¤褰� List<ArdAppPatrolpointRecord> list = ardAppPatrolpointRecordMapper.selectList(queryWrapper); + for (int i = 0; i < list.size(); i++) { + ArdAppPatrolpointRecord ardAppPatrolpointRecord = list.get(i); + ardAppPatrolpointRecord.setPlanUserName(nikeName); + } //鏌ヨ璇ヨ鍒掔殑鎵�鏈夊叴瓒g偣 List<ArdAlarmpointsWell> wellList = wellMapper.wellByPlanId(planId); if(list.size()==0){ @@ -383,6 +326,7 @@ ardAppPatrolpointRecord.setUserName(userName); ardAppPatrolpointRecord.setLatitude(String.valueOf(ardAlarmpointsWell.getLatitude())); ardAppPatrolpointRecord.setLongitude(String.valueOf(ardAlarmpointsWell.getLongitude().toString())); + ardAppPatrolpointRecord.setPlanUserName(nikeName); list.add(ardAppPatrolpointRecord); } return Results.succeed(list); @@ -416,6 +360,7 @@ ardAppPatrolpointRecord.setUserName(userName); ardAppPatrolpointRecord.setLatitude(String.valueOf(ardAlarmpointsWell.getLatitude())); ardAppPatrolpointRecord.setLongitude(String.valueOf(ardAlarmpointsWell.getLongitude().toString())); + ardAppPatrolpointRecord.setPlanUserName(nikeName); list.add(ardAppPatrolpointRecord); } } @@ -423,7 +368,7 @@ } @Override - public Results executeMonth(RecordMonthParam RecordMonthParam) throws ParseException { + public Results executeMonthOld(RecordMonthParam RecordMonthParam) throws ParseException { //鑾峰彇鍓嶇鍙傛暟 String begin = RecordMonthParam.getBegin(); String end = RecordMonthParam.getEnd(); @@ -515,7 +460,7 @@ } @Override - public Results executeDetails(RecordDetailsParam recordDetailsParam) throws ParseException { + public Results executeDetailsOld(RecordDetailsParam recordDetailsParam) throws ParseException { SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat dateFormatTime = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); String userId = SecurityUtils.getUserId(); @@ -622,4 +567,206 @@ return Results.succeed(list); } + @Override + public Results executeMonth(RecordMonthExParam recordMonthExParam) throws ParseException { + //鑾峰彇鍓嶇鍙傛暟 + String begin = recordMonthExParam.getBegin(); + String end = recordMonthExParam.getEnd(); + //杩斿洖杩欎釜 + JSONArray jsonArray = new JSONArray(); + //鏃堕棿鎷嗗垎 + String[] parts = end.split("[-\\s:]"); + int year = Integer.parseInt(parts[0]); + int month = Integer.parseInt(parts[1]); + int day = Integer.parseInt(parts[2]); + String monthZero; + if(month<10){ + monthZero = String.format("%02d", month); + }else { + monthZero = String.valueOf(month); + } + String userId = SecurityUtils.getUserId(); + recordMonthExParam.setUserId(userId); + //鏌ヨ璇ョ敤鎴蜂笅闇�瑕佹墽琛岀殑鍗曟璁″垝 + List<ArdAppPatrolplan> onceList = patrolplanMapper.oncePlan(recordMonthExParam); + //鏌ヨ璇ョ敤鎴蜂笅闇�瑕佹墽琛岀殑姣忔棩璁″垝 + List<ArdAppPatrolplan> dayList = patrolplanMapper.dayPlan(recordMonthExParam); + //寰幆涓�涓湀涓殑姣忎竴澶� + for (int i = 1; i <= day; i++) { + String di; + Boolean planBoolean = false; + Boolean recordBoolean = false; + //璁板綍杩欏ぉ璁″垝鏉℃暟 + int dayNum = 0; + int onceNum = 0; + //璁板綍杩欏ぉ鐨勬墦寮�鍦扮偣鏁� + int dayWell = 0; + int onceWell = 0; + if (i < 10) { + di = String.format("%02d", i); + } else { + di = String.valueOf(i); + } + //姣忎竴澶� + String ymd = year + "-" + monthZero + "-" + di; + JSONObject jsonObject = new JSONObject(); + jsonObject.put("toDay",ymd ); + //濡傛灉姣忔棩璁″垝鏈夋暟鎹� + if (dayList.size() > 0) { + for (int j = 0; j < dayList.size(); j++) { + String dayTime = dayList.get(j).getCreateTime(); + String dt = dayTime.substring(0,10); + //濡傛灉姣忔棩璁″垝鏃ユ湡绛変簬杩欎竴澶╋紝閭d粠杩欎竴澶╀箣鍚庣殑姣忎竴澶╅兘鏄湁璁″垝鐨� + if(dt.compareTo(ymd)<=0){ + planBoolean =true; + dayNum+=1; + String id = dayList.get(j).getId(); + List<ArdAlarmpointsWell> dayWells = wellMapper.wellByPlanId(id); + dayWell = dayWells.size(); + } + } + } + //濡傛灉鍗曟璁″垝鏈夋暟鎹� + if(onceList.size()>0){ + for (int j = 0; j < onceList.size(); j++) { + String beginTime = onceList.get(j).getPatroBeginTime(); + String bt = beginTime.substring(0,10); + if(bt.equals(ymd)){ + planBoolean = true; + onceNum+=1; + List<ArdAlarmpointsWell> onceWells = wellMapper.wellByPlanId(onceList.get(j).getId()); + onceWell = onceWells.size(); + } + } + } + if(planBoolean){ + //杩欏ぉ鎬讳换鍔℃潯鏁� + int planNum = dayNum+onceNum; + //杩欏ぉ鎬诲叴瓒g偣鏁� + int wellNum = dayWell+onceWell; + QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>(); + queryWrapper.eq("user_id",userId).like("record_time",ymd); + List<ArdAppPatrolpointRecord> list = ardAppPatrolpointRecordMapper.selectList(queryWrapper); + //宸叉墦鍗℃�绘潯鏁� + int num = list.size(); + //搴旀墦鍗℃�绘潯鏁� + int record = planNum*wellNum; + if(num==record){ + recordBoolean = true; + } + } + jsonObject.put("toDay",ymd ); + jsonObject.put("plan",planBoolean); + jsonObject.put("record",recordBoolean); + jsonArray.add(jsonObject); + } + return Results.succeed(jsonArray); + } + + @Override + public Results executeDetails(RecordDetailsExParam recordDetailsExParam) throws ParseException { + String userId = SecurityUtils.getUserId(); + //鑾峰彇鍙傛暟 + Boolean plan = recordDetailsExParam.getPlan(); + String toDay = recordDetailsExParam.getToDay(); + JSONArray jsonArray = new JSONArray(); + if(plan){ + //鏌ヨ杩欎釜鐢ㄦ埛涓嬩负鎵ц浜虹殑鎵�鏈夊贰妫�璁″垝 + ArdAppPatrolplan ardAppPatrolplan = new ArdAppPatrolplan(); + ardAppPatrolplan.setUserId(SecurityUtils.getUserId()); + List<ArdAppPatrolplan> list = patrolplanMapper.executeList(ardAppPatrolplan); + //鎵惧嚭浠婂ぉ鐨勫崟娆″拰姣忔棩璁″垝 + List<ArdAppPatrolplan> patrolplanList = new ArrayList<>(); + for (int i = 0; i < list.size(); i++) { + String cycle = list.get(i).getCycle(); + //濡傛灉鏄崟娆′换鍔� + if(cycle.equals("once")){ + String begin = list.get(i).getPatroBeginTime(); + String b = begin.substring(0,10); + if(b.equals(toDay)){ + //鏄粖澶╃殑璁″垝 + patrolplanList.add(list.get(i)); + } + } + //濡傛灉鏄瘡鏃ヤ换鍔� + else if(cycle.equals("day")){ + String create = list.get(i).getCreateTime(); + String c = create.substring(0,10); + if(c.compareTo(toDay)<=0){ + //鏈変粖澶╃殑璁″垝 + patrolplanList.add(list.get(i)); + } + } + } + if(patrolplanList.size()>0){ + //閬嶅巻浠婂ぉ鐨勮鍒� + for (int i = 0; i < patrolplanList.size(); i++) { + String planId = patrolplanList.get(i).getId(); + String planName = patrolplanList.get(i).getPlanName(); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("planId",planId); + jsonObject.put("planName",planName); + //鏌ヨ杩欏ぉ鏈夊灏戠偣 + List<ArdAlarmpointsWell> dayWells = wellMapper.wellByPlanId(planId); + int dayWellNum = dayWells.size(); + //鏌ヨ杩欎釜鐢ㄦ埛鐨勮繖涓鍒掑湪浠婂ぉ鎵撳崱鐨勬潯鏁� + QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>(); + queryWrapper.eq("user_id",userId).eq("plan_id",planId).like("record_time",toDay); + List<ArdAppPatrolpointRecord> recordList = ardAppPatrolpointRecordMapper.selectList(queryWrapper); + int recordNum = recordList.size(); + //濡傛灉鐩哥瓑閭h繖鏉′粖澶╃殑璁″垝灏辨槸鍏ㄩ儴瀹屾垚浜� + if(recordNum==dayWellNum){ + jsonObject.put("type",true); + }else { + jsonObject.put("type",false); + } + jsonArray.add(jsonObject); + } + } + }else { + //娌℃湁璁″垝 + return Results.succeed("[]"); + } + return Results.succeed(jsonArray); + } + + @Override + public Results recordBefore(RecordBeforeParam recordBeforeParam) { + String planId = recordBeforeParam.getPlanId(); + String wellId = recordBeforeParam.getWellId(); + String toDay = recordBeforeParam.getToDay(); + String userId = SecurityUtils.getUserId(); + JSONArray jsonArray = new JSONArray(); + ArdAppPatrolplan plan = patrolplanMapper.selectById(planId); + jsonArray.add(plan); + QueryWrapper<ArdAppPatrolpointRecord> queryWrapper = new QueryWrapper<>(); + queryWrapper.eq("plan_id",planId).eq("app_patrolpoints_id",wellId).eq("user_id",userId).like("record_time",toDay); + ArdAppPatrolpointRecord record = ardAppPatrolpointRecordMapper.selectOne(queryWrapper); + //鏍规嵁濮撳悕ID鏌ヨ璁″垝鍒跺畾浜虹殑濮撳悕 + String planUserId = plan.getUserId(); + SysUser sysUser = sysUserMapper.selectById(planUserId); + String nikeName = sysUser.getNickName(); + if(record==null){ + //鏍规嵁濮撳悕ID鏌ヨ鎵ц浜哄鍚� + SysUser user = sysUserMapper.selectById(userId); + String userName = user.getNickName(); + //鏌ヨ璇ヨ鍒掔殑鎵�鏈夊叴瓒g偣 + ArdAlarmpointsWell ardAlarmpointsWell = wellMapper.selectById(wellId); + //娌℃墦鍗$殑鏁版嵁 + ArdAppPatrolpointRecord record1 = new ArdAppPatrolpointRecord(); + record1.setAppPatrolpointsId(ardAlarmpointsWell.getId()); + record1.setAppPatrolpointsName(ardAlarmpointsWell.getWellId()); + record1.setPlanId(planId); + record1.setPlanName(plan.getPlanName()); + record1.setUserId(userId); + record1.setUserName(userName); + record1.setLatitude(String.valueOf(ardAlarmpointsWell.getLatitude())); + record1.setLongitude(String.valueOf(ardAlarmpointsWell.getLongitude().toString())); + record1.setPlanUserName(nikeName); + jsonArray.add(record1); + }else { + jsonArray.add(record); + } + return Results.succeed(jsonArray); + } } -- Gitblit v1.9.3