parent
536c183fb6
commit
6983e44cad
29 changed files with 1329 additions and 322 deletions
@ -0,0 +1,42 @@ |
||||
package org.springblade.system.user.entity; |
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableField; |
||||
import com.baomidou.mybatisplus.annotation.TableName; |
||||
import com.fasterxml.jackson.annotation.JsonFormat; |
||||
import io.swagger.models.auth.In; |
||||
import lombok.Data; |
||||
import lombok.EqualsAndHashCode; |
||||
import org.springblade.core.mp.base.BaseEntity; |
||||
import org.springframework.format.annotation.DateTimeFormat; |
||||
|
||||
import java.util.Date; |
||||
|
||||
/** |
||||
* 培训计划表实体类 |
||||
* @author litao |
||||
* @since 2022-06-10 |
||||
*/ |
||||
@Data |
||||
@TableName("blade_train_year") |
||||
@EqualsAndHashCode(callSuper = true) |
||||
public class TrainYear extends BaseEntity { |
||||
|
||||
private static final long serialVersionUID = 1L; |
||||
|
||||
/** |
||||
* 年份 |
||||
*/ |
||||
private String year; |
||||
|
||||
/** |
||||
* 人员现状分析 |
||||
*/ |
||||
private String userStatusAnalysis; |
||||
|
||||
/** |
||||
* 计划数量 |
||||
*/ |
||||
private Integer count; |
||||
|
||||
private String trainJson; |
||||
} |
||||
@ -0,0 +1,100 @@ |
||||
package org.springblade.system.user.controller; |
||||
|
||||
import com.alibaba.fastjson.JSON; |
||||
import com.alibaba.nacos.common.utils.CollectionUtils; |
||||
import com.alibaba.nacos.common.utils.StringUtils; |
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
||||
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
||||
import lombok.AllArgsConstructor; |
||||
import org.apache.commons.lang3.RandomUtils; |
||||
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.secure.utils.AuthUtil; |
||||
import org.springblade.core.tool.api.R; |
||||
import org.springblade.core.tool.utils.StringUtil; |
||||
import org.springblade.system.user.entity.Train; |
||||
import org.springblade.system.user.entity.TrainPerson; |
||||
import org.springblade.system.user.entity.TrainYear; |
||||
import org.springblade.system.user.service.ITrainService; |
||||
import org.springblade.system.user.service.ITrainYearService; |
||||
import org.springframework.web.bind.annotation.*; |
||||
|
||||
import javax.servlet.http.HttpServletResponse; |
||||
import java.io.IOException; |
||||
import java.util.Date; |
||||
import java.util.List; |
||||
|
||||
/** |
||||
* 年度培训计划 控制器 |
||||
* @author litao1 |
||||
* @since 2022-06-10 |
||||
*/ |
||||
@RestController |
||||
@RequestMapping("/trainYear") |
||||
@AllArgsConstructor |
||||
public class TrainYearController extends BladeController { |
||||
|
||||
private final ITrainYearService trainYearService; |
||||
|
||||
private final ITrainService trainService; |
||||
|
||||
/** |
||||
* 分页 |
||||
*/ |
||||
@GetMapping("/list") |
||||
public R<IPage<TrainYear>> list(TrainYear trainYear, Query query) { |
||||
LambdaQueryWrapper<TrainYear> wrapper = new LambdaQueryWrapper<>(); |
||||
if (StringUtils.isNotBlank(trainYear.getYear())) { |
||||
wrapper.like(TrainYear::getYear, trainYear.getYear()); |
||||
} |
||||
wrapper.orderByDesc(TrainYear::getCreateTime); |
||||
return R.data(trainYearService.page(Condition.getPage(query), wrapper)); |
||||
} |
||||
|
||||
/** |
||||
* 新增 |
||||
*/ |
||||
@PostMapping("/save") |
||||
public R<TrainYear> save(@RequestBody TrainYear trainYear) { |
||||
long id = RandomUtils.nextLong(); |
||||
trainYear.setId(id); |
||||
trainYear.setCreateTime(new Date()); |
||||
trainYearService.save(trainYear); |
||||
return R.data(trainYear); |
||||
} |
||||
|
||||
/** |
||||
* 修改 |
||||
*/ |
||||
@PostMapping("/update") |
||||
public R<TrainYear> update(@RequestBody TrainYear trainYear) { |
||||
trainYearService.updateById(trainYear); |
||||
return R.data(trainYear); |
||||
} |
||||
|
||||
/** |
||||
* 三级审批后确认 |
||||
*/ |
||||
@PostMapping("/confirm") |
||||
public R confirm(@RequestBody TrainYear trainYear) { |
||||
List<Train> trains = JSON.parseArray(trainYear.getTrainJson(), Train.class); |
||||
if (CollectionUtils.isNotEmpty(trains)) { |
||||
for (Train train : trains) { |
||||
train.setYearId(trainYear.getId()); |
||||
train.setStatus(0); |
||||
} |
||||
} |
||||
trainService.saveBatch(trains); |
||||
return R.status(trainYearService.updateById(trainYear)); |
||||
} |
||||
|
||||
/** |
||||
* 下载年度人员培训计划表 |
||||
*/ |
||||
@GetMapping("/trainYear") |
||||
public void trainYear(String id, HttpServletResponse response){ |
||||
trainYearService.trainYear(id, response); |
||||
} |
||||
} |
||||
@ -0,0 +1,14 @@ |
||||
package org.springblade.system.user.mapper; |
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper; |
||||
import org.springblade.system.user.entity.Train; |
||||
import org.springblade.system.user.entity.TrainYear; |
||||
|
||||
/** |
||||
* 培训计划 Mapper 接口 |
||||
* |
||||
* @author litao |
||||
* @since 2022-06-10 |
||||
*/ |
||||
public interface TrainYearMapper extends BaseMapper<TrainYear> { |
||||
} |
||||
@ -0,0 +1,18 @@ |
||||
package org.springblade.system.user.service; |
||||
|
||||
import org.springblade.core.mp.base.BaseService; |
||||
import org.springblade.system.user.entity.Train; |
||||
import org.springblade.system.user.entity.TrainYear; |
||||
|
||||
import javax.servlet.http.HttpServletResponse; |
||||
|
||||
/** |
||||
* 培训计划服务类 |
||||
* |
||||
* @author litao |
||||
* @since 2022-06-10 |
||||
*/ |
||||
public interface ITrainYearService extends BaseService<TrainYear> { |
||||
void trainYear(String id, HttpServletResponse response); |
||||
|
||||
} |
||||
@ -0,0 +1,110 @@ |
||||
package org.springblade.system.user.service.impl; |
||||
|
||||
import cn.afterturn.easypoi.word.WordExportUtil; |
||||
import com.alibaba.fastjson.JSON; |
||||
import com.alibaba.nacos.common.utils.CollectionUtils; |
||||
import lombok.AllArgsConstructor; |
||||
import org.apache.poi.xwpf.usermodel.XWPFDocument; |
||||
import org.springblade.core.mp.base.BaseServiceImpl; |
||||
import org.springblade.system.cache.DictBizCache; |
||||
import org.springblade.system.enums.DictBizEnum; |
||||
import org.springblade.system.user.entity.*; |
||||
import org.springblade.system.user.mapper.TrainYearMapper; |
||||
import org.springblade.system.user.service.*; |
||||
import org.springframework.stereotype.Service; |
||||
import org.springframework.transaction.annotation.Transactional; |
||||
|
||||
import javax.servlet.http.HttpServletResponse; |
||||
import java.io.IOException; |
||||
import java.text.SimpleDateFormat; |
||||
import java.util.ArrayList; |
||||
import java.util.HashMap; |
||||
import java.util.List; |
||||
import java.util.Map; |
||||
|
||||
/** |
||||
* 培训计划服务实现类 |
||||
* |
||||
* @author litao |
||||
* @since 2022-06-10 |
||||
*/ |
||||
@Service |
||||
@AllArgsConstructor |
||||
public class TrainYearServiceImpl extends BaseServiceImpl<TrainYearMapper, TrainYear> implements ITrainYearService { |
||||
|
||||
@Override |
||||
public void trainYear(String id, HttpServletResponse response) { |
||||
Map<String, Object> result = new HashMap<>(); |
||||
List<Map<String, Object>> resultList = new ArrayList<>(); |
||||
|
||||
TrainYear trainYear = this.getById(id); |
||||
result.put("1", trainYear.getYear()); |
||||
result.put("2", trainYear.getUserStatusAnalysis()); |
||||
List<Train> trains = JSON.parseArray(trainYear.getTrainJson(), Train.class); |
||||
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); |
||||
if (CollectionUtils.isNotEmpty(trains)) { |
||||
for (int i = 0; i < trains.size(); i++) { |
||||
Map<String, Object> map = new HashMap<>(); |
||||
Train train = trains.get(i); |
||||
map.put("xuhao", i + 1); |
||||
map.put("time", format.format(train.getStartTime())); |
||||
map.put("content", train.getContent()); |
||||
map.put("trainTarget", train.getTrainTarget()); |
||||
map.put("trainDept", train.getTrainDept()); |
||||
map.put("remark", train.getRemark()); |
||||
resultList.add(map); |
||||
} |
||||
int count = 15 - trains.size(); |
||||
if (count > 0) { |
||||
for (int i = 0; i < count; i++) { |
||||
Map<String, Object> map = new HashMap<>(); |
||||
map.put("xuhao", trains.size() + i + 1); |
||||
map.put("time", ""); |
||||
map.put("content", ""); |
||||
map.put("trainTarget", ""); |
||||
map.put("trainDept", ""); |
||||
map.put("remark", ""); |
||||
resultList.add(map); |
||||
} |
||||
} |
||||
} |
||||
result.put("list", resultList); |
||||
String url = DictBizCache.getKey(DictBizEnum.PRINT_URL.getName(), "trainYear"); |
||||
XWPFDocument doc = null; |
||||
// FileOutputStream fos = null;
|
||||
try { |
||||
doc = WordExportUtil.exportWord07(url, result); |
||||
// fos = new FileOutputStream("C://Users//AAA//Desktop//烁今//打印模板//检测任务书.docx");
|
||||
String filename = "测试.docx"; |
||||
response.setContentType("application/octet-stream"); |
||||
response.setHeader("content-disposition", "attachment;filename=12344.docx"); |
||||
doc.write(response.getOutputStream()); |
||||
} catch (Exception e) { |
||||
e.printStackTrace(); |
||||
} finally { |
||||
// if (null != doc) {
|
||||
//// doc.close();
|
||||
// try {
|
||||
// doc.write(fos);
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
// if (null != fos) {
|
||||
// try {
|
||||
// fos.close();
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
// }
|
||||
if (null != doc) { |
||||
try { |
||||
doc.close(); |
||||
} catch (IOException e) { |
||||
e.printStackTrace(); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
} |
||||
Loading…
Reference in new issue