package com.doumee.cloud.admin; 
 | 
  
 | 
import com.doumee.api.BaseController; 
 | 
import com.doumee.config.annotation.CloudRequiredPermission; 
 | 
import com.doumee.core.annotation.excel.ExcelExporter; 
 | 
import com.doumee.core.annotation.pr.PreventRepeat; 
 | 
import com.doumee.core.constants.ResponseStatus; 
 | 
import com.doumee.core.exception.BusinessException; 
 | 
import com.doumee.service.business.third.model.ApiResponse; 
 | 
import com.doumee.service.business.third.model.LoginUserInfo; 
 | 
import com.doumee.service.business.third.model.PageData; 
 | 
import com.doumee.service.business.third.model.PageWrap; 
 | 
import com.doumee.core.utils.Constants; 
 | 
import com.doumee.dao.business.model.HiddenDanger; 
 | 
import com.doumee.service.business.HiddenDangerService; 
 | 
import io.swagger.annotations.Api; 
 | 
import io.swagger.annotations.ApiOperation; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.web.bind.annotation.*; 
 | 
  
 | 
import javax.servlet.http.HttpServletResponse; 
 | 
import java.util.List; 
 | 
import java.util.Objects; 
 | 
  
 | 
/** 
 | 
 * @author 江蹄蹄 
 | 
 * @since 2024/04/28 16:06 
 | 
 */ 
 | 
@Api(tags = "隐患信息表") 
 | 
@RestController 
 | 
@RequestMapping(Constants.CLOUD_SERVICE_URL_INDEX+"/business/hiddenDanger") 
 | 
public class HiddenDangerCloudController extends BaseController { 
 | 
  
 | 
    @Autowired 
 | 
    private HiddenDangerService hiddenDangerService; 
 | 
  
 | 
    @PreventRepeat 
 | 
    @ApiOperation("新建") 
 | 
    @PostMapping("/create") 
 | 
    @CloudRequiredPermission("business:hiddendanger:create") 
 | 
    public ApiResponse create(@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        LoginUserInfo loginUserInfo = this.getLoginUser(token); 
 | 
        if(Objects.isNull(loginUserInfo.getMemberId())||Objects.isNull(loginUserInfo)){ 
 | 
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前账户无法进行该操作"); 
 | 
        } 
 | 
        hiddenDanger.setLoginUserInfo(loginUserInfo); 
 | 
        return ApiResponse.success(hiddenDangerService.create(hiddenDanger)); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("根据ID删除") 
 | 
    @GetMapping("/delete/{id}") 
 | 
    @CloudRequiredPermission("business:hiddendanger:delete") 
 | 
    public ApiResponse deleteById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        hiddenDangerService.deleteById(id,this.getLoginUser(token)); 
 | 
        return ApiResponse.success(null); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("批量删除") 
 | 
    @GetMapping("/delete/batch") 
 | 
    @CloudRequiredPermission("business:hiddendanger:delete") 
 | 
    public ApiResponse deleteByIdInBatch(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        hiddenDangerService.deleteByIdInBatch(this.getIdList(ids)); 
 | 
        return ApiResponse.success(null); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("根据ID修改") 
 | 
    @PostMapping("/updateById") 
 | 
    @CloudRequiredPermission("business:hiddendanger:update") 
 | 
    public ApiResponse updateById(@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        LoginUserInfo loginUserInfo = this.getLoginUser(token); 
 | 
        if(Objects.isNull(loginUserInfo.getMemberId())||Objects.isNull(loginUserInfo)){ 
 | 
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"当前账户无法进行该操作"); 
 | 
        } 
 | 
        hiddenDanger.setLoginUserInfo(loginUserInfo); 
 | 
        hiddenDangerService.updateById(hiddenDanger); 
 | 
        return ApiResponse.success(null); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("分页查询") 
 | 
    @PostMapping("/page") 
 | 
    @CloudRequiredPermission("business:hiddendanger:query") 
 | 
    public ApiResponse<PageData<HiddenDanger>> findPage (@RequestBody PageWrap<HiddenDanger> pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); 
 | 
        return ApiResponse.success(hiddenDangerService.findPage(pageWrap)); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("导出Excel") 
 | 
    @PostMapping("/exportExcel") 
 | 
    @CloudRequiredPermission("business:hiddendanger:exportExcel") 
 | 
    public void exportExcel (@RequestBody PageWrap<HiddenDanger> pageWrap, HttpServletResponse response,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        pageWrap.getModel().setLoginUserInfo(this.getLoginUser(token)); 
 | 
        List<HiddenDanger> list = hiddenDangerService.findPage(pageWrap).getRecords(); 
 | 
  
 | 
        ExcelExporter.build(HiddenDanger.class).export(list, "隐患信息表", response); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("根据ID查询") 
 | 
    @GetMapping("/{id}") 
 | 
    @CloudRequiredPermission("business:hiddendanger:query") 
 | 
    public ApiResponse<HiddenDanger> findById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        return ApiResponse.success(hiddenDangerService.findById(id)); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("隐患处理") 
 | 
    @PostMapping("/dealHiddenDanger") 
 | 
    public ApiResponse dealHiddenDanger (@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        hiddenDanger.setLoginUserInfo(getLoginUser(token)); 
 | 
        hiddenDangerService.dealHiddenDanger(hiddenDanger); 
 | 
        return ApiResponse.success("操作成功"); 
 | 
    } 
 | 
  
 | 
    @ApiOperation("隐患转交") 
 | 
    @PostMapping("/transferHiddenDanger") 
 | 
    public ApiResponse transferHiddenDanger (@RequestBody HiddenDanger hiddenDanger,@RequestHeader(Constants.HEADER_USER_TOKEN) String token){ 
 | 
        hiddenDanger.setLoginUserInfo(getLoginUser(token)); 
 | 
        hiddenDangerService.transferHiddenDanger(hiddenDanger); 
 | 
        return ApiResponse.success("操作成功"); 
 | 
    } 
 | 
  
 | 
} 
 |