package com.ruoyi.web.controller.zhang;
import com.ruoyi.common.annotation.Log;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.text.Convert;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.utils.ServletUtils;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.domain.ZfCollection;
import com.ruoyi.domain.excel.ZfCleanExcelBean;
import com.ruoyi.domain.excel.ZfCollectionExcelBean;
import com.ruoyi.service.ZfCollectionService;
import lombok.extern.slf4j.Slf4j;
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.util.Arrays;
import java.util.Collections;
import java.util.List;
import static com.ruoyi.common.core.page.TableSupport.PAGE_NUM;
import static com.ruoyi.common.core.page.TableSupport.PAGE_SIZE;
/**
*
* 前端控制器
*
*
* @author ojq
* @since 2023-03-12
*/
@RestController
@Slf4j
@RequestMapping("/zfCollection")
public class ZfCollectionController extends BaseController {
@Autowired
private ZfCollectionService zfCollectionService;
@GetMapping("/all")
public AjaxResult listAll(ZfCollection zfCollection){
Integer pageNum = Convert.toInt(ServletUtils.getParameter(PAGE_NUM), 1);
Integer pageSize = Convert.toInt(ServletUtils.getParameter(PAGE_SIZE), 10);
return zfCollectionService.selectDataList(zfCollection, pageNum, pageSize);
}
@GetMapping("/type")
public AjaxResult listType(){
return zfCollectionService.listType();
}
/**
* 根据id查询
*/
@GetMapping()
public AjaxResult listById(Long id){
return AjaxResult.success(zfCollectionService.getById(id));
}
/**
* 获取导入模板
*/
@PostMapping("/model")
public void getExportModel(HttpServletResponse response){
List list = Collections.singletonList(new ZfCollectionExcelBean());
ExcelUtil util = new ExcelUtil<>(ZfCollectionExcelBean.class);
util.exportExcel(response,list,"收藏荣誉导入模板");
}
/**
* 导出收藏和荣誉记录列表
*/
// @PreAuthorize("@ss.hasPermi('system:property:export')")
@Log(title = "收藏和荣誉记录", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, ZfCollection zfCollection)
{
List list = zfCollectionService.selectByCondition(zfCollection);
log.info("导出记录为:{}",list);
ExcelUtil util = new ExcelUtil<>(ZfCollection.class);
util.exportExcel(response, list, "收藏和荣誉记录数据");
}
/**
* 导出收藏和荣誉记录列表
*/
// @PreAuthorize("@ss.hasPermi('system:property:export')")
@Log(title = "收藏和荣誉记录", businessType = BusinessType.EXPORT)
@PostMapping("/export1/{ids}")
public void export(HttpServletResponse response, @PathVariable Long[] ids)
{
List list = zfCollectionService.selectByIds(ids);
log.info("导出记录为:{}",list);
ExcelUtil util = new ExcelUtil<>(ZfCollection.class);
util.exportExcel(response, list, "收藏和荣誉记录数据");
}
//
/**
* 导入收藏和荣誉记录列表
*/
@Log(title = "用户管理", businessType = BusinessType.IMPORT)
@PostMapping("/importData")
public AjaxResult importData(@RequestParam("excelImport") MultipartFile file) throws Exception
{
return zfCollectionService.importExcel(file);
}
/**
* 获取收藏和荣誉记录详细信息
*/
// @PreAuthorize("@ss.hasPermi('system:property:query')")
@GetMapping(value = "/{id}")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(zfCollectionService.getById(id));
}
//
/**
* 新增收藏和荣誉记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:add')")
@Log(title = "收藏和荣誉记录", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody ZfCollection zfCollection)
{
return zfCollectionService.addData(zfCollection);
}
/**
* 修改收藏和荣誉记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:edit')")
@Log(title = "收藏和荣誉记录", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody ZfCollection zfCollection)
{
return zfCollectionService.updateData(zfCollection);
}
//
/**
* 批量删除收藏和荣誉记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:remove')")
@Log(title = "收藏和荣誉记录", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return zfCollectionService.deleteData(ids);
}
}