| | |
| | | tips: 'The import is running, please do not close this tab.', |
| | | err: 'Failed to import this file, please make sure your provided a valid CSV file.', |
| | | download: 'Download Import Template', |
| | | result: 'Contacts import complete. Imported %{success} contacts, with %{error} errors', |
| | | result: 'Contacts import complete. Imported %{success} success, with %{error} errors', |
| | | } |
| | | }, |
| | | }, |
| | |
| | | start_code,end_code,distance,"direction(0:无序,1:正向,2:反向)" |
| | | start_code,end_code,"direction(0:无序,1:正向,2:反向)" |
New file |
| | |
| | | package com.zy.acs.manager.common.domain; |
| | | |
| | | import lombok.Data; |
| | | |
| | | /** |
| | | * Created by vincent on 9/19/2024 |
| | | */ |
| | | @Data |
| | | public class RouteExcel { |
| | | |
| | | private String startCode; |
| | | |
| | | private String endCode; |
| | | |
| | | private Integer direction; |
| | | |
| | | } |
| | |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.zy.acs.common.utils.GsonUtils; |
| | | import com.zy.acs.common.constant.CommonConstant; |
| | | import com.zy.acs.common.utils.Utils; |
| | | import com.zy.acs.framework.common.Cools; |
| | | import com.zy.acs.framework.common.R; |
| | |
| | | import com.zy.acs.manager.common.domain.BaseParam; |
| | | import com.zy.acs.manager.common.domain.KeyValVo; |
| | | import com.zy.acs.manager.common.domain.PageParam; |
| | | import com.zy.acs.manager.common.domain.RouteExcel; |
| | | import com.zy.acs.manager.common.utils.ExcelUtil; |
| | | import com.zy.acs.manager.manager.entity.Code; |
| | | import com.zy.acs.manager.manager.entity.Route; |
| | | import com.zy.acs.manager.manager.service.CodeGapService; |
| | | import com.zy.acs.manager.manager.service.CodeService; |
| | | import com.zy.acs.manager.manager.service.RouteService; |
| | | import com.zy.acs.manager.system.controller.BaseController; |
| | |
| | | private RouteService routeService; |
| | | @Autowired |
| | | private CodeService codeService; |
| | | @Autowired |
| | | private CodeGapService codeGapService; |
| | | |
| | | @PreAuthorize("hasAuthority('manager:route:list')") |
| | | @PostMapping("/route/page") |
| | |
| | | @PreAuthorize("hasAuthority('manager:route:save')") |
| | | @PostMapping("/route/import") |
| | | public R importBatch(@RequestBody List<Map<String, Object>> list) { |
| | | Date now = new Date(); Long userId = getLoginUserId(); |
| | | Long userId = getLoginUserId(); |
| | | String regex = "([a-zA-Z]+)\\("; |
| | | Pattern pattern = Pattern.compile(regex); |
| | | for (Map<String, Object> map : list) { |
| | |
| | | key = Utils.toCamelCase(key); |
| | | one.put(key, entry.getValue()); |
| | | } |
| | | Route route = Cools.conver(one, Route.class); |
| | | System.out.println(GsonUtils.toJson(route)); |
| | | RouteExcel excelDto = Cools.conver(one, RouteExcel.class); |
| | | |
| | | Code code0 = codeService.selectByData(Utils.zeroFill(excelDto.getStartCode(), CommonConstant.QR_CODE_LEN)); |
| | | Code code1 = codeService.selectByData(Utils.zeroFill(excelDto.getEndCode(), CommonConstant.QR_CODE_LEN)); |
| | | |
| | | if (null == code0 || null == code1) { continue; } |
| | | |
| | | routeService.createRouteByCode(code0, code1, excelDto.getDirection(), userId); |
| | | codeGapService.createCodeGapByCode(code0, code1, userId); |
| | | } |
| | | return R.ok(); |
| | | } |
| | |
| | | package com.zy.acs.manager.manager.entity; |
| | | |
| | | import com.baomidou.mybatisplus.annotation.IdType; |
| | | import com.baomidou.mybatisplus.annotation.TableField; |
| | | import com.baomidou.mybatisplus.annotation.TableId; |
| | | import com.baomidou.mybatisplus.annotation.TableName; |
| | | import com.zy.acs.framework.common.SpringUtils; |
| | |
| | | */ |
| | | @ApiModelProperty(value= "备注") |
| | | private String memo; |
| | | |
| | | @TableField(exist = false) |
| | | private Double distance; |
| | | |
| | | public Route() {} |
| | | |
| | |
| | | package com.zy.acs.manager.manager.service; |
| | | |
| | | import com.baomidou.mybatisplus.extension.service.IService; |
| | | import com.zy.acs.manager.manager.entity.Code; |
| | | import com.zy.acs.manager.manager.entity.CodeGap; |
| | | |
| | | public interface CodeGapService extends IService<CodeGap> { |
| | | |
| | | CodeGap createCodeGapByCode(Code code0, Code code1, Long userId); |
| | | |
| | | CodeGap findByCodeOfBoth(Long code0, Long code1); |
| | | |
| | | } |
| | |
| | | |
| | | Route createRouteByCode(Code code0, Code code1); |
| | | |
| | | Route createRouteByCode(Code code0, Code code1, Integer direction, Long userId); |
| | | |
| | | List<String> findCodeDataOfSingle(Long code); |
| | | |
| | | Route findByCodeOfBoth(Long code0, Long code1); |
| | |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.zy.acs.framework.exception.CoolException; |
| | | import com.zy.acs.manager.core.service.MapService; |
| | | import com.zy.acs.manager.manager.entity.Code; |
| | | import com.zy.acs.manager.manager.entity.CodeGap; |
| | | import com.zy.acs.manager.manager.mapper.CodeGapMapper; |
| | | import com.zy.acs.manager.manager.service.CodeGapService; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.util.Date; |
| | | |
| | | @Service("codeGapService") |
| | | public class CodeGapServiceImpl extends ServiceImpl<CodeGapMapper, CodeGap> implements CodeGapService { |
| | | |
| | | @Autowired |
| | | private MapService mapService; |
| | | |
| | | @Override |
| | | public CodeGap createCodeGapByCode(Code code0, Code code1, Long userId) { |
| | | CodeGap codeGap = findByCodeOfBoth(code0.getId(), code1.getId()); |
| | | if (null == codeGap) { |
| | | Date now = new Date(); |
| | | codeGap = new CodeGap(); |
| | | |
| | | codeGap.setCode0(code0.getId()); |
| | | codeGap.setCode1(code1.getId()); |
| | | double distance = mapService.calculateDistance(code0.getX(), code0.getY(), code1.getX(), code1.getY()); |
| | | codeGap.setDistance(distance); |
| | | |
| | | codeGap.setStatus(1); |
| | | codeGap.setCreateBy(userId); |
| | | codeGap.setCreateTime(now); |
| | | codeGap.setUpdateBy(userId); |
| | | codeGap.setUpdateTime(now); |
| | | if (!this.save(codeGap)) { |
| | | throw new CoolException(code0.getData() + "-" + code1.getData() + " save fail![Route]"); |
| | | } |
| | | } |
| | | return codeGap; |
| | | } |
| | | |
| | | @Override |
| | | public CodeGap findByCodeOfBoth(Long code0, Long code1) { |
| | | CodeGap codeGap = getOne(new LambdaQueryWrapper<CodeGap>().eq(CodeGap::getCode0, code0).eq(CodeGap::getCode1, code1)); |
| | |
| | | package com.zy.acs.manager.manager.service.impl; |
| | | |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.zy.acs.manager.common.exception.BusinessException; |
| | | import com.zy.acs.common.utils.GsonUtils; |
| | | import com.zy.acs.framework.exception.CoolException; |
| | | import com.zy.acs.manager.manager.entity.Code; |
| | | import com.zy.acs.manager.manager.entity.Route; |
| | | import com.zy.acs.manager.manager.mapper.RouteMapper; |
| | |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Arrays; |
| | | import java.util.List; |
| | | import java.util.*; |
| | | |
| | | @Service("routeService") |
| | | public class RouteServiceImpl extends ServiceImpl<RouteMapper, Route> implements RouteService { |
| | |
| | | |
| | | @Override |
| | | public Route createRouteByCode(Code code0, Code code1) { |
| | | return createRouteByCode(code0, code1, 0, null); |
| | | } |
| | | |
| | | @Override |
| | | public Route createRouteByCode(Code code0, Code code1, Integer direction, Long userId) { |
| | | Route route = this.findByCodeOfBoth(code0.getId(), code1.getId()); |
| | | direction = Optional.ofNullable(direction).orElse(0); |
| | | if (null == route) { |
| | | Date now = new Date(); |
| | | route = new Route(); |
| | | route.setUuid(code0.getData()+"-"+code1.getData()); |
| | | route.setStartCode(code0.getId()); |
| | | route.setEndCode(code1.getId()); |
| | | route.setDirection(0); |
| | | route.setCodeArr(JSON.toJSONString(Arrays.asList(code0.getId(), code1.getId()))); |
| | | route.setDirection(direction); |
| | | route.setCodeArr(GsonUtils.toJson(Arrays.asList(code0.getId(), code1.getId()))); |
| | | route.setCreateBy(userId); |
| | | route.setCreateTime(now); |
| | | route.setUpdateBy(userId); |
| | | route.setUpdateTime(now); |
| | | if (!this.save(route)) { |
| | | throw new BusinessException(route.getCodeArr()+" save fail![Route]"); |
| | | throw new CoolException(route.getCodeArr()+" save fail![Route]"); |
| | | } |
| | | } |
| | | return route; |