package com.doumee.api.business;
|
|
import com.doumee.api.BaseController;
|
import com.doumee.core.annotation.excel.ExcelExporter;
|
import com.doumee.core.annotation.pr.PreventRepeat;
|
import com.doumee.core.model.ApiResponse;
|
import com.doumee.core.model.PageWrap;
|
import com.doumee.core.model.PageData;
|
import com.doumee.dao.business.model.ProjectSo;
|
import com.doumee.service.business.ProjectSoService;
|
import io.swagger.annotations.Api;
|
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 javax.servlet.http.HttpServletResponse;
|
|
import java.util.ArrayList;
|
import java.util.List;
|
|
/**
|
* @author 江蹄蹄
|
* @date 2023/02/15 08:55
|
*/
|
@Api(tags = "项目关联服务机构、综合服务单位关联表")
|
@RestController
|
@RequestMapping("/business/projectSo")
|
public class ProjectSoController extends BaseController {
|
|
@Autowired
|
private ProjectSoService projectSoService;
|
|
@PreventRepeat
|
@ApiOperation("新建")
|
@PostMapping("/create")
|
@RequiresPermissions("business:projectso:create")
|
public ApiResponse create(@RequestBody ProjectSo projectSo) {
|
projectSo.setCreator(this.getLoginUser().getId());
|
return ApiResponse.success(projectSoService.create(projectSo));
|
}
|
|
/**
|
* 批量创建综合服务单位
|
*
|
* @param projectSo 实体对象
|
* @return Integer
|
*/
|
@PreventRepeat
|
@ApiOperation("批量创建综合服务单位关联信息")
|
@PostMapping("/createBatch")
|
@RequiresPermissions("business:projectso:create")
|
public ApiResponse createBatch(@RequestBody ProjectSo projectSo){
|
projectSo.setCreator(this.getLoginUser().getId());
|
return ApiResponse.success(projectSoService.createBatch(projectSo));
|
}
|
|
@ApiOperation("根据ID删除")
|
@GetMapping("/delete/{id}")
|
@RequiresPermissions("business:projectso:delete")
|
public ApiResponse deleteById(@PathVariable Integer id) {
|
projectSoService.deleteById(id);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("批量删除")
|
@GetMapping("/delete/batch")
|
@RequiresPermissions("business:projectso:delete")
|
public ApiResponse deleteByIdInBatch(@RequestParam String ids) {
|
String [] idArray = ids.split(",");
|
List<Integer> idList = new ArrayList<>();
|
for (String id : idArray) {
|
idList.add(Integer.valueOf(id));
|
}
|
projectSoService.deleteByIdInBatch(idList);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("根据ID修改")
|
@PostMapping("/updateById")
|
@RequiresPermissions("business:projectso:update")
|
public ApiResponse updateById(@RequestBody ProjectSo projectSo) {
|
projectSoService.updateById(projectSo);
|
return ApiResponse.success(null);
|
}
|
@ApiOperation("修改价格")
|
@PostMapping("/updateByPrice")
|
@RequiresPermissions("business:projectso:update")
|
public ApiResponse updateByPrice(@RequestBody ProjectSo projectSo) {
|
projectSo.setEditor(this.getLoginUser().getId());
|
projectSoService.updateByPrice(projectSo);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("分页查询")
|
@PostMapping("/page")
|
@RequiresPermissions("business:projectso:query")
|
public ApiResponse<PageData<ProjectSo>> findPage (@RequestBody PageWrap<ProjectSo> pageWrap) {
|
return ApiResponse.success(projectSoService.findPage(pageWrap));
|
}
|
|
@ApiOperation("导出Excel")
|
@PostMapping("/exportExcel")
|
@RequiresPermissions("business:projectso:exportExcel")
|
public void exportExcel (@RequestBody PageWrap<ProjectSo> pageWrap, HttpServletResponse response) {
|
ExcelExporter.build(ProjectSo.class).export(projectSoService.findPage(pageWrap).getRecords(), "项目关联服务机构关联表", response);
|
}
|
|
@ApiOperation("根据ID查询")
|
@GetMapping("/{id}")
|
@RequiresPermissions("business:projectso:query")
|
public ApiResponse<ProjectSo> findById(@PathVariable Integer id) {
|
return ApiResponse.success(projectSoService.findById(id));
|
}
|
}
|