package cn.huge.module.sy.controller.web; import cn.huge.base.common.utils.ReturnFailUtils; import cn.huge.base.common.utils.ReturnSucUtils; import cn.huge.module.sy.domain.po.SyTimeLimit; import cn.huge.module.sy.service.SyTimeLimitService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.google.common.collect.Maps; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Page; import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Sort; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import java.util.Map; import java.util.stream.Collectors; import java.util.stream.Stream; /** * @title: 系统时限配置表接口api-web端 * @description: 系统时限配置表接口api-web端 * @company: hugeinfo * @author: wangwh * @time: 2024-09-04 16:48:57 * @version: 1.0.0 */ @Slf4j @RestController @RequestMapping("/api/web/syTimeLimit") public class SyTimeLimitWebController { @Autowired(required = false) private HttpServletRequest request; @Autowired private SyTimeLimitService service; /** * 获取请求URL参数 * @return Map */ private Map getParameter(){ Map terms = Maps.newHashMap(); // 主键编号 String id = request.getParameter("id"); if (StringUtils.isNotBlank(id)){ terms.put("id", id); } // 时限类型 String limitType = request.getParameter("limitType"); if (StringUtils.isNotBlank(limitType)){ terms.put("limitType", limitType); } // 时限名称 String limitTypeName = request.getParameter("limitTypeName"); if (StringUtils.isNotBlank(limitTypeName)){ terms.put("limitTypeName", limitTypeName); } // 时限对应表 String limitTable = request.getParameter("limitTable"); if (StringUtils.isNotBlank(limitTable)){ terms.put("limitTable", limitTable); } // 期限 String timeTerm = request.getParameter("timeTerm"); if (StringUtils.isNotBlank(timeTerm)){ terms.put("timeTerm", timeTerm); } // 期限单位 String termUnit = request.getParameter("termUnit"); if (StringUtils.isNotBlank(termUnit)){ terms.put("termUnit", termUnit); } // 操作人编号 String operUserId = request.getParameter("operUserId"); if (StringUtils.isNotBlank(operUserId)){ terms.put("operUserId", operUserId); } // 操作人名称 String operUserName = request.getParameter("operUserName"); if (StringUtils.isNotBlank(operUserName)){ terms.put("operUserName", operUserName); } // 删除状态,0:未删除,1:已删除 String deleteStatus = request.getParameter("deleteStatus"); if (StringUtils.isNotBlank(deleteStatus)){ terms.put("deleteStatus", deleteStatus); } // 创建时间区间 String createStart = request.getParameter("createStart"); String createEnd = request.getParameter("createEnd"); if(StringUtils.isNotBlank(createStart) && StringUtils.isNotBlank(createEnd)) { terms.put("createStart", createStart); terms.put("createEnd", createEnd); } // 更新时间区间 String updateStart = request.getParameter("updateStart"); String updateEnd = request.getParameter("updateEnd"); if(StringUtils.isNotBlank(updateStart) && StringUtils.isNotBlank(updateEnd)) { terms.put("updateStart", updateStart); terms.put("updateEnd", updateEnd); } return terms; } /** * 条件查询多个 * @url {ctx}/api/web/syTimeLimit/listQuery * @return Object */ @GetMapping("/listQuery") public Object listQuery() { try { Map terms = getParameter(); return ReturnSucUtils.getRepInfo(service.listTerms(terms)); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } /** * 条件分页查询 * @url {ctx}/api/web/syTimeLimit/pageQuery * @param page 页码 * @param size 每页数量 * @return Object */ @GetMapping("/pageQuery") public Object pageQuery(@RequestParam(value = "page") int page, @RequestParam(value = "size") int size) { try { Map terms = getParameter(); Sort sort = Sort.by(Sort.Direction.DESC, "create_time"); PageRequest pageRequest = PageRequest.of(page-1, size, sort); Page syTimeLimitPage = service.pageQuery(pageRequest, terms); return ReturnSucUtils.getRepInfo( "处理成功", syTimeLimitPage); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } /** * 根据编号查询单个 * @url {ctx}/api/web/syTimeLimit/getById * @param id 主键编号 * @return Object */ @GetMapping("/getById") public Object getById(@RequestParam(value = "id") String id) { try { return ReturnSucUtils.getRepInfo(service.getById(id)); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } /** * 根据主键单个 * @url {ctx}/api/web/syTimeLimit/deleteById * @param id 主键编号 * @return Object */ @GetMapping("/deleteById") public Object deleteById(@RequestParam(value = "id") String id) { try { service.removeById(id); return ReturnSucUtils.getRepInfo(); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } /** * 新增或更新对象 * @url {ctx}/api/web/syTimeLimit/saveSyTimeLimit * @param syTimeLimit 实体对象 * @return Object */ @PostMapping("/saveSyTimeLimit") public Object saveSyTimeLimit(@RequestBody SyTimeLimit syTimeLimit) { try { service.saveSyTimeLimit(syTimeLimit); return ReturnSucUtils.getRepInfo(); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } /** * 条件分页查询 * @url {ctx}/api/web/syTimeLimit/getTimeLimit * @param limitTable 时限对应表 * @param limitType 时限类型 * @return Object */ @GetMapping("/getTimeLimit") public Object getTimeLimit(@RequestParam(value = "limitTable") int limitTable, @RequestParam(value = "limitType") int limitType) { try { QueryWrapper syTimeLimitQueryWrapper = new QueryWrapper<>(); syTimeLimitQueryWrapper.eq("limit_table", limitTable).eq("limit_type", limitType); SyTimeLimit syTimeLimit = service.getOne(syTimeLimitQueryWrapper); return ReturnSucUtils.getRepInfo( "处理成功", syTimeLimit.getTimeTerm()); } catch (Exception e) { return ReturnFailUtils.getRepInfo(); } } }