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.domain.entity.SysUser;
import com.ruoyi.common.enums.BusinessType;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.poi.ExcelUtil;
import com.ruoyi.domain.ZCertificate;
import com.ruoyi.service.ZCertificateService;
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.List;
/**
*
* 持有出入境证件情况 前端控制器
*
*
* @author ojq
* @since 2023-03-14
*/
@Slf4j
@RestController
@RequestMapping("/zCertificate")
public class ZCertificateController extends BaseController {
@Autowired
private ZCertificateService zCertificateService;
@GetMapping("/all")
public AjaxResult listAll(){
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
List zCertificates = zCertificateService.selectExperienceList(userId);
return AjaxResult.success(zCertificates);
}
@GetMapping("/type")
public AjaxResult listType(){
return zCertificateService.listType();
}
/**
* 导出持有出入境证件情况记录列表
*/
// @PreAuthorize("@ss.hasPermi('system:property:export')")
@Log(title = "持有出入境证件情况记录", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, ZCertificate zCertificate)
{
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
List list = zCertificateService.selectExperienceList(userId);
log.info("导出记录为:{}",list);
ExcelUtil util = new ExcelUtil<>(ZCertificate.class);
util.exportExcel(response, list, "持有出入境证件情况记录数据");
}
//
/**
* 导入持有出入境证件情况记录列表
*/
@Log(title = "用户管理", businessType = BusinessType.IMPORT)
@PostMapping("/importData")
public AjaxResult importData(@RequestParam("excelImport") MultipartFile file) throws Exception
{
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
boolean flag=zCertificateService.importExcel(file,userId);
if(flag){
return AjaxResult.success("导入数据成功");
}
return AjaxResult.error("导入数据失败");
}
/**
* 新增持有出入境证件情况记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:add')")
@Log(title = "持有出入境证件情况记录", businessType = BusinessType.INSERT)
@PostMapping
public AjaxResult add(@RequestBody ZCertificate zCertificate)
{
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
zCertificate.setUserId(userId);
return toAjax(zCertificateService.save(zCertificate));
}
/**
* 修改持有出入境证件情况记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:edit')")
@Log(title = "持有出入境证件情况记录", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody ZCertificate zCertificate)
{
return toAjax(zCertificateService.updateById(zCertificate));
}
//
/**
* 批量删除持有出入境证件情况记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:remove')")
@Log(title = "持有出入境证件情况记录", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(zCertificateService.removeByIds(Arrays.asList(ids)));
}
}