| 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.BaseGoods; | 
| import com.doumee.dao.business.model.dto.BaseGoodsCreateOrUpdateRequest; | 
| import com.doumee.dao.business.model.dto.BaseGoodsDTO; | 
| import com.doumee.service.business.BaseGoodsService; | 
| 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/07 11:41 | 
|  */ | 
| @Api(tags = "素材库-商品信息表") | 
| @RestController | 
| @RequestMapping("/business/baseGoods") | 
| public class BaseGoodsController extends BaseController { | 
|   | 
|     @Autowired | 
|     private BaseGoodsService baseGoodsService; | 
|   | 
|     @PreventRepeat | 
|     @ApiOperation("新建") | 
|     @PostMapping("/create") | 
|     @RequiresPermissions("business:basegoods:create") | 
|     public ApiResponse create(@RequestBody BaseGoodsCreateOrUpdateRequest baseGoods) { | 
|         return ApiResponse.success(baseGoodsService.create(baseGoods)); | 
|     } | 
|   | 
|     @ApiOperation("根据ID删除") | 
|     @GetMapping("/delete/{id}") | 
|     @RequiresPermissions("business:basegoods:delete") | 
|     public ApiResponse deleteById(@PathVariable Integer id) { | 
|         baseGoodsService.deleteById(id); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("批量删除") | 
|     @GetMapping("/delete/batch") | 
|     @RequiresPermissions("business:basegoods: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)); | 
|         } | 
|         baseGoodsService.deleteByIdInBatch(idList); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("根据ID修改") | 
|     @PostMapping("/updateById") | 
|     @RequiresPermissions("business:basegoods:update") | 
|     public ApiResponse updateById(@RequestBody BaseGoods baseGoods) { | 
|         baseGoodsService.updateById(baseGoods); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("分页查询") | 
|     @PostMapping("/page") | 
|     @RequiresPermissions("business:basegoods:query") | 
|     public ApiResponse<PageData<BaseGoods>> findPage (@RequestBody PageWrap<BaseGoods> pageWrap) { | 
|         return ApiResponse.success(baseGoodsService.findPage(pageWrap)); | 
|     } | 
|   | 
|     @ApiOperation("导出Excel") | 
|     @PostMapping("/exportExcel") | 
|     @RequiresPermissions("business:basegoods:exportExcel") | 
|     public void exportExcel (@RequestBody PageWrap<BaseGoods> pageWrap, HttpServletResponse response) { | 
|         ExcelExporter.build(BaseGoods.class).export(baseGoodsService.findPage(pageWrap).getRecords(), "素材库-商品信息表", response); | 
|     } | 
|   | 
|     @ApiOperation("根据ID查询") | 
|     @GetMapping("/{id}") | 
|     @RequiresPermissions("business:basegoods:query") | 
|     public ApiResponse<BaseGoodsDTO> findById(@PathVariable Integer id) { | 
|         return ApiResponse.success(baseGoodsService.findByIdBaseGoods(id)); | 
|     } | 
|   | 
|     /** | 
|      * 主键上下架 | 
|      * | 
|      */ | 
|     @ApiOperation("根据ID查询批量上架下架") | 
|     @PostMapping("/updateStatus") | 
|     @RequiresPermissions("business:basegoods:update") | 
|     public ApiResponse updateStatusByIds(@RequestBody   BaseGoods param ){ | 
|         baseGoodsService.updateStatusByIds(param); | 
|         return ApiResponse.success("操作成功!"); | 
|     } | 
|   | 
|   | 
| //    /** | 
| //     * 主键上下架 | 
| //     * | 
| //     * @param id 实体对象 | 
| //     */ | 
| //    @ApiOperation("上架 、下架") | 
| //    @GetMapping("/updateStatusById") | 
| //    @RequiresPermissions("business:basegoods:update") | 
| //    public ApiResponse updateStatusById(@RequestParam Integer id,@RequestParam Integer status){ | 
| //        baseGoodsService.updateStatusById(id,status); | 
| //        return ApiResponse.success(null); | 
| //    } | 
|   | 
|     /** | 
|      * 主键查询 | 
|      * | 
|      * @param id 主键 | 
|      * @return BaseGoods | 
|      */ | 
|     @ApiOperation("根据ID查询平台商品详细信息") | 
|     @GetMapping("/findByIdBaseGoods") | 
|     @RequiresPermissions("business:basegoods:query") | 
|     public ApiResponse<BaseGoodsDTO> findByIdBaseGoods(@RequestParam Integer id){ | 
|         BaseGoodsDTO byIdBaseGoods = baseGoodsService.findByIdBaseGoods(id); | 
|         return ApiResponse.success(byIdBaseGoods); | 
|     } | 
|   | 
|     /** | 
|      * 主键更新 | 
|      * | 
|      * @param baseGoods 实体对象 | 
|      */ | 
|     @ApiOperation("根据ID修改-编辑修改") | 
|     @PostMapping("/update") | 
|     @RequiresPermissions("business:basegoods:update") | 
|     public ApiResponse update(@RequestBody BaseGoodsCreateOrUpdateRequest baseGoods){ | 
|         baseGoodsService.update(baseGoods); | 
|         return ApiResponse.success(null); | 
|     } | 
|   | 
|     @ApiOperation("导入模板") | 
|     @PostMapping("/importExcel") | 
|     @ApiImplicitParams({ | 
|             @ApiImplicitParam(name = "file", value = "file", required = true, paramType = "query", dataType = "file", dataTypeClass = File.class), | 
|     }) | 
|     @RequiresPermissions("business:basegoods:create") | 
|     public ApiResponse<Integer> importExcel (@ApiParam(value = "file") MultipartFile file) { | 
|         return ApiResponse.success(baseGoodsService.importBaseGoodsBatch(file)); | 
|     } | 
| } |