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.PageData; import com.doumee.core.model.PageWrap; import com.doumee.dao.business.model.Bikes; import com.doumee.service.business.BikesService; import io.swagger.annotations.*; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse; import java.io.File; import java.util.ArrayList; import java.util.List; /** * @author 江蹄蹄 * @date 2023/09/27 18:06 */ @Api(tags = "自行车信息表") @RestController @RequestMapping("/business/bikes") public class BikesController extends BaseController { @Autowired private BikesService bikesService; @PreventRepeat @ApiOperation("新建") @PostMapping("/create") @RequiresPermissions("business:bikes:create") public ApiResponse create(@RequestBody Bikes bikes) { return ApiResponse.success(bikesService.create(bikes)); } @ApiOperation("根据ID删除") @GetMapping("/delete/{id}") @RequiresPermissions("business:bikes:delete") public ApiResponse deleteById(@PathVariable String id) { bikesService.deleteById(id); return ApiResponse.success(null); } @ApiOperation("批量删除") @GetMapping("/delete/batch") @RequiresPermissions("business:bikes:delete") public ApiResponse deleteByIdInBatch(@RequestParam String ids) { String [] idArray = ids.split(","); List idList = new ArrayList<>(); for (String id : idArray) { idList.add(id); } bikesService.deleteByIdInBatch(idList); return ApiResponse.success(null); } @ApiOperation("根据ID修改") @PostMapping("/updateById") @RequiresPermissions("business:bikes:update") public ApiResponse updateById(@RequestBody Bikes bikes) { bikesService.updateById(bikes); return ApiResponse.success(null); } @ApiOperation("分页查询") @PostMapping("/page") @RequiresPermissions("business:bikes:query") public ApiResponse> findPage (@RequestBody PageWrap pageWrap) { return ApiResponse.success(bikesService.findPage(pageWrap)); } @ApiOperation("实时车位信息-分页查询-弃用") @PostMapping("/pageCurrent") @RequiresPermissions("business:bikes:query") public ApiResponse> pageCurrent (@RequestBody PageWrap pageWrap) { PageData list = bikesService.findJoinPage(pageWrap); return ApiResponse.success(list); } @ApiOperation("导出Excel") @PostMapping("/exportExcel") @RequiresPermissions("business:bikes:exportExcel") public void exportExcel (@RequestBody PageWrap pageWrap, HttpServletResponse response) { ExcelExporter.build(Bikes.class).export(bikesService.findPage(pageWrap).getRecords(), "自行车信息表", response); } @ApiOperation(value = "电车批量导入" ,notes = "保单申请") @PostMapping("/importExcel") @ApiImplicitParams({ @ApiImplicitParam(name = "file", value = "file", required = true, paramType = "query", dataType = "file", dataTypeClass = File.class), }) @RequiresPermissions("business:member:create") public ApiResponse importExcel (@ApiParam(value = "file") MultipartFile file) { return ApiResponse.success(bikesService.importBatch(file)); } @ApiOperation("根据ID查询") @GetMapping("/{id}") @RequiresPermissions("business:bikes:query") public ApiResponse findById(@PathVariable String id) { return ApiResponse.success(bikesService.findById(id)); } }