From 6f201b8d3743e246a71f00a9ba98d10b128fae38 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Tue, 16 Jan 2024 08:59:52 +0800
Subject: [PATCH] 派遣记录导入

---
 src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java |  533 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 490 insertions(+), 43 deletions(-)

diff --git a/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java b/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java
index 4bb23ec..5521f38 100644
--- a/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java
+++ b/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java
@@ -16,36 +16,58 @@
  */
 package org.springblade.modules.dispatcher.controller;
 
+import com.alibaba.excel.EasyExcel;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
 import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
 import lombok.AllArgsConstructor;
+
+import javax.servlet.http.HttpServletResponse;
 import javax.validation.Valid;
 
-import org.springblade.common.utils.arg;
+import org.apache.commons.codec.Charsets;
+import org.apache.commons.lang3.StringUtils;
+import org.springblade.common.excel.RowWriteHandler;
+import org.springblade.core.excel.util.ExcelUtil;
+import org.springblade.core.log.exception.ServiceException;
 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.DateUtil;
 import org.springblade.core.tool.utils.Func;
-import org.springblade.modules.FTP.FtpUtil;
+import org.springblade.modules.dispatcher.entity.DispatcherUnit;
+import org.springblade.modules.dispatcher.excel.DispatcherExcel;
+import org.springblade.modules.dispatcher.excel.DispatcherImporter;
+import org.springblade.modules.dispatcher.excel.DispatcherUnitExcel;
+import org.springblade.modules.dispatcher.excel.DispatcherUnitImporter;
 import org.springblade.modules.dispatcher.service.IDispatcherUnitService;
+import org.springblade.modules.dispatcher.vo.DispatcherStatistics;
 import org.springblade.modules.system.entity.User;
+import org.springblade.modules.system.excel.UserCertificateExcel;
 import org.springblade.modules.system.service.IUserService;
+import org.springblade.modules.system.service.MyAsyncService;
+import org.springblade.modules.system.vo.UserVO;
 import org.springframework.web.bind.annotation.*;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import org.springblade.modules.dispatcher.entity.Dispatcher;
 import org.springblade.modules.dispatcher.vo.DispatcherVO;
 import org.springblade.modules.dispatcher.service.IDispatcherService;
 import org.springblade.core.boot.ctrl.BladeController;
+import org.springframework.web.multipart.MultipartFile;
 
+import java.io.IOException;
+import java.net.URLEncoder;
+import java.text.ParseException;
 import java.text.SimpleDateFormat;
+import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.Date;
 import java.util.List;
+import java.util.concurrent.atomic.AtomicBoolean;
 
 /**
- *  控制器
+ * 控制器
  *
  * @author BladeX
  * @since 2021-07-07
@@ -61,6 +83,7 @@
 	private final IDispatcherUnitService dispatcherUnitService;
 
 	private final IUserService userService;
+	private final MyAsyncService myAsyncService;
 
 	/**
 	 * 详情
@@ -123,6 +146,7 @@
 
 	/**
 	 * 结束派遣
+	 *
 	 * @param dispatcher
 	 */
 	@PostMapping("/over-dispatcher")
@@ -130,20 +154,33 @@
 		dispatcher.setStatus(1);
 		Boolean status = dispatcherService.updateById(dispatcher);
 
-		//用户状态改变
+		//查询当前用户的派遣记录,是否存在多条未结束派遣的
+		Dispatcher dispatcher1 = new Dispatcher();
+		dispatcher1.setUserIds(dispatcher.getUserIds());
+		dispatcher1.setStatus(0);
+		List<Dispatcher> dispatcherList = dispatcherService.list(Condition.getQueryWrapper(dispatcher1));
+
 		User user = new User();
+		if (dispatcherList.size() < 1) {
+			//用户状态改变
+			user.setDispatch("1");
+		} else {
+			//用户状态改变
+			user.setDispatch("0");
+		}
 		user.setId(Long.parseLong(dispatcher.getUserIds()));
-		user.setDispatch("1");
 		userService.updateById(user);
+
 
 		//内网同步
 		String s1 =
 			"update sys_dispatcher set status = " + "'" + dispatcher.getStatus() + "'" +
 				",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()) + "'" +
-				" " +"where id = " + "'" + dispatcher.getId() + "';"+
+				" " + "where id = " + "'" + dispatcher.getId() + "';" +
 				"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
-				" " +"where id = " + "'" + user.getId() + "'";
-		FtpUtil.sqlFileUpload(s1);
+				" " + "where id = " + "'" + user.getId() + "'";
+		//FtpUtil.sqlFileUpload(s1);
+		myAsyncService.dataSync(s1);
 		return R.status(status);
 	}
 
@@ -154,14 +191,11 @@
 	@ApiOperationSupport(order = 6)
 	@ApiOperation(value = "新增或修改", notes = "传入dispatcher")
 	public R submit(@Valid @RequestBody Dispatcher dispatcher) {
-		//List<String> list = Arrays.asList(dispatcher.getUserIds().split(","));
-		//计算派遣人数
-		//dispatcher.setNum(list.size());
-
 		boolean status = false;
-		if (dispatcher.getId()==null){
+		if (dispatcher.getId() == null) {
 			dispatcher.setCreateTime(new Date());
 			dispatcher.setStatus(0);
+			dispatcher.setUserIds(dispatcher.getUserIds());
 
 			User user = new User();
 			user.setId(Long.parseLong(dispatcher.getUserIds()));
@@ -170,33 +204,264 @@
 
 			//新增派遣记录
 			status = dispatcherService.save(dispatcher);
+			if (status) {
+				//数据同步
+				String s1 =
+					"insert into sys_dispatcher(id,dispatcherTime,dispatcherAddress,dispatcher_unit_id,user_ids,end_time,dept_id,jurisdiction,create_time,status) " +
+						"values(" + "'" + dispatcher.getId() + "'" + "," +
+						"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" + "," +
+						"'" + dispatcher.getDispatcheraddress() + "'" + "," +
+						"'" + dispatcher.getDispatcherUnitId() + "'" + "," +
+						"'" + dispatcher.getUserIds() + "'" + "," +
+						"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" + "," +
+						"'" + dispatcher.getDeptId() + "'" + "," +
+						"'" + dispatcher.getJurisdiction() + "'" + "," +
+						"'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getCreateTime()) + "'" + "," +
+						"'" + dispatcher.getStatus() + "'" + ");" +
+						"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+						" " + "where id = " + "'" + user.getId() + "'";
+				myAsyncService.dataSync(s1);
+			}
+		} else {
+			dispatcher.setUpdateTime(new Date());
+			//查询当前派遣记录
+			Dispatcher dispatcher1 = dispatcherService.getById(dispatcher.getId());
+			if (!dispatcher1.getUserIds().equals(dispatcher.getUserIds())) {
+				//修改原保安人员的派遣状态
+				//查询原保安人员的派遣记录,是否存在多条未结束派遣的
+				Dispatcher dispatcher2 = new Dispatcher();
+				dispatcher2.setUserIds(dispatcher1.getUserIds());
+				dispatcher2.setStatus(0);
+				List<Dispatcher> dispatcherList = dispatcherService.list(Condition.getQueryWrapper(dispatcher2));
+				User user = new User();
+				user.setId(Long.parseLong(dispatcher1.getUserIds()));
+				if (dispatcherList.size() == 1) {
+					//用户状态改变
+					user.setDispatch("1");
+				} else {
+					user.setDispatch("0");
+				}
+				//修改原保安人员用户信息
+				userService.updateById(user);
 
-			//数据同步
-			String s1 =
-				"insert into sys_dispatcher(id,dispatcherTime,dispatcherAddress,dispatcher_unit_id,user_ids,end_time,dept_id,jurisdiction,create_time,status) " +
-				"values(" + "'" + dispatcher.getId() + "'" + "," +
-					"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" + "," +
-					"'" + dispatcher.getDispatcheraddress() + "'" + "," +
-					"'" + dispatcher.getDispatcherUnitId() + "'" + "," +
-					"'" + dispatcher.getUserIds() + "'" + "," +
-					"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" + "," +
-					"'" + dispatcher.getDeptId() + "'" + "," +
-					"'" + dispatcher.getJurisdiction() + "'" + "," +
-					"'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getCreateTime()) + "'" + "," +
-					"'" +dispatcher.getStatus() + "'" + ");" +
-				"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
-					" " +"where id = " + "'" + user.getId() + "'";
-			FtpUtil.sqlFileUpload(s1);
-		}else {
-				dispatcher.setUpdateTime(new Date());
+				//修改当前保安人员的派遣状态
+				User user1 = new User();
+				user1.setId(Long.parseLong(dispatcher.getUserIds()));
+				user1.setDispatch("0");
+				userService.updateById(user1);
 
-				//查询当前派遣记录
-				Dispatcher dispatcher1 = dispatcherService.getById(dispatcher.getId());
-				if (!dispatcher1.getUserIds().equals(dispatcher.getUserIds())){
+				//修改
+				status = dispatcherService.updateById(dispatcher);
+			} else {
+				//没有修改保安员,只修改了派遣时间等信息
+				//修改
+				status = dispatcherService.updateById(dispatcher);
+			}
+		}
+		return R.status(status);
+	}
+
+
+	/**
+	 * 新增派遣(批量)
+	 */
+	@PostMapping("/saveDispatcher")
+	public R saveDispatcher(@RequestBody DispatcherVO dispatcher) {
+		List<String> list = Arrays.asList(dispatcher.getIds().split(","));
+		//修改状态
+		AtomicBoolean status = new AtomicBoolean(false);
+		AtomicBoolean errorStatus = new AtomicBoolean(true);
+		//将不能导入的保安员账号存起来
+		List<String> errorList = new ArrayList<>();
+		if (list.size() > 0) {
+			//遍历
+			list.forEach(id -> {
+				dispatcher.setCreateTime(new Date());
+				dispatcher.setStatus(0);
+				dispatcher.setUserIds(id);
+				//判断派遣单位类型,如果是医院,学校,银行等单位,则派遣人员年龄不应大于50岁
+				DispatcherUnit dispatcherUnit = dispatcherUnitService.getById(dispatcher.getDispatcherUnitId());
+				if (null != dispatcherUnit.getDistrict() && !dispatcherUnit.getDistrict().equals("") && !dispatcherUnit.getDistrict().equals(-1)) {
+					//判断
+					if (dispatcherUnit.getDistrict().equals(1) ||
+						dispatcherUnit.getDistrict().equals(2) ||
+						dispatcherUnit.getDistrict().equals(3)) {
+						//查询保安员年龄
+						UserVO user1 = userService.getUserAgeById(Long.parseLong(dispatcher.getUserIds()));
+						if (user1.getAge() > 50) {
+							errorStatus.set(false);
+							errorList.add(user1.getCardid());
+							//跳出本次循环
+							return;
+						} else {
+							User user = new User();
+							user.setId(Long.parseLong(id));
+							user.setDispatch("0");
+							userService.updateById(user);
+
+							//新增派遣记录
+							status.set(dispatcherService.save(dispatcher));
+							//数据同步
+							String s1 =
+								"insert into sys_dispatcher(id,dispatcherTime,dispatcherAddress,dispatcher_unit_id,user_ids,end_time,dept_id,jurisdiction,create_time,status) " +
+									"values(" + "'" + dispatcher.getId() + "'" + "," +
+									"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" + "," +
+									"'" + dispatcher.getDispatcheraddress() + "'" + "," +
+									"'" + dispatcher.getDispatcherUnitId() + "'" + "," +
+									"'" + dispatcher.getUserIds() + "'" + "," +
+									"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" + "," +
+									"'" + dispatcher.getDeptId() + "'" + "," +
+									"'" + dispatcher.getJurisdiction() + "'" + "," +
+									"'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getCreateTime()) + "'" + "," +
+									"'" + dispatcher.getStatus() + "'" + ");" +
+									"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+									" " + "where id = " + "'" + user.getId() + "'";
+							myAsyncService.dataSync(s1);
+						}
+					} else {
+						User user = new User();
+						user.setId(Long.parseLong(id));
+						user.setDispatch("0");
+						userService.updateById(user);
+
+						//新增派遣记录
+						status.set(dispatcherService.save(dispatcher));
+						//数据同步
+						String s1 =
+							"insert into sys_dispatcher(id,dispatcherTime,dispatcherAddress,dispatcher_unit_id,user_ids,end_time,dept_id,jurisdiction,create_time,status) " +
+								"values(" + "'" + dispatcher.getId() + "'" + "," +
+								"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" + "," +
+								"'" + dispatcher.getDispatcheraddress() + "'" + "," +
+								"'" + dispatcher.getDispatcherUnitId() + "'" + "," +
+								"'" + dispatcher.getUserIds() + "'" + "," +
+								"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" + "," +
+								"'" + dispatcher.getDeptId() + "'" + "," +
+								"'" + dispatcher.getJurisdiction() + "'" + "," +
+								"'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getCreateTime()) + "'" + "," +
+								"'" + dispatcher.getStatus() + "'" + ");" +
+								"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+								" " + "where id = " + "'" + user.getId() + "'";
+						//FtpUtil.sqlFileUpload(s1);
+						myAsyncService.dataSync(s1);
+					}
+				} else {
+					User user = new User();
+					user.setId(Long.parseLong(id));
+					user.setDispatch("0");
+					userService.updateById(user);
+
+					//新增派遣记录
+					status.set(dispatcherService.save(dispatcher));
+					//数据同步
+					String s1 =
+						"insert into sys_dispatcher(id,dispatcherTime,dispatcherAddress,dispatcher_unit_id,user_ids,end_time,dept_id,jurisdiction,create_time,status) " +
+							"values(" + "'" + dispatcher.getId() + "'" + "," +
+							"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" + "," +
+							"'" + dispatcher.getDispatcheraddress() + "'" + "," +
+							"'" + dispatcher.getDispatcherUnitId() + "'" + "," +
+							"'" + dispatcher.getUserIds() + "'" + "," +
+							"'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" + "," +
+							"'" + dispatcher.getDeptId() + "'" + "," +
+							"'" + dispatcher.getJurisdiction() + "'" + "," +
+							"'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getCreateTime()) + "'" + "," +
+							"'" + dispatcher.getStatus() + "'" + ");" +
+							"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+							" " + "where id = " + "'" + user.getId() + "'";
+					myAsyncService.dataSync(s1);
+				}
+
+			});
+			if (!errorStatus.get()) {
+				String errorAccount = StringUtils.join(errorList, "\\\n");
+				throw new ServiceException("保安员[" + errorAccount + "]派遣失败!派遣到学校,医院,银行的保安员年龄应不超过50周岁!");
+			}
+		}
+		return R.status(status.get());
+	}
+
+
+	/**
+	 * 派遣记录修改
+	 */
+	@PostMapping("/updateDispatcher")
+	public R updateDispatcher(@RequestBody DispatcherVO dispatcher) {
+		boolean status = false;
+		dispatcher.setUpdateTime(new Date());
+		//查询当前派遣记录
+		Dispatcher dispatcher1 = dispatcherService.getById(dispatcher.getId());
+		//判断派遣单位类型,如果是医院,学校,银行等单位,则派遣人员年龄不应大于50岁
+		DispatcherUnit dispatcherUnit = dispatcherUnitService.getById(dispatcher.getDispatcherUnitId());
+		if (!dispatcher1.getUserIds().equals(dispatcher.getUserIds())) {
+			if (null != dispatcherUnit.getDistrict() && !dispatcherUnit.getDistrict().equals("") && !dispatcherUnit.getDistrict().equals(-1)) {
+				//判断
+				if (dispatcherUnit.getDistrict().equals(1) ||
+					dispatcherUnit.getDistrict().equals(2) ||
+					dispatcherUnit.getDistrict().equals(3)) {
+					//查询保安员年龄
+					UserVO userVO = userService.getUserAgeById(Long.parseLong(dispatcher.getUserIds()));
+					if (userVO.getAge() > 50) {
+						throw new ServiceException("保安员[" + userVO.getCardid() + "]变更派遣失败!派遣到学校,医院,银行的保安员年龄应不超过50周岁!");
+					} else {
+						//修改原保安人员的派遣状态
+						//查询原保安人员的派遣记录,是否存在多条未结束派遣的
+						Dispatcher dispatcher2 = new Dispatcher();
+						dispatcher2.setUserIds(dispatcher1.getUserIds());
+						dispatcher2.setStatus(0);
+						List<Dispatcher> dispatcherList = dispatcherService.list(Condition.getQueryWrapper(dispatcher2));
+						User user = new User();
+						user.setId(Long.parseLong(dispatcher1.getUserIds()));
+						if (dispatcherList.size() == 1) {
+							//用户状态改变
+							user.setDispatch("1");
+						} else {
+							user.setDispatch("0");
+						}
+						//修改原保安人员用户信息
+						userService.updateById(user);
+
+						//修改当前保安人员的派遣状态
+						User user1 = new User();
+						user1.setId(Long.parseLong(dispatcher.getUserIds()));
+						user1.setDispatch("0");
+						userService.updateById(user1);
+
+						//修改派遣记录信息
+						status = dispatcherService.updateById(dispatcher);
+
+						//内网同步
+						String s1 =
+							"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+								" " + "where id = " + "'" + user.getId() + "';" +
+								"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
+								",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
+								",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
+								",user_ids = " + "'" + dispatcher.getUserIds() + "'" +
+								",end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" +
+								",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
+								",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
+								",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
+								" " + "where id = " + "'" + dispatcher.getId() + "';" +
+								"update blade_user set dispatch = " + "'" + user1.getDispatch() + "'" +
+								" " + "where id = " + "'" + user1.getId() + "'";
+						//FtpUtil.sqlFileUpload(s1);
+						myAsyncService.dataSync(s1);
+					}
+				} else {
 					//修改原保安人员的派遣状态
+					//查询原保安人员的派遣记录,是否存在多条未结束派遣的
+					Dispatcher dispatcher2 = new Dispatcher();
+					dispatcher2.setUserIds(dispatcher1.getUserIds());
+					dispatcher2.setStatus(0);
+					List<Dispatcher> dispatcherList = dispatcherService.list(Condition.getQueryWrapper(dispatcher2));
 					User user = new User();
 					user.setId(Long.parseLong(dispatcher1.getUserIds()));
-					user.setDispatch("1");
+					if (dispatcherList.size() == 1) {
+						//用户状态改变
+						user.setDispatch("1");
+					} else {
+						user.setDispatch("0");
+					}
+					//修改原保安人员用户信息
 					userService.updateById(user);
 
 					//修改当前保安人员的派遣状态
@@ -205,13 +470,108 @@
 					user1.setDispatch("0");
 					userService.updateById(user1);
 
-					//修改
+					//修改派遣记录信息
 					status = dispatcherService.updateById(dispatcher);
 
 					//内网同步
 					String s1 =
 						"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
-							" " +"where id = " + "'" + user.getId() + "';"+
+							" " + "where id = " + "'" + user.getId() + "';" +
+							"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
+							",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
+							",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
+							",user_ids = " + "'" + dispatcher.getUserIds() + "'" +
+							",end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" +
+							",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
+							",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
+							",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
+							" " + "where id = " + "'" + dispatcher.getId() + "';" +
+							"update blade_user set dispatch = " + "'" + user1.getDispatch() + "'" +
+							" " + "where id = " + "'" + user1.getId() + "'";
+					//FtpUtil.sqlFileUpload(s1);
+					myAsyncService.dataSync(s1);
+				}
+			} else {
+				//修改原保安人员的派遣状态
+				//查询原保安人员的派遣记录,是否存在多条未结束派遣的
+				Dispatcher dispatcher2 = new Dispatcher();
+				dispatcher2.setUserIds(dispatcher1.getUserIds());
+				dispatcher2.setStatus(0);
+				List<Dispatcher> dispatcherList = dispatcherService.list(Condition.getQueryWrapper(dispatcher2));
+				User user = new User();
+				user.setId(Long.parseLong(dispatcher1.getUserIds()));
+				if (dispatcherList.size() == 1) {
+					//用户状态改变
+					user.setDispatch("1");
+				} else {
+					user.setDispatch("0");
+				}
+				//修改原保安人员用户信息
+				userService.updateById(user);
+
+				//修改当前保安人员的派遣状态
+				User user1 = new User();
+				user1.setId(Long.parseLong(dispatcher.getUserIds()));
+				user1.setDispatch("0");
+				userService.updateById(user1);
+
+				//修改派遣记录信息
+				status = dispatcherService.updateById(dispatcher);
+
+				//内网同步
+				String s1 =
+					"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+						" " + "where id = " + "'" + user.getId() + "';" +
+						"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
+						",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
+						",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
+						",user_ids = " + "'" + dispatcher.getUserIds() + "'" +
+						",end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" +
+						",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
+						",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
+						",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
+						" " + "where id = " + "'" + dispatcher.getId() + "';" +
+						"update blade_user set dispatch = " + "'" + user1.getDispatch() + "'" +
+						" " + "where id = " + "'" + user1.getId() + "'";
+				//FtpUtil.sqlFileUpload(s1);
+				myAsyncService.dataSync(s1);
+			}
+		} else {
+			if (null != dispatcherUnit.getDistrict() && !dispatcherUnit.getDistrict().equals("") && !dispatcherUnit.getDistrict().equals(-1)) {
+				//判断
+				if (dispatcherUnit.getDistrict().equals(1) ||
+					dispatcherUnit.getDistrict().equals(2) ||
+					dispatcherUnit.getDistrict().equals(3)) {
+					//查询保安员年龄
+					UserVO userVO = userService.getUserAgeById(Long.parseLong(dispatcher.getUserIds()));
+					if (userVO.getAge() > 50) {
+						throw new ServiceException("保安员[" + userVO.getCardid() + "]变更派遣失败!派遣到学校,医院,银行的保安员年龄应不超过50周岁!");
+					} else {
+						//没有修改保安员,只修改了派遣时间等信息
+						//修改
+						status = dispatcherService.updateById(dispatcher);
+
+						//内网同步
+						String s1 =
+							"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
+								",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
+								",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
+								",user_ids = " + "'" + dispatcher.getUserIds() + "'" +
+								",end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" +
+								",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
+								",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
+								",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
+								" " + "where id = " + "'" + dispatcher.getId() + "'";
+						//FtpUtil.sqlFileUpload(s1);
+						myAsyncService.dataSync(s1);
+					}
+				} else {
+					//没有修改保安员,只修改了派遣时间等信息
+					//修改
+					status = dispatcherService.updateById(dispatcher);
+
+					//内网同步
+					String s1 =
 						"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
 							",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
 							",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
@@ -220,12 +580,29 @@
 							",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
 							",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
 							",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
-							" " +"where id = " + "'" + dispatcher.getId() + "';"+
-						"update blade_user set dispatch = " + "'" + user1.getDispatch() + "'" +
-							" " +"where id = " + "'" + user1.getId() + "'";
-					FtpUtil.sqlFileUpload(s1);
+							" " + "where id = " + "'" + dispatcher.getId() + "'";
+					//FtpUtil.sqlFileUpload(s1);
+					myAsyncService.dataSync(s1);
 				}
+			} else {
+				//没有修改保安员,只修改了派遣时间等信息
+				//修改
+				status = dispatcherService.updateById(dispatcher);
 
+				//内网同步
+				String s1 =
+					"update sys_dispatcher set dispatcherTime = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getDispatchertime()) + "'" +
+						",dispatcherAddress = " + "'" + dispatcher.getDispatcheraddress() + "'" +
+						",dispatcher_unit_id = " + "'" + dispatcher.getDispatcherUnitId() + "'" +
+						",user_ids = " + "'" + dispatcher.getUserIds() + "'" +
+						",end_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd").format(dispatcher.getEndTime()) + "'" +
+						",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(dispatcher.getUpdateTime()) + "'" +
+						",dept_id = " + "'" + dispatcher.getDeptId() + "'" +
+						",jurisdiction = " + "'" + dispatcher.getJurisdiction() + "'" +
+						" " + "where id = " + "'" + dispatcher.getId() + "'";
+				//FtpUtil.sqlFileUpload(s1);
+				myAsyncService.dataSync(s1);
+			}
 		}
 		return R.status(status);
 	}
@@ -240,13 +617,83 @@
 	public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
 		//内网删除
 		List<Long> list = Func.toLongList(ids);
-		list.forEach(id ->{
+		list.forEach(id -> {
 			//内网同步
 			String s1 = "delete from sys_dispatcher where id = " + "'" + id + "'";
-			FtpUtil.sqlFileUpload(s1);
+			//FtpUtil.sqlFileUpload(s1);
+			myAsyncService.dataSync(s1);
 		});
 		return R.status(dispatcherService.removeByIds(Func.toLongList(ids)));
 	}
 
+	/**
+	 * 派遣服务单位统计
+	 * @return
+	 */
+	@GetMapping("/getStatistics")
+	public R getStatistics(DispatcherStatistics dispatcherStatistics){
+		List<DispatcherStatistics> list =  dispatcherService.getDispatcherStatisticsList(dispatcherStatistics);
+		return R.data(list);
+	}
+
+	/**
+	 * 导入派遣数据
+	 *
+	 * @param isCovered 1 覆盖  0不覆盖
+	 * @return
+	 */
+	@PostMapping("import-dispatcher")
+	public R importDispatcherUnit(MultipartFile file, Integer isCovered) {
+		DispatcherImporter dispatcherImporter = new DispatcherImporter(dispatcherService, false);
+		ExcelUtil.save(file, dispatcherImporter, DispatcherExcel.class);
+		return R.success("操作成功");
+	}
+
+	/**
+	 * 导出模板
+	 */
+	@GetMapping("export-template")
+	@ApiOperation(value = "导出模板")
+	public void exportUser(HttpServletResponse response) throws ParseException, IOException {
+		List<DispatcherExcel> list = new ArrayList<>();
+
+		DispatcherExcel dispatcher = new DispatcherExcel();
+		dispatcher.setDispatcherUnitId("****公司");
+		dispatcher.setDeptId("****保安服务公司");
+		dispatcher.setUserIds("张三");
+		dispatcher.setCardid("360XXX19XXXXXX****");
+		dispatcher.setDispatcherTime(new SimpleDateFormat("yyyy/MM/dd").parse("2024/10/10"));
+		dispatcher.setEndTime(new SimpleDateFormat("yyyy/MM/dd").parse("2025/10/10"));
+		dispatcher.setDispatcherAddress("*****");
+		list.add(dispatcher);
+
+		DispatcherExcel dispatcher2 = new DispatcherExcel();
+		dispatcher2.setDispatcherUnitId("****公司");
+		dispatcher2.setDeptId("****保安服务公司");
+		dispatcher2.setUserIds("张三");
+		dispatcher2.setCardid("360XXX19XXXXXX****");
+		dispatcher2.setDispatcherTime(new SimpleDateFormat("yyyy/MM/dd").parse("2024/10/10"));
+		dispatcher2.setEndTime(new SimpleDateFormat("yyyy/MM/dd").parse("2025/10/10"));
+		dispatcher2.setDispatcherAddress("*****");
+		list.add(dispatcher2);
+
+
+
+//		ExcelUtil.export(response, "派遣数据导入模板" + DateUtil.time(), "派遣单位数据表", list, DispatcherExcel.class);
+
+		String fileName = null;
+		try {
+			response.setContentType("application/vnd.ms-excel");
+			response.setCharacterEncoding(org.apache.commons.codec.Charsets.UTF_8.name());
+			fileName = URLEncoder.encode("派遣数据导入模板" + DateUtil.time(), Charsets.UTF_8.name());
+			response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
+			//修改单元格格式为文本格式
+			EasyExcel.write(response.getOutputStream(), DispatcherExcel.class).sheet("派遣数据表").registerWriteHandler(new RowWriteHandler()).doWrite(list);
+		} catch (Throwable var6) {
+			throw var6;
+		}
+
+	}
+
 
 }

--
Gitblit v1.9.3