package com.yeshi.fanli.controller.admin.homemodule; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; import java.util.Set; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.multipart.MultipartHttpServletRequest; 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.AppVersionInfo; import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl; import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl.AdActivityType; import com.yeshi.fanli.entity.bus.homemodule.CommonShareInfo; import com.yeshi.fanli.entity.bus.homemodule.Special; import com.yeshi.fanli.entity.bus.homemodule.SpecialCard; import com.yeshi.fanli.exception.homemodule.SpecialCardException; import com.yeshi.fanli.exception.homemodule.SpecialException; import com.yeshi.fanli.service.inter.config.AppVersionService; import com.yeshi.fanli.service.inter.homemodule.AdActivityVersionControlService; import com.yeshi.fanli.service.inter.homemodule.SpecialCardService; import com.yeshi.fanli.service.inter.homemodule.SpecialService; import com.yeshi.fanli.tag.PageEntity; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.StringUtil; import com.yeshi.fanli.vo.homemodule.SpecialVO; import net.sf.json.JSONArray; import net.sf.json.JSONObject; @Controller @RequestMapping("admin/new/api/v1/specialcard") public class SpecialCardAdminController { @Resource private SpecialService specialService; @Resource private SpecialCardService specialCardService; @Resource private AppVersionService appVersionService; @Resource private AdActivityVersionControlService adActivityVersionControlService; /** * 保存信息 * * @param callback * @param special * @param out */ @RequestMapping(value = "save") public void save(String callback, SpecialCard specialCard, HttpServletRequest request, PrintWriter out) { try { // 1. 先判断httpRequest 是否含有文件类型 if (request instanceof MultipartHttpServletRequest) { MultipartHttpServletRequest fileRequest = (MultipartHttpServletRequest) request; specialCardService.saveObject(fileRequest.getFile("file"), specialCard); } else { specialCardService.saveObject(null, specialCard); } JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("保存成功")); } catch (SpecialCardException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("保存失败")); e.printStackTrace(); } } /** * 查询 * * @param callback * @param pageIndex * @param pageSize * @param key * 模糊查询:说明、标识 * @param out */ @RequestMapping(value = "queryActivity") public void queryActivity(String callback, Integer pageIndex, Integer pageSize, String key, Integer sort, PrintWriter out) { List listPid = new ArrayList(); listPid.add(15L); listPid.add(16L); listPid.add(17L); queryList(callback, pageIndex, pageSize, key, sort, listPid, out); } /** * 查询 * * @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) { queryList(callback, pageIndex, pageSize, key, sort, null, out); } public void queryList(String callback, Integer pageIndex, Integer pageSize, String key, Integer sort, List listPid, 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, listPid); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据")); return; } long count = specialCardService.countlistQuery(key, listPid); 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 special * @param out */ @RequestMapping(value = "saveSpecial") public void saveSpecial(String callback, Special record, String jumpType, CommonShareInfo extra, HttpServletRequest request, PrintWriter out) { try { // 1. 先判断httpRequest 是否含有文件类型 if (request instanceof MultipartHttpServletRequest) { MultipartHttpServletRequest fileRequest = (MultipartHttpServletRequest) request; specialService.saveObject(fileRequest.getFile("file"), fileRequest.getFile("file2"), fileRequest.getFile("file3"), record, jumpType, extra); } else { specialService.saveObject(null, null, null, record, jumpType, extra); } JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("保存成功")); } catch (SpecialException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, 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 goodsClass * @param out */ @RequestMapping(value = "saveSpecialOrder") public void saveSpecialOrder(String callback, Long id, Integer moveType, Integer sex, PrintWriter out) { try { specialService.updateOrder(id, moveType, sex); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("操作成功")); } catch (SpecialException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } 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, Integer sex, String version, String platform, PrintWriter out) { pageSize = 100; 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; } List versionList = null; if (!StringUtil.isNullOrEmpty(version) || !StringUtil.isNullOrEmpty(platform)) { versionList = new ArrayList<>(); if (!StringUtil.isNullOrEmpty(version)) { AppVersionInfo appVersion = appVersionService.selectByPrimaryKey(Long.parseLong(version)); if (appVersion != null) versionList.add(appVersion); } else { List appVersionList = appVersionService.getAppVersionInfoListByPlatform(platform); if (appVersionList != null) { versionList.addAll(appVersionList); } } } try { List list = specialService.listQueryByCard((pageIndex - 1) * pageSize, pageSize, cardId, key, sex); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据")); return; } long count = specialService.countlistQueryByCard(cardId, key, sex); // 过滤 if (versionList != null) { if (versionList.size() > 0) { List sourceIdList = new ArrayList<>(); for (SpecialVO special : list) { sourceIdList.add(special.getId()); } List versionIdList = new ArrayList<>(); for (AppVersionInfo versionInfo : versionList) versionIdList.add(versionInfo.getId()); Set sets = adActivityVersionControlService.filterSourceIdByVersion(sourceIdList, AdActivityType.special, versionIdList); for (int i = 0; i < list.size(); i++) { if (!sets.contains(list.get(i).getId())) { list.remove(i--); } } count = list.size(); } else { list.clear(); count = 0; } } 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 id * @param moveType * @param sex * @param out */ @RequestMapping(value = "setVersions") public void setVersions(String callback, Long id, String versions, PrintWriter out) { JSONArray versionArray = JSONArray.fromObject(versions); List versionIds = new ArrayList<>(); for (int i = 0; i < versionArray.size(); i++) { Long version = versionArray.optLong(i); versionIds.add(version); } try { specialService.setVersions(id, versionIds); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMessage())); } } @RequestMapping(value = "getVersions") public void getVersions(String callback, Long id, PrintWriter out) { List list = adActivityVersionControlService .listByTypeAndSourceId(AdActivityType.special, id); List versionList = new ArrayList<>(); if (list != null) for (AdActivityVersionControl control : list) versionList.add(control.getVersion().getId()); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(versionList)); } /** * 修改状态 * @param callback * @param id * @param out */ @RequestMapping(value = "switchStateCard") public void switchStateCard(String callback, Long id, PrintWriter out) { try { specialCardService.switchState(id); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("操作成功")); } catch (SpecialCardException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作失败")); e.printStackTrace(); } } /** * 修改状态 * @param callback * @param id * @param out */ @RequestMapping(value = "switchState") public void switchState(String callback, Long id, PrintWriter out) { try { specialService.switchState(id); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("操作成功")); } catch (SpecialException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作失败")); e.printStackTrace(); } } }