houseAction.java 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. package com.happy.action;
  2. import com.alibaba.fastjson.JSONArray;
  3. import com.google.gson.Gson;
  4. import com.google.gson.reflect.TypeToken;
  5. import com.happy.Model.*;
  6. import com.happy.Until.*;
  7. import com.happy.dto.HouseSumEto;
  8. import com.happy.dto.IPage;
  9. import com.happy.service.BookService;
  10. import com.happy.service.FileService;
  11. import com.happy.service.HotelDictService;
  12. import com.happy.service.HouseService;
  13. import com.opensymphony.xwork2.ActionSupport;
  14. import net.sf.json.JSONObject;
  15. import org.apache.struts2.ServletActionContext;
  16. import org.apache.struts2.interceptor.ServletRequestAware;
  17. import javax.annotation.Resource;
  18. import javax.servlet.http.HttpServletRequest;
  19. import javax.servlet.http.HttpServletResponse;
  20. import java.util.List;
  21. import java.util.Objects;
  22. public class houseAction extends ActionSupport implements ServletRequestAware {
  23. private HttpServletRequest request;
  24. public HttpServletResponse response;
  25. @Resource
  26. public HouseService houseService;
  27. @Resource
  28. public BookService bookService;
  29. @Resource
  30. public FileService fileService;
  31. @Resource
  32. public HotelDictService hotelDictService;
  33. public Integer id;
  34. public Integer managerId;
  35. public String hName;//房型名称
  36. public int page; // 当前页
  37. public int rows;// 每页显示的行数rows
  38. public String orderTime;//住房时间
  39. public String fileListJson;
  40. public HttpServletRequest getRequest() {
  41. return request;
  42. }
  43. public void setRequest(HttpServletRequest request) {
  44. this.request = request;
  45. }
  46. public void setServletRequest(HttpServletRequest request) {
  47. this.request = request;
  48. }
  49. public HttpServletResponse getResponse() {
  50. return response;
  51. }
  52. public void setResponse(HttpServletResponse response) {
  53. this.response = response;
  54. }
  55. /**
  56. * 描述:新增房型
  57. * @return
  58. */
  59. public String insterHouser(){
  60. JSONObject resultJson = new JSONObject();
  61. Gson gson = new Gson();
  62. com.alibaba.fastjson.JSONObject json = GetHttpParam.getRequestParameters(request);
  63. if (json == null) {
  64. resultJson.put("message", "请传入参数");
  65. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  66. return null;
  67. }
  68. House house = null;
  69. try {
  70. house = gson.fromJson(json.toString(), new TypeToken<House>() {}.getType());
  71. if (house == null) {
  72. resultJson.put("message", "数据为空");
  73. resultJson.put("code", 500);
  74. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  75. return null;
  76. }
  77. if (house.getManagerId()==null || house.gethName()==null || house.getPrice()==null || house.getNumber()==null || house.gethAreas()==null){
  78. resultJson.put("message", "各参数不能为空");
  79. resultJson.put("code", 500);
  80. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  81. return null;
  82. }
  83. //详细图附件
  84. List<FileInfo> fileList = JSONArray.parseArray(fileListJson, FileInfo.class);
  85. // if(fileList==null){
  86. // resultJson.put("message", "请上传详细图");
  87. // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  88. // return null;
  89. // }
  90. StringBuilder getOneSqlx = new StringBuilder("");
  91. getOneSqlx.append(" and h_name = '").append(house.gethName()).append("'")
  92. .append(" and manager_id = '").append(house.getManagerId()).append("'");
  93. House listc = houseService.getOen(getOneSqlx.toString());
  94. if (listc != null) {
  95. resultJson.put("message", "房型已存在");
  96. resultJson.put("code", 500);
  97. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  98. return null;
  99. }
  100. house.setId(Math.toIntExact(UUIDUtil.generateID()));
  101. int m = houseService.insertHouse(house);
  102. if (m > 0) {
  103. for(FileInfo file : fileList){
  104. file.setLinkId(house.getId());
  105. if(file==null){
  106. fileService.insertFile(file);
  107. }else{
  108. fileService.updateFile(file);
  109. }
  110. }
  111. resultJson.put("message", "新增成功");
  112. resultJson.put("code", 200);
  113. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  114. return null;
  115. } else {
  116. resultJson.put("message", "新增失败");
  117. resultJson.put("code", 502);
  118. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  119. return null;
  120. }
  121. } catch (Exception e) {
  122. e.printStackTrace();
  123. }
  124. resultJson.put("message", "未知异常");
  125. resultJson.put("code", 205);
  126. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  127. return null;
  128. }
  129. /**
  130. * 描述:修改房型
  131. * @return
  132. */
  133. public String updateHouser(){
  134. JSONObject resultJson = new JSONObject();
  135. Gson gson = new Gson();
  136. com.alibaba.fastjson.JSONObject json = GetHttpParam.getRequestParameters(request);
  137. if (json == null) {
  138. resultJson.put("message", "请传入参数");
  139. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  140. return null;
  141. }
  142. House house = null;
  143. try {
  144. house = gson.fromJson(json.toString(), new TypeToken<House>() {}.getType());
  145. if (house == null) {
  146. resultJson.put("message", "数据为空");
  147. resultJson.put("code", 500);
  148. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  149. return null;
  150. }
  151. if (house.getId() == null) {
  152. resultJson.put("message", "房型Id为空");
  153. resultJson.put("code", 500);
  154. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  155. return null;
  156. }
  157. if (house.getManagerId()==null || house.gethName()==null || house.getPrice()==null || house.getNumber()==null || house.gethAreas()==null){
  158. resultJson.put("message", "各参数不能为空");
  159. resultJson.put("code", 500);
  160. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  161. return null;
  162. }
  163. //详细图附件
  164. List<FileInfo> fileList = JSONArray.parseArray(fileListJson, FileInfo.class);
  165. // if(fileList==null){
  166. // resultJson.put("message", "请上传详细图");
  167. // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  168. // return null;
  169. // }
  170. StringBuilder getOneSqlx = new StringBuilder("");
  171. getOneSqlx.append(" and h_name = '").append(house.gethName()).append("'");
  172. getOneSqlx.append(" and manager_id = '").append(house.getManagerId()).append("'");
  173. getOneSqlx.append(" and id != '").append(house.getId()).append("'");
  174. House listc = houseService.getOen(getOneSqlx.toString());
  175. if (listc != null) {
  176. resultJson.put("message", "房型已存在");
  177. resultJson.put("code", 500);
  178. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  179. return null;
  180. }
  181. int m = houseService.updateHouse(house);
  182. if (m > 0) {
  183. if(house.getId()!= null){
  184. fileService.delLinkFile(house.getId());
  185. }
  186. for(FileInfo file : fileList){
  187. FileInfo fileInfo = fileService.getById(file.getId());
  188. file.setLinkId(house.getId());
  189. if(fileInfo==null){
  190. fileService.insertFile(file);
  191. }else{
  192. fileService.updateFile(file);
  193. }
  194. }
  195. resultJson.put("message", "修改成功");
  196. resultJson.put("code", 200);
  197. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  198. return null;
  199. } else {
  200. resultJson.put("message", "修改败");
  201. resultJson.put("code", 502);
  202. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  203. return null;
  204. }
  205. } catch (Exception e) {
  206. e.printStackTrace();
  207. }
  208. resultJson.put("message", "未知异常");
  209. resultJson.put("code", 205);
  210. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  211. return null;
  212. }
  213. /**
  214. * 描述:删除房型
  215. * @return
  216. */
  217. public String delHouser(){
  218. JSONObject resultJson = new JSONObject();
  219. if (id == null) {
  220. resultJson.put("message", "请传入id");
  221. resultJson.put("code", 500);
  222. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  223. return null;
  224. }
  225. int m = houseService.delHouse(id);
  226. if (m > 0) {
  227. resultJson.put("message", "删除成功");
  228. resultJson.put("code", 200);
  229. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  230. return null;
  231. }
  232. resultJson.put("message", "未知异常");
  233. resultJson.put("code", 205);
  234. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  235. return null;
  236. }
  237. /**
  238. * 描述:根据Id查询详细
  239. * @return
  240. */
  241. public String getById(){
  242. JSONObject resultJson = new JSONObject();
  243. if (id == null) {
  244. resultJson.put("message", "请传入id");
  245. resultJson.put("code", 500);
  246. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  247. return null;
  248. }
  249. House house = houseService.getById(id);
  250. StringBuilder fileSqlx = new StringBuilder("");
  251. fileSqlx.append("and link_id = '").append(id).append("'");
  252. List<FileInfo> fileInfoList = fileService.queryList(fileSqlx.toString());
  253. house.setFileInfoList(fileInfoList);
  254. if (house != null) {
  255. //获取有效房型服务
  256. if(house.gethConfig() != null && !"".equals(house.gethConfig())){
  257. house.sethConfig(hotelDictService.setConfig(house.gethConfig()));
  258. }
  259. resultJson.put("message", "查询成功");
  260. resultJson.put("code", 200);
  261. resultJson.put("data", house);
  262. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  263. return null;
  264. }else{
  265. resultJson.put("message", "未查到信息");
  266. resultJson.put("code", 500);
  267. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  268. return null;
  269. }
  270. }
  271. /**
  272. * 描述:分页查询
  273. * @return
  274. */
  275. public String queryPage(){
  276. JSONObject resultJson = new JSONObject();
  277. StringBuilder s1 = new StringBuilder("");
  278. if (hName!=null){
  279. s1.append(" and h_name like '%").append(hName).append("%'");
  280. }
  281. if (managerId!=null){
  282. s1.append(" and manager_id = '").append(managerId).append("'");
  283. }
  284. IPage<House> houseIPage = houseService.queryPage(s1.toString(),page,rows);
  285. if(houseIPage!=null && !"".equals(houseIPage)){
  286. resultJson.put("message", "查询分页成功");
  287. resultJson.put("code", 200);
  288. resultJson.put("data", houseIPage);
  289. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  290. }else{
  291. resultJson.put("message", "查询分页失败");
  292. resultJson.put("code", 500);
  293. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  294. }
  295. return null;
  296. }
  297. /**
  298. * 描述:房源分页查询
  299. * @return
  300. */
  301. public String queryPageHouseSum(){
  302. JSONObject resultJson = new JSONObject();
  303. StringBuilder s1 = new StringBuilder("");
  304. if (orderTime!=null){
  305. s1.append(" and DATE_FORMAT(order_start_time,'%Y-%m-%d') = '").append(orderTime).append("'");
  306. }
  307. if (hName!=null){
  308. s1.append(" and house_name like '%").append(hName).append("%'");
  309. }
  310. if (managerId!=null){
  311. s1.append(" and hotel_manager_id = '").append(managerId).append("'");
  312. }
  313. IPage<HouseSumEto> houseIPage = houseService.queryPageHouseSum(s1.toString(),page,rows);
  314. if(houseIPage!=null && !"".equals(houseIPage)){
  315. resultJson.put("message", "查询分页成功");
  316. resultJson.put("code", 200);
  317. resultJson.put("data", houseIPage);
  318. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  319. }else{
  320. resultJson.put("message", "查询分页失败");
  321. resultJson.put("code", 500);
  322. ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
  323. }
  324. return null;
  325. }
  326. }