Compare commits

..

No commits in common. "26d4bef142acf92598098137bb71e24a33843580" and "54cc6be9fa1372aa2e1a4af56c12d01f348487d5" have entirely different histories.

18 changed files with 47 additions and 298 deletions

View File

@ -44,7 +44,7 @@ public class StatisticsController extends BaseController
//询盘流量 //询盘流量
rtnMap.put("ipInquiry",busiThirdItemService.inquiryMap(tenantId)); rtnMap.put("ipInquiry",busiThirdItemService.inquiryMap(tenantId));
//询盘来源前十国家 //询盘来源前十国家
rtnMap.put("nationalData",busiThirdItemService.nationalData(tenantId,null,null,10)); rtnMap.put("nationalData",busiThirdItemService.nationalData(tenantId));
//询盘设备 //询盘设备
rtnMap.put("equipmentData",busiThirdItemService.equipmentData(tenantId)); rtnMap.put("equipmentData",busiThirdItemService.equipmentData(tenantId));
//近一个月询盘数 //近一个月询盘数
@ -59,11 +59,4 @@ public class StatisticsController extends BaseController
public AjaxResult inquiryChart(String tenantId,String startDate,String endDate){ public AjaxResult inquiryChart(String tenantId,String startDate,String endDate){
return success(busiThirdItemService.inquiryChart(tenantId,startDate,endDate)); return success(busiThirdItemService.inquiryChart(tenantId,startDate,endDate));
} }
/**
* 询盘国家分布指定时间范围
*/
@GetMapping("/countryChart")
public AjaxResult countryChart(String tenantId,String startDate,String endDate){
return success(busiThirdItemService.nationalData(tenantId,startDate,endDate,null));
}
} }

View File

@ -80,6 +80,7 @@ public class BusiInquiryItem extends DlBaseEntity
private String equipment; private String equipment;
/** 页面路径 */ /** 页面路径 */
@Excel(name = "页面路径")
private String pageUrl; private String pageUrl;
/** 站点唯一编码租户id */ /** 站点唯一编码租户id */

View File

@ -49,6 +49,7 @@ public class BusiThirdItem extends DlBaseEntity
private String viewType; private String viewType;
/** 页面路径 */ /** 页面路径 */
@Excel(name = "页面路径")
private String pageUrl; private String pageUrl;
/** 设备类型 */ /** 设备类型 */

View File

@ -33,7 +33,7 @@ public interface BusiChatMainMapper extends BaseMapper<BusiChatMain>
**/ **/
Integer selectIpCount(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate); Integer selectIpCount(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate);
List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate); List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId);
/** /**
* 查询询盘设备 * 查询询盘设备

View File

@ -33,7 +33,7 @@ public interface BusiInquiryItemMapper extends BaseMapper<BusiInquiryItem>
**/ **/
Integer selectIpCount(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate); Integer selectIpCount(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate);
List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate); List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId);
/** /**
* 查询询盘设备 * 查询询盘设备

View File

@ -4,7 +4,10 @@ import java.util.List;
import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.busi.domain.BusiThirdItem; import com.ruoyi.busi.domain.BusiThirdItem;
import com.ruoyi.busi.vo.*; import com.ruoyi.busi.vo.ChartDataVO;
import com.ruoyi.busi.vo.IndexInquiryVO;
import com.ruoyi.busi.vo.ThirdSoftVO;
import com.ruoyi.busi.vo.ThirdVO;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
@ -37,7 +40,7 @@ public interface BusiThirdItemMapper extends BaseMapper<BusiThirdItem>
* @param tenantId 站点ID * @param tenantId 站点ID
* @return java.util.List<com.ruoyi.busi.vo.ChartDataVO> * @return java.util.List<com.ruoyi.busi.vo.ChartDataVO>
**/ **/
List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId,@Param("startDate")String startDate,@Param("endDate")String endDate); List<ChartDataVO> selectNationalSortList(@Param("tenantId")String tenantId);
/** /**
* 查询询盘设备 * 查询询盘设备

View File

@ -37,7 +37,7 @@ public interface IBusiThirdItemService extends IService<BusiThirdItem>
* @param tenantId 站点编码 * @param tenantId 站点编码
* @return java.util.List<com.ruoyi.busi.vo.ChartDataVO> * @return java.util.List<com.ruoyi.busi.vo.ChartDataVO>
**/ **/
List<ChartDataVO> nationalData(String tenantId,String startDate,String endDate,Integer num); List<ChartDataVO> nationalData(String tenantId);
/** /**
* 查询盘设备 * 查询盘设备
@ -67,14 +67,4 @@ public interface IBusiThirdItemService extends IService<BusiThirdItem>
* @return java.util.Map<java.lang.String,java.lang.Object> * @return java.util.Map<java.lang.String,java.lang.Object>
**/ **/
Map<String, Object> inquiryChart(String tenantId,String startDate,String endDate); Map<String, Object> inquiryChart(String tenantId,String startDate,String endDate);
/**
* 询盘国家分布
* @author vinjor-M
* @date 17:12 2025/7/16
* @param tenantId 站点编码
* @param startDate 开始日期
* @param endDate 结束日期
* @return java.util.Map<java.lang.String,java.lang.Object>
**/
Map<String, Object> countryChart(String tenantId, String startDate, String endDate);
} }

View File

@ -139,17 +139,13 @@ public class BusiThirdItemServiceImpl extends ServiceImpl<BusiThirdItemMapper,Bu
* @date 10:47 2025/7/16 * @date 10:47 2025/7/16
**/ **/
@Override @Override
public List<ChartDataVO> nationalData(String tenantId,String startDate,String endDate,Integer num) { public List<ChartDataVO> nationalData(String tenantId) {
//开始日期
String startDateStr = null==startDate?null:startDate+StrConstants.START_DATE;
//截止日期
String endDateStr = null==endDate?null:endDate+StrConstants.END_DATE;
//三方系统跳转 //三方系统跳转
List<ChartDataVO> thirdList = busiThirdItemMapper.selectNationalSortList(tenantId,startDateStr,endDateStr); List<ChartDataVO> thirdList = busiThirdItemMapper.selectNationalSortList(tenantId);
//在线询盘 //在线询盘
List<ChartDataVO> inquiryList = inquiryItemMapper.selectNationalSortList(tenantId,startDateStr,endDateStr); List<ChartDataVO> inquiryList = inquiryItemMapper.selectNationalSortList(tenantId);
//在线聊天 //在线聊天
List<ChartDataVO> chatList = chatMainMapper.selectNationalSortList(tenantId,startDateStr,endDateStr); List<ChartDataVO> chatList = chatMainMapper.selectNationalSortList(tenantId);
//数据合并 //数据合并
Map<String,ChartDataVO> nationalMap = new HashMap<>(); Map<String,ChartDataVO> nationalMap = new HashMap<>();
this.dealMapFun(thirdList,nationalMap); this.dealMapFun(thirdList,nationalMap);
@ -158,9 +154,6 @@ public class BusiThirdItemServiceImpl extends ServiceImpl<BusiThirdItemMapper,Bu
//转list //转list
List<ChartDataVO> dataVOList = new ArrayList<>(nationalMap.values()) List<ChartDataVO> dataVOList = new ArrayList<>(nationalMap.values())
.stream().sorted(Comparator.comparingInt(ChartDataVO::getValue).reversed()).collect(Collectors.toList()); .stream().sorted(Comparator.comparingInt(ChartDataVO::getValue).reversed()).collect(Collectors.toList());
if(null!=num && dataVOList.size()>num){
return dataVOList.subList(0,num);
}
return dataVOList; return dataVOList;
} }
@ -345,25 +338,4 @@ public class BusiThirdItemServiceImpl extends ServiceImpl<BusiThirdItemMapper,Bu
return rtnMap; return rtnMap;
} }
/**
* 询盘国家分布
*
* @param tenantId 站点编码
* @param startDate 开始日期
* @param endDate 结束日期
* @return java.util.Map<java.lang.String, java.lang.Object>
* @author vinjor-M
* @date 17:12 2025/7/16
**/
@Override
public Map<String, Object> countryChart(String tenantId, String startDate, String endDate) {
Map<String,Object> rtnMap = new HashMap<>();
//开始日期
String startDateStr = startDate+StrConstants.START_DATE;
//截止日期
String endDateStr = endDate+StrConstants.END_DATE;
//先查出这段时间所有三方询盘国家分布情况
return rtnMap;
}
} }

View File

@ -2,15 +2,8 @@ package com.ruoyi.busi.vo;
import lombok.Data; import lombok.Data;
/**
* 国家分布饼图实体
* @author vinjor-M
* @date 16:28 2025/7/17
**/
@Data @Data
public class ChartDataVO { public class ChartDataVO {
/** 国家名称 */
private String name; private String name;
/** 数量 */
private Integer value; private Integer value;
} }

View File

@ -86,12 +86,6 @@
WHERE WHERE
del_flag = '0' del_flag = '0'
AND tenant_id = #{tenantId} AND tenant_id = #{tenantId}
<if test="startDate != null and startDate != ''">
and create_time &gt;= #{startDate}
</if>
<if test="endDate != null and endDate != ''">
and create_time &lt;= #{endDate}
</if>
GROUP BY GROUP BY
national national
</select> </select>

View File

@ -72,12 +72,6 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
WHERE WHERE
del_flag = '0' del_flag = '0'
AND tenant_id = #{tenantId} AND tenant_id = #{tenantId}
<if test="startDate != null and startDate != ''">
and create_time &gt;= #{startDate}
</if>
<if test="endDate != null and endDate != ''">
and create_time &lt;= #{endDate}
</if>
GROUP BY GROUP BY
national national
</select> </select>

View File

@ -77,12 +77,6 @@ order by dbti.create_time DESC
WHERE WHERE
del_flag = '0' del_flag = '0'
AND tenant_id = #{tenantId} AND tenant_id = #{tenantId}
<if test="startDate != null and startDate != ''">
and create_time &gt;= #{startDate}
</if>
<if test="endDate != null and endDate != ''">
and create_time &lt;= #{endDate}
</if>
GROUP BY GROUP BY
national national
</select> </select>

View File

@ -17,12 +17,4 @@ export function inquiryChart(query) {
params: query params: query
}) })
} }
//国家分布
export function countryChart(query) {
return request({
url: '/statistics/countryChart',
method: 'get',
params: query
})
}

View File

@ -26,7 +26,7 @@ export default {
}, },
data() { data() {
return { return {
chart: null, chart: null
} }
}, },
mounted() { mounted() {
@ -68,28 +68,18 @@ export default {
}, },
series: [ series: [
{ {
name: '询盘设备', name: '',
type: 'pie', type: 'pie',
roseType: 'radius', roseType: 'radius',
radius: [15, 95], radius: [15, 95],
center: ['50%', '38%'], center: ['50%', '38%'],
data:dataArray, data:dataArray,
animationEasing: 'cubicInOut', animationEasing: 'cubicInOut',
animationDuration: 2600, animationDuration: 2600
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
},
label: {
formatter: '{b}: {c} ({d}%)'
}
} }
] ]
}) })
}, }
} }
} }
</script> </script>

View File

@ -1,78 +0,0 @@
<template>
<div :class="className" :style="{height:height,width:width}"/>
</template>
<script>
import * as echarts from 'echarts'
require('echarts/theme/macarons') // echarts theme
import resize from './mixins/resize'
export default {
mixins: [resize],
props: {
className: {
type: String,
default: 'chart'
},
width: {
type: String,
default: '100%'
},
height: {
type: String,
default: '600px'
}
},
data() {
return {
chart: null,
//
}
},
mounted() {
},
beforeDestroy() {
if (!this.chart) {
return
}
this.chart.dispose()
this.chart = null
},
methods: {
initChart(data) {
this.chart = echarts.init(this.$el, 'macarons')
const option = {
tooltip: {
trigger: 'item',
formatter: '{a} <br/>{b}: {c} ({d}%)'
},
// legend: {
// orient: 'vertical',
// left: 'left',
// data: data.map(item => item.name)
// },
series: [
{
name: '国家分布',
type: 'pie',
radius: '50%',
data: data,
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
},
label: {
formatter: '{b}: {c} ({d}%)'
}
}
]
};
this.chart.setOption(option);
}
}
}
</script>

View File

@ -37,7 +37,7 @@
<img src="@/assets/index/third.png"> <img src="@/assets/index/third.png">
<span>三方询盘</span> <span>三方询盘</span>
</div> </div>
<div class="dl-menu-box" @click="goMenuClick('/statistics/inquiryItem')"> <div class="dl-menu-box" @click="goMenuClick('/base/pics')">
<img src="@/assets/index/chat.png"> <img src="@/assets/index/chat.png">
<span>在线询盘</span> <span>在线询盘</span>
</div> </div>

View File

@ -1,122 +1,10 @@
<template> <template>
<div class="app-container"> <div class="app-container">www</div>
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="120px">
<el-form-item label="时间范围" prop="dataRange">
<el-date-picker
v-model="queryParams.dataRange"
type="monthrange"
align="right"
unlink-panels
range-separator="至"
start-placeholder="开始月份"
end-placeholder="结束月份"
:picker-options="pickerOptions">
</el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<pie-cus-chart ref="pieCusChart"></pie-cus-chart>
</div>
</template> </template>
<script> <script>
import { countryChart } from "@/api/statistics/statistics";
import PieCusChart from '../../dashboard/PieCusChart'
export default { export default {
name: 'countryChart', name: 'countryChart'
components: { PieCusChart },
data() {
return {
//
queryParams: {
dataRange: '',
startDate: '',
endDate: '',
tenantId: null
},
pickerOptions: {
shortcuts: [{
text: '本月',
onClick(picker) {
picker.$emit('pick', [new Date(), new Date()]);
}
}, {
text: '今年至今',
onClick(picker) {
const end = new Date();
const start = new Date(new Date().getFullYear(), 0);
picker.$emit('pick', [start, end]);
}
}, {
text: '最近六个月',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setMonth(start.getMonth() - 6);
picker.$emit('pick', [start, end]);
}
}]
},
}
},
created() {
this.initDateRange()
},
methods:{
initDateRange(){
const end = new Date();
const start = new Date();
start.setMonth(start.getMonth() - 6);
this.queryParams.dataRange = [start,end]
this.handleQuery()
},
/** 搜索按钮操作 */
handleQuery() {
this.queryParams.pageNum = 1
if (this.queryParams.dataRange && this.queryParams.dataRange.length > 1) {
this.queryParams.startDate = this.formatDate(this.queryParams.dataRange[0],false)
this.queryParams.endDate = this.formatDate(this.queryParams.dataRange[1],true)
console.log(this.queryParams, '12')
} else {
this.queryParams.startDate = null
this.queryParams.endDate = null
}
this.getList()
},
/** 重置按钮操作 */
resetQuery() {
this.resetForm('queryForm')
this.initDateRange()
},
/**
* 查询数据
*/
getList(){
countryChart(this.queryParams).then(response => {
this.$refs.pieCusChart.initChart(response.data)
});
},
/**
* 格式化时间戳
*/
formatDate(timestamp,ifEnd) {
const date = new Date(timestamp)
const year = date.getFullYear()
// 01
const month = String(date.getMonth() + 1).padStart(2, '0')
if(ifEnd){
//
const date = new Date(year, month, 0);
return `${year}-${month}`+"-"+date.getDate();
}else{
//
return `${year}-${month}`+"-01"
}
},
}
} }
</script> </script>

View File

@ -18,16 +18,36 @@
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
</el-form-item> </el-form-item>
</el-form> </el-form>
<line-chart ref="lineChart"></line-chart> <line-chart ref="lineChart" :chart-data="lineChartData"></line-chart>
</div> </div>
</template> </template>
<script> <script>
const lineChartData = {
newVisitis: {
expectedData: [100, 120, 161, 134, 105, 160, 165],
actualData: [120, 82, 91, 154, 162, 140, 145]
},
messages: {
expectedData: [200, 192, 120, 144, 160, 130, 140],
actualData: [180, 160, 151, 106, 145, 150, 130]
},
purchases: {
expectedData: [80, 100, 121, 104, 105, 90, 100],
actualData: [120, 90, 100, 138, 142, 130, 130]
},
shoppings: {
expectedData: [130, 140, 141, 142, 145, 150, 160],
actualData: [120, 82, 91, 154, 162, 140, 130]
}
}
import { inquiryChart } from "@/api/statistics/statistics"; import { inquiryChart } from "@/api/statistics/statistics";
import LineChart from '../../dashboard/LineChart' import LineChart from '../../dashboard/LineChart'
import PanelGroup from '../../dashboard/PanelGroup'
import RaddarChart from '../../dashboard/RaddarChart'
export default { export default {
name: 'inquiryChart', name: 'inquiryChart',
components: { LineChart }, components: { RaddarChart, PanelGroup, LineChart },
data() { data() {
return { return {
// //
@ -37,6 +57,7 @@ export default {
endDate: '', endDate: '',
tenantId: null tenantId: null
}, },
lineChartData: {},
pickerOptions: { pickerOptions: {
shortcuts: [{ shortcuts: [{
text: '本月', text: '本月',
@ -96,7 +117,8 @@ export default {
*/ */
getList(){ getList(){
inquiryChart(this.queryParams).then(response => { inquiryChart(this.queryParams).then(response => {
this.$refs.lineChart.initChart(response.data) this.lineChartData = response.data
this.$refs.lineChart.initChart(this.lineChartData)
}); });
}, },
/** /**