From 98b1a0affd69bbe63223c21fdd2c404e8bedfccb Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期三, 20 五月 2020 17:25:08 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/div' into 2.1.2 --- fanli/src/main/java/com/yeshi/fanli/service/impl/homemodule/SpecialCardServiceImpl.java | 246 ++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 230 insertions(+), 16 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/homemodule/SpecialCardServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/homemodule/SpecialCardServiceImpl.java index d66fbf4..3dac5f8 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/homemodule/SpecialCardServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/homemodule/SpecialCardServiceImpl.java @@ -1,12 +1,28 @@ package com.yeshi.fanli.service.impl.homemodule; +import java.io.InputStream; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.List; +import java.util.UUID; + import javax.annotation.Resource; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.web.multipart.MultipartFile; +import org.yeshi.utils.tencentcloud.COSManager; import com.yeshi.fanli.dao.mybatis.homemodule.SpecialCardMapper; import com.yeshi.fanli.entity.bus.homemodule.SpecialCard; +import com.yeshi.fanli.entity.bus.homemodule.SpecialPlace; +import com.yeshi.fanli.exception.homemodule.SpecialCardException; +import com.yeshi.fanli.service.inter.config.BusinessSystemService; import com.yeshi.fanli.service.inter.homemodule.SpecialCardService; +import com.yeshi.fanli.service.inter.homemodule.SpecialPlaceService; +import com.yeshi.fanli.service.inter.homemodule.SpecialService; +import com.yeshi.fanli.util.FilePathEnum; +import com.yeshi.fanli.util.StringUtil; @Service @@ -15,35 +31,233 @@ @Resource private SpecialCardMapper specialCardMapper; + @Resource + private BusinessSystemService businessSystemService; + + @Resource + private SpecialService specialService; + + @Resource + private SpecialPlaceService specialPlaceService; + @Override - public int deleteByPrimaryKey(Long id) { - return specialCardMapper.deleteByPrimaryKey(id); + public void saveObject(MultipartFile file, SpecialCard record) throws SpecialCardException, Exception{ + + String name = record.getName(); + if (name == null || name.trim().length() == 0) { + throw new SpecialCardException(1, "鍚嶇О涓嶈兘涓虹┖"); + } + + Long placeId = record.getPlaceId(); + if (placeId == null || placeId == 0) { + throw new SpecialCardException(1, "浣跨敤浣嶇疆涓嶈兘涓虹┖"); + } + + // 鏃堕棿浠诲姟鎺у埗 + handleTime(record); + + + // 鍥剧墖涓婁紶 + String picture = null; + if (file != null) { + picture = uploadPicture(file); + } + + Integer state = record.getState(); + if (state == null) { + record.setState(0); + } + + Long id = record.getId(); + if (id == null) { + record.setBottomPicture(picture); + + record.setCreatetime(new Date()); + record.setUpdatetime(new Date()); + specialCardMapper.insert(record); + } else { + // 淇敼 + SpecialCard resultObj = specialCardMapper.selectByPrimaryKey(id); + if (resultObj == null) { + throw new SpecialCardException(1, "淇敼鍐呭宸蹭笉瀛樺湪"); + } + + // 鍒犻櫎鍥剧墖 + Boolean delPicture = record.getDelPicture(); + if (delPicture != null && delPicture) { + removePicture(resultObj.getBottomPicture()); + resultObj.setBottomPicture(null); + } + + if (picture != null && picture.trim().length() > 0) { + // 鍒犻櫎鑰佸浘 + removePicture(resultObj.getBottomPicture()); + // 瀛樺偍鏂板浘 + record.setBottomPicture(picture); + } else { + record.setBottomPicture(resultObj.getBottomPicture()); + } + + record.setCreatetime(resultObj.getCreatetime()); + record.setUpdatetime(new Date()); + specialCardMapper.updateByPrimaryKey(record); + } + } + + /** + * web娈垫椂闂磋浆鎹� + * + * @param record + */ + private void handleTime(SpecialCard record) throws SpecialCardException, Exception { + SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm"); + + String startTime_str = record.getStartTime_str(); + if (!StringUtil.isNullOrEmpty(startTime_str)) { + startTime_str = startTime_str.replaceAll("T", " "); + record.setStartTime(format.parse(startTime_str)); + } + + String endTime_str = record.getEndTime_str(); + if (!StringUtil.isNullOrEmpty(endTime_str)) { + endTime_str = endTime_str.replaceAll("T", " "); + record.setEndTime(format.parse(endTime_str)); + } + + if (record.getEndTime() != null && record.getStartTime() != null + && record.getStartTime().getTime() > record.getEndTime().getTime()) { + throw new SpecialCardException(1, "璧峰鏃堕棿涓嶈兘灏忎簬缁撴潫鏃堕棿"); + } + } + + + + /** + * 涓婁紶鍥剧墖 + * @param file + * @return + * @throws Exception + */ + public String uploadPicture(MultipartFile file) throws Exception { + + // 鏂囦欢瑙f瀽 + InputStream inputStream = file.getInputStream(); + String contentType = file.getContentType(); + String type = contentType.substring(contentType.indexOf("/") + 1); + + // 鏂囦欢璺緞 + String filePath=FilePathEnum.specialCard.getPath() +UUID.randomUUID().toString().replace("-", "") + "." + type; + // 鎵ц涓婁紶 + String fileLink= COSManager.getInstance().uploadFile(inputStream, filePath).getUrl(); + + return fileLink; } - @Override - public int insert(SpecialCard record) { - return specialCardMapper.insert(record); + /** + * 鍒犻櫎鍥剧墖-涓嶆洿鏂版暟鎹簱 + * @param record + * @throws Exception + */ + public void removePicture(String picture) throws Exception { + if (picture != null && picture.trim().length() > 0) { + COSManager.getInstance().deleteFile(picture); + } } + @Override - public int insertSelective(SpecialCard record) { - return specialCardMapper.insertSelective(record); + @Transactional(rollbackFor=Exception.class) + public int deleteBatchByPrimaryKey(List<Long> list) throws Exception{ + specialService.deleteBatchByCardID(list); + return specialCardMapper.deleteBatchByPrimaryKey(list); } - + @Override - public SpecialCard selectByPrimaryKey(Long id) { - return specialCardMapper.selectByPrimaryKey(id); + public List<SpecialCard> listQuery(long start, int count, String key, Integer sort, List<Long> listPid) { + + List<SpecialCard> listObj = specialCardMapper.listQuery(start, count, key, listPid); + if (listObj == null || listObj.size() == 0) { + return null; + } + + for (SpecialCard specialCard: listObj) { + long totalSpecial= specialService.countlistQueryByCard(specialCard.getId(), null, null); + specialCard.setTotalSpecial(totalSpecial); + + // 灏嗙姸鎬佸彉鍖� + if (specialCard.getState() != null && specialCard.getState() == 0) { + specialCard.setState(1); + } else { + specialCard.setState(0); + } + + + Date startTime = specialCard.getStartTime(); + Date endTime = specialCard.getEndTime(); + if (startTime == null && endTime == null) { + specialCard.setStartTime_str(""); + specialCard.setEndTime_str(""); + } else { + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm"); + if (startTime == null) { + specialCard.setStartTime_str(""); + } else { + specialCard.setStartTime_str(sdf.format(startTime)); + } + + if (endTime == null) { + specialCard.setEndTime_str(""); + } else { + specialCard.setEndTime_str(sdf.format(endTime)); + } + } + + Long placeId = specialCard.getPlaceId(); + if (placeId != null) { + SpecialPlace specialPlace = specialPlaceService.selectByPrimaryKey(placeId); + if (specialPlace != null) { + specialCard.setPlaceName(specialPlace.getName()); + } + } + } + return listObj; } - + @Override - public int updateByPrimaryKeySelective(SpecialCard record) { - return specialCardMapper.updateByPrimaryKeySelective(record); + public long countlistQuery(String key, List<Long> listPid) { + return specialCardMapper.countlistQuery(key, listPid); } - + @Override - public int updateByPrimaryKey(SpecialCard record) { - return specialCardMapper.updateByPrimaryKey(record); + public String getbottomPicture(String placeKey) { + return specialCardMapper.getbottomPicture(placeKey); } + + + @Override + public void switchState(Long id) throws SpecialCardException { + if (id == null) { + throw new SpecialCardException(1, "璇蜂紶閫掓纭弬鏁�"); + } + + SpecialCard resultObj = specialCardMapper.selectByPrimaryKey(id); + if (resultObj == null) { + throw new SpecialCardException(1, "姝ゅ唴瀹瑰凡涓嶅瓨鍦�"); + } + + Integer state = resultObj.getState(); + if (state == null || state == 0) { + state = 1; + } else { + state = 0; + } + + SpecialCard updateObj = new SpecialCard(); + updateObj.setId(id); + updateObj.setState(state); + specialCardMapper.updateByPrimaryKeySelective(updateObj); + } + } -- Gitblit v1.8.0