/*
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
|
*
|
* Redistribution and use in source and binary forms, with or without
|
* modification, are permitted provided that the following conditions are met:
|
*
|
* Redistributions of source code must retain the above copyright notice,
|
* this list of conditions and the following disclaimer.
|
* Redistributions in binary form must reproduce the above copyright
|
* notice, this list of conditions and the following disclaimer in the
|
* documentation and/or other materials provided with the distribution.
|
* Neither the name of the dreamlu.net developer nor the names of its
|
* contributors may be used to endorse or promote products derived from
|
* this software without specific prior written permission.
|
* Author: Chill 庄骞 (smallchill@163.com)
|
*/
|
package org.springblade.modules.experience.controller;
|
|
import com.alibaba.fastjson.JSON;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
|
import io.swagger.annotations.Api;
|
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiParam;
|
import lombok.AllArgsConstructor;
|
import org.springblade.core.boot.ctrl.BladeController;
|
import org.springblade.core.mp.support.Condition;
|
import org.springblade.core.mp.support.Query;
|
import org.springblade.core.tool.api.R;
|
import org.springblade.core.tool.utils.Func;
|
import org.springblade.modules.FTP.FtpUtil;
|
import org.springblade.modules.experience.entity.Experience;
|
import org.springblade.modules.experience.service.IExperienceService;
|
import org.springblade.modules.experience.vo.ExperienceVO;
|
import org.springblade.modules.system.entity.User;
|
import org.springblade.modules.system.service.IUserService;
|
import org.springblade.modules.system.service.MyAsyncService;
|
import org.springframework.web.bind.annotation.*;
|
|
import javax.validation.Valid;
|
import java.text.SimpleDateFormat;
|
import java.util.List;
|
import java.util.Map;
|
|
/**
|
* 用户从业控制器
|
*
|
* @author BladeX
|
* @since 2021-07-08
|
*/
|
@RestController
|
@AllArgsConstructor
|
@RequestMapping("/experience")
|
@Api(value = "", tags = "接口")
|
public class ExperienceController extends BladeController {
|
|
private final IExperienceService experienceService;
|
|
|
private final IUserService userService;
|
private final MyAsyncService myAsyncService;
|
|
/**
|
* 详情
|
*/
|
@GetMapping("/detail")
|
@ApiOperationSupport(order = 1)
|
@ApiOperation(value = "详情", notes = "传入experience")
|
public R<Experience> detail(Experience experience) {
|
Experience detail = experienceService.getOne(Condition.getQueryWrapper(experience));
|
return R.data(detail);
|
}
|
|
/**
|
* 分页
|
*/
|
@GetMapping("/list")
|
@ApiOperationSupport(order = 2)
|
@ApiOperation(value = "分页", notes = "传入experience")
|
public R<IPage<Experience>> list(Experience experience, Query query) {
|
IPage<Experience> pages = experienceService.page(Condition.getPage(query), Condition.getQueryWrapper(experience));
|
return R.data(pages);
|
}
|
|
/**
|
* 自定义分页
|
*/
|
@GetMapping("/page")
|
@ApiOperationSupport(order = 3)
|
@ApiOperation(value = "分页", notes = "传入experience")
|
public R<IPage<ExperienceVO>> page(ExperienceVO experience, Query query) {
|
IPage<ExperienceVO> pages = experienceService.selectExperiencePage(Condition.getPage(query), experience);
|
return R.data(pages);
|
}
|
|
/**
|
* 新增
|
*/
|
@PostMapping("/save")
|
@ApiOperationSupport(order = 4)
|
@ApiOperation(value = "新增", notes = "传入experience")
|
public R save(@Valid @RequestBody Experience experience) {
|
return R.status(experienceService.save(experience));
|
}
|
|
|
/**
|
* 新增或修改
|
*/
|
@PostMapping("/saveOrUpdate")
|
public R save(@Valid @RequestBody Map<String,Object> experience ) {
|
if (experience.size()>0) {
|
String securityid = experience.get("securityid").toString();
|
//先删除原有的从业信息
|
experienceService.delbyCardId(securityid);
|
//重新新增从业信息
|
List<Experience> experiences = (List<Experience>) experience.get("userPractitionersInfo");
|
int count = 0;
|
if (experiences.size() > 0) {
|
for (int i = 0; i < experiences.size(); i++) {
|
Experience e = JSON.parseObject(JSON.toJSONString(experiences.get(i)), Experience.class);
|
experienceService.save(e);
|
count++;
|
}
|
if (count < 1) {
|
return R.status(false);
|
}
|
}
|
}
|
return R.status(true);
|
}
|
|
/**
|
* 修改
|
*/
|
@PostMapping("/update")
|
@ApiOperationSupport(order = 5)
|
@ApiOperation(value = "修改", notes = "传入experience")
|
public R update(@Valid @RequestBody Experience experience) {
|
return R.status(experienceService.updateById(experience));
|
}
|
|
/**
|
* 新增或修改
|
*/
|
@PostMapping("/submit")
|
@ApiOperationSupport(order = 6)
|
@ApiOperation(value = "新增或修改", notes = "传入experience")
|
public R submit(@Valid @RequestBody Experience experience) {
|
boolean status = false;
|
if (null!=experience.getId()){
|
//更新
|
status = experienceService.updateById(experience);
|
|
String s1 =
|
"update sys_experience set name = " + "'" + experience.getName() + "'"
|
+ ",post = " + "'" + experience.getPost() + "'"
|
+ ",department = " + "'" + experience.getDepartment() + "'"
|
+ ",responsibilities = " + "'" + experience.getResponsibilities() + "'"
|
+ ",entryTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(experience.getEntrytime()) + "'"
|
+ ",departureTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(experience.getDeparturetime()) + "'"
|
+ ",leaving = " + "'" + experience.getLeaving() + "'"
|
+ ",cardId = " + "'" + experience.getCardid() + "'"
|
+ ",companyname = " + "'" + experience.getCompanyname() + "'"
|
+ ",securityId = " + "'" + experience.getSecurityid() + "'"
|
+ " " + "where id = " + "'" + experience.getId() + "'";
|
//FtpUtil.sqlFileUpload(s1);
|
myAsyncService.dataSync(s1);
|
|
}else {
|
//新增
|
//查询用户身份证号
|
User user = userService.getById(experience.getSecurityid());
|
experience.setCardid(user.getCardid());
|
experience.setName(user.getRealName());
|
status = experienceService.save(experience);
|
|
//内网同步
|
String s = "insert into sys_experience(id,name,post,department,responsibilities,entryTime,departureTime,leaving," +
|
"cardId,companyname,securityId) " +
|
"values(" + "'" + experience.getId() + "'" + "," +
|
"'" + experience.getName() + "'" + "," +
|
"'" + experience.getPost() + "'" + "," +
|
"'" + experience.getDepartment() + "'" + "," +
|
"'" + experience.getResponsibilities() + "'" + "," +
|
"," + "'" + new SimpleDateFormat("yyyy-MM-dd").format(experience.getEntrytime()) + "'" +
|
"," + "'" + new SimpleDateFormat("yyyy-MM-dd").format(experience.getDeparturetime()) + "'" +
|
"," + "'" + experience.getLeaving() + "'" +
|
"," + "'" + experience.getCardid() + "'" +
|
"," + "'" + experience.getCompanyname() + "'" +
|
"," + "'" + experience.getSecurityid() + "'"
|
+ ")";
|
//FtpUtil.sqlFileUpload(s);
|
myAsyncService.dataSync(s);
|
}
|
return R.status(status);
|
}
|
|
|
/**
|
* 删除
|
*/
|
@PostMapping("/remove")
|
@ApiOperationSupport(order = 8)
|
@ApiOperation(value = "删除", notes = "传入ids")
|
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
|
return R.status(experienceService.removeByIds(Func.toLongList(ids)));
|
}
|
|
/**
|
* 保安就业记录
|
* @param securityid 身份证
|
* @return
|
*/
|
@GetMapping("/selectExperienceInfo")
|
public R selectExperienceInfo(String securityid) {
|
return R.data(experienceService.selectExperienceInfo(securityid));
|
}
|
|
|
}
|