package io.hmit.modules.serviceOrder.controller; import io.hmit.common.annotation.LogOperation; import io.hmit.common.constant.Constant; import io.hmit.common.page.PageData; import io.hmit.common.utils.ExcelUtils; import io.hmit.common.utils.Result; import io.hmit.common.validator.AssertUtils; import io.hmit.common.validator.ValidatorUtils; import io.hmit.common.validator.group.AddGroup; import io.hmit.common.validator.group.DefaultGroup; import io.hmit.common.validator.group.UpdateGroup; import io.hmit.modules.security.user.SecurityUser; import io.hmit.modules.serviceOrder.dto.PensionOrderDTO; import io.hmit.modules.serviceOrder.entity.UserEntity; import io.hmit.modules.serviceOrder.excel.PensionOrderExcel; import io.hmit.modules.serviceOrder.service.PensionOrderService; import io.hmit.modules.serviceOrder.service.UserService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import springfox.documentation.annotations.ApiIgnore; import javax.servlet.http.HttpServletResponse; import java.security.Security; import java.util.List; import java.util.Map; /** * 订单表 * * @author zsh 408538940@qq.com * @since 1.0.0 2021-01-26 */ @RestController @RequestMapping("serviceOrder/pensionorder") @Api(tags="订单表") public class PensionOrderController { @Autowired private PensionOrderService pensionOrderService; @Autowired private UserService userService; @GetMapping("page") @ApiOperation("分页") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query",required = true, dataType="int") , @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType="String") , @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType="String"), @ApiImplicitParam(name = "status", value = "状态值", paramType = "query", dataType="String") }) @RequiresPermissions("serviceOrder:pensionorder:page") public Result<PageData<PensionOrderDTO>> page(@ApiIgnore @RequestParam Map<String, Object> params){ PageData<PensionOrderDTO> page = pensionOrderService.page(params); return new Result<PageData<PensionOrderDTO>>().ok(page); } @GetMapping("{id}") @ApiOperation("信息") @RequiresPermissions("serviceOrder:pensionorder:info") public Result<PensionOrderDTO> get(@PathVariable("id") Long id){ PensionOrderDTO data = pensionOrderService.get(id); return new Result<PensionOrderDTO>().ok(data); } /** * 机构订单接口 */ @GetMapping("organization") @ApiOperation(value = "根据状态返回订单列表(机构)") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = "status", value = "订单状态: 0未接单 1已派发 2已完成 3已取消 5已接单未派发", paramType = "query", dataType="int") , @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType="String") , @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType="String") }) public Result<PageData<PensionOrderDTO>> organization(@ApiIgnore @RequestParam Map<String, Object> params){ //登录->查询登录人员所属机构ID->机构ID查询服务ID(List)->服务ID + 状态查询订单(List) PageData<PensionOrderDTO> page = pensionOrderService.getOrganizationOrder(params, SecurityUser.getUserId()); return new Result<PageData<PensionOrderDTO>>().ok(page); } @PostMapping @ApiOperation("保存") @LogOperation("保存") @RequiresPermissions("serviceOrder:pensionorder:save") public Result save(@RequestBody PensionOrderDTO dto){ //校验数据 ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class); pensionOrderService.save(dto); return new Result(); } @PutMapping @ApiOperation("修改") @LogOperation("修改") @RequiresPermissions("serviceOrder:pensionorder:update") public Result update(@RequestBody PensionOrderDTO dto){ //校验数据 ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class); pensionOrderService.update(dto); return new Result(); } @DeleteMapping @ApiOperation("删除") @LogOperation("删除") @RequiresPermissions("serviceOrder:pensionorder:delete") public Result delete(@RequestBody Long[] ids){ //校验数据 AssertUtils.isArrayEmpty(ids, "id"); pensionOrderService.delete(ids); return new Result(); } @GetMapping("export") @ApiOperation("导出") @LogOperation("导出") @RequiresPermissions("serviceOrder:pensionorder:export") public void export(@ApiIgnore @RequestParam Map<String, Object> params, HttpServletResponse response) throws Exception { List<PensionOrderDTO> list = pensionOrderService.list(params); ExcelUtils.exportExcelToTarget(response, null, list, PensionOrderExcel.class); } /** * 机构处理 */ @GetMapping("organizationHandle") @ApiOperation(value = "机构处理(机构)", notes = "传参为1(派单)时,recipient_id必传") @ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "订单ID", paramType = "query", required = true, dataType="long") , @ApiImplicitParam(name = "status", value = "处理状态: 5接单 1派单 3取消", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = "recipient_id", value = "接单服务人员ID", paramType = "query", dataType="long") }) public Result organizationHandle(@ApiIgnore @RequestParam Map<String, Object> params){ // Boolean result = pensionOrderService.organizationHandle(params, SecurityUser.getUserId()); Boolean result = pensionOrderService.organizationHandle(params, 1L); if (!result) { return new Result().error(); } return new Result(); } /** * 本机构全部人员 */ @GetMapping("organizationStaff") @ApiOperation(value = "本机构全部人员(机构)") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType="String") , @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType="String") }) public Result<PageData<UserEntity>> organizationStaff(@ApiIgnore @RequestParam Map<String, Object> params){ PageData<UserEntity> page = userService.getOrganizationAllUsers(params, SecurityUser.getUserId()); return new Result<PageData<UserEntity>>().ok(page); } }