智慧保安后台管理-外网-验收版本
tangzy
2021-09-15 ff7b03055d36d1217858fd96d57a73c85e366bef
src/main/java/org/springblade/modules/information/controller/InformationController.java
@@ -21,29 +21,37 @@
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.AllArgsConstructor;
import com.alibaba.fastjson.JSON;
import org.springblade.common.cache.DictCache;
import org.springblade.common.constant.FtpConstant;
import org.springblade.common.enums.DictEnum;
import org.springblade.common.utils.arg;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.cache.utils.CacheUtil;
import org.springblade.core.excel.util.ExcelUtil;
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.support.Kv;
import org.springblade.modules.FTP.FtpUtil;
import org.springblade.modules.FTP.OutJson;
import org.springblade.modules.information.entity.Information;
import org.springblade.modules.information.excel.InforExcel;
import org.springblade.modules.information.excel.InforImporter;
import org.springblade.modules.information.service.IInformationService;
import org.springblade.modules.information.vo.InformationVO;
import org.springblade.modules.system.entity.Dept;
import org.springblade.modules.system.service.IDeptService;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import javax.validation.Valid;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.io.*;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.*;
import static org.springblade.core.cache.constant.CacheConstant.SYS_CACHE;
/**
 * 控制器
@@ -56,10 +64,19 @@
@RequestMapping("/information")
@Api(value = "", tags = "接口")
public class InformationController extends BladeController {
   //ftp服务器IP地址
   private static String ftpHost = "192.168.0.105";
   //ftp服务器端口
   private static int ftpPort = 21;
   //ftp服务器用户名
   private static String ftpUserName = "yly";
   //ftp服务器密码
   private static String ftpPassword = "Yly@123";
   //本地路径
   private static String localPath = "D:\\anbao";
   private final IInformationService informationService;
   private final IDeptService iDeptService;
   /**
    * 详情
@@ -93,6 +110,26 @@
      IPage<InformationVO> pages = informationService.selectInformationPage(Condition.getPage(query), information);
      return R.data(pages);
   }
   /**
    * 培训公司信息查询
    */
   @GetMapping("/security-page")
   public R<IPage<InformationVO>> securityPage(InformationVO information, Query query) {
      IPage<InformationVO> pages = informationService.securityPage(Condition.getPage(query), information);
      return R.data(pages);
   }
   /**
    * 培训公司信息查询,下拉
    */
   @GetMapping("/train-unit-tree")
   public List<InformationVO> trainUnitTree(InformationVO information) {
      List<InformationVO> pages = informationService.trainUnitTree(information);
      return pages;
   }
   /**
    * 新增
@@ -138,6 +175,15 @@
         dept.setAncestors("0,1420222961377357825");
         dept.setDeptCategory(1);
      }
      //跨区域保安公司
      if (information.getStats().equals("4")) {
         Long i = 1425366663452196865L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setAncestors("0,1425366663452196865");
         dept.setDeptCategory(1);
      }
      if (iDeptService.submit(dept)) {
         CacheUtil.clear(SYS_CACHE);
         // 返回懒加载树更新节点所需字段
@@ -146,8 +192,22 @@
         String id = kv.get("id").toString();
         information.setDepartmentid(id);
      }
      arg.test01(arg.url + "/information/save", information);
      return R.status(informationService.save(information));
      informationService.save(information);
      String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(information.getEstablishtime());
      //Integer id = information.getId();
      String s = "insert into sys_information(id,creditcode,enterprisename,representative,establishtime," +
         "registeredcapital,organizationcode,registrationnumber, enterprises, address," +
         " business,region,registration,industry,departmentid,stats,jurisdiction,representativecell,contacts,contactscell) " +
         "values(" + "'" + information.getId() + "'" + "," + "'" + information.getCreditcode() + "'" + "," + "'" + information.getEnterprisename() + "'" + "," + "'" + information.getRepresentative() + "'" + "," +
         "'" + formatStr + "'" + "," + "'" + information.getRegisteredcapital() + "'" + "," + "'" + information.getOrganizationcode() + "'" + "," + "'" + information.getRegistrationnumber() + "'" + "," + "'" + information.getEnterprises() + "'" + "," + "'" +
         information.getAddress() + "'" + "," + "'" + information.getBusiness() + "'" + "," + "'" +
         information.getRegion() + "'" + "," + "'" + information.getRegistration() + "'" + "," + "'" + information.getIndustry() + "'" + "," + "'" + information.getDepartmentid() + "'" + "," +
         "'" + information.getStats() + "'" + "," + "'" + information.getJurisdiction() + "'" + "," + "'" + information.getRepresentativecell() + "'" + "," +
         "'" + information.getContacts() + "'" + "," + "'" + information.getContactscell() + "'" + ");" +
         "insert into blade_dept(id,parent_id,tenant_id,dept_name,ancestors,dept_category) values(" + "'" + information.getDepartmentid() + "'" + "," + "'" + dept.getParentId() + "'" + ","
         + "'" + dept.getTenantId() + "'" + "," + "'" + information.getEnterprisename() + "'" + "," + "'" + dept.getAncestors() + "'" + "," + "'" + dept.getDeptCategory() + "'" + ")";
      FtpUtil.sqlFileUpload(s);
      return R.success("成功");
   }
   /**
@@ -157,8 +217,42 @@
   @ApiOperationSupport(order = 5)
   @ApiOperation(value = "修改", notes = "传入information")
   public R update(@Valid @RequestBody Information information) throws Exception {
      arg.test01(arg.url + "/information/update", information);
      return R.status(informationService.updateById(information));
      informationService.updateById(information);
      String businessLicense=null;
      String licence=null;
      String format="";
      if(information.getBusinessLicense()!=null && !"".equals(information.getBusinessLicense())){
          businessLicense = information.getBusinessLicense().substring(26, information.getBusinessLicense().length());
      }
      if(information.getLicence()!=null && !"".equals(information.getLicence())){
          licence = information.getLicence().substring(26, information.getLicence().length());
      }
      if (information.getEstablishtime()!=null && !"".equals(information.getEstablishtime())){
          format = new SimpleDateFormat("yyyy-MM-dd").format(information.getEstablishtime());
      }
      //内网同步
      String s1 = "update sys_information set creditCode = " + "'" + information.getCreditcode() + "'" +
         ",enterpriseName = " + "'" + information.getEnterprisename() + "'" +
         ",representative = " + "'" + information.getRepresentative() + "'" +
         ",establishTime = " + "'" + format + "'" +
         ",registeredCapital = " + "'" + information.getRegisteredcapital() + "'" +
         ",jurisdiction = " + "'" + information.getJurisdiction() + "'" +
         ",enterprises = " + "'" + information.getEnterprises() + "'" +
         ",address = " + "'" + information.getAddress() + "'" +
         ",business = " + "'" + information.getBusiness() + "'" +
         ",region = " + "'" + information.getRegion() + "'" +
         ",registration = " + "'" + information.getRegistration() + "'" +
         ",industry = " + "'" + information.getIndustry() + "'" +
         ",departmentid = " + "'" + information.getDepartmentid() + "'" +
         ",stats = " + "'" + information.getStats() + "'" +
         ",representativecell = " + "'" + information.getRepresentativecell() + "'" +
         ",contacts = " + "'" + information.getContacts() + "'" +
         ",contactscell = " + "'" + information.getContactscell() + "'" +
         ",business_License = " + "'" + FtpConstant.ip + businessLicense + "'" +
         ",licence = " + "'" + FtpConstant.ip + licence + "'" +
         " " + "where id = " + "'" + information.getId() + "'";
      FtpUtil.sqlFileUpload(s1);
      return R.success("修改成功");
   }
   /**
@@ -185,13 +279,11 @@
         informationService.deleteIn(strArray[i]);
         informationService.deleteSh(strArray[i]);
         informationService.deleteMe(strArray[i]);
         arg.sendPostRemoveByIds(arg.url + "/information/remove", strArray[i]);
      }
      for (int j = 0; j < strArrays.length; j++) {
         //机构删除
         informationService.deleteDept(strArrays[j]);
         arg.sendPostRemoveByIds(arg.url + "/information/deleteDept", strArrays[j]);
      }
      return R.success("删除成功");
@@ -201,8 +293,8 @@
    * 统计保安员资格异常的数量
    */
   @PostMapping("/selectExtype")
   public R selectExtype(String deptid) {
      List<Map<Object, Object>> lists = informationService.selectExtype(deptid);
   public R selectExtype(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectExtype(deptid,jurisdiction);
      return R.data(lists);
   }
@@ -210,10 +302,11 @@
    * 统计保安员持证的数量
    */
   @PostMapping("/selectHold")
   public R selectHold(String deptid) {
      List<Map<Object, Object>> lists = informationService.selectHold(deptid);
   public R selectHold(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectHold(deptid,jurisdiction);
      return R.data(lists);
   }
   /**
    * 派遣服务单位统计
    */
@@ -227,31 +320,87 @@
    * 保安派遣数量统计
    */
   @PostMapping("/selectDisp")
   public R selectDisp(String deptid) {
      List<Map<Object, Object>> lists = informationService.selectDisp(deptid);
   public R selectDisp(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectDisp(deptid,jurisdiction);
      return R.data(lists);
   }
   /**
    * 保安派遣数量统计
    * 社保统计
    */
   @PostMapping("/selectSoil")
   public R selectSoil(String deptid) {
      List<Map<Object, Object>> lists = informationService.selectSoil(deptid);
   public R selectSoil(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectSoil(deptid,jurisdiction);
      List<Map<String, Object>> list = new ArrayList<>();
      for (int i=0;i<lists.size();i++){
      for (int i = 0; i < lists.size(); i++) {
         Map<String, Object> map = new HashMap<String, Object>();
         String numj = lists.get(i).get("numj").toString();
         Integer a=Integer.valueOf(numj);
         Integer a = Integer.valueOf(numj);
         String numz = lists.get(i).get("numz").toString();
         Integer b=Integer.valueOf(numz);
         Integer c=b-a;
         map.put("numj",a);
         map.put("nmuwj",c);
         Integer b = Integer.valueOf(numz);
         Integer c = b - a;
         map.put("numj", a);
         map.put("nmuwj", c);
         list.add(map);
      }
      return R.data(list);
   }
   /**
    * 导入单位信息
    */
   @PostMapping("import-informaton")
   @ApiOperationSupport(order = 12)
   @ApiOperation(value = "导入单位", notes = "传入excel")
   public R importUser(MultipartFile file, Integer isCovered) {
      InforImporter inforImporter = new InforImporter(informationService, false);
      ExcelUtil.save(file, inforImporter, InforExcel.class);
      return R.success("操作成功");
   }
   /**
    * 查询本年所有月份的客户数量
    *
    * @return
    */
   @PostMapping("/queryYearKh")
   public List queryYearKh(String jurisdiction, String deptid) {
      Calendar cal = Calendar.getInstance();
      String year = String.valueOf(cal.get(Calendar.YEAR));
      List list = informationService.queryYearKh(year, jurisdiction, deptid);
      return list;
   }
   //升序
   public static Map<String, String> sortMapBykeyAsc(Map<String, String> oriMap) {
      Map<String, String> sortedMap = new LinkedHashMap<String, String>();
      try {
         if (oriMap != null && !oriMap.isEmpty()) {
            List<Map.Entry<String, String>> entryList = new ArrayList<Map.Entry<String, String>>(oriMap.entrySet());
            Collections.sort(entryList,
               new Comparator<Map.Entry<String, String>>() {
                  public int compare(Map.Entry<String, String> entry2,
                                 Map.Entry<String, String> entry1) {
                     int value2 = 0, value1 = 0;
                     try {
                        value2 = Integer.parseInt(entry1.getKey());
                        value1 = Integer.parseInt(entry2.getKey());
                     } catch (NumberFormatException e) {
                        value2 = 0;
                        value1 = 0;
                     }
                     return value1 - value2;
                  }
               });
            Iterator<Map.Entry<String, String>> iter = entryList.iterator();
            Map.Entry<String, String> tmpEntry = null;
            while (iter.hasNext()) {
               tmpEntry = iter.next();
               sortedMap.put(tmpEntry.getKey(), tmpEntry.getValue());
            }
         }
      } catch (Exception e) {
      }
      return sortedMap;
   }
}