| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396 |
- package com.happy.action;
- import com.alibaba.fastjson.JSONArray;
- import com.google.gson.Gson;
- import com.google.gson.reflect.TypeToken;
- import com.happy.Model.*;
- import com.happy.Until.*;
- import com.happy.dto.HouseSumEto;
- import com.happy.dto.IPage;
- import com.happy.service.*;
- import com.opensymphony.xwork2.ActionSupport;
- import net.sf.json.JSONObject;
- import org.apache.struts2.ServletActionContext;
- import org.apache.struts2.interceptor.ServletRequestAware;
- import javax.annotation.Resource;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import java.util.ArrayList;
- import java.util.Arrays;
- import java.util.List;
- import java.util.Objects;
- public class houseAction extends ActionSupport implements ServletRequestAware {
- private HttpServletRequest request;
- public HttpServletResponse response;
- @Resource
- public HouseService houseService;
- @Resource
- public BookService bookService;
- @Resource
- public FileService fileService;
- @Resource
- public HotelDictService hotelDictService;
- @Resource
- public HouseNumberService houseNumberService;
- public Integer id;
- public Integer managerId;
- public String hName;//房型名称
- public int page; // 当前页
- public int rows;// 每页显示的行数rows
- public String orderTime;//住房时间
- public String fileListJson;
- public String houseNumber; // 房间号
- public HttpServletRequest getRequest() {
- return request;
- }
- public void setRequest(HttpServletRequest request) {
- this.request = request;
- }
- public void setServletRequest(HttpServletRequest request) {
- this.request = request;
- }
- public HttpServletResponse getResponse() {
- return response;
- }
- public void setResponse(HttpServletResponse response) {
- this.response = response;
- }
- /**
- * 描述:新增房型
- * @return
- */
- public String insterHouser(){
- JSONObject resultJson = new JSONObject();
- Gson gson = new Gson();
- com.alibaba.fastjson.JSONObject json = GetHttpParam.getRequestParameters(request);
- if (json == null) {
- resultJson.put("message", "请传入参数");
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- House house = null;
- try {
- house = gson.fromJson(json.toString(), new TypeToken<House>() {}.getType());
- if (house == null) {
- resultJson.put("message", "数据为空");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- if (house.getManagerId()==null || house.gethName()==null || house.getPrice()==null || house.getNumber()==null || house.gethAreas()==null){
- resultJson.put("message", "各参数不能为空");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- //详细图附件
- List<FileInfo> fileList = JSONArray.parseArray(fileListJson, FileInfo.class);
- // if(fileList==null){
- // resultJson.put("message", "请上传详细图");
- // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- // return null;
- // }
- // List<String> numberList = JSONArray.parseArray(houseNumberList, String.class);
- StringBuilder getOneSqlx = new StringBuilder("");
- getOneSqlx.append(" and h_name = '").append(house.gethName()).append("'")
- .append(" and manager_id = '").append(house.getManagerId()).append("'");
- House listc = houseService.getOen(getOneSqlx.toString());
- if (listc != null) {
- resultJson.put("message", "房型已存在");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- //房型验证成功添加房号
- String id = Func.newGuid();
- List<String> houseNumberList = Arrays.asList(houseNumber.split(","));
- List<HouseNumber> houseNumbers = new ArrayList<HouseNumber>();
- long count = houseNumberList.stream().distinct().count();
- if (count != houseNumberList.size()){
- resultJson.put("message", "房号不可重复");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- for (String s : houseNumberList){
- HouseNumber h1 = new HouseNumber();
- h1.setHouseId(id);
- h1.setNumberName(s);
- h1.setStatus(1);
- houseNumbers.add(h1);
- }
- //执行批量房间号表操作
- int a = houseNumberService.saveBatch(houseNumbers);
- house.setId(id);
- int m = houseService.insertHouse(house);
- if (m > 0) {
- for(FileInfo file : fileList){
- FileInfo fileInfo = fileService.getById(file.getId());
- file.setLinkId(String.valueOf(house.getId()));
- if(fileInfo==null){
- fileService.insertFile(file);
- }else{
- fileService.updateFile(file);
- }
- }
- resultJson.put("message", "新增成功");
- resultJson.put("code", 200);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- } else {
- resultJson.put("message", "新增失败");
- resultJson.put("code", 502);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- resultJson.put("message", "未知异常");
- resultJson.put("code", 205);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- /**
- * 描述:修改房型
- * @return
- */
- public String updateHouser(){
- JSONObject resultJson = new JSONObject();
- Gson gson = new Gson();
- com.alibaba.fastjson.JSONObject json = GetHttpParam.getRequestParameters(request);
- if (json == null) {
- resultJson.put("message", "请传入参数");
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- House house = null;
- try {
- house = gson.fromJson(json.toString(), new TypeToken<House>() {}.getType());
- if (house == null) {
- resultJson.put("message", "数据为空");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- //2023-09-19 A-jax 房型数量必须和房间数量一致
- List<String> houseNumberList = Arrays.asList(houseNumber.split(","));
- if(house.getNumber().intValue() != houseNumberList.size()){
- resultJson.put("message", "房型数量与房间数量不一致");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- if (house.getId() == null) {
- resultJson.put("message", "房型Id为空");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- if (house.getManagerId()==null || house.gethName()==null || house.getPrice()==null || house.getNumber()==null || house.gethAreas()==null){
- resultJson.put("message", "各参数不能为空");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- //详细图附件
- List<FileInfo> fileList = JSONArray.parseArray(fileListJson, FileInfo.class);
- // if(fileList==null){
- // resultJson.put("message", "请上传详细图");
- // ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- // return null;
- // }
- // List<String> numberList = JSONArray.parseArray(houseNumberList, String.class);
- StringBuilder getOneSqlx = new StringBuilder("");
- getOneSqlx.append(" and h_name = '").append(house.gethName()).append("'");
- getOneSqlx.append(" and manager_id = '").append(house.getManagerId()).append("'");
- getOneSqlx.append(" and id != '").append(house.getId()).append("'");
- House listc = houseService.getOen(getOneSqlx.toString());
- if (listc != null) {
- resultJson.put("message", "房型已存在");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- //验证成功修改房号表
- List<HouseNumber> houseNumbers = new ArrayList<HouseNumber>();
- for (String s : houseNumberList){
- HouseNumber h1 = new HouseNumber();
- h1.setHouseId(house.getId());
- h1.setNumberName(s);
- h1.setStatus(1);
- houseNumbers.add(h1);
- }
- int a = houseNumberService.updateBatch(houseNumbers);
- int m = houseService.updateHouse(house);
- if (m > 0) {
- if(house.getId()!= null){
- fileService.delLinkFile(String.valueOf(house.getId()));
- }
- for(FileInfo file : fileList){
- FileInfo fileInfo = fileService.getById(file.getId());
- file.setLinkId(String.valueOf(house.getId()));
- if(fileInfo==null){
- fileService.insertFile(file);
- }else{
- fileService.updateFile(file);
- }
- }
- resultJson.put("message", "修改成功");
- resultJson.put("code", 200);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- } else {
- resultJson.put("message", "修改败");
- resultJson.put("code", 502);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- resultJson.put("message", "未知异常");
- resultJson.put("code", 205);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- /**
- * 描述:删除房型
- * @return
- */
- public String delHouser(){
- JSONObject resultJson = new JSONObject();
- if (id == null) {
- resultJson.put("message", "请传入id");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- int m = houseService.delHouse(id);
- if (m > 0) {
- resultJson.put("message", "删除成功");
- resultJson.put("code", 200);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- resultJson.put("message", "未知异常");
- resultJson.put("code", 205);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- /**
- * 描述:根据Id查询详细
- * @return
- */
- public String getById(){
- JSONObject resultJson = new JSONObject();
- if (id == null) {
- resultJson.put("message", "请传入id");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- House house = houseService.getById(id);
- StringBuilder fileSqlx = new StringBuilder("");
- fileSqlx.append("and link_id = '").append(id).append("'");
- List<FileInfo> fileInfoList = fileService.queryList(fileSqlx.toString());
- house.setFileInfoList(fileInfoList);
- if (house != null) {
- //获取有效房型服务
- if(house.gethConfig() != null && !"".equals(house.gethConfig())){
- house.sethConfig(hotelDictService.setConfig(house.gethConfig()));
- }
- resultJson.put("message", "查询成功");
- resultJson.put("code", 200);
- resultJson.put("data", house);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }else{
- resultJson.put("message", "未查到信息");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- return null;
- }
- }
- /**
- * 描述:分页查询
- * @return
- */
- public String queryPage(){
- JSONObject resultJson = new JSONObject();
- StringBuilder s1 = new StringBuilder("");
- if (hName!=null){
- s1.append(" and h_name like '%").append(hName).append("%'");
- }
- if (managerId!=null){
- s1.append(" and manager_id = '").append(managerId).append("'");
- }
- IPage<House> houseIPage = houseService.queryPage(s1.toString(),page,rows);
- if(houseIPage!=null && !"".equals(houseIPage)){
- resultJson.put("message", "查询分页成功");
- resultJson.put("code", 200);
- resultJson.put("data", houseIPage);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- }else{
- resultJson.put("message", "查询分页失败");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- }
- return null;
- }
- /**
- * 描述:房源分页查询
- * @return
- */
- public String queryPageHouseSum(){
- JSONObject resultJson = new JSONObject();
- StringBuilder s1 = new StringBuilder("");
- StringBuilder s2 = new StringBuilder("");
- if (orderTime!=null){
- s1.append(" and DATE_FORMAT(order_start_time,'%Y-%m-%d') = '").append(orderTime).append("'");
- }else{
- orderTime = UUIDUtil.getNewDate().substring(0,10);
- }
- if (hName!=null){
- s2.append(" and a.h_name like '%").append(hName).append("%'");
- }
- if (managerId!=null){
- s2.append(" and a.manager_id = '").append(managerId).append("'");
- }
- IPage<HouseSumEto> houseIPage = houseService.queryPageHouseSum(orderTime,s2.toString(),page,rows);
- if(houseIPage!=null && !"".equals(houseIPage)){
- resultJson.put("message", "查询分页成功");
- resultJson.put("code", 200);
- resultJson.put("data", houseIPage);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- }else{
- resultJson.put("message", "查询分页失败");
- resultJson.put("code", 500);
- ResUtil.writeJson(ServletActionContext.getResponse(), resultJson.toString());
- }
- return null;
- }
- }
|