MouldEquipmentServiceImpl.java 17 KB

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