parent
9d544a4f3e
commit
5866dc2ac2
|
@ -59,7 +59,7 @@ public class ShiroUtils {
|
|||
//分享相关接口
|
||||
filterChainDefinitionMap.put("/share/info/generateShareInfoWithExpired", "anon");
|
||||
filterChainDefinitionMap.put("/share/list", "anon");
|
||||
filterChainDefinitionMap.put("/share/info/selectHistoryReportById", "anon");
|
||||
filterChainDefinitionMap.put("/report/stat/share/**", "anon");
|
||||
filterChainDefinitionMap.put("/share/get/**", "anon");
|
||||
filterChainDefinitionMap.put("/share/info", "apikey, csrf, authc"); // 需要认证
|
||||
filterChainDefinitionMap.put("/document/**", "anon");
|
||||
|
|
|
@ -0,0 +1,12 @@
|
|||
package io.metersphere.reportstatistics.controller;
|
||||
|
||||
import org.springframework.stereotype.Controller;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
|
||||
@Controller
|
||||
public class PageRedirectController {
|
||||
@GetMapping(value = "/chart-pic")
|
||||
public String getChart() {
|
||||
return "share-enterprise-report.html";
|
||||
}
|
||||
}
|
|
@ -3,30 +3,21 @@ package io.metersphere.reportstatistics.controller;
|
|||
import io.metersphere.base.domain.ReportStatisticsWithBLOBs;
|
||||
import io.metersphere.reportstatistics.dto.ReportStatisticsSaveRequest;
|
||||
import io.metersphere.reportstatistics.service.ReportStatisticsService;
|
||||
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.RequestBody;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
|
||||
@Controller
|
||||
@RestController
|
||||
@RequestMapping(value = "/report/stat/share")
|
||||
public class ReportStatShareController {
|
||||
@GetMapping(value = "/chart-pic")
|
||||
public String getChart() {
|
||||
return "share-enterprise-report.html";
|
||||
}
|
||||
}
|
||||
|
||||
@RequestMapping(value = "/share/info")
|
||||
class ShareInfoController {
|
||||
@Resource
|
||||
private ReportStatisticsService reportStatisticsService;
|
||||
|
||||
@PostMapping("/selectHistoryReportById")
|
||||
@PostMapping("/select/report/by/id")
|
||||
public ReportStatisticsWithBLOBs selectById(@RequestBody ReportStatisticsSaveRequest request) {
|
||||
return reportStatisticsService.selectById(request.getId());
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -84,7 +84,7 @@ public class ReportStatisticsService {
|
|||
boolean isReportNeedUpdate = this.isReportNeedUpdate(blob);
|
||||
if (isReportNeedUpdate) {
|
||||
TestCaseCountRequest countRequest = JSON.parseObject(blob.getSelectOption(), TestCaseCountRequest.class);
|
||||
Map<String, Object> returnDataOption = this.reloadData(countRequest, JSON.toJSONString(dataOption.get("chartType")));
|
||||
Map<String, Object> returnDataOption = this.reloadData(countRequest, dataOption.get("chartType").toString());
|
||||
if (returnDataOption != null) {
|
||||
dataOption = returnDataOption;
|
||||
}
|
||||
|
@ -94,8 +94,13 @@ public class ReportStatisticsService {
|
|||
if (dataOption.get("tableData") != null) {
|
||||
String tableDataJsonStr = JSON.toJSONString(dataOption.get("tableData"));
|
||||
List<TestCaseCountTableDTO> dtos = JSON.parseArray(tableDataJsonStr, TestCaseCountTableDTO.class);
|
||||
List<String> yaxis = new ArrayList<>();
|
||||
try {
|
||||
yaxis = (List<String>) selectOption.get("yaxis");
|
||||
} catch (Exception e) {
|
||||
String yaxisStr = JSON.toJSONString(selectOption.get("yaxis"));
|
||||
List<String> yaxis = JSON.parseArray(yaxisStr, String.class);
|
||||
yaxis = JSON.parseArray(yaxisStr, String.class);
|
||||
}
|
||||
TestCaseCountTableDataDTO showTable = this.countShowTable(String.valueOf(selectOption.get("xaxis")), yaxis, dtos);
|
||||
dataOption.put("showTable", showTable);
|
||||
blob.setDataOption(JSON.toJSONString(dataOption));
|
||||
|
|
|
@ -70,7 +70,7 @@ public class ChromeUtil {
|
|||
driver.get(url);
|
||||
driver.manage().window().fullscreen();
|
||||
//预留echart动画的加载时间
|
||||
Thread.sleep(3 * 1000);
|
||||
Thread.sleep(10 * 1000);
|
||||
String js = "var chartsCanvas = document.getElementById('picChart').getElementsByTagName('canvas')[0];" +
|
||||
"var imageUrl = null;" +
|
||||
"if (chartsCanvas!= null) {" +
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
import {post} from "metersphere-frontend/src/plugins/request"
|
||||
|
||||
let basePath = '/share/info';
|
||||
let basePath = '/report/stat/share';
|
||||
|
||||
export function selectShareReportById(param) {
|
||||
return post(basePath + '/selectHistoryReportById', param)
|
||||
return post(basePath + '/select/report/by/id', param)
|
||||
}
|
||||
|
||||
export function getShareId() {
|
||||
|
|
|
@ -203,6 +203,12 @@ export default {
|
|||
if (typeof (formatData.xaxis) === 'string') {
|
||||
formatData.xaxis = JSON.parse(formatData.xaxis);
|
||||
}
|
||||
if (typeof (formatData.xAxis) === 'string') {
|
||||
formatData.xAxis = JSON.parse(formatData.xAxis);
|
||||
}
|
||||
if (typeof (formatData.yAxis) === 'string') {
|
||||
formatData.yAxis = JSON.parse(formatData.yAxis);
|
||||
}
|
||||
if (typeof (formatData.series) === 'string') {
|
||||
formatData.series = JSON.parse(formatData.series);
|
||||
}
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
<template>
|
||||
<report-chart v-if="!needReloading" :read-only="true" :need-full-screen="false" :chart-type="dataOption.chartType"
|
||||
<report-chart v-if="!needReloading" :read-only="true" :need-full-screen="false"
|
||||
:chart-type="dataOption.chartType"
|
||||
ref="analysisChart" :load-option="dataOption.loadOption" :pie-option="dataOption.pieOption"/>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
// import ReportChart from "@/template/enterprise/share/ReportChart";
|
||||
import ReportChart from "@/business/enterprisereport/components/chart/ReportChart";
|
||||
import {getShareId, selectShareReportById} from "@/api/share";
|
||||
|
||||
|
|
Loading…
Reference in New Issue