From 8853292babb2ad94de4a3207966f1e83b767cd2d Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Sun, 17 Sep 2023 16:38:34 +0800
Subject: [PATCH] 新增流程节点进程查询接口

---
 src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java |  536 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 516 insertions(+), 20 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 96d44cb..44d8ec0 100644
--- a/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java
+++ b/src/main/java/org/springblade/modules/dispatcher/controller/DispatcherController.java
@@ -22,13 +22,18 @@
 import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
 import lombok.AllArgsConstructor;
 import javax.validation.Valid;
-
-import org.springblade.common.utils.arg;
+import org.apache.commons.lang3.StringUtils;
+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.Func;
+import org.springblade.modules.dispatcher.entity.DispatcherUnit;
 import org.springblade.modules.dispatcher.service.IDispatcherUnitService;
+import org.springblade.modules.system.entity.User;
+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;
@@ -36,10 +41,15 @@
 import org.springblade.modules.dispatcher.service.IDispatcherService;
 import org.springblade.core.boot.ctrl.BladeController;
 
+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
@@ -53,6 +63,9 @@
 	private final IDispatcherService dispatcherService;
 
 	private final IDispatcherUnitService dispatcherUnitService;
+
+	private final IUserService userService;
+	private final MyAsyncService myAsyncService;
 
 	/**
 	 * 详情
@@ -94,6 +107,11 @@
 	@ApiOperationSupport(order = 4)
 	@ApiOperation(value = "新增", notes = "传入dispatcher")
 	public R save(@Valid @RequestBody Dispatcher dispatcher) {
+		if (null != dispatcher.getUserIds() && dispatcher.getUserIds() != "") {
+			//计算派遣人数
+//			dispatcher.setNum(Arrays.asList(dispatcher.getUserIds().split(",")).size());
+			//查询派遣单位的信息,设置行政区
+		}
 		return R.status(dispatcherService.save(dispatcher));
 	}
 
@@ -107,32 +125,502 @@
 		return R.status(dispatcherService.updateById(dispatcher));
 	}
 
+
+	/**
+	 * 结束派遣
+	 *
+	 * @param dispatcher
+	 */
+	@PostMapping("/over-dispatcher")
+	public R overDispatcher(@Valid @RequestBody Dispatcher dispatcher) {
+		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()));
+		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() + "';" +
+				"update blade_user set dispatch = " + "'" + user.getDispatch() + "'" +
+				" " + "where id = " + "'" + user.getId() + "'";
+		//FtpUtil.sqlFileUpload(s1);
+		myAsyncService.dataSync(s1);
+		return R.status(status);
+	}
+
 	/**
 	 * 新增或修改
 	 */
 	@PostMapping("/submit")
 	@ApiOperationSupport(order = 6)
 	@ApiOperation(value = "新增或修改", notes = "传入dispatcher")
-	public R submit(@Valid @RequestBody Dispatcher dispatcher) throws Exception {
-		if (dispatcher.getId()==null){
-			if (null!=dispatcher.getUserIds() && dispatcher.getUserIds()!=""){
-				//计算派遣人数
-				dispatcher.setNum(Arrays.asList(dispatcher.getUserIds().split(",")).size());
-				//查询派遣单位的信息,设置行政区
-				dispatcher.setJurisdiction(dispatcherUnitService.getById(dispatcher.getDispatcherUnitId()).getJurisdiction().toString());
+	public R submit(@Valid @RequestBody Dispatcher dispatcher) {
+		boolean status = false;
+		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()));
+			user.setDispatch("0");
+			userService.updateById(user);
+
+			//新增派遣记录
+			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);
 			}
-			arg arg = new arg();
-			arg.test01(arg.url+"/dispatcher/save",dispatcher);
-		}
-		else {
-			if (null != dispatcher.getUserIds() && dispatcher.getUserIds() != "") {
-				//计算派遣人数
-				dispatcher.setNum(Arrays.asList(dispatcher.getUserIds().split(",")).size());
-				//查询派遣单位的信息,设置行政区
-				dispatcher.setJurisdiction(dispatcherUnitService.getById(dispatcher.getDispatcherUnitId()).getJurisdiction().toString());
+		} 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);
+
+				//修改当前保安人员的派遣状态
+				User user1 = new User();
+				user1.setId(Long.parseLong(dispatcher.getUserIds()));
+				user1.setDispatch("0");
+				userService.updateById(user1);
+
+				//修改
+				status = dispatcherService.updateById(dispatcher);
+				if (status) {
+					//内网同步
+					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 {
+				//没有修改保安员,只修改了派遣时间等信息
+				//修改
+				status = dispatcherService.updateById(dispatcher);
+				if (status) {
+					//内网同步
+					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(dispatcherService.saveOrUpdate(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()));
+					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()));
+				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() + "'" +
+							",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() + "'" +
+						",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);
 	}
 
 
@@ -143,6 +631,14 @@
 	@ApiOperationSupport(order = 8)
 	@ApiOperation(value = "删除", notes = "传入ids")
 	public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
+		//内网删除
+		List<Long> list = Func.toLongList(ids);
+		list.forEach(id -> {
+			//内网同步
+			String s1 = "delete from sys_dispatcher where id = " + "'" + id + "'";
+			//FtpUtil.sqlFileUpload(s1);
+			myAsyncService.dataSync(s1);
+		});
 		return R.status(dispatcherService.removeByIds(Func.toLongList(ids)));
 	}
 

--
Gitblit v1.9.3