From 184261483e5371c61d43a71598c404da19b7820a Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期四, 23 二月 2023 18:12:21 +0800 Subject: [PATCH] 司机管理完善,佣金管理列表 --- management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java | 129 +++++ management/guns-admin/src/main/resources/application.yml | 24 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/HttpUtils.java | 295 +++++++++++++ management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/RespBody.java | 33 + management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverCommission.html | 61 ++ management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriverCommission.js | 227 ++++++++++ management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriver.js | 6 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TDriverController.java | 132 +++-- management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverArea.html | 23 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/AccessTokenRespBody.java | 38 + management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/Constant.java | 28 + management/guns-admin/pom.xml | 9 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/WxJsonUtils.java | 109 ++++ management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/TokenUtils.java | 53 ++ management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/model/TDriver.java | 22 + management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverAudit.html | 6 management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverDetail.html | 18 management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/config/WxConfig.java | 48 ++ management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/ITDriverService.java | 24 19 files changed, 1,195 insertions(+), 90 deletions(-) diff --git a/management/guns-admin/pom.xml b/management/guns-admin/pom.xml index ebeb9ff..d4f4371 100644 --- a/management/guns-admin/pom.xml +++ b/management/guns-admin/pom.xml @@ -248,6 +248,15 @@ <scope>system</scope> <systemPath>${project.basedir}/lib/proguard.jar</systemPath> </dependency> + <dependency> + <groupId>org.apache.httpcomponents</groupId> + <artifactId>httpmime</artifactId> + <version>4.5.6</version> + </dependency> + <dependency> + <groupId>org.springframework.boot</groupId> + <artifactId>spring-boot-starter-data-redis</artifactId> + </dependency> <!--引入本地工行支付jar end--> </dependencies> diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/config/WxConfig.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/config/WxConfig.java new file mode 100644 index 0000000..182b6cc --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/config/WxConfig.java @@ -0,0 +1,48 @@ +package com.stylefeng.guns.modular.system.config; + + +import com.fasterxml.jackson.annotation.JsonProperty; +import org.springframework.boot.context.properties.ConfigurationProperties; +import org.springframework.stereotype.Component; + +/** + * 项目中需继承此类 + * + * @author lihen + */ +@Component +@ConfigurationProperties(prefix = "wx.conf") +public class WxConfig { + + /** + * 获取 App ID + * + * @return App ID + */ + @JsonProperty("appId") + public String appId; + + /** + * 获取 Secret + * + * @return Secret + */ + @JsonProperty("secret") + public String secret; + + public String getAppId() { + return appId; + } + + public void setAppId(String appId) { + this.appId = appId; + } + + public String getSecret() { + return secret; + } + + public void setSecret(String secret) { + this.secret = secret; + } +} diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TDriverController.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TDriverController.java index 907dfaa..eb37640 100644 --- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TDriverController.java +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/general/TDriverController.java @@ -1,12 +1,12 @@ package com.stylefeng.guns.modular.system.controller.general; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.stylefeng.guns.core.base.controller.BaseController; import com.stylefeng.guns.core.shiro.ShiroKit; import com.stylefeng.guns.core.shiro.ShiroUser; import com.stylefeng.guns.modular.system.controller.resp.TDriverResp; -import com.stylefeng.guns.modular.system.controller.util.ExcelUtil; -import com.stylefeng.guns.modular.system.controller.util.UUIDUtil; +import com.stylefeng.guns.modular.system.controller.util.*; import com.stylefeng.guns.modular.system.model.*; import com.stylefeng.guns.modular.system.service.ITAgentService; import com.stylefeng.guns.modular.system.service.ITBranchOfficeService; @@ -19,6 +19,7 @@ import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.shiro.subject.Subject; import org.springframework.beans.BeanUtils; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Controller; import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.RequestMapping; @@ -31,6 +32,7 @@ import com.stylefeng.guns.modular.system.service.ITDriverService; import javax.servlet.http.HttpServletResponse; +import java.io.File; import java.io.OutputStream; import java.math.BigDecimal; import java.text.DateFormat; @@ -38,6 +40,7 @@ import java.util.Date; import java.util.List; import java.util.Objects; +import java.util.stream.Collectors; /** * 控制器 @@ -62,6 +65,12 @@ @Autowired private ITBranchOfficeService tBranchOfficeService; + @Autowired + private RedisTemplate<String,String> redisTemplate; + @Autowired + private HttpUtils httpUtils; + @Autowired + private TokenUtils tokenUtils; /** * 跳转到首页 @@ -69,6 +78,14 @@ @RequestMapping("") public String index() { return PREFIX + "tDriver.html"; + } + + /** + * 跳转到佣金首页 + */ + @RequestMapping("/commission") + public String commissionIndex() { + return PREFIX + "tDriverCommission.html"; } /** @@ -173,7 +190,7 @@ */ @RequestMapping("/driverDetail") public String driverDetail(Integer tDriverId, Model model) { - tDriverService.detail(tDriverId,model); + tDriverService.auditPage(tDriverId,model); return PREFIX + "tDriverDetail.html"; } @@ -181,9 +198,30 @@ * 跳转区域页面 */ @RequestMapping("/areaPage") - public String areaDetail(Model model) { + public String areaDetail(String area,String areaId,Model model) { List<TRegion> tRegions = tRegionService.selectList(new EntityWrapper<TRegion>().eq("parent_id", 0)); - model.addAttribute("province",tRegions); + model.addAttribute("provinceList",tRegions); + List<Integer> provinceIds = tRegions.stream().map(TRegion::getId).collect(Collectors.toList()); + // 查询市 + List<TRegion> tRegions1 = tRegionService.selectList(new EntityWrapper<TRegion>().in("parent_id", provinceIds)); + model.addAttribute("cityList",tRegions1); + + // 查询区 + List<Integer> cityIds = tRegions1.stream().map(TRegion::getId).collect(Collectors.toList()); + List<TRegion> tRegions2 = tRegionService.selectList(new EntityWrapper<TRegion>().in("parent_id", cityIds)); + model.addAttribute("districtList",tRegions2); + + if(StringUtils.hasLength(area) && StringUtils.hasLength(areaId)){ + String[] split = area.split("/"); + model.addAttribute("provinceName",split[0]); + model.addAttribute("cityName",split[1]); + model.addAttribute("districtName",split[2]); + + String[] split1 = areaId.split("/"); + model.addAttribute("provinceId",split1[0]); + model.addAttribute("cityId",split1[1]); + model.addAttribute("districtId",split1[2]); + } return PREFIX + "tDriverArea.html"; } @@ -194,6 +232,17 @@ @ResponseBody public Object list(String createTime,String phone,Integer status) { EntityWrapper<TDriver> wrapper = tDriverService.getPageList(createTime,phone,status); + wrapper.ne("isException",2); + List<TDriver> tDrivers = tDriverService.selectList(wrapper); + return tDriverService.getTDriverResp(tDrivers); + } + /** + * 获取佣金列表 + */ + @RequestMapping(value = "/commission/list") + @ResponseBody + public Object commissionList(String name,String phone,Integer status) { + EntityWrapper<TDriver> wrapper = tDriverService.getCommissionPageList(name,phone,status); wrapper.ne("isException",2); List<TDriver> tDrivers = tDriverService.selectList(wrapper); return tDriverService.getTDriverResp(tDrivers); @@ -217,6 +266,24 @@ @ResponseBody public Object listBack(String condition) { return tDriverService.selectList(null); + } + /** + * ocr + */ + @RequestMapping(value = "/ocr") + @ResponseBody + public Object ocr(String imgUrl) { + /*String accessToken = redisTemplate.opsForValue().get(TokenUtils.ACCESS_TOKEN_CACHE_KEY); + if (!StringUtils.hasLength(accessToken)) { + accessToken = tokenUtils.getSimpleAccessToken(); + } + File file = new File(imgUrl); + String url = Constant.OCR_URL.replace("MODE", "scan").replace("ACCESS_TOKEN", accessToken); + String result = httpUtils.registRequest(url, file); + JSONObject jsonObject = JSONObject.parseObject(result); + System.err.println(jsonObject); + return jsonObject;*/ + return tDriverService.ocr(imgUrl); } /** @@ -248,51 +315,7 @@ if(count>0){ return "该司机已存在!"; } - - // 对省市区做处理 - String[] split = tDriver.getAreaId().split("/"); - // 查询省市 - // 黑龙江省/大兴安岭地区 - // 702/852 - TRegion province = tRegionService.selectById(split[0]); - tDriver.setProvinceName(province.getName()); - tDriver.setProvinceCode(province.getCode()); - - TRegion city = tRegionService.selectById(split[1]); - tDriver.setCityName(city.getName()); - tDriver.setCityCode(city.getCode()); - - TRegion area = tRegionService.selectById(split[2]); - tDriver.setAreaName(area.getName()); - tDriver.setAreaCode(area.getCode()); - - tDriver.setCode(UUIDUtil.getNumberRandom(16)); - tDriver.setBalance(BigDecimal.ZERO); - tDriver.setBackgroundBalance(BigDecimal.ZERO); - - // 通过省市查询代理商 - TAgent tAgent = tAgentService.selectOne(new EntityWrapper<TAgent>().eq("provinceCode", province.getCode()) - .eq("cityCode", city.getCode()) - .last("LIMIT 1")); - if(Objects.nonNull(tAgent)){ - tDriver.setAgentId(tAgent.getId()); - } - // 查询邀约人(司机端) - TDriver emergencyDriver = tDriverService.selectOne(new EntityWrapper<TDriver>().eq("phone", tDriver.getEmergencyPhone()) - .last("LIMIT 1")); - if(Objects.nonNull(emergencyDriver)){ - tDriver.setInviterId(emergencyDriver.getId()); - tDriver.setInviterType(2); - } - // 通过省市区查询分公司 - TBranchOffice tBranchOffice = tBranchOfficeService.selectOne(new EntityWrapper<TBranchOffice>().eq("provinceCode", province.getCode()) - .eq("cityCode", city.getCode()) - .eq("districtCode", area.getCode()) - .last("LIMIT 1")); - if(Objects.nonNull(tBranchOffice)){ - tDriver.setBranchOfficeId(tBranchOffice.getId()); - } - + tDriverService.addOrUpdate(tDriver); tDriverService.insert(tDriver); return SUCCESS_TIP; } @@ -345,6 +368,9 @@ @RequestMapping(value = "/update") @ResponseBody public Object update(TDriver tDriver) { +// Object ocr = ocr("E:\\071bf986db0b00355c0ed190bbd3b16.png"); +// System.err.println(ocr); + tDriverService.addOrUpdate(tDriver); tDriverService.updateById(tDriver); return SUCCESS_TIP; } @@ -368,8 +394,10 @@ @ApiOperation(value = "市区查询",notes="市区查询") @RequestMapping(value = "/areaCity") @ResponseBody - public Object areaCity(Integer parentId) { - return tRegionService.selectList(new EntityWrapper<TRegion>().eq("parent_id",parentId)); + public Object areaCity(Integer parentId,Model model) { + List<TRegion> tRegions = tRegionService.selectList(new EntityWrapper<TRegion>().eq("parent_id", parentId)); + model.addAttribute("list",tRegions); + return tRegions; } diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/AccessTokenRespBody.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/AccessTokenRespBody.java new file mode 100644 index 0000000..040dec1 --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/AccessTokenRespBody.java @@ -0,0 +1,38 @@ +package com.stylefeng.guns.modular.system.controller.resp; + +import com.fasterxml.jackson.annotation.JsonProperty; + +import java.io.Serializable; + +/** + * 接收accessToken实体 + */ +public class AccessTokenRespBody extends RespBody implements Serializable { + + /** + * 获取到的凭证 + */ + @JsonProperty("access_token") + private String accessToken; + /** + * 凭证有效时间,单位:秒 + */ + @JsonProperty("expires_in") + private int expiresIn; + + public String getAccessToken() { + return accessToken; + } + + public void setAccessToken(String accessToken) { + this.accessToken = accessToken; + } + + public int getExpiresIn() { + return expiresIn; + } + + public void setExpiresIn(int expiresIn) { + this.expiresIn = expiresIn; + } +} \ No newline at end of file diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/RespBody.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/RespBody.java new file mode 100644 index 0000000..4f8c789 --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/resp/RespBody.java @@ -0,0 +1,33 @@ +package com.stylefeng.guns.modular.system.controller.resp; + +import com.fasterxml.jackson.annotation.JsonProperty; + +/** + * @author ck + * @ClassName RespBody + * @Description + * @date 2023-02-23 11:44 + */ +public class RespBody { + @JsonProperty("errcode") + private Integer errorCode; + + @JsonProperty("errmsg") + private String errorMsg; + + public Integer getErrorCode() { + return errorCode; + } + + public void setErrorCode(Integer errorCode) { + this.errorCode = errorCode; + } + + public String getErrorMsg() { + return errorMsg; + } + + public void setErrorMsg(String errorMsg) { + this.errorMsg = errorMsg; + } +} \ No newline at end of file diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/Constant.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/Constant.java new file mode 100644 index 0000000..3cff83b --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/Constant.java @@ -0,0 +1,28 @@ +package com.stylefeng.guns.modular.system.controller.util; + +public class Constant { + + /** + * OCR识别地址 + */ + public static final String OCR_URL = "https://api.weixin.qq.com/cv/ocr/driving?type=MODE&access_token=ACCESS_TOKEN"; + + /** + * 请求参数 + * 属性 类型 默认值 必填 说明 + * grant_type string 是 填写 client_credential + * appid string 是 小程序唯一凭证,即 AppID,可在「微信公众平台 - 设置 - 开发设置」页中获得。(需要已经成为开发者,且帐号没有异常状态) + * secret string 是 小程序唯一凭证密钥,即 AppSecret,获取方式同 appid + * 返回值 + * Object + * 返回的 JSON 数据包 + * <p> + * 属性 类型 说明 + * access_token string 获取到的凭证 + * expires_in number 凭证有效时间,单位:秒。目前是7200秒之内的值。 + * errcode number 错误码 + * errmsg string 错误信息 + */ + public static String ACCESS_TOKEN_URL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}"; + +} diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/HttpUtils.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/HttpUtils.java new file mode 100644 index 0000000..084d76d --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/HttpUtils.java @@ -0,0 +1,295 @@ +package com.stylefeng.guns.modular.system.controller.util; + +import com.google.common.collect.Lists; +import org.apache.http.Consts; +import org.apache.http.HttpEntity; +import org.apache.http.HttpStatus; +import org.apache.http.client.config.RequestConfig; +import org.apache.http.client.entity.UrlEncodedFormEntity; +import org.apache.http.client.methods.CloseableHttpResponse; +import org.apache.http.client.methods.HttpGet; +import org.apache.http.client.methods.HttpPost; +import org.apache.http.client.methods.HttpUriRequest; +import org.apache.http.client.protocol.HttpClientContext; +import org.apache.http.conn.ConnectTimeoutException; +import org.apache.http.entity.ContentType; +import org.apache.http.entity.StringEntity; +import org.apache.http.entity.mime.MultipartEntityBuilder; +import org.apache.http.entity.mime.content.FileBody; +import org.apache.http.entity.mime.content.StringBody; +import org.apache.http.impl.client.CloseableHttpClient; +import org.apache.http.impl.client.HttpClients; +import org.apache.http.impl.conn.PoolingHttpClientConnectionManager; +import org.apache.http.message.BasicNameValuePair; +import org.apache.http.util.EntityUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.stereotype.Component; + +import java.io.*; +import java.net.SocketTimeoutException; +import java.net.URI; +import java.nio.charset.StandardCharsets; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; + +@Component +public class HttpUtils { + + private Logger log = LoggerFactory.getLogger(this.getClass()); + + private final static String KEY = "5cc9622f299335639dbc046f3812c52a"; + + //请求超时时间 + private final static Integer TIME_OUT = 1000; + //http连接池 + private static volatile PoolingHttpClientConnectionManager poolingHttpClientConnectionManager; + //请求配置 + private static RequestConfig requestConfig; + + public static PoolingHttpClientConnectionManager getPoolingHttpClientConnectionManager() { + if (poolingHttpClientConnectionManager == null) { + synchronized (HttpUtils.class) { + if (poolingHttpClientConnectionManager == null) { + poolingHttpClientConnectionManager = new PoolingHttpClientConnectionManager(); + //连接池最大连接数 + poolingHttpClientConnectionManager.setMaxTotal(1024); + //每个路由最大连接数 + poolingHttpClientConnectionManager.setDefaultMaxPerRoute(32); + + //配置请求的超时设置 + requestConfig = + RequestConfig.custom().setConnectionRequestTimeout(TIME_OUT).setConnectTimeout(TIME_OUT).setSocketTimeout(TIME_OUT).build(); + } + } + } + return poolingHttpClientConnectionManager; + } + + public static CloseableHttpClient getHttpClient() { + return HttpClients.custom().setConnectionManager(getPoolingHttpClientConnectionManager()).setDefaultRequestConfig(requestConfig).build(); + } + + /** + * 请求发送执行 + * + * @param httpMethd + * @return + */ + public String registRequest(HttpUriRequest httpMethd) { + CloseableHttpClient httpClient = getHttpClient(); + CloseableHttpResponse httpResponse = null; + try { + httpResponse = httpClient.execute(httpMethd, HttpClientContext.create()); + int statusCode = httpResponse.getStatusLine().getStatusCode(); + if (httpResponse.getStatusLine().getStatusCode() != HttpStatus.SC_OK) { + log.error("响应失败 statusCode {}", statusCode); + httpMethd.abort(); + } + log.debug("响应成功 statusCode {}", statusCode); + String response = EntityUtils.toString(httpResponse.getEntity(), Consts.UTF_8); + log.debug("响应成功 response {}", response); + return response; + } catch (ConnectTimeoutException e) { + throw new RuntimeException("接口超时"); + } catch (SocketTimeoutException e) { + throw new RuntimeException("读取接口数据超时"); + } catch (IOException e) { + throw new RuntimeException("接口请求失败,请尝试检查网络环境或请求接口是否能正常访问"); + } finally { + // 关闭响应 + try { + if (httpResponse != null) { + httpResponse.close(); + } + // 关闭连接 + //httpClient.close(); + } catch (IOException e) { + throw new RuntimeException("关闭流异常:IOException"); + } + } + } + + /** + * 请求发送执行 + * + * @param url + * @return + */ + public String registRequest(String url, File file) { + CloseableHttpClient httpClient = HttpClients.createDefault(); + CloseableHttpResponse httpResponse = null; + try { + HttpPost httpPost = new HttpPost(url); + RequestConfig requestConfig = RequestConfig.custom() + .setSocketTimeout(10000) + .setConnectTimeout(5000) + .build(); + httpPost.setConfig(requestConfig); + HttpEntity entity = MultipartEntityBuilder.create().addPart("img", new FileBody(file)).build(); + httpPost.setEntity(entity); + httpResponse = httpClient.execute(httpPost); + int statusCode = httpResponse.getStatusLine().getStatusCode(); + if (httpResponse.getStatusLine().getStatusCode() != HttpStatus.SC_OK) { + log.error("响应失败 statusCode {}", statusCode); + httpPost.abort(); + } + log.debug("响应成功 statusCode {}", statusCode); + String response = EntityUtils.toString(httpResponse.getEntity(), Consts.UTF_8); + log.debug("响应成功 response {}", response); + return response; + } catch (ConnectTimeoutException e) { + throw new RuntimeException("接口超时"); + } catch (SocketTimeoutException e) { + throw new RuntimeException("读取接口数据超时"); + } catch (IOException e) { + throw new RuntimeException("接口请求失败,请尝试检查网络环境或请求接口是否能正常访问"); + } finally { + // 关闭响应 + try { + if (httpResponse != null) { + httpResponse.close(); + } + // 关闭连接 + httpClient.close(); + } catch (IOException e) { + throw new RuntimeException("关闭流异常:IOException"); + } + } + } + + /** + * + * @param type + * @param file + * @return + * @throws Exception + */ + public String ocr(String type, File file){ + CloseableHttpClient httpClient = HttpClients.createDefault(); + CloseableHttpResponse response = null; + String result = null; + // HttpClient请求的相关设置,可以不用配置,用默认的参数,这里设置连接和超时时长(毫秒) + RequestConfig config = RequestConfig.custom().setConnectTimeout(30000).setSocketTimeout(30000).build(); + try { + HttpPost httppost = new HttpPost("http://v.juhe.cn/certificates/query"); + // FileBody封装File类型的参数 + FileBody bin = new FileBody(file); + // StringBody封装String类型的参数 + StringBody keyBody = new StringBody(KEY, ContentType.TEXT_PLAIN); + StringBody typeBody = new StringBody(type, ContentType.TEXT_PLAIN); + // addPart将参数传入,并指定参数名称 + HttpEntity reqEntity = MultipartEntityBuilder.create() + .addPart("pic", bin).addPart("key", keyBody) + .addPart("cardType", typeBody).build(); + httppost.setEntity(reqEntity); + httppost.setConfig(config); + // 执行网络请求并返回结果 + response = httpClient.execute(httppost); + HttpEntity resEntity = response.getEntity(); + if (resEntity != null) { + result = ConvertStreamToString(resEntity.getContent(), "UTF-8"); + } + EntityUtils.consume(resEntity); + } catch (Exception e) { + throw new RuntimeException("接口请求失败,请尝试检查网络环境或请求接口是否能正常访问"+":"+e); + } finally { + try { + response.close(); + httpClient.close(); + } catch (IOException e) { + throw new RuntimeException("流关闭失败!"+":"+e); + } + } + // 得到的是JSON类型的数据需要第三方解析JSON的jar包来解析 + return result; + } + + // 此方法是把传进的字节流转化为相应的字符串并返回,此方法一般在网络请求中用到 + public static String ConvertStreamToString(InputStream is, String charset) + throws Exception { + StringBuilder sb = new StringBuilder(); + try (InputStreamReader inputStreamReader = new InputStreamReader(is,charset)) { + try (BufferedReader reader = new BufferedReader(inputStreamReader)) { + String line = null; + while ((line = reader.readLine()) != null) { + sb.append(line).append("\r\n"); + } + } + } + return sb.toString(); + } + + public List<BasicNameValuePair> toPairs(Map<String, Object> params) { + List<BasicNameValuePair> pairs = Lists.newArrayList(); + if (params != null && !params.isEmpty()) { + pairs = params.entrySet().stream().map(entry -> new BasicNameValuePair(entry.getKey(), + entry.getValue().toString())).collect(Collectors.toList()); + } + return pairs; + } + + /** + * get url请求 + * + * @param url + * @return + */ + public String get(String url) { + HttpGet request = new HttpGet(); + try { + request.setURI(new URI(url)); + return registRequest(request); + } catch (Exception e) { + log.error("请求失败", e); + } + return null; + } + + /** + * PSOT URL方式提交 + * + * @param url 请求url + * @param params 请求参数 + * @return + */ + public String postFromUrl(String url, Map<String, Object> params) { + HttpPost request = new HttpPost(url); + RequestConfig requestConfig = RequestConfig.custom() + .setSocketTimeout(10000) + .setConnectTimeout(5000) + .build(); + request.setConfig(requestConfig); + request.setEntity(new UrlEncodedFormEntity(toPairs(params), Consts.UTF_8)); + return registRequest(request); + } + + /** + * PSOT JSON方式提交 + * + * @param url 请求url + * @param params json串 + * @return + */ + public String postFromJson(String url, String params) { + HttpPost request = new HttpPost(url); + request.setHeader("Content-type", "application/json"); + request.setHeader("Accept", "application/json"); + RequestConfig requestConfig = RequestConfig.custom() + .setSocketTimeout(8000) + .setConnectTimeout(6000) + .build(); + request.setConfig(requestConfig); + StringEntity entity = new StringEntity(params, StandardCharsets.UTF_8); + entity.setContentType("application/json"); + request.setEntity(entity); + try { + return registRequest(request); + } catch (Exception e) { + log.error("请求失败", e); + } + return null; + } +} + diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/TokenUtils.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/TokenUtils.java new file mode 100644 index 0000000..cf18ad9 --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/TokenUtils.java @@ -0,0 +1,53 @@ +package com.stylefeng.guns.modular.system.controller.util; + +import com.stylefeng.guns.modular.system.config.WxConfig; +import com.stylefeng.guns.modular.system.controller.resp.AccessTokenRespBody; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisTemplate; +import org.springframework.stereotype.Component; +import org.springframework.util.StringUtils; +import org.springframework.web.client.RestTemplate; + +import java.text.MessageFormat; +import java.util.concurrent.TimeUnit; + +/** + * @Description + * @Author xiaochen + * @Date 2021/11/5/00519:26 + */ +@Component +public class TokenUtils { + public final static String ACCESS_TOKEN_CACHE_KEY = "accessToken"; + @Autowired + private RedisTemplate<String, String> redisTemplate; + @Autowired + private WxConfig wxConfig; + @Autowired + private RestTemplate wxRestTemplate; + @Autowired + private WxJsonUtils wxJsonUtils; +// @Autowired +// private RedisUtils redisUtils; + + /** + * @return + */ + public String getSimpleAccessToken() { + String accessToken = redisTemplate.opsForValue().get(ACCESS_TOKEN_CACHE_KEY); + if (StringUtils.hasLength(accessToken)) { + return accessToken; + } + String requestUrl = MessageFormat.format(Constant.ACCESS_TOKEN_URL, wxConfig.getAppId(), wxConfig.getSecret()); + String respBody = wxRestTemplate.getForEntity(requestUrl, String.class).getBody(); + AccessTokenRespBody accessTokenRespBody = wxJsonUtils.parseObject(respBody, AccessTokenRespBody.class); + // 判断有误异常 + if (StringUtils.hasLength(accessTokenRespBody.getErrorMsg())) { + // 抛出错误 + throw new RuntimeException(accessTokenRespBody.getErrorCode() + ":" + accessTokenRespBody.getErrorMsg()); + } + redisTemplate.opsForValue().set(ACCESS_TOKEN_CACHE_KEY, accessTokenRespBody.getAccessToken(), 2, TimeUnit.HOURS); + return accessTokenRespBody.getAccessToken(); + } + +} diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/WxJsonUtils.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/WxJsonUtils.java new file mode 100644 index 0000000..3d170f8 --- /dev/null +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/controller/util/WxJsonUtils.java @@ -0,0 +1,109 @@ +package com.stylefeng.guns.modular.system.controller.util; + +import com.fasterxml.jackson.core.JsonGenerator; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.core.type.TypeReference; +import com.fasterxml.jackson.databind.DeserializationFeature; +import com.fasterxml.jackson.databind.JsonSerializer; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.SerializerProvider; +import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; +import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateDeserializer; +import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.stereotype.Component; + +import java.io.IOException; +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; + +@Component +public final class WxJsonUtils { + + private Logger log = LoggerFactory.getLogger(this.getClass()); + + public static final String dateFormat = "yyyy-MM-dd"; + public static final String dateTimeFormat = "yyyy-MM-dd HH:mm:ss"; + private static final ObjectMapper OM = new ObjectMapper(); + private static final JavaTimeModule timeModule = new JavaTimeModule(); + + /** + * 转换LocalDateTime + */ + static class LocalDateTimeSerializer extends JsonSerializer<LocalDateTime> { + @Override + public void serialize(LocalDateTime localDateTime, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException { + jsonGenerator.writeString(localDateTime.format(DateTimeFormatter.ofPattern(dateTimeFormat))); + } + } + + /** + * 转换LocalDate + */ + static class LocalDateSerializer extends JsonSerializer<LocalDate> { + @Override + public void serialize(LocalDate localDate, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException { + jsonGenerator.writeString(localDate.format(DateTimeFormatter.ofPattern(dateFormat))); + } + } + + /** + * 设置 ObjectMapper + * + * @return + */ + private ObjectMapper getObjectMapper() { + // 序列化 + timeModule.addSerializer(LocalDateTime.class, new LocalDateTimeSerializer()); + timeModule.addSerializer(LocalDate.class, new LocalDateSerializer()); + // 反序列化 + timeModule.addDeserializer(LocalDateTime.class, + new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(dateTimeFormat))); + timeModule.addDeserializer(LocalDate.class, + new LocalDateDeserializer(DateTimeFormatter.ofPattern(dateFormat))); + // 允许对象忽略json中不存在的属性 + OM.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); + OM.registerModule(timeModule); + return OM; + } + + /** + * 将对象序列化 + */ + public <T> String toJsonString(T obj) { + try { + ObjectMapper om = getObjectMapper(); + return om.writeValueAsString(obj); + } catch (JsonProcessingException e) { + log.error("转json字符串失败:{}", obj); + return null; + } + } + + /** + * 反序列化对象字符串 + */ + public <T> T parseObject(String json, Class<T> clazz) { + try { + ObjectMapper om = getObjectMapper(); + return om.readValue(json, clazz); + } catch (IOException e) { + throw new RuntimeException("反序列化对象字符串失败"); + } + } + + /** + * 反序列化字符串成为对象 + */ + public <T> T parseObject(String json, TypeReference<T> valueTypeRef) { + try { + ObjectMapper om = getObjectMapper(); + return om.readValue(json, valueTypeRef); + } catch (IOException e) { + throw new RuntimeException("反序列化字符串成为对象失败"); + } + } + +} diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/model/TDriver.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/model/TDriver.java index fdb2968..53dbfca 100644 --- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/model/TDriver.java +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/model/TDriver.java @@ -131,6 +131,10 @@ */ private Integer integral; /** + * 剩余积分 + */ + private Double score; + /** * 状态(1=正常,2=冻结,3=删除) */ private Integer status; @@ -165,6 +169,8 @@ @ApiModelProperty(value = "驾驶证初次领证时间") private Date firstCertificateTime; + @ApiModelProperty(value = "佣金") + private BigDecimal commission; @TableField(exist = false) @ApiModelProperty(value = "区域") @@ -174,6 +180,22 @@ @ApiModelProperty(value = "区域id") private String areaId; + public BigDecimal getCommission() { + return commission; + } + + public void setCommission(BigDecimal commission) { + this.commission = commission; + } + + public Double getScore() { + return score; + } + + public void setScore(Double score) { + this.score = score; + } + public String getArea() { return area; } diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/ITDriverService.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/ITDriverService.java index 0da500f..8da146e 100644 --- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/ITDriverService.java +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/ITDriverService.java @@ -1,5 +1,6 @@ package com.stylefeng.guns.modular.system.service; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.stylefeng.guns.modular.system.controller.resp.TDriverResp; import com.stylefeng.guns.modular.system.model.TDriver; @@ -42,10 +43,25 @@ void auditPage(Integer id, Model model); /** - * 跳转详情页面 - * @param tDriverId - * @param model + * 聚合ocr识别 + * @param imgUrl + * @return */ - void detail(Integer tDriverId, Model model); + JSONObject ocr(String imgUrl); + + /** + * 新增修改处理数据 + * @param tDriver + */ + void addOrUpdate(TDriver tDriver); + + /** + * 查询佣金列表 + * @param name + * @param phone + * @param status + * @return + */ + EntityWrapper<TDriver> getCommissionPageList(String name, String phone, Integer status); } diff --git a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java index 65a23b0..a3d2fd9 100644 --- a/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java +++ b/management/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/TDriverServiceImpl.java @@ -1,13 +1,17 @@ package com.stylefeng.guns.modular.system.service.impl; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.stylefeng.guns.core.util.DateUtil; import com.stylefeng.guns.modular.system.controller.resp.TDriverResp; +import com.stylefeng.guns.modular.system.controller.util.HttpUtils; +import com.stylefeng.guns.modular.system.controller.util.UUIDUtil; import com.stylefeng.guns.modular.system.dao.*; import com.stylefeng.guns.modular.system.enums.OrderStateEnum; import com.stylefeng.guns.modular.system.model.*; import com.stylefeng.guns.modular.system.service.ITDriverService; import com.baomidou.mybatisplus.service.impl.ServiceImpl; +import com.stylefeng.guns.modular.system.service.ITRegionService; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -15,6 +19,8 @@ import org.springframework.util.CollectionUtils; import org.springframework.util.StringUtils; +import java.io.File; +import java.math.BigDecimal; import java.text.SimpleDateFormat; import java.time.LocalDate; import java.time.Period; @@ -49,6 +55,12 @@ private TAppUserMapper tAppUserMapper; @Autowired private TOrderRefusalMapper tOrderRefusalMapper; + @Autowired + private TRegionMapper tRegionMapper; + @Autowired + private ITRegionService itRegionService; + @Autowired + private HttpUtils httpUtils; @Override public EntityWrapper<TDriver> getPageList(String createTime, String phone, Integer status) { @@ -123,6 +135,7 @@ model.addAttribute("id",tDriver.getId()); model.addAttribute("code",tDriver.getCode()); model.addAttribute("name",tDriver.getName()); + model.addAttribute("avatar",tDriver.getAvatar()); model.addAttribute("phone",tDriver.getPhone()); model.addAttribute("sex",tDriver.getSex()); model.addAttribute("driverLicenseNumber",tDriver.getDriverLicenseNumber()); @@ -135,6 +148,8 @@ model.addAttribute("provinceName",tDriver.getProvinceName()); model.addAttribute("cityName",tDriver.getCityName()); model.addAttribute("areaName",tDriver.getAreaName()); + model.addAttribute("integral",tDriver.getIntegral()); + model.addAttribute("score",tDriver.getScore()); model.addAttribute("createTime",new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(tDriver.getCreateTime())); // 计算驾龄 @@ -152,8 +167,13 @@ String monthDate = new SimpleDateFormat("yyyyMM").format(new Date()); - // 设置余额 - tDriver.setBalance(tDriver.getBackgroundBalance().add(tDriver.getBalance())); + if(Objects.nonNull(tDriver.getBackgroundBalance()) && Objects.nonNull(tDriver.getBalance())){ + // 设置余额 + tDriver.setBalance(tDriver.getBackgroundBalance().add(tDriver.getBalance())); + model.addAttribute("balance",tDriver.getBalance()); + }else { + model.addAttribute("balance",BigDecimal.ZERO); + } // 所属代理商 TAgent tAgent = tAgentMapper.selectById(tDriver.getAgentId()); @@ -184,6 +204,16 @@ model.addAttribute("inviterPhone",""); } + // 查询当前用户邀请了哪些人 + List<TDriver> list = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("inviterId", tDriver.getId())); + if(!CollectionUtils.isEmpty(list)){ + model.addAttribute("inviterCount",list.size()); + model.addAttribute("inviterCommission",0); + }else { + model.addAttribute("inviterCommission",0); + model.addAttribute("inviterCount",0); + } + if(!CollectionUtils.isEmpty(tOrders)){ //累计订单量 List<TOrder> cumulativeOrderCount = tOrders.stream().filter(order -> order.getDriverId().equals(tDriver.getId()) @@ -197,17 +227,98 @@ // 拒单次数 List<TOrderRefusal> driverRefusalList = tOrderRefusalMapper.selectList(new EntityWrapper<TOrderRefusal>().eq("driver_id", tDriver.getId())); model.addAttribute("refusalCount",driverRefusalList.size()); + // todo 累计收入 + model.addAttribute("cumulativeIncome",0); }else { - model.addAttribute("cumulativeOrderCount",""); - model.addAttribute("monthOrderCount",""); - model.addAttribute("refusalCount",""); + model.addAttribute("cumulativeOrderCount",0); + model.addAttribute("monthOrderCount",0); + model.addAttribute("refusalCount",0); + // 累计收入 + model.addAttribute("cumulativeIncome",0); } } @Override - public void detail(Integer tDriverId, Model model) { - auditPage(tDriverId,model); - // TODO 查询司机 - TDriver tDriver = tDriverMapper.selectById(tDriverId); + public JSONObject ocr(String imgUrl) { + File file = new File(imgUrl); + String result = httpUtils.ocr("2", file); + JSONObject jsonObject = JSONObject.parseObject(result); + return jsonObject; + } + + @Override + public void addOrUpdate(TDriver tDriver) { + // 对省市区做处理 + String[] split = tDriver.getAreaId().split("/"); + // 查询省市 + // 黑龙江省/大兴安岭地区 + // 702/852 + TRegion province = tRegionMapper.selectById(split[0]); + tDriver.setProvinceName(province.getName()); + tDriver.setProvinceCode(province.getCode()); + + TRegion city = tRegionMapper.selectById(split[1]); + if(Objects.isNull(city)){ + city = itRegionService.selectOne(new EntityWrapper<TRegion>().eq("name",split[1])); + } + tDriver.setCityName(city.getName()); + tDriver.setCityCode(city.getCode()); + + TRegion area = tRegionMapper.selectById(split[2]); + if(Objects.isNull(area)){ + area = itRegionService.selectOne(new EntityWrapper<TRegion>().eq("name",split[2])); + } + tDriver.setAreaName(area.getName()); + tDriver.setAreaCode(area.getCode()); + + tDriver.setCode(UUIDUtil.getNumberRandom(16)); + tDriver.setBalance(BigDecimal.ZERO); + tDriver.setBackgroundBalance(BigDecimal.ZERO); + + // 通过省市查询代理商 + List<TAgent> tAgent = tAgentMapper.selectList(new EntityWrapper<TAgent>().eq("provinceCode", province.getCode()) + .eq("cityCode", city.getCode()) + .last("LIMIT 1")); + if(!CollectionUtils.isEmpty(tAgent)){ + tDriver.setAgentId(tAgent.get(0).getId()); + } + // 查询邀约人(司机端) + List<TDriver> emergencyDriver = tDriverMapper.selectList(new EntityWrapper<TDriver>().eq("phone", tDriver.getEmergencyPhone()) + .last("LIMIT 1")); + if(!CollectionUtils.isEmpty(emergencyDriver)){ + tDriver.setInviterId(emergencyDriver.get(0).getId()); + tDriver.setInviterType(2); + } + // 通过省市区查询分公司 + List<TBranchOffice> tBranchOffice = tBranchOfficeMapper.selectList(new EntityWrapper<TBranchOffice>().eq("provinceCode", province.getCode()) + .eq("cityCode", city.getCode()) + .eq("districtCode", area.getCode()) + .last("LIMIT 1")); + if(!CollectionUtils.isEmpty(tBranchOffice)){ + tDriver.setBranchOfficeId(tBranchOffice.get(0).getId()); + } + + // ocr识别 +// JSONObject ocr = this.ocr("E:\\071bf986db0b00355c0ed190bbd3b16.png"); +// System.err.println(ocr); + } + + @Override + public EntityWrapper<TDriver> getCommissionPageList(String name, String phone, Integer status) { + EntityWrapper<TDriver> wrapper = new EntityWrapper<>(); + // 手机号 + if(StringUtils.hasLength(phone)){ + wrapper.like("phone",phone); + } + // 状态 + if(Objects.nonNull(status)){ + wrapper.eq("status",status); + } + // 姓名 + if(StringUtils.hasLength(name)){ + wrapper.like("name",name); + } + wrapper.orderBy(true,"approvalStatus"); + return wrapper; } } diff --git a/management/guns-admin/src/main/resources/application.yml b/management/guns-admin/src/main/resources/application.yml index f4ab612..abbfe9c 100644 --- a/management/guns-admin/src/main/resources/application.yml +++ b/management/guns-admin/src/main/resources/application.yml @@ -16,12 +16,12 @@ spring: profiles: active: local - datasource: - url: jdbc:mysql://192.168.0.80:3306/super_save_driving?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=GMT%2B8 - username: root - password: 123456 - db-name: super_save_driving #用来搜集数据库的所有表 - filters: wall,mergeStat +# datasource: +# url: jdbc:mysql://192.168.0.80:3306/super_save_driving?autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=GMT%2B8 +# username: root +# password: 123456 +# db-name: super_save_driving #用来搜集数据库的所有表 +# filters: wall,mergeStat mvc: static-path-pattern: /static/** view: @@ -35,6 +35,12 @@ multipart: max-request-size: 100MB max-file-size: 100MB + redis: + #测试环境 + host: 127.0.0.1 + port: 6379 + timeout: 5000 + database: 10 mybatis-plus: type-aliases-package: com.stylefeng.guns.modular.system.model @@ -44,8 +50,10 @@ configuration: configuration.map-underscore-to-camel-case: true #是否开启自动驼峰命名规则(camel case)映射 log-impl: org.apache.ibatis.logging.slf4j.Slf4jImpl #输出Sql,如需打印Sql注释该配置 - - +wx: + conf: + appId: wx3613e8d4c8624ea1 + secret: 25782eabe39e796a92d2fcb38947e7dc #eureka: # client: diff --git a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverArea.html b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverArea.html index 11100a6..2876b71 100644 --- a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverArea.html +++ b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverArea.html @@ -5,25 +5,38 @@ <div class="ibox-content"> <div class="row row-lg"> <div class="col-sm-12" style="height: 100px;"> + <input hidden id="provinceName" value="${provinceName}"> + <input hidden id="cityName" value="${cityName}"> + <input hidden id="districtName" value="${districtName}"> + <input hidden id="provinceId" value="${provinceId}"> + <input hidden id="cityId" value="${cityId}"> + <input hidden id="districtId" value="${districtId}"> + <div class="col-sm-4 control-label"> <label class="col-sm-1" style="width: 20px;">省:</label> <select class="input-group col-sm-2 " onclick="TDriver.areaCity()" id="province" style="width: 200px;height: 33px" name="province"> <option value="">请选择省</option> - @for(i in province){ - <option id="${i.id}" value="${i.name}">${i.name}</option> + @for(i in provinceList){ + <option id="${i.id}" value="${i.name}"${i.name == provinceName ? 'selected=selected' : ''}>${i.name}</option> @} </select> </div> <div class="col-sm-4 control-label"> <label class="col-sm-1" style="width: 20px;">市:</label> <select class="input-group col-sm-2" onclick="TDriver.areaDistrict()" id="city" style="width: 200px;height: 33px" name="city"> - <option value="">请选择市</option> + <option>请选择市</option> + @for(city in cityList){ + <option id="${city.id}" value="${city.name}"${city.name == cityName ? 'selected=selected' : ''}>${city.name}</option> + @} </select> </div> <div class="col-sm-4 control-label"> <label class="col-sm-1" style="width: 20px;">区:</label> <select class="input-group col-sm-2" id="district" style="width: 200px;height: 33px" name="district"> - <option value="">请选择区</option> + <option>请选择区</option> + @for(district in districtList){ + <option id="${district.id}" value="${district.name}"${district.name == districtName ? 'selected=selected' : ''}>${district.name}</option> + @} </select> </div> </div> @@ -39,4 +52,6 @@ </div> <script src="${ctxPath}/static/modular/system/tDriver/tDriver.js"></script> <script src="${ctxPath}/static/modular/system/tDriver/tDriver_info.js"></script> +<script type="text/javascript"> +</script> @} diff --git a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverAudit.html b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverAudit.html index 161689d..64a22d6 100644 --- a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverAudit.html +++ b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverAudit.html @@ -25,7 +25,7 @@ </div> <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label">头像:</label> - <img src="https://lmg.jj20.com/up/allimg/1114/040221103339/210402103339-7-1200.jpg" /> + <img src="${avatar}" style="height: 100px;width: 100px"/> </div> <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label">紧急联系人:</label> @@ -89,11 +89,11 @@ <div class="initialLevel col-sm-12 control-label form-group" > <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >驾驶证照片:</label> - <img src="https://lmg.jj20.com/up/allimg/1114/040221103339/210402103339-7-1200.jpg" /> + <img src="${driverLicense}" style="height: 100px;width: 100px"/> </div> <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label">身份证照片:</label> - <img src="https://lmg.jj20.com/up/allimg/1114/040221103339/210402103339-7-1200.jpg" /> + <img src="${idcardFront}" style="height: 100px;width: 100px"/> </div> </div> diff --git a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverCommission.html b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverCommission.html new file mode 100644 index 0000000..5fb163e --- /dev/null +++ b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverCommission.html @@ -0,0 +1,61 @@ +@layout("/common/_container.html"){ +<div class="row"> + <div class="col-sm-12"> + <div class="ibox float-e-margins"> + <div class="ibox-title"> + <h5>管理</h5> + </div> + <div class="ibox-content"> + <div class="row row-lg"> + <div class="col-sm-12"> + <div class="row"> + <div class="col-sm-3"> + <#NameCon id="phone" name="手机号" /> + </div> + <div class="col-sm-3"> + <#NameCon id="name" name="司机姓名" /> + </div> + <div class="col-sm-1"> + <select class="input-group" id="status" style="width: 80px;height: 33px" name="status"> + <option value="">状态</option> + <option value="1">正常</option> + <option value="2">冻结</option> + </select> + </div> + <div class="col-sm-3"> + <#button name="搜索" icon="fa-search" clickFun="TDriverCommission.search()"/> + <#button name="重置" icon="fa-trash" clickFun="TDriverCommission.resetSearch()" space="true"/> + </div> + <div class="col-sm-3"> + <button type="button" class="btn btn-primary " onclick="TDriverCommission.export()" id="export"> + <i class="fa "></i> 导出 + </button> + </div> + </div> + <!--<div class="hidden-xs" id="TDriverTableToolbar" role="group"> + @if(shiro.hasPermission("/tDriver/add")){ + <#button name="添加" icon="fa-plus" clickFun="TDriver.openAddTDriver()"/> + @} + @if(shiro.hasPermission("/tDriver/update")){ + <#button name="修改" icon="fa-edit" clickFun="TDriver.openTDriverDetail()" space="true"/> + @} + @if(shiro.hasPermission("/tDriver/delete")){ + <#button name="删除" icon="fa-remove" clickFun="TDriver.delete()" space="true"/> + @} + </div>--> + <#table id="TDriverCommissionTable"/> + </div> + </div> + </div> + </div> + </div> +</div> +<script src="${ctxPath}/static/modular/system/tDriver/tDriverCommission.js"></script> +<script type="text/javascript"> + laydate.render({ + elem: '#createTime', + type: 'date', + range: true + }); +</script> +@} diff --git a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverDetail.html b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverDetail.html index 5e45363..d77e2c5 100644 --- a/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverDetail.html +++ b/management/guns-admin/src/main/webapp/WEB-INF/view/system/tDriver/tDriverDetail.html @@ -66,7 +66,7 @@ <div class="initialLevel col-sm-12 control-label form-group" > <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >身份证正面照:</label> - <img id="" src="${idcardFront}" style="height: 100px;width: 100px"/> + <img src="${idcardFront}" style="height: 100px;width: 100px"/> </div> <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label">身份证背面照:</label> @@ -96,38 +96,38 @@ <div class="initialLevel col-sm-12 control-label form-group" > <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label" >累计订单:</label> - <label>${name}</label> + <label>${cumulativeOrderCount}</label> </div> <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >邀约用户人数:</label> - <label>${idcard}</label> + <label>${inviterCount}</label> </div> <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >累计获得佣金:</label> - <label>${idcard}</label> + <label>${inviterCommission}</label> </div> <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label" >当前积分:</label> - <label>${idcard}</label> + <label>${integral}</label> </div> <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label" >代驾次数:</label> - <label>${idcard}</label> + <label>${cumulativeOrderCount}</label> </div> </div> <div class="initialLevel col-sm-12 control-label form-group" > <div class="initialLevel col-sm-2 control-label form-group" > <label class="control-label" >累计获得收入:</label> - <label>${name}</label> + <label>${cumulativeIncome}</label> </div> <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >钱包余额:</label> - <label>${idcard}</label> + <label>${balance}</label> </div> <div class="initialLevel col-sm-3 control-label form-group" > <label class="control-label" >评论分数:</label> - <label>${idcard}</label> + <label>${score}</label> </div> </div> diff --git a/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriver.js b/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriver.js index 6be84db..84ef40e 100644 --- a/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriver.js +++ b/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriver.js @@ -305,13 +305,17 @@ * 打开区域选择页面 */ TDriver.area = function () { + + var area = $("#area").val(); + var areaId = $("#areaId").val(); + var index = layer.open({ type: 2, title: '区域选择', area: ['1000px', '270px'], //宽高 fix: false, //不固定 maxmin: true, - content: Feng.ctxPath + '/tDriver/areaPage' + content: Feng.ctxPath + '/tDriver/areaPage?area='+area+'&areaId='+areaId }); this.layerIndex = index; } diff --git a/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriverCommission.js b/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriverCommission.js new file mode 100644 index 0000000..ac01992 --- /dev/null +++ b/management/guns-admin/src/main/webapp/static/modular/system/tDriver/tDriverCommission.js @@ -0,0 +1,227 @@ +/** + * 管理初始化 + */ +var TDriverCommission = { + id: "TDriverCommissionTable", //表格id + seItem: null, //选中的条目 + table: null, + layerIndex: -1 +}; + +/** + * 初始化表格的列 + */ +TDriverCommission.initColumn = function () { + return [ + {field: 'selectItem', radio: true}, + {title: '主键', field: 'id', visible: false, align: 'center', valign: 'middle'}, + {title: '姓名', field: 'name', visible: true, align: 'center', valign: 'middle'}, + {title: '手机号', field: 'phone', visible: true, align: 'center', valign: 'middle'}, + {title: '所属代理商', field: 'agentName', visible: true, align: 'center', valign: 'middle'}, + {title: '性别', field: 'sex', visible: false, align: 'center', valign: 'middle', + formatter: function (value, row) { + if (row.sex === 1){ + return '<span>男</span>' + }else if (row.sex === 2){ + return '<span>女</span>' + }else { + return '<span>未知</span>' + } + }}, + {title: '推广人数', field: 'cumulativeOrderCount', visible: true, align: 'center', valign: 'middle'}, + {title: '关联人数', field: 'cumulativeOrderCount', visible: true, align: 'center', valign: 'middle'}, + {title: '累计获得佣金', field: 'cumulativeOrderCount', visible: true, align: 'center', valign: 'middle'}, + {title: '可提现佣金', field: 'monthOrderCount', visible: true, align: 'center', valign: 'middle'}, + {title: '已提现金额', field: 'integral', visible: true, align: 'center', valign: 'middle'}, + {title: '状态', field: 'status', visible: true, align: 'center', valign: 'middle', + formatter: function (value, row) { + if (row.status === 1){ + return '<span>正常</span>' + }else if (row.status === 2){ + return '<span>冻结</span>' + }else if (row.status === 3){ + return '<span>已删除</span>' + } + }}, + {title: '操作', visible: true, align: 'center', valign: 'middle',width:150, + formatter: function (value, row) { + if (row.status === 1){ + return '<a href="#" onclick="TDriverCommission.searchTDriverDetail('+row.id+')" style="color:green">详情</a>' + }else if (row.status === 2){ + return '<a href="#" onclick="TDriverCommission.searchTDriverDetail('+row.id+')" style="color:green">详情</a>' + } + } + } + ]; +}; + +/** + * 检查是否选中 + */ +TDriverCommission.check = function () { + var selected = $('#' + this.id).bootstrapTable('getSelections'); + if(selected.length == 0){ + Feng.info("请先选中表格中的某一记录!"); + return false; + }else{ + TDriverCommission.seItem = selected[0]; + return true; + } +}; + +/** + * 点击添加 + */ +TDriverCommission.openAddTDriver = function () { + var index = layer.open({ + type: 2, + title: '添加', + area: ['100%', '100%'], //宽高 + fix: false, //不固定 + maxmin: true, + content: Feng.ctxPath + '/tDriver/tDriver_add' + }); + this.layerIndex = index; +}; + +/** + * 打开查看详情 + */ +TDriverCommission.openTDriverDetail = function () { + if (this.check()) { + var index = layer.open({ + type: 2, + title: '详情', + area: ['100%', '100%'], //宽高 + fix: false, //不固定 + maxmin: true, + content: Feng.ctxPath + '/tDriver/tDriver_update/' + TDriver.seItem.id + }); + this.layerIndex = index; + } +}; + +/** + * 打开查看详情(使用中) + */ +TDriverCommission.searchTDriverDetail = function (id) { + var index = layer.open({ + type: 2, + title: '详情', + area: ['100%', '100%'], //宽高 + fix: false, //不固定 + maxmin: true, + content: Feng.ctxPath + '/tDriver/driverDetail?tDriverId=' + id + }); + this.layerIndex = index; +}; + +/** + * 删除 + */ +TDriverCommission.delete = function () { + if (this.check()) { + var ajax = new $ax(Feng.ctxPath + "/tDriver/delete", function (data) { + Feng.success("删除成功!"); + TDriverCommission.table.refresh(); + }, function (data) { + Feng.error("删除失败!" + data.responseJSON.message + "!"); + }); + ajax.set("tDriverId",this.seItem.id); + ajax.start(); + } +}; + +/** + * 停用页面 + */ +TDriverCommission.stop = function (id) { + var index = layer.open({ + type: 2, + title: '停用', + area: ['45%', '50%'], //宽高 + fix: false, //不固定 + maxmin: true, + content: Feng.ctxPath + '/tDriver/tDriver_start_and_stop?id='+id + }); + this.layerIndex = index; +}; + +/** + * 启动页面 + */ +TDriverCommission.start = function (id) { + var index = layer.open({ + type: 2, + title: '启用', + area: ['45%', '50%'], //宽高 + fix: false, //不固定 + maxmin: true, + content: Feng.ctxPath + '/tDriver/tDriver_start_and_stop?id='+id + }); + this.layerIndex = index; +}; + +/** + * 提交启用冻结 + */ +TDriverCommission.updateStatus = function () { + var ajax = new $ax(Feng.ctxPath + "/tDriver/update-status", function (data) { + Feng.success("修改成功!"); + TDriverInfoDlg.close(); + parent.TDriverCommission.table.refresh(); + }, function (data) { + Feng.error("修改失败!" + data.responseJSON.message + "!"); + }); + ajax.set("id",$("#id").val()); + ajax.set("status",$("#status").val()); + if($("#status").val() == 1){ + ajax.set("remark",$("#stopRemark").val()); + } + if($("#status").val() == 2){ + ajax.set("remark",$("#startRemark").val()); + } + ajax.start(); +}; + +/** + * 司机信息导出 + */ +TDriverCommission.export=function(){ + var createTime=$("#name").val() + var phone=$("#phone").val() + var status=$("#status").val() + window.location.href=Feng.ctxPath + "/tDriver/export?name="+name + +"&status="+status + +"&phone="+phone + ; +} + + +/** + * 查询列表 + */ +TDriverCommission.search = function () { + var queryData = {}; + queryData['name'] = $("#name").val(); + queryData['phone'] = $("#phone").val(); + queryData['status'] = $("#status").val(); + TDriverCommission.table.refresh({query: queryData}); +}; + +/** + * 重置 + */ +TDriverCommission.resetSearch = function (){ + $("#name").val(''); + $("#phone").val(''); + $("#status").val(''); + TDriverCommission.search(); +} + +$(function () { + var defaultColunms = TDriverCommission.initColumn(); + var table = new BSTable(TDriverCommission.id, "/tDriver/commission/list", defaultColunms); + table.setPaginationType("client"); + TDriverCommission.table = table.init(); +}); -- Gitblit v1.7.1