呼入,呼出列表提交

master
wangxy 1 year ago
parent 6c5529181a
commit 2225e74371

@ -0,0 +1,49 @@
package com.ruoyi.web.controller.manager;
import com.ruoyi.system.domain.FsChannelRecord;
import com.ruoyi.system.domain.FsChannelRecordVo;
import com.ruoyi.system.service.FsChannelRecordService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.List;
/**
* packageName com.ruoyi.web.controller.manager
*
* @author wangxy
* @version JDK 8
* @className FsChannelRecordManager
* @date 2024/4/7
* @description
*/
@Component
public class FsChannelRecordManager {
@Autowired
private FsChannelRecordService recordService;
public List<FsChannelRecordVo> selectFsChannelRecordList(FsChannelRecord record)
{
record.setChannelType(1);
return recordService.selectFsChannelRecordList(record);
}
public List<FsChannelRecordVo> selectOutboundList(FsChannelRecord record)
{
record.setChannelType(3);
return recordService.selectFsChannelRecordList(record);
}
}

@ -0,0 +1,55 @@
package com.ruoyi.web.controller.system;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.system.domain.FsChannelRecord;
import com.ruoyi.system.domain.FsChannelRecordVo;
import com.ruoyi.web.controller.manager.FsChannelRecordManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
/**
* packageName com.ruoyi.web.controller.home
*
* @author wangxy
* @version JDK 8
* @className
* @date 2024/4/7
* @description
*/
@Controller
@RequestMapping("/incoming")
public class IncomingCallController extends BaseController {
@Autowired
private FsChannelRecordManager recordManager;
private String prefix = "system/incoming";
@GetMapping()
public String incoming()
{
return prefix + "/incoming";
}
/**
*
*/
@PostMapping("/list")
@ResponseBody
public TableDataInfo list(FsChannelRecord record)
{
startPage();
List<FsChannelRecordVo> list = recordManager.selectFsChannelRecordList(record);
return getDataTable(list);
}
}

@ -0,0 +1,53 @@
package com.ruoyi.web.controller.system;
import com.ruoyi.common.core.controller.BaseController;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.system.domain.FsChannelRecord;
import com.ruoyi.system.domain.FsChannelRecordVo;
import com.ruoyi.web.controller.manager.FsChannelRecordManager;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
/**
* packageName com.ruoyi.web.controller.system
*
* @author wangxy
* @version JDK 8
* @className OutboundController
* @date 2024/4/7
* @description
*/
@Controller
@RequestMapping("/outbound")
public class OutboundController extends BaseController {
@Autowired
private FsChannelRecordManager recordManager;
private String prefix = "system/outbound";
@GetMapping()
public String outbound()
{
return prefix + "/outbound";
}
/**
*
*/
@PostMapping("/list")
@ResponseBody
public TableDataInfo list(FsChannelRecord record)
{
startPage();
List<FsChannelRecordVo> list = recordManager.selectOutboundList(record);
return getDataTable(list);
}
}

@ -7,7 +7,7 @@ spring:
# 主库数据源
master:
#url: jdbc:mysql://192.168.254.6:3306/work-portal?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
url: jdbc:mysql://192.168.254.83:3306/java_cti?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
url: jdbc:mysql://192.168.254.85:3306/java_cti?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
#username: root
#password: fq3gG@Ep
username: ENC(qIDwFzwTd7W+6W3NTJsfsQ==)

@ -7,7 +7,7 @@ spring:
# 主库数据源
master:
#url: jdbc:mysql://192.168.254.6:3306/work-portal?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
url: jdbc:mysql://192.168.254.83:3306/java_cti?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
url: jdbc:mysql://192.168.254.85:3306/java_cti?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
#username: root
#password: fq3gG@Ep
username: ENC(qIDwFzwTd7W+6W3NTJsfsQ==)

@ -16,7 +16,7 @@ ruoyi:
# 开发环境配置
server:
# 服务器的HTTP端口默认为80
port: 5000
port: 8087
servlet:
# 应用的访问路径
context-path: /

@ -0,0 +1,144 @@
<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
<th:block th:include="include :: header('呼入通话列表')" />
</head>
<body class="gray-bg">
<div class="container-div">
<div class="row">
<div class="col-sm-12 search-collapse">
<form id="notice-form">
<div class="select-list">
<ul>
<li>
客户号码:<input type="text" name="outside"/>
</li>
<li>
号码区号:<input type="text" name="areacode"/>
</li>
<li>
<a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
<a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
</li>
</ul>
</div>
</form>
</div>
<div class="col-sm-12 select-table table-striped">
<table id="bootstrap-table"></table>
</div>
</div>
</div>
<th:block th:include="include :: footer" />
<script th:inline="javascript">
var prefix = ctx + "incoming";
$(function() {
var options = {
uniqueId: "id",
url: prefix + "/list",
modalName: "呼入通话",
columns: [
{
field : 'routePhone',
title : '中继号码'
},
{
field : 'outside',
title : '客户号码'
},
{
field : 'areacode',
title : '号码区号'
},
{
field : 'cityGsd',
title : '归属地'
},
{
field : 'inside',
title : '坐席号码'
},
{
field : 'seatName',
title : '坐席账号'
},
{
field : 'code',
title : '所属部门'
},
{
field : 'other',
title : '第三方号码'
},
{
field : 'aj',
title : '按键'
},
{
field : 'start',
title : '呼入开始时间'
},
{
field : 'talk',
title : '通话开始时间'
},
{
field : 'end',
title : '呼叫结束时间'
},
{
field : 'listTime',
title : '排队时长'
},
{
field : 'ringTime',
title : '振铃时长'
},
{
field : 'calltime',
title : '通话时长'
},
{
field : 'endType',
title : '结束类型',
formatter: function(value, item, index) {
if (item.endType == '1') {
return '排队放弃';
} else if (item.endType == '2') {
return '呼入漏接';
}else if (item.endType == '3') {
return '呼入接听后挂断';
}else if (item.endType == '4') {
return '外呼无人接听挂断';
}else if (item.endType == '5') {
return '外呼接听后挂断';
}else if (item.endType == '0') {
return '呼入放弃';
}else{
return '呼入放弃';
}
}
},
{
field : 'terminalType',
title : '终端类型',
formatter: function(value, item, index) {
if (item.terminalType == '1') {
return 'WEB';
}
else if (item.terminalType == '2') {
return '话机';
}else{
return '未知';
}
}
}]
};
$.table.init(options);
});
</script>
</body>
</html>

@ -0,0 +1,132 @@
<!DOCTYPE html>
<html lang="zh" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
<th:block th:include="include :: header('呼出通话列表')" />
</head>
<body class="gray-bg">
<div class="container-div">
<div class="row">
<div class="col-sm-12 search-collapse">
<form id="notice-form">
<div class="select-list">
<ul>
<li>
客户号码:<input type="text" name="outside"/>
</li>
<li>
号码区号:<input type="text" name="areacode"/>
</li>
<li>
<a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
<a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
</li>
</ul>
</div>
</form>
</div>
<div class="col-sm-12 select-table table-striped">
<table id="bootstrap-table"></table>
</div>
</div>
</div>
<th:block th:include="include :: footer" />
<script th:inline="javascript">
var prefix = ctx + "outbound";
$(function() {
var options = {
uniqueId: "id",
url: prefix + "/list",
modalName: "呼入通话",
columns: [
{
field : 'routePhone',
title : '中继号码'
},
{
field : 'outside',
title : '客户号码'
},
{
field : 'areacode',
title : '号码区号'
},
{
field : 'cityGsd',
title : '归属地'
},
{
field : 'inside',
title : '坐席号码'
},
{
field : 'seatName',
title : '坐席账号'
},
{
field : 'code',
title : '所属部门'
},
{
field : 'other',
title : '第三方号码'
},
{
field : 'start',
title : '呼出开始时间'
},
{
field : 'talk',
title : '通话开始时间'
},
{
field : 'end',
title : '呼叫结束时间'
},
{
field : 'calltime',
title : '通话时长'
},
{
field : 'endType',
title : '结束类型',
formatter: function(value, item, index) {
if (item.endType == '1') {
return '排队放弃';
} else if (item.endType == '2') {
return '呼入漏接';
}else if (item.endType == '3') {
return '呼入接听后挂断';
}else if (item.endType == '4') {
return '外呼无人接听挂断';
}else if (item.endType == '5') {
return '外呼接听后挂断';
}else if (item.endType == '0') {
return '呼入放弃';
}else{
return '呼入放弃';
}
}
},
{
field : 'terminalType',
title : '终端类型',
formatter: function(value, item, index) {
if (item.terminalType == '1') {
return 'WEB';
}
else if (item.terminalType == '2') {
return '话机';
}else{
return '未知';
}
}
}]
};
$.table.init(options);
});
</script>
</body>
</html>

@ -299,6 +299,8 @@ public class ShiroConfig
filterChainDefinitionMap.put("/profile/**", "anon");
filterChainDefinitionMap.put("/search", "anon");
filterChainDefinitionMap.put("/getTree", "anon");
filterChainDefinitionMap.put("/incoming/**", "anon");
filterChainDefinitionMap.put("/outbound/**", "anon");
// 注册相关
filterChainDefinitionMap.put("/register", "anon,captchaValidate");

@ -0,0 +1,224 @@
package com.ruoyi.system.domain;
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 java.io.Serializable;
import java.util.Date;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
/**
*
* @TableName fs_channel_record
*/
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class FsChannelRecord implements Serializable {
/**
*
*/
@TableId(type = IdType.AUTO)
private Integer id;
/**
* UUID
*/
private String uuid;
/**
* =1 =2 =3456访
*/
private Integer channelType;
/**
* 线
*/
private String inside;
/**
* 线
*/
private String outside;
/**
* 线UUID
*/
private String chnIdOutside;
/**
*
*/
private String other;
/**
* UUID
*/
private String chnIdOther;
/**
*
*/
private String seatName;
/**
*
*/
private Date start;
/**
* 线
*/
private Date answer;
/**
*
*/
private Date talk;
/**
*
*/
private Date end;
/**
*
*/
private String recordFilename;
/**
*
*/
private String recordResult;
/**
*
*/
private Date calltime;
/**
*
*/
private String aj;
/**
* =0=1
*/
private Integer isLost;
/**
*
*/
private Integer seatGroup;
/**
*
*/
private Double money;
/**
*
*/
private String ajJilu;
/**
*
*/
private Integer pleaseAj;
/**
*
*/
private String routePhone;
/**
* =0=1=2=3=4=5
*/
private Integer endType;
/**
*
*/
private String code;
/**
*
*/
private Date save;
/**
*
*/
private String province;
/**
*
*/
private String city;
/**
* =0=1=2=3
*/
private Integer clientType;
/**
*
*/
private String areacode;
/**
* ID
*/
private Integer pid;
/**
*
*/
private Date listIn;
/**
* 退
*/
private Date listEnd;
/**
*
*/
private Date listTime;
/**
* 线
*/
private Date inRing;
/**
* 线
*/
private Date inAnswer;
/**
* 线
*/
private Date ringTime;
/**
* =0=1WEB=2
*/
private Integer terminalType;
/**
* 线
*/
private Date answertime;
/**
*
*/
private Date saveTime;
@TableField(exist = false)
private static final long serialVersionUID = 1L;
}

@ -0,0 +1,294 @@
package com.ruoyi.system.domain;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import java.io.Serializable;
import java.util.Date;
/**
*
* @TableName fs_channel_record
*/
@Data
public class FsChannelRecordVo implements Serializable {
/**
*
*/
private Integer id;
/**
* UUID
*/
private String uuid;
/**
* =1 =2 =3456访
*/
private Integer channelType;
/**
* 线
*/
private String inside;
/**
* 线
*/
private String outside;
/**
* 线UUID
*/
private String chnIdOutside;
/**
*
*/
private String other;
/**
* UUID
*/
private String chnIdOther;
/**
*
*/
private String seatName;
/**
*
*/
private Date start;
/**
* 线
*/
private Date answer;
/**
*
*/
private Date talk;
/**
*
*/
private Date end;
/**
*
*/
private String recordFilename;
/**
*
*/
private String recordResult;
/**
*
*/
@JsonFormat(pattern = "HH:mm:ss")
private Date calltime;
/**
*
*/
private String aj;
/**
* =0=1
*/
private Integer isLost;
/**
*
*/
private Integer seatGroup;
/**
*
*/
private Double money;
/**
*
*/
private String ajJilu;
/**
*
*/
private Integer pleaseAj;
/**
*
*/
private String routePhone;
/**
* =0=1=2=3=4=5
*/
private Integer endType;
/**
*
*/
private String code;
/**
*
*/
private Date save;
/**
*
*/
private String province;
/**
*
*/
private String city;
/**
*
*/
private String cityGsd;
/**
* =0=1=2=3
*/
private Integer clientType;
/**
*
*/
private String areacode;
/**
* ID
*/
private Integer pid;
/**
*
*/
private Date listIn;
/**
* 退
*/
private Date listEnd;
/**
*
*/
@JsonFormat(pattern = "HH:mm:ss")
private Date listTime;
/**
* 线
*/
private Date inRing;
/**
* 线
*/
private Date inAnswer;
/**
* 线
*/
@JsonFormat(pattern = "HH:mm:ss")
private Date ringTime;
/**
* =0=1WEB=2
*/
private Integer terminalType;
/**
* 线
*/
private Date answertime;
/**
*
*/
private Date saveTime;
/**
*
*/
private String remark;
/**
* 1
*/
private String bak1;
/**
*
*/
private String clientstatus;
/**
*
*/
private String businesstype;
/**
*
*/
private String office;
/**
*
*/
private String shopname;
/**
*
*/
private String shopaddress;
/**
*
*/
private String enclosure;
/**
*
*/
private Date dealtime;
/**
* 1
*/
private String linkage11;
/**
* 2
*/
private String linkage12;
/**
*
*/
private String checkbox1;
}

@ -0,0 +1,134 @@
package com.ruoyi.system.domain;
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 java.io.Serializable;
import java.util.Date;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
/**
*
* @TableName fs_remark_record
*/
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class FsRemarkRecord implements Serializable {
/**
* UUID
*/
@TableId
private String uuid;
/**
*
*/
private String calltype;
/**
*
*/
private String remark;
/**
*
*/
private String clientstatus;
/**
*
*/
private Date dealtime;
/**
*
*/
private String province;
/**
*
*/
private String city;
/**
*
*/
private String areacode;
/**
* 1
*/
private String bak1;
/**
*
*/
private String dealseat;
/**
* 线
*/
private String phonenum;
/**
* pid
*/
private Integer pid;
/**
*
*/
private String code;
/**
*
*/
private String dealseatnum;
/**
*
*/
private String businesstype;
/**
*
*/
private String office;
/**
*
*/
private String shopname;
/**
*
*/
private String shopaddress;
/**
*
*/
private String enclosure;
/**
* 1
*/
private String linkage11;
/**
* 2
*/
private String linkage12;
/**
*
*/
private String checkbox1;
@TableField(exist = false)
private static final long serialVersionUID = 1L;
}

@ -0,0 +1,26 @@
package com.ruoyi.system.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ruoyi.system.domain.FsChannelRecord;
import com.ruoyi.system.domain.FsChannelRecordVo;
import java.util.List;
/**
* @author 13560
* @description fs_channel_recordMapper
* @createDate 2024-04-07 14:25:04
* @Entity generator.domain.FsChannelRecord
*/
public interface FsChannelRecordMapper extends BaseMapper<FsChannelRecord> {
List<FsChannelRecordVo> selectFsChannelRecordList(FsChannelRecord record);
}

@ -0,0 +1,19 @@
package com.ruoyi.system.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.ruoyi.system.domain.FsRemarkRecord;
/**
* @author 13560
* @description fs_remark_recordMapper
* @createDate 2024-04-07 14:29:10
* @Entity generator.domain.FsRemarkRecord
*/
public interface FsRemarkRecordMapper extends BaseMapper<FsRemarkRecord> {
}

@ -0,0 +1,20 @@
package com.ruoyi.system.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.ruoyi.system.domain.FsChannelRecord;
import com.ruoyi.system.domain.FsChannelRecordVo;
import java.util.List;
/**
* @author 13560
* @description fs_channel_recordService
* @createDate 2024-04-07 14:25:04
*/
public interface FsChannelRecordService extends IService<FsChannelRecord> {
List<FsChannelRecordVo> selectFsChannelRecordList(FsChannelRecord record);
}

@ -0,0 +1,14 @@
package com.ruoyi.system.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.ruoyi.system.domain.FsRemarkRecord;
/**
* @author 13560
* @description fs_remark_recordService
* @createDate 2024-04-07 14:29:10
*/
public interface FsRemarkRecordService extends IService<FsRemarkRecord> {
}

@ -0,0 +1,38 @@
package com.ruoyi.system.service.impl;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.system.domain.FsChannelRecordVo;
import com.ruoyi.system.mapper.FsChannelRecordMapper;
import com.ruoyi.system.service.FsChannelRecordService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.system.domain.FsChannelRecord;
import java.util.List;
/**
* @author 13560
* @description fs_channel_recordService
* @createDate 2024-04-07 14:25:04
*/
@Service
public class FsChannelRecordServiceImpl extends ServiceImpl<FsChannelRecordMapper, FsChannelRecord>
implements FsChannelRecordService {
@Autowired
private FsChannelRecordMapper recordMapper;
@Override
public List<FsChannelRecordVo> selectFsChannelRecordList(FsChannelRecord record)
{
return recordMapper.selectFsChannelRecordList(record);
}
}

@ -0,0 +1,22 @@
package com.ruoyi.system.service.impl;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.system.domain.FsRemarkRecord;
import com.ruoyi.system.mapper.FsRemarkRecordMapper;
import com.ruoyi.system.service.FsRemarkRecordService;
import org.springframework.stereotype.Service;
/**
* @author 13560
* @description fs_remark_recordService
* @createDate 2024-04-07 14:29:10
*/
@Service
public class FsRemarkRecordServiceImpl extends ServiceImpl<FsRemarkRecordMapper, FsRemarkRecord>
implements FsRemarkRecordService {
}

@ -0,0 +1,129 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.system.mapper.FsChannelRecordMapper">
<resultMap id="BaseResultMap" type="com.ruoyi.system.domain.FsChannelRecord">
<id property="id" column="id" jdbcType="INTEGER"/>
<result property="uuid" column="uuid" jdbcType="VARCHAR"/>
<result property="channelType" column="channel_type" jdbcType="INTEGER"/>
<result property="inside" column="inside" jdbcType="VARCHAR"/>
<result property="outside" column="outside" jdbcType="VARCHAR"/>
<result property="chnIdOutside" column="chn_id_outside" jdbcType="VARCHAR"/>
<result property="other" column="other" jdbcType="VARCHAR"/>
<result property="chnIdOther" column="chn_id_other" jdbcType="VARCHAR"/>
<result property="seatName" column="seat_name" jdbcType="VARCHAR"/>
<result property="start" column="start" jdbcType="TIMESTAMP"/>
<result property="answer" column="answer" jdbcType="TIMESTAMP"/>
<result property="talk" column="talk" jdbcType="TIMESTAMP"/>
<result property="end" column="end" jdbcType="TIMESTAMP"/>
<result property="recordFilename" column="record_filename" jdbcType="VARCHAR"/>
<result property="recordResult" column="record_result" jdbcType="VARCHAR"/>
<result property="calltime" column="calltime" jdbcType="TIME"/>
<result property="aj" column="aj" jdbcType="VARCHAR"/>
<result property="isLost" column="is_lost" jdbcType="INTEGER"/>
<result property="seatGroup" column="seat_group" jdbcType="INTEGER"/>
<result property="money" column="money" jdbcType="FLOAT"/>
<result property="ajJilu" column="aj_jilu" jdbcType="VARCHAR"/>
<result property="pleaseAj" column="please_aj" jdbcType="INTEGER"/>
<result property="routePhone" column="route_phone" jdbcType="VARCHAR"/>
<result property="endType" column="end_type" jdbcType="INTEGER"/>
<result property="code" column="code" jdbcType="VARCHAR"/>
<result property="save" column="save" jdbcType="TIMESTAMP"/>
<result property="province" column="province" jdbcType="VARCHAR"/>
<result property="city" column="city" jdbcType="VARCHAR"/>
<result property="clientType" column="client_type" jdbcType="INTEGER"/>
<result property="areacode" column="areacode" jdbcType="VARCHAR"/>
<result property="pid" column="pid" jdbcType="INTEGER"/>
<result property="listIn" column="list_in" jdbcType="TIMESTAMP"/>
<result property="listEnd" column="list_end" jdbcType="TIMESTAMP"/>
<result property="listTime" column="list_time" jdbcType="TIME"/>
<result property="inRing" column="in_ring" jdbcType="TIMESTAMP"/>
<result property="inAnswer" column="in_answer" jdbcType="TIMESTAMP"/>
<result property="ringTime" column="ring_time" jdbcType="TIME"/>
<result property="terminalType" column="terminal_type" jdbcType="INTEGER"/>
<result property="answertime" column="answertime" jdbcType="TIME"/>
<result property="saveTime" column="save_time" jdbcType="TIME"/>
</resultMap>
<sql id="Base_Column_List">
id,uuid,channel_type,
inside,outside,chn_id_outside,
other,chn_id_other,seat_name,
start,answer,talk,
end,record_filename,record_result,
calltime,aj,is_lost,
seat_group,money,aj_jilu,
please_aj,route_phone,end_type,
code,save,province,
city,client_type,areacode,
pid,list_in,list_end,
list_time,in_ring,in_answer,
ring_time,terminal_type,answertime,
save_time
</sql>
<select id="selectFsChannelRecordList" parameterType="FsChannelRecord" resultType="com.ruoyi.system.domain.FsChannelRecordVo">
SELECT
a.uuid AS uuid,
a.channel_type AS channel_type,
a.inside AS inside,
a.outside AS outside,
a.other AS other,
a.seat_name AS seat_name,
a.start AS start,
a.answer AS answer,
a.talk AS talk,
a.end AS end,
a.record_filename AS record_filename,
a.record_result AS record_result,
a.calltime AS calltime,
a.aj AS aj,
a.is_lost AS is_lost,
a.code AS code,
a.pid AS pid,
a.ring_time AS ring_time,
a.list_in AS list_in,
a.list_end AS list_end,
a.list_time AS list_time,
a.in_ring AS in_ring,
a.in_answer AS in_answer,
a.seat_group AS seat_group,
a.money AS money,
a.aj_jilu AS aj_jilu,
a.please_aj AS please_aj,
a.end_type AS end_type,
a.save AS save,
a.route_phone AS route_phone,
a.terminal_type AS terminal_type,
b.remark AS remark,
a.province AS province,
b.bak1 AS bak1,
b.clientstatus AS clientstatus,
a.city AS city,
CONCAT(a.province, a.city) AS cityGsd,
a.areacode AS areacode,
b.businesstype AS businesstype,
b.office AS office,
b.shopname AS shopname,
b.shopaddress AS shopaddress,
b.enclosure AS enclosure,
b.dealtime AS dealtime,
b.linkage11 AS linkage11,
b.linkage12 AS linkage12,
b.checkbox1 AS checkbox1 from fs_channel_record a
LEFT JOIN fs_remark_record b ON a.uuid = b.uuid
<where>
<if test="channelType != null">
AND a.channel_type = #{channelType}
</if>
<if test="outside != null and outside != ''">
AND a.outside = #{outside}
</if>
<if test="areacode != null and areacode != ''">
AND a.areacode = #{areacode}
</if>
</where>
order by end desc
</select>
</mapper>

@ -0,0 +1,42 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.system.mapper.FsRemarkRecordMapper">
<resultMap id="BaseResultMap" type="com.ruoyi.system.domain.FsRemarkRecord">
<id property="uuid" column="uuid" jdbcType="VARCHAR"/>
<result property="calltype" column="calltype" jdbcType="VARCHAR"/>
<result property="remark" column="remark" jdbcType="VARCHAR"/>
<result property="clientstatus" column="clientstatus" jdbcType="VARCHAR"/>
<result property="dealtime" column="dealtime" jdbcType="TIMESTAMP"/>
<result property="province" column="province" jdbcType="VARCHAR"/>
<result property="city" column="city" jdbcType="VARCHAR"/>
<result property="areacode" column="areacode" jdbcType="VARCHAR"/>
<result property="bak1" column="bak1" jdbcType="VARCHAR"/>
<result property="dealseat" column="dealseat" jdbcType="VARCHAR"/>
<result property="phonenum" column="phonenum" jdbcType="VARCHAR"/>
<result property="pid" column="pid" jdbcType="INTEGER"/>
<result property="code" column="code" jdbcType="VARCHAR"/>
<result property="dealseatnum" column="dealseatnum" jdbcType="VARCHAR"/>
<result property="businesstype" column="businesstype" jdbcType="VARCHAR"/>
<result property="office" column="office" jdbcType="VARCHAR"/>
<result property="shopname" column="shopname" jdbcType="VARCHAR"/>
<result property="shopaddress" column="shopaddress" jdbcType="VARCHAR"/>
<result property="enclosure" column="enclosure" jdbcType="VARCHAR"/>
<result property="linkage11" column="linkage11" jdbcType="VARCHAR"/>
<result property="linkage12" column="linkage12" jdbcType="VARCHAR"/>
<result property="checkbox1" column="checkbox1" jdbcType="VARCHAR"/>
</resultMap>
<sql id="Base_Column_List">
uuid,calltype,remark,
clientstatus,dealtime,province,
city,areacode,bak1,
dealseat,phonenum,pid,
code,dealseatnum,businesstype,
office,shopname,shopaddress,
enclosure,linkage11,linkage12,
checkbox1
</sql>
</mapper>
Loading…
Cancel
Save