admin
2019-07-30 573c491b4a1ba60e12a5678a01c1546c0077c1ee
fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java
@@ -2,15 +2,14 @@
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
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.bind.annotation.RequestParam;
import org.springframework.web.multipart.commons.CommonsMultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.yeshi.utils.JsonUtil;
import com.google.gson.Gson;
@@ -18,16 +17,10 @@
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.BusinessSystem;
import com.yeshi.fanli.service.AdminUserService;
import com.yeshi.fanli.service.inter.common.JumpDetailV2Service;
import com.yeshi.fanli.service.inter.config.BusinessSystemService;
import com.yeshi.fanli.service.inter.config.SystemConfigService;
import com.yeshi.fanli.exception.FloatADException;
import com.yeshi.fanli.exception.homemodule.SpecialException;
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;
@@ -44,207 +37,33 @@
   @Resource
   private SpecialCardService specialCardService;
   
   @Resource
   private SuperSpecialCardService superSpecialCardService;
   @Resource
   private SystemConfigService systemConfigService;
   @Resource
   private JumpDetailV2Service jumpDetailV2Service;
   @Resource
   private AdminUserService adminUserService;
   @Resource
   private BusinessSystemService businessSystemService;
   /**
    * 新增
    * 保存信息
    *
    * @param callback
    * @param special
    * @param out
    */
   @RequestMapping(value = "saveAdd")
   public void saveAdd(String callback, SpecialCard specialCard, PrintWriter 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);
           }
         
         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<BusinessSystem> systemList = businessSystemService.getBusinessSystems();
         if (systemList != null && systemList.size() > 0) {
            for (BusinessSystem system: systemList) {
               SuperSpecialCard superCard = new  SuperSpecialCard();
               superCard.setSpecialCard(specialCard);
               superCard.setSystem(system);
               superSpecialCardService.insertSelective(superCard);
            }
         }
         JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("添加成功"));
         JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("保存成功"));
      } catch (FloatADException e) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg()));
      } catch (Exception e) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常"));
         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<SuperSpecialCard> 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);
            BusinessSystem system = new BusinessSystem();
            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("修改失败"));
      }
   }
   
   /**
    * 查询
@@ -275,11 +94,6 @@
            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);
@@ -339,188 +153,30 @@
   
   
   /**
    *  查询专题
    * @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<Special> 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);
         }
         if (!StringUtil.isNullOrEmpty(jumpType)) {
            List<JumpDetailV2> listByType = jumpDetailV2Service.listByType(jumpType);
            if (listByType !=null && listByType.size() > 0) {
               resultObj.setJumpDetail(listByType.get(0));
            }
         }
         String name = record.getName();
         if (name != null && name.trim().length() > 0) {
            resultObj.setName(name);
         }
         if (params != null && params.trim().length() > 0) {
            resultObj.setParams(params);
         }
         String showType = record.getShowType();
         if (showType != null && showType.trim().length() > 0) {
            resultObj.setShowType(record.getShowType());
         }
         String remark = record.getRemark();
         if (remark != null && remark.trim().length() > 0) {
            resultObj.setRemark(remark);
         }
         specialService.updateByPrimaryKey(resultObj);
         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 special
    * @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;
      }
   public void saveSpecial(String callback, Special record, String jumpType, HttpServletRequest request,PrintWriter out) {
      try {
         Special resultObj = null;
         if (id != null) {
            resultObj = specialService.selectByPrimaryKey(id);
            if (resultObj == null) {
               out.print(JsonUtil.loadFalseResult("该专题已不存在"));
               return;
            }
         }
         // 1. 先判断httpRequest 是否含有文件类型
         if (request instanceof MultipartHttpServletRequest) {
              MultipartHttpServletRequest fileRequest = (MultipartHttpServletRequest) request;
              specialService.saveObject(fileRequest.getFile("file"), fileRequest.getFile("file2"), fileRequest.getFile("file3"), record, jumpType);
           }else{
              specialService.saveObject(null, null, null,  record, jumpType);
           }
         
         specialService.uploadPicture(file, resultObj, cardId);
         out.print(JsonUtil.loadTrueResult("上传成功"));
         JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("保存成功"));
      } catch (SpecialException e) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg()));
      } catch (Exception e) {
         out.print(JsonUtil.loadFalseResult("操作失败"));
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("保存失败"));
         e.printStackTrace();
      }
   }
@@ -560,48 +216,6 @@
   }
   
   /**
    * 修该状态
    * @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();
      }
   }
   /**
    * 修改排序
@@ -611,49 +225,73 @@
    * @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;
   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();
      }
      if (id == null) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空"));
   }
   /**
    *  查询专题
    * @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, 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<Special> list = specialService.listQueryByCard((pageIndex - 1) * pageSize, pageSize, cardId, key, sex);
         Special resultObj = specialService.selectByPrimaryKey(id);
         if (resultObj == null) {
            JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在"));
         if (list == null || list.size() == 0) {
            JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据"));
            return;
         }
         
         Long cid = resultObj.getCardId();
         Integer oldOrder = resultObj.getOrderby();
         List<Special> list = specialService.getOrderByCardID(cid, moveType, oldOrder);
         long count = specialService.countlistQueryByCard(cardId, key, sex);
         
         if (list != null && list.size() > 0) {
            Special changeObj = list.get(0);
            // 交换排序序号
            resultObj.setOrderby(changeObj.getOrderby());
            changeObj.setOrderby(oldOrder);
            specialService.updateByPrimaryKeySelective(changeObj);
         }
         specialService.updateByPrimaryKeySelective(resultObj);
         int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1);
         PageEntity pe = new PageEntity(pageIndex, pageSize, count, totalPage);
         JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("操作成功"));
         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) {
         e.printStackTrace();
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常"));
         e.printStackTrace();
      }
   }
   
}