package com.yeshi.fanli.controller.admin.customerservice; 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.yeshi.utils.JsonUtil; import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.reflect.TypeToken; import com.yeshi.fanli.entity.customerservice.CustomerServiceCommonQuestion; import com.yeshi.fanli.exception.CustomerServiceCommonQuestionException; import com.yeshi.fanli.service.AdminUserService; import com.yeshi.fanli.service.inter.customerservice.CustomerServiceCommonQuestionService; import com.yeshi.fanli.tag.PageEntity; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.StringUtil; @Controller @RequestMapping("admin/new/api/v1/commonQuestion") public class CustomerServiceCommonQuestionAdminController { @Resource private AdminUserService adminUserService; @Resource private CustomerServiceCommonQuestionService commonQuestionService; /** * 新增 * @param callback * @param special * @param out */ @RequestMapping(value = "save") public void saveAdd(String callback, long uid, CustomerServiceCommonQuestion commonQuestion, PrintWriter out) { try { commonQuestionService.save(commonQuestion); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("添加成功")); } catch (CustomerServiceCommonQuestionException e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 修改 * @param callback * @param special * @param out */ @RequestMapping(value = "getInfo") public void getInfo(String callback, Long id, PrintWriter out) { if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } try { CustomerServiceCommonQuestion commonQuestion = commonQuestionService.selectByPrimaryKey(id); if (commonQuestion == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("数据已不存在")); return; } JSONObject data = new JSONObject(); data.put("result", commonQuestion); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("获取信息失败")); e.printStackTrace(); } } /** * 修改 * @param callback * @param special * @param out */ @RequestMapping(value = "saveWeight") public void saveWeight(String callback, Long id, Integer weight, PrintWriter out) { if (id == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("ID不能为空")); return; } try { CustomerServiceCommonQuestion commonQuestion = commonQuestionService.selectByPrimaryKey(id); if (commonQuestion == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("数据已不存在")); return; } commonQuestion.setWeight(weight); commonQuestion.setUpdateTime(new Date()); commonQuestionService.updateByPrimaryKeySelective(commonQuestion); 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; } CustomerServiceCommonQuestion resultObj = commonQuestionService.selectByPrimaryKey(id); if (resultObj == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作数据已不存在")); return; } boolean state = resultObj.isState(); if (state) { resultObj.setState(false); } else { resultObj.setState(true); } commonQuestionService.updateByPrimaryKeySelective(resultObj); JSONObject data = new JSONObject(); data.put("state", resultObj.isState()); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("操作异常")); e.printStackTrace(); } } /** * 查询 * @param callback * @param pageIndex * @param pageSize * @param key 模糊查询:说明、标识 * @param out */ @RequestMapping(value = "query") public void query(String callback, Integer pageIndex, Integer pageSize, String key, String type, Integer state, Integer sort, PrintWriter out) { if (pageIndex == null || pageIndex < 1) { pageIndex = 1; } if (pageSize == null || pageSize < 1) { pageSize = Constant.PAGE_SIZE; } try { List list = commonQuestionService.listQuery((pageIndex - 1) * pageSize, pageSize, key, type, state, sort); if (list == null || list.size() == 0) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("暂无数据")); return; } long count = commonQuestionService.countQuery(key, type, state); 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 = commonQuestionService.deleteBatchByPrimaryKey(list); JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("成功删除["+ count +"]条数据")); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("删除失败")); e.printStackTrace(); } } }