MouldEquipmentServiceImpl.java 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. package com.hssx.cloudmodel.service.impl;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.github.pagehelper.PageHelper;
  6. import com.github.pagehelper.PageInfo;
  7. import com.hssx.cloudmodel.constant.Constant;
  8. import com.hssx.cloudmodel.entity.*;
  9. import com.hssx.cloudmodel.entity.vo.MouldEquipmentVO;
  10. import com.hssx.cloudmodel.entity.vo.UserVO;
  11. import com.hssx.cloudmodel.mapper.*;
  12. import com.hssx.cloudmodel.service.MouldEquipmentService;
  13. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  14. import com.hssx.cloudmodel.util.*;
  15. import org.apache.commons.lang3.StringEscapeUtils;
  16. import org.apache.poi.ss.usermodel.Cell;
  17. import org.apache.poi.xssf.usermodel.XSSFCell;
  18. import org.apache.poi.xssf.usermodel.XSSFRow;
  19. import org.apache.poi.xssf.usermodel.XSSFSheet;
  20. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  21. import org.springframework.stereotype.Service;
  22. import org.springframework.web.bind.annotation.RequestParam;
  23. import org.springframework.web.multipart.MultipartFile;
  24. import javax.annotation.Resource;
  25. import java.io.*;
  26. import java.security.KeyManagementException;
  27. import java.security.NoSuchAlgorithmException;
  28. import java.security.NoSuchProviderException;
  29. import java.text.SimpleDateFormat;
  30. import java.time.LocalDateTime;
  31. import java.time.LocalTime;
  32. import java.util.*;
  33. import java.util.stream.Collectors;
  34. /**
  35. * <p>
  36. * 服务实现类
  37. * </p>
  38. *
  39. * @author 吴涛涛
  40. * @since 2019-08-02
  41. */
  42. @Service
  43. public class MouldEquipmentServiceImpl extends ServiceImpl<MouldEquipmentMapper, MouldEquipment> implements MouldEquipmentService {
  44. @Resource
  45. MouldEquipmentMapper mouldEquipmentMapper;
  46. @Resource
  47. MouldMapper mouldMapper;
  48. @Resource
  49. UserMapper userMapper;
  50. @Resource
  51. NewsNoticeMapper newsNoticeMapper;
  52. @Resource
  53. NewsNoticeUserMapper newsNoticeUserMapper;
  54. @Resource
  55. PowerMapper powerMapper;
  56. @Resource
  57. ProjectMapper projectMapper;
  58. @Resource
  59. ProjectApproveMapper projectApproveMapper;
  60. @Resource
  61. CustomCompanyMapper customCompanyMapper;
  62. @Resource
  63. CompanyMapper companyMapper;
  64. @Resource
  65. ProjectUserMapper projectUserMapper;
  66. @Override
  67. public HttpRespMsg addAndUpdateMouldEquipment(MouldEquipment mouldEquipment, User user) {
  68. HttpRespMsg msg = new HttpRespMsg();
  69. if (user.getParentId() == 0) {
  70. if (mouldEquipment.getId() == null) {
  71. //添加设备
  72. //查询当前设备编号的模具是否存在
  73. Integer count = mouldEquipmentMapper.selectCount(new QueryWrapper<MouldEquipment>().eq("equipment_no", mouldEquipment.getEquipmentNo()));
  74. if (count > 0) {
  75. msg.setError("当前设备编号已存在,请重新输入其他模具编号");
  76. } else {
  77. mouldEquipmentMapper.insert(mouldEquipment);
  78. }
  79. } else {
  80. //修改设备
  81. MouldEquipment mouldEqu = mouldEquipmentMapper.selectById(mouldEquipment.getId());
  82. MouldEquipment m = mouldEquipmentMapper.selectOne(new QueryWrapper<MouldEquipment>().eq("equipment_no", mouldEquipment.getEquipmentNo()));
  83. if (mouldEqu.getEquipmentNo().equals(mouldEquipment.getEquipmentNo()) || m==null) {
  84. mouldEquipmentMapper.updateById(mouldEquipment);
  85. } else{
  86. msg.setError("当前设备编号已存在,请重新输入其他模具编号");
  87. }
  88. }
  89. } else {
  90. msg.setError("对不起,您不是管理员,不具备设备创建或修改的权限");
  91. }
  92. return msg;
  93. }
  94. @Override
  95. public HttpRespMsg isUse(MouldEquipment mouldEquipment, User user) {
  96. HttpRespMsg msg = new HttpRespMsg();
  97. //判断是不是超级管理员,是才可操作
  98. if (user.getParentId() == 0) {
  99. //修改设备
  100. MouldEquipment newMouldEquipment = mouldEquipmentMapper.selectById(mouldEquipment.getId());
  101. if (null == newMouldEquipment.getBelongCompanyId()) {
  102. msg.setError("该设备没有所属公司,请添加所属公司后再启用");
  103. return msg;
  104. }
  105. newMouldEquipment.setIsUse(mouldEquipment.getIsUse());
  106. LocalDateTime now = LocalDateTime.now();
  107. newMouldEquipment.setStartTime(now);
  108. newMouldEquipment.setEndTime(now.plusYears(newMouldEquipment.getUseLife()));
  109. mouldEquipmentMapper.updateById(newMouldEquipment);
  110. } else {
  111. msg.setError("对不起,您不是超级管理员,不具备启用设备的权限");
  112. return msg;
  113. }
  114. return msg;
  115. }
  116. @Override
  117. public HttpRespMsg getList(User user, PageUtil page, Integer companyId, String keyName) {
  118. HttpRespMsg msg = new HttpRespMsg();
  119. if (user != null) {
  120. if (Constant.SYS_PARENT_ID.equals(user.getParentId())) {
  121. PageHelper.startPage(page.getPageNum(), page.getPageSize());
  122. List<MouldEquipmentVO> mouldEquipments = mouldEquipmentMapper.getList(companyId, keyName);
  123. PageInfo<MouldEquipmentVO> pageInfo = new PageInfo<>(mouldEquipments);
  124. msg.data = pageInfo;
  125. } else {
  126. msg.setError("对不起,您不含有查看该列表的权利");
  127. }
  128. }
  129. return msg;
  130. }
  131. @Override
  132. public HttpRespMsg getListByCompanyId(MouldEquipmentVO mouldEquipmentVO) {
  133. HttpRespMsg msg = new HttpRespMsg();
  134. List<Integer> mouldsEquipmentIds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", mouldEquipmentVO.getBelongCompanyId()).isNotNull("equipment_id")).stream().map(Mould::getEquipmentId).collect(Collectors.toList());
  135. mouldsEquipmentIds.add(-1);
  136. List<Integer> equipmentIds = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("belong_company_id", mouldEquipmentVO.getBelongCompanyId()).eq("stage", 0)).stream().map(MouldEquipment::getId).collect(Collectors.toList());
  137. equipmentIds.removeAll(mouldsEquipmentIds);//把已经使用的设备剔除
  138. equipmentIds.add(-1);
  139. List<MouldEquipmentVO> list = mouldEquipmentMapper.getListByCompanyId(mouldEquipmentVO.getBelongCompanyId(), equipmentIds);
  140. msg.data = list;
  141. return msg;
  142. }
  143. @Override
  144. public HttpRespMsg MouldEquipmentAlarm() {
  145. HttpRespMsg msg = new HttpRespMsg();
  146. String token = GainTokenUtil.getToken();
  147. List<MouldEquipment> mouldEquipments = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("is_use", 1));
  148. for (MouldEquipment mouldEquipment : mouldEquipments) {
  149. Mould mould = mouldMapper.selectOne(new QueryWrapper<Mould>().eq("equipment_id", mouldEquipment.getId()));
  150. Project project = projectMapper.selectById(mould.getProjectId());
  151. List<Integer> uids = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId())).stream().map(ProjectUser::getUserId).collect(Collectors.toList());
  152. uids.add(project.getManagerId());
  153. uids.add(project.getCreatorId());
  154. uids.add(-1);
  155. List<User> userList = userMapper.selectList(new QueryWrapper<User>().in("id", uids).isNotNull("openid").eq("is_disable", 1));
  156. if (Constant.ELECTRICITY_THRESHOLD >= Double.parseDouble(mouldEquipment.getHillNumber())) {
  157. if (0 == mouldEquipment.getStage()) {
  158. mouldEquipment.setStage(2);
  159. } else {
  160. mouldEquipment.setStage(3);
  161. }
  162. mouldEquipmentMapper.updateById(mouldEquipment);
  163. //公众号的推送to do
  164. userList.forEach(u -> {
  165. try {
  166. WechatTemplateUtil.sendEmergencyTemplateMessage(u.getOpenid(), mouldEquipment.getEquipmentName(), Constant.ELECTRICITY_TYPE, Constant.ELECTRICITY_CONTENT, token);
  167. } catch (Exception e) {
  168. e.printStackTrace();
  169. }
  170. });
  171. //查询到参与该项目的人
  172. List<Integer> userIds = new ArrayList<>();
  173. userIds.add(-1);
  174. userIds.add(project.getCreatorId());
  175. userIds.add(project.getManagerId());
  176. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId()));
  177. for (ProjectUser projectUser : projectUsers) {
  178. userIds.add(projectUser.getUserId());
  179. }
  180. List<ProjectApprove> projectApproves = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()));
  181. for (ProjectApprove projectApprove : projectApproves) {
  182. userIds.add(projectApprove.getApproverId());
  183. }
  184. List<User> users = userMapper.selectList(new QueryWrapper<User>().in("id", userIds));
  185. //查询到之前模具保养的消息
  186. NewsNotice oldNews = newsNoticeMapper.selectOne(new QueryWrapper<NewsNotice>().eq("ref_id", mould.getId()).eq("notice_type", 2));
  187. NewsNotice newsNotice = new NewsNotice();
  188. if (oldNews != null) {
  189. NewsNotice newNews = new NewsNotice();
  190. newNews.setId(oldNews.getId());
  191. oldNews.setIndate(LocalDateTime.now());
  192. newsNoticeMapper.updateById(oldNews);
  193. newsNoticeUserMapper.updateNewsNoticeUserByNewsNoticeId(oldNews.getId());
  194. // for (User u : users) {
  195. // //添加通知的消息
  196. // NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  197. // newsNoticeUser.setNewsId(oldNews.getId());
  198. // newsNoticeUser.setUserId(u.getId());
  199. // newsNoticeUser.setIsRead(0);
  200. // newsNoticeUserMapper.updateById(newsNoticeUser);
  201. // }
  202. } else {
  203. newsNotice.setNoticeType(Constant.EMERGENCY_TYPE);
  204. newsNotice.setProjectId(project.getId());
  205. newsNotice.setProjectName(project.getProjectName() + "-" + mould.getModelName());
  206. // newsNotice.setRefId(mould.getId());
  207. newsNotice.setContent(mouldEquipment.getEquipmentNo() + "-" + Constant.EMERGENCY_ELECTRICITY_NOTICE);
  208. newsNoticeMapper.insert(newsNotice);
  209. for (User u : users) {
  210. //添加通知的消息
  211. NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  212. newsNoticeUser.setNewsId(newsNotice.getId());
  213. newsNoticeUser.setUserId(u.getId());
  214. newsNoticeUserMapper.insert(newsNoticeUser);
  215. }
  216. }
  217. }
  218. if (Constant.TEMPERATURE_THRESHOLD <= mouldEquipment.getTemperature()) {
  219. if (0 == mouldEquipment.getStage()) {
  220. mouldEquipment.setStage(1);
  221. } else {
  222. mouldEquipment.setStage(3);
  223. }
  224. mouldEquipmentMapper.updateById(mouldEquipment);
  225. //公众号的推送to do
  226. userList.forEach(u -> {
  227. try {
  228. WechatTemplateUtil.sendEmergencyTemplateMessage(u.getOpenid(), mouldEquipment.getEquipmentName(), Constant.TEMPERATURE_TYPE, Constant.TEMPERATURE_CONTENT, token);
  229. } catch (Exception e) {
  230. e.printStackTrace();
  231. }
  232. });
  233. //查询到参与该项目的人
  234. List<Integer> userIds = new ArrayList<>();
  235. userIds.add(-1);
  236. userIds.add(project.getCreatorId());
  237. userIds.add(project.getManagerId());
  238. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId()));
  239. for (ProjectUser projectUser : projectUsers) {
  240. userIds.add(projectUser.getUserId());
  241. }
  242. List<ProjectApprove> projectApproves = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()));
  243. for (ProjectApprove projectApprove : projectApproves) {
  244. userIds.add(projectApprove.getApproverId());
  245. }
  246. List<User> users = userMapper.selectList(new QueryWrapper<User>().in("id", userIds));
  247. //查询到之前模具保养的消息
  248. NewsNotice oldNews = newsNoticeMapper.selectOne(new QueryWrapper<NewsNotice>().eq("ref_id", mould.getId()).eq("notice_type", 2));
  249. NewsNotice newsNotice = new NewsNotice();
  250. if (oldNews != null) {
  251. NewsNotice newNews = new NewsNotice();
  252. newNews.setId(oldNews.getId());
  253. oldNews.setIndate(LocalDateTime.now());
  254. newsNoticeMapper.updateById(oldNews);
  255. newsNoticeUserMapper.updateNewsNoticeUserByNewsNoticeId(oldNews.getId());
  256. // for (User u : users) {
  257. // //添加通知的消息
  258. // NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  259. // newsNoticeUser.setNewsId(oldNews.getId());
  260. // newsNoticeUser.setUserId(u.getId());
  261. // newsNoticeUser.setIsRead(0);
  262. // newsNoticeUserMapper.updateById(newsNoticeUser);
  263. // }
  264. } else {
  265. newsNotice.setNoticeType(Constant.EMERGENCY_TYPE);
  266. newsNotice.setProjectId(project.getId());
  267. newsNotice.setProjectName(project.getProjectName() + "-" + mould.getModelName());
  268. // newsNotice.setRefId(mould.getId());
  269. newsNotice.setContent(mouldEquipment.getEquipmentNo() + "-" + Constant.EMERGENCY_TEMPERATURE_NOTICE);
  270. newsNoticeMapper.insert(newsNotice);
  271. for (User u : users) {
  272. //添加通知的消息
  273. NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  274. newsNoticeUser.setNewsId(newsNotice.getId());
  275. newsNoticeUser.setUserId(u.getId());
  276. newsNoticeUserMapper.insert(newsNoticeUser);
  277. }
  278. }
  279. }
  280. }
  281. return msg;
  282. }
  283. @Override
  284. public HttpRespMsg importMouldEquipmentExcel(MultipartFile file, UserVO userVO) {
  285. HttpRespMsg msg = new HttpRespMsg();
  286. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  287. if (user != null) {
  288. List<MouldEquipment> mouldEquipments = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>());
  289. try {
  290. File f = null;
  291. if ("".equals(file) || file.getSize() <= 0) {
  292. file = null;
  293. } else {
  294. //获取输入流
  295. InputStream ins = file.getInputStream();
  296. //新建一个文件
  297. f = new File(file.getOriginalFilename());
  298. //输入流转file
  299. inputStreamToFile(ins, f);
  300. }
  301. //根据文件创建工作簿
  302. XSSFWorkbook wookbook = new XSSFWorkbook(f);
  303. XSSFSheet sheet = wookbook.getSheetAt(0);
  304. int s = sheet.getLastRowNum();
  305. // 遍历当前sheet中的所有行,第一行是数据对应的字段,不是数据,
  306. // 故从第二行开始遍历拿数据(如果有标题的话,则从第三行开始拿数据)
  307. for (int j = 1; j < sheet.getLastRowNum() + 1; j++) {
  308. XSSFRow row = sheet.getRow(j);
  309. //新建云模盒对象
  310. MouldEquipment mouldEquipment = new MouldEquipment();
  311. // 遍历所有的列,下面的10是excle表格里共有10列即对应了10个字段
  312. for (int y = 0; y < 3; y++) {
  313. XSSFCell cell = row.getCell(y);
  314. cell.setCellType(Cell.CELL_TYPE_STRING);
  315. //取出当前列的值
  316. String value = cell.getStringCellValue();
  317. //判断第几列插入数据,后面就是从列中取数据往对象里放,然后插入到数据库里
  318. if (value == null && "".equals(value)) {
  319. log.error("数据不可为空");
  320. msg.setError("数据不可为空");
  321. return msg;
  322. } else if (y == 0) {
  323. //云模编号
  324. for (MouldEquipment p : mouldEquipments) {
  325. if (value.equals(p.getEquipmentNo())) {
  326. // msg.setError("第" + j + "行的云模盒编号:" + value + "已被占用,请修改后重新上传");
  327. msg.setError("云模盒编号已被占用,请修改后重新上传");
  328. return msg;
  329. }
  330. }
  331. mouldEquipment.setEquipmentNo(value);
  332. } else if (y == 1) {
  333. //使用年限
  334. mouldEquipment.setUseLife(Integer.parseInt(value));
  335. } else if (y == 2) {
  336. //代理商
  337. mouldEquipment.setAgent(value);
  338. }
  339. }
  340. mouldEquipmentMapper.insert(mouldEquipment);
  341. }
  342. //用完后删除临时文件
  343. if (!f.isDirectory()) {
  344. f.delete();
  345. }
  346. } catch (Exception e) {
  347. log.error(e.getMessage(), e);
  348. msg.setError(e.getMessage());
  349. return msg;
  350. }
  351. } else {
  352. msg.setError("用户不存在或者未登录");
  353. }
  354. return msg;
  355. }
  356. @Override
  357. public HttpRespMsg getEquipmentListByOldMouldAndUser(UserVO userVO) {
  358. HttpRespMsg msg = new HttpRespMsg();
  359. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  360. if (user == null) {
  361. msg.setError("用户不存在或者未登录");
  362. } else {
  363. Mould mould = mouldMapper.selectById(userVO.getMouldId());
  364. User admin = userMapper.selectById(projectMapper.selectById(mould.getProjectId()).getCreatorId());
  365. List<Integer> mouldsEquipmentIds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", admin.getCompanyId()).isNotNull("equipment_id")).stream().map(Mould::getEquipmentId).collect(Collectors.toList());
  366. mouldsEquipmentIds.add(-1);
  367. List<Integer> equipmentIds = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("belong_company_id", admin.getCompanyId()).eq("stage", 0)).stream().map(MouldEquipment::getId).collect(Collectors.toList());
  368. equipmentIds.removeAll(mouldsEquipmentIds);//把已经使用的设备剔除
  369. equipmentIds.add(-1);
  370. List<MouldEquipmentVO> list = mouldEquipmentMapper.getListByCompanyId(admin.getCompanyId(), equipmentIds);
  371. msg.data = list;
  372. }
  373. return msg;
  374. }
  375. /**
  376. * 输入流转file
  377. *
  378. * @param ins
  379. * @param file
  380. */
  381. public static void inputStreamToFile(InputStream ins, File file) {
  382. try {
  383. OutputStream os = new FileOutputStream(file);
  384. int bytesRead = 0;
  385. byte[] buffer = new byte[8192];
  386. while ((bytesRead = ins.read(buffer, 0, 8192)) != -1) {
  387. os.write(buffer, 0, bytesRead);
  388. }
  389. os.close();
  390. ins.close();
  391. } catch (Exception e) {
  392. e.printStackTrace();
  393. }
  394. }
  395. }