package com.yeshi.fanli.controller.admin.homemodule; import java.io.PrintWriter; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.annotation.Resource; import net.sf.json.JSONObject; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.commons.CommonsMultipartFile; import org.yeshi.utils.JsonUtil; import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.reflect.TypeToken; import com.yeshi.fanli.entity.bus.homemodule.Special; import com.yeshi.fanli.entity.bus.homemodule.SpecialCard; import com.yeshi.fanli.entity.bus.homemodule.SuperSpecialCard; import com.yeshi.fanli.entity.common.JumpDetailV2; import com.yeshi.fanli.entity.system.System; import com.yeshi.fanli.service.AdminUserService; import com.yeshi.fanli.service.inter.common.JumpDetailV2Service; import com.yeshi.fanli.service.inter.config.SystemConfigService; import com.yeshi.fanli.service.inter.config.SystemService; import com.yeshi.fanli.service.inter.homemodule.SpecialCardService; import com.yeshi.fanli.service.inter.homemodule.SpecialService; import com.yeshi.fanli.service.inter.homemodule.SuperSpecialCardService; import com.yeshi.fanli.tag.PageEntity; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.StringUtil; @Controller @RequestMapping("admin/new/api/v1/specialcard") public class SpecialCardAdminController { @Resource private SpecialService specialService; @Resource private SpecialCardService specialCardService; @Resource private SuperSpecialCardService superSpecialCardService; @Resource private SystemConfigService systemConfigService; @Resource private JumpDetailV2Service jumpDetailV2Service; @Resource private AdminUserService adminUserService; @Resource private SystemService systemService; /** * 新增 * @param callback * @param special * @param out */ @RequestMapping(value = "saveAdd") public void saveAdd(String callback, SpecialCard specialCard, PrintWriter out) { try { String name = specialCard.getName(); String card = specialCard.getCard(); if (StringUtil.isNullOrEmpty(name) || StringUtil.isNullOrEmpty(card)) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("专题信息与标识不能为空")); return; } Date nowTime = new Date(); specialCard.setState(1); // 默认停用 specialCard.setCreatetime(nowTime); specialCard.setUpdatetime(nowTime); specialCardService.insert(specialCard); List systemList = systemService.getSystems(); if (systemList != null && systemList.size() > 0) { for (System system: systemList) { SuperSpecialCard superCard = new SuperSpecialCard(); superCard.setSpecialCard(specialCard); superCard.setSystem(system); superSpecialCardService.insertSelective(superCard); } } JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("添加成功")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修改 * @param callback * @param special * @param out */ @RequestMapping(value = "saveModify") public void saveModify(String callback, SpecialCard specialCard, PrintWriter out) { try { Long id = specialCard.getId(); if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } SpecialCard resultObj = specialCardService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } String name = specialCard.getName(); String card = specialCard.getCard(); if (StringUtil.isNullOrEmpty(name) && StringUtil.isNullOrEmpty(card)) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("修改内容不能为空")); return; } if (StringUtil.isNullOrEmpty(name)) { specialCard.setName(null); } if (StringUtil.isNullOrEmpty(card)) { specialCard.setCard(null); } specialCard.setUpdatetime(new Date()); specialCardService.updateByPrimaryKeySelective(specialCard); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("修改成功")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修该状态 * @param callback * @param id * @param out */ @RequestMapping(value = "updateState") public void updateState(String callback, Long id, PrintWriter out) { try { if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } SpecialCard resultObj = specialCardService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } Integer state = resultObj.getState(); if (state == null || state.equals(1) || state == 1) { resultObj.setState(0); } else { resultObj.setState(1); } specialCardService.updateByPrimaryKeySelective(resultObj); JSONObject data = new JSONObject(); data.put("state", resultObj.getState()); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修改系统状态 * @param callback * @param type * @param cardId * @param systemId * @param out */ @RequestMapping(value = "saveSystemState") public void saveSystemState(String callback, Long cardId, Long systemId, PrintWriter out) { if (cardId == null || systemId == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("传递参数不能为空")); return; } try { List list = superSpecialCardService.querybyCardIdAndSystemId(cardId, systemId); if (list != null && list.size() > 0) { superSpecialCardService.deletebyCardIdAndSystemId(cardId, systemId); JSONObject data = new JSONObject(); data.put("check", 0); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } else { SpecialCard specialCard = new SpecialCard(); specialCard.setId(cardId); System system = new System(); system.setId(systemId); SuperSpecialCard superCard = new SuperSpecialCard(); superCard.setSpecialCard(specialCard); superCard.setSystem(system); superSpecialCardService.insertSelective(superCard); JSONObject data = new JSONObject(); data.put("check", 1); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } } catch (Exception e1) { e1.printStackTrace(); JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("修改失败")); } } /** * 查询 * @param callback * @param pageIndex * @param pageSize * @param key 模糊查询:说明、标识 * @param out */ @RequestMapping(value = "query") public void query(String callback, Integer pageIndex, Integer pageSize, String key, Integer sort, PrintWriter out) { if (pageIndex == null || pageIndex < 1) { pageIndex = 1; } if (pageSize == null || pageSize < 1) { pageSize = Constant.PAGE_SIZE; } try { List list = specialCardService.listQuery((pageIndex - 1) * pageSize, pageSize, key, sort); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据")); return; } for (SpecialCard specialCard: list) { long totalSpecial= specialService.countlistQueryByCard(specialCard.getId(), null); specialCard.setTotalSpecial(totalSpecial); } long count = specialCardService.countlistQuery(key); int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1); PageEntity pe = new PageEntity(pageIndex, pageSize, count, totalPage); GsonBuilder gsonBuilder = new GsonBuilder(); gsonBuilder.serializeNulls(); Gson gson = gsonBuilder.setDateFormat("yyyy/MM/dd HH:mm:ss").create(); JSONObject data = new JSONObject(); data.put("pe", pe); data.put("result_list", gson.toJson(list)); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 删除 * @param callback * @param idArray * @param out */ @RequestMapping(value = "delete") public void delete(String callback, String idArray, PrintWriter out) { try { if (StringUtil.isNullOrEmpty(idArray)) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("请选择操作的数据")); return; } Gson gson = new Gson(); List list = gson.fromJson(idArray, new TypeToken>() {}.getType()); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("未检测到删除的数据")); return; } int count = specialCardService.deleteBatchByPrimaryKey(list); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("成功删除["+ count +"]条数据")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("删除失败")); e.printStackTrace(); } } /** * 查询专题 * @param callback * @param pageIndex * @param pageSize * @param bannerId * @param out */ @RequestMapping(value = "querySpecial") public void querySpecial(String callback, Integer pageIndex, Integer pageSize, String key, Long cardId, PrintWriter out) { if (pageIndex == null || pageIndex < 1) { pageIndex = 1; } if (pageSize == null || pageSize < 1) { pageSize = Constant.PAGE_SIZE; } if (cardId == null) { out.print(JsonUtil.loadFalseResult("唯一标识ID不能为空")); return; } try { List list = specialService.listQueryByCard((pageIndex - 1) * pageSize, pageSize, cardId, key); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据")); return; } // 跳转链接 for (Special special: list) { String params = special.getParams(); if (!StringUtil.isNullOrEmpty(params)) { JSONObject jsonData = JSONObject.fromObject(params); if (jsonData.get("url") != null){ special.setParams(jsonData.get("url").toString()); } else { special.setParams(null); } } JumpDetailV2 jumpDetail = special.getJumpDetail(); if (jumpDetail == null) { // 默认未选择 JumpDetailV2 jumpDetailV2 = new JumpDetailV2(); jumpDetailV2.setName("-未选择-"); jumpDetailV2.setType("default"); special.setJumpDetail(jumpDetailV2); } } long count = specialService.countlistQueryByCard(cardId, key); int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1); PageEntity pe = new PageEntity(pageIndex, pageSize, count, totalPage); GsonBuilder gsonBuilder = new GsonBuilder(); gsonBuilder.serializeNulls(); Gson gson = gsonBuilder.setDateFormat("yyyy/MM/dd HH:mm:ss").create(); JSONObject data = new JSONObject(); data.put("pe", pe); data.put("result_list", gson.toJson(list)); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修改专题信息 * @param callback * @param record * @param out */ @RequestMapping(value = "modifySpecial") public void modifySpecial(String callback, Special record, String jumpType, PrintWriter out) { Long id = record.getId(); if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } try { Special resultObj = specialService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } String params = record.getParams(); if (!StringUtil.isNullOrEmpty(params)) { String jumpValue = systemConfigService.get("jump"); if (StringUtil.isNullOrEmpty(jumpValue)) { jumpValue = "{\"url\":\"#\"}"; } params = jumpValue.replace("#", params); record.setParams(params); } if (!StringUtil.isNullOrEmpty(jumpType)) { List listByType = jumpDetailV2Service.listByType(jumpType); if (listByType !=null && listByType.size() > 0) { record.setJumpDetail(listByType.get(0)); } } specialService.updateByPrimaryKeySelective(record); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("保存成功")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作失败")); e.printStackTrace(); } } /** * 专题图片上传 * @param file * @param uid * @param id * @param request * @param response * @param out */ @RequestMapping(value = "saveSpecial") public void saveSpecial(@RequestParam("file") CommonsMultipartFile file, Long id, Long cardId, PrintWriter out) { if (file == null) { out.print(JsonUtil.loadFalseResult("上传文件为空")); return; } try { Special resultObj = null; if (id != null) { resultObj = specialService.selectByPrimaryKey(id); if (resultObj == null) { out.print(JsonUtil.loadFalseResult("该专题已不存在")); return; } } specialService.uploadPicture(file, resultObj, cardId); out.print(JsonUtil.loadTrueResult("上传成功")); } catch (Exception e) { out.print(JsonUtil.loadFalseResult("操作失败")); e.printStackTrace(); } } /** * 删除专题 * @param callback * @param idArray * @param out */ @RequestMapping(value = "deleteSpecial") public void deleteSpecial(String callback, String idArray, PrintWriter out) { try { if (StringUtil.isNullOrEmpty(idArray)) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("请选择操作的数据")); return; } Gson gson = new Gson(); List list = gson.fromJson(idArray, new TypeToken>() {}.getType()); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("未检测到删除的数据")); return; } int count = specialService.deleteBatchByPrimaryKey(list); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("成功删除["+ count +"]条数据")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("删除失败")); e.printStackTrace(); } } /** * 修该状态 * @param callback * @param id * @param out */ @RequestMapping(value = "updateSpecialState") public void updateSpecialState(String callback, Long id, PrintWriter out) { try { if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } Special resultObj = specialService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } Long state = resultObj.getState(); if (state == null || state.equals(1) || state == 1) { resultObj.setState(0L); } else { resultObj.setState(1L); } specialService.updateByPrimaryKeySelective(resultObj); JSONObject data = new JSONObject(); data.put("state", resultObj.getState()); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修改排序 * * @param callback * @param goodsClass * @param out */ @RequestMapping(value = "saveSpecialOrder") public void saveSpecialOrder(String callback, Long id,Integer moveType, PrintWriter out) { if (moveType == null || (!moveType.equals(1) && !moveType.equals(-1))) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("传递的类型不正确")); return; } if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } try { Special resultObj = specialService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } Long cid = resultObj.getCardId(); Integer oldOrder = resultObj.getOrderby(); List list = specialService.getOrderByCardID(cid, moveType, oldOrder); if (list != null && list.size() > 0) { Special changeObj = list.get(0); // 交换排序序号 resultObj.setOrderby(changeObj.getOrderby()); changeObj.setOrderby(oldOrder); specialService.updateByPrimaryKeySelective(changeObj); } specialService.updateByPrimaryKeySelective(resultObj); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("操作成功")); } catch (Exception e) { e.printStackTrace(); JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); } } }