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.ZAbroad;
import com.ruoyi.service.ZAbroadService;
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;
import java.util.prefs.BackingStoreException;
/**
*
* 出国(境)情况 前端控制器
*
*
* @author ojq
* @since 2023-03-14
*/
@Slf4j
@RestController
@RequestMapping("/zAbroad")
public class ZAbroadController extends BaseController {
@Autowired
private ZAbroadService zAbroadService;
@GetMapping("/all")
public AjaxResult listAll(){
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
List zAbroads = zAbroadService.selectExperienceList(userId);
return AjaxResult.success(zAbroads);
}
/**
* 导出出国(境)情况记录列表
*/
// @PreAuthorize("@ss.hasPermi('system:property:export')")
@Log(title = "出国(境)情况记录", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, ZAbroad zAbroad)
{
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
List list = zAbroadService.selectExperienceList(userId);
log.info("导出记录为:{}",list);
ExcelUtil util = new ExcelUtil<>(ZAbroad.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=zAbroadService.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 ZAbroad zAbroad)
{
SysUser user = SecurityUtils.getLoginUser().getUser();
Long userId = user.getUserId();
zAbroad.setUserId(userId);
return toAjax(zAbroadService.save(zAbroad));
}
/**
* 修改出国(境)情况记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:edit')")
@Log(title = "出国(境)情况记录", businessType = BusinessType.UPDATE)
@PutMapping
public AjaxResult edit(@RequestBody ZAbroad zAbroad)
{
return toAjax(zAbroadService.updateById(zAbroad));
}
//
/**
* 批量删除出国(境)情况记录
*/
// @PreAuthorize("@ss.hasPermi('system:property:remove')")
@Log(title = "出国(境)情况记录", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(zAbroadService.removeByIds(Arrays.asList(ids)));
}
}