DriverStockController.java 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. package com.template.controller;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.baomidou.mybatisplus.core.conditions.Wrapper;
  4. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  5. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  6. import com.baomidou.mybatisplus.core.metadata.IPage;
  7. import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
  8. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  9. import com.github.pagehelper.PageHelper;
  10. import com.github.pagehelper.PageInfo;
  11. import com.template.annotation.DESRespondSecret;
  12. import com.template.annotation.PassToken;
  13. import com.template.api.DriverStockControllerAPI;
  14. import com.template.common.utils.TimeExchange;
  15. import com.template.model.pojo.SmartClass;
  16. import com.template.model.pojo.SmartUser;
  17. import com.template.model.pojo.SmartWarning;
  18. import com.template.model.result.CommonResult;
  19. import com.template.model.result.PageUtils;
  20. import com.template.model.tongji.*;
  21. import com.template.model.vo.VisitorTjVo;
  22. import com.template.services.DriverStockService;
  23. import com.template.services.SmartClassService;
  24. import com.template.services.SmartUserService;
  25. import com.template.services.SmartWarningService;
  26. import org.springframework.beans.factory.annotation.Autowired;
  27. import org.springframework.stereotype.Controller;
  28. import java.math.BigDecimal;
  29. import java.sql.Time;
  30. import java.text.SimpleDateFormat;
  31. import java.time.LocalDateTime;
  32. import java.time.format.DateTimeFormatter;
  33. import java.util.ArrayList;
  34. import java.util.Calendar;
  35. import java.util.List;
  36. import java.util.stream.Collectors;
  37. @Controller
  38. public class DriverStockController implements DriverStockControllerAPI {
  39. @Autowired
  40. public DriverStockService driverStockService;
  41. @Autowired
  42. public SmartWarningService smartWarningService;
  43. @Autowired
  44. public SmartUserService smartUserService;
  45. @Autowired
  46. public SmartClassService smartClassService;
  47. @Override
  48. @PassToken
  49. @DESRespondSecret(validated = false)
  50. public CommonResult getClassTj() {
  51. List<Tj> list = driverStockService.getClassTj();
  52. BigDecimal num = new BigDecimal(0.0);
  53. for (Tj teacherData:list) {
  54. if (teacherData.getName().contains("老师") || teacherData.getName().contains("班主任") || teacherData.getName().contains("年级主任") || teacherData.getName().contains("超级管理员") || teacherData.getName().contains("其他")) {
  55. num = num.add(new BigDecimal(teacherData.getNum()));
  56. }
  57. }
  58. Tj teacher = new Tj();
  59. teacher.setName("教师");
  60. teacher.setNum(num.doubleValue());
  61. list = list.stream().filter(e -> !e.name.contains("老师") && !e.name.contains("家长")&& !e.name.contains("未分组")).collect(Collectors.toList());
  62. list.add(teacher);
  63. // 去掉班主任
  64. ArrayList<Tj> vos = new ArrayList<>();
  65. for (Tj tj : list) {
  66. if (!tj.getName().contains("班主任") && !tj.getName().contains("年级主任") && !tj.getName().contains("超级管理员") && !tj.getName().contains("其他")) {
  67. vos.add(tj);
  68. }
  69. }
  70. return CommonResult.ok(vos);
  71. }
  72. @Override
  73. @PassToken
  74. @DESRespondSecret(validated = false)
  75. public CommonResult getVisitorTj() {
  76. DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM");
  77. ArrayList<VisitorTjVo> visitorTjVos = new ArrayList<>();
  78. // 近1年数据
  79. LocalDateTime localDateTime = LocalDateTime.now().withDayOfMonth(1).withHour(0).withMinute(0).withSecond(0).plusMonths(1);
  80. ArrayList<Tj> tjs = new ArrayList<>();
  81. Tj tj2 = new Tj();
  82. tj2.setName("家长");
  83. tj2.setNum(0.0);
  84. tjs.add(tj2);
  85. Tj tj3 = new Tj();
  86. tj3.setName("其他");
  87. tj3.setNum(0.0);
  88. tjs.add(tj3);
  89. for (int i = 0; i < 12; i++) {
  90. VisitorTjVo visitorTjVo = new VisitorTjVo();
  91. LocalDateTime start = localDateTime.minusMonths(i + 1);
  92. LocalDateTime end = localDateTime.minusMonths(i);
  93. String dataTime = start.format(dateTimeFormatter);
  94. List<Tj> list = driverStockService.getVisitorTj(start, end);
  95. if (ObjectUtils.isNotEmpty(list) && list.size() > 0) {
  96. if (list.size()<2) {
  97. ArrayList<Tj> tjs2 = new ArrayList<>();
  98. for (Tj tj : list) {
  99. tjs2.add(tj);
  100. String name = tj.getName();
  101. if ("家长".equals(name)) {
  102. tjs2.add(tj3);
  103. }else {
  104. tjs2.add(tj2);
  105. }
  106. }
  107. visitorTjVo.setTjs(tjs2);
  108. }else {
  109. visitorTjVo.setTjs(list);
  110. }
  111. } else {
  112. visitorTjVo.setTjs(tjs);
  113. }
  114. visitorTjVo.setDataTime(dataTime);
  115. visitorTjVos.add(visitorTjVo);
  116. }
  117. return CommonResult.ok(visitorTjVos);
  118. }
  119. public static void main(String[] args) {
  120. LocalDateTime start = LocalDateTime.now().withDayOfMonth(1).withHour(0).withMinute(0).withSecond(0);
  121. int year = start.getYear();
  122. System.out.println("year = " + year);
  123. int monthValue = start.getMonthValue();
  124. System.out.println("monthValue = " + monthValue);
  125. DateTimeFormatter dateTimeFormatter2 = DateTimeFormatter.ofPattern("yyyy-MM");
  126. String format = start.format(dateTimeFormatter2);
  127. System.out.println("format = " + format);
  128. }
  129. @Override
  130. @PassToken
  131. @DESRespondSecret(validated = false)
  132. public CommonResult queryPageSmartWarning(int currentPage, int pageCount, String name, String state) {
  133. PageUtils<SmartWarning> result = smartWarningService.queryPageSmartWarnings(currentPage, pageCount, name, state);
  134. return CommonResult.ok(result);
  135. }
  136. @Override
  137. @PassToken
  138. @DESRespondSecret(validated = false)
  139. public CommonResult getEnergyTj() {
  140. List<TjFloat> list = driverStockService.getEnergyTj();
  141. for (int i = 0; i < list.size(); i++) {
  142. TjFloat tjFloat = list.get(i);
  143. String name = tjFloat.getName();
  144. if ("用电量".equals(name)) {
  145. Double num = tjFloat.getNum();
  146. BigDecimal bigDecimal = new BigDecimal(num);
  147. double v = bigDecimal.multiply(new BigDecimal(80)).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
  148. tjFloat.setNum(v);
  149. }
  150. }
  151. return CommonResult.ok(list);
  152. }
  153. @Override
  154. @PassToken
  155. @DESRespondSecret(validated = false)
  156. public CommonResult getEnergyTjAvg() {
  157. List<TjFloat> list = driverStockService.getEnergyTj();
  158. QueryWrapper<SmartUser> queryWrapper = new QueryWrapper<>();
  159. queryWrapper.eq("deleted", 0);
  160. queryWrapper.eq("identity_id",2)
  161. .or()
  162. .eq("identity_id",3);
  163. Integer userNum = smartUserService.list(queryWrapper).size();
  164. for (int i = 0; i < list.size(); i++) {
  165. list.get(i).setNum(list.get(i).getNum() / userNum);
  166. }
  167. for (int j = 0; j < list.size(); j++) {
  168. TjFloat tjFloat = list.get(j);
  169. String name = tjFloat.getName();
  170. if ("用电量".equals(name)) {
  171. Double num = tjFloat.getNum();
  172. BigDecimal bigDecimal = new BigDecimal(num);
  173. double v = bigDecimal.multiply(new BigDecimal(80)).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
  174. tjFloat.setNum(v);
  175. }
  176. }
  177. return CommonResult.ok(list);
  178. }
  179. @Override
  180. @PassToken
  181. @DESRespondSecret(validated = false)
  182. public CommonResult getEnergyMonth(Integer type) {
  183. SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM");
  184. List<JSONObject> jList = new ArrayList<>();
  185. for (int i = -5; i <= 0; i++) {
  186. Calendar calendar = Calendar.getInstance();
  187. calendar.add(Calendar.MONTH, i);
  188. String date = simpleDateFormat.format(calendar.getTime());
  189. List<TjFloat> list = driverStockService.getEnergyMonth(date, type);
  190. if (type==1) {
  191. for (int i1 = 0; i1 < list.size(); i1++) {
  192. TjFloat tj = list.get(i1);
  193. Double num = tj.getNum();
  194. BigDecimal bigDecimal = new BigDecimal(num);
  195. if (ObjectUtils.isNotEmpty(num)) {
  196. BigDecimal multiply = bigDecimal.multiply(new BigDecimal(80)).setScale(2,BigDecimal.ROUND_HALF_UP);
  197. num=multiply.doubleValue();
  198. }
  199. tj.setNum(num);
  200. }
  201. }
  202. JSONObject jsonObject = new JSONObject();
  203. jsonObject.put("month", date);
  204. jsonObject.put("data", list);
  205. jList.add(jsonObject);
  206. }
  207. return CommonResult.ok(jList);
  208. }
  209. @Override
  210. @PassToken
  211. @DESRespondSecret(validated = false)
  212. public CommonResult getEnergyDay(Integer type) {
  213. SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
  214. List<JSONObject> jList = new ArrayList<>();
  215. for (int i = -11; i <= 0; i++) {
  216. Calendar calendar = Calendar.getInstance();
  217. calendar.add(Calendar.DATE, i);
  218. String date = simpleDateFormat.format(calendar.getTime());
  219. List<TjFloat> list = driverStockService.getEnergyDay(date, type);
  220. if (type==1) {
  221. for (int i1 = 0; i1 < list.size(); i1++) {
  222. TjFloat tj = list.get(i1);
  223. Double num = tj.getNum();
  224. BigDecimal bigDecimal = new BigDecimal(num);
  225. if (ObjectUtils.isNotEmpty(num)) {
  226. BigDecimal multiply = bigDecimal.multiply(new BigDecimal(80)).setScale(2,BigDecimal.ROUND_HALF_UP);
  227. num=multiply.doubleValue();
  228. }
  229. tj.setNum(num);
  230. }
  231. }
  232. JSONObject jsonObject = new JSONObject();
  233. jsonObject.put("date", date);
  234. jsonObject.put("data", list);
  235. jList.add(jsonObject);
  236. }
  237. return CommonResult.ok(jList);
  238. }
  239. @Override
  240. @PassToken
  241. @DESRespondSecret(validated = false)
  242. public CommonResult getDeviceT() {
  243. List<JSONObject> list = new ArrayList<>();
  244. JSONObject jsonObject1 = new JSONObject();
  245. List<TjFloat> allList = driverStockService.getTotalDevice();
  246. jsonObject1.put("name", "总设备数");
  247. jsonObject1.put("data", allList);
  248. list.add(jsonObject1);
  249. List<TjFloat> onlineList = driverStockService.getOnlineDevice(TimeExchange.getDate());
  250. JSONObject jsonObject2 = new JSONObject();
  251. jsonObject2.put("name", "在线设备数");
  252. jsonObject2.put("data", onlineList);
  253. list.add(jsonObject2);
  254. return CommonResult.ok(list);
  255. }
  256. @Override
  257. @PassToken
  258. @DESRespondSecret(validated = false)
  259. public CommonResult getMeterPage(int currentPage, int pageCount, Integer meterType) {
  260. PageHelper.startPage(currentPage, pageCount);
  261. PageInfo<MeterPage> list = driverStockService.getMeterDetail(meterType);
  262. return CommonResult.ok(list);
  263. }
  264. @Override
  265. @PassToken
  266. @DESRespondSecret(validated = false)
  267. public CommonResult getUserComp() {
  268. List<Tj> list = driverStockService.getUserComp();
  269. return CommonResult.ok(list);
  270. }
  271. @Override
  272. @PassToken
  273. @DESRespondSecret(validated = false)
  274. public CommonResult getUserPage(int currentPage, int pageCount, String key, Integer identityId,Integer graderId,Integer classId) {
  275. // 当班级和年级为空时则不要毕业的班级
  276. List<SmartClass> smartClasses=new ArrayList<>();
  277. if (ObjectUtils.isEmpty(graderId)||ObjectUtils.isEmpty(classId)) {
  278. // 获取未毕业的班级
  279. List<Integer> grades=smartUserService.getNotGraduateGrade();
  280. LambdaQueryWrapper<SmartClass> wrapper = new LambdaQueryWrapper<>();
  281. wrapper.in(SmartClass::getGradeId,grades);
  282. smartClasses = smartClassService.list(wrapper);
  283. }else {
  284. // 查询对应的班级
  285. LambdaQueryWrapper<SmartClass> wrapper=new LambdaQueryWrapper<>();
  286. wrapper.eq(ObjectUtils.isNotEmpty(graderId),SmartClass::getGradeId,graderId)
  287. .eq(ObjectUtils.isNotEmpty(classId),SmartClass::getId,classId);
  288. smartClasses = smartClassService.list(wrapper);
  289. }
  290. // 组合班级id
  291. String classIds="";
  292. for (int i = 0; i < smartClasses.size(); i++) {
  293. SmartClass smartClass = smartClasses.get(i);
  294. String id = smartClass.getId()+"";
  295. if (0==i) {
  296. classIds=id;
  297. }else {
  298. classIds=classIds+","+id;
  299. }
  300. }
  301. PageHelper.startPage(currentPage, pageCount);
  302. PageInfo<userPage> list = driverStockService.getUserPage(key, identityId,classIds);
  303. return CommonResult.ok(list);
  304. }
  305. @Override
  306. @PassToken
  307. @DESRespondSecret(validated = false)
  308. public CommonResult getScorePer(String examName, String updateUser) {
  309. List<Tj> list = driverStockService.getScorePer(examName, updateUser);
  310. return CommonResult.ok(list);
  311. }
  312. @Override
  313. @PassToken
  314. @DESRespondSecret(validated = false)
  315. public CommonResult getExamName() {
  316. List<Tj> list = driverStockService.getExamName();
  317. return CommonResult.ok(list);
  318. }
  319. @Override
  320. @PassToken
  321. @DESRespondSecret(validated = false)
  322. public CommonResult getTeacherExam(String cardNo) {
  323. Tj list = driverStockService.getTeacherExam(cardNo);
  324. return CommonResult.ok(list);
  325. }
  326. }