fix(项目报告): 修复项目报告预览中看不到统计图表的问题

修复项目报告预览中看不到统计图表的问题
This commit is contained in:
song-tianyang 2023-02-22 14:35:27 +08:00 committed by 建国
parent 9209fb589a
commit 063921f059
4 changed files with 291 additions and 195 deletions

View File

@ -374,8 +374,8 @@ public class EnterpriseTestReportService {
} }
reportContent.append(previweContent); reportContent.append(previweContent);
} else if (isReportStep(step.getType())) { } else if (isReportStep(step.getType())) {
if (isSchedule) { if (isSchedule && syncReportMap.containsKey(step.getReportRecordId())) {
//定时任务触发的数据需要检查图片是否需要重新生成如果生成不成功就不贴图 //定时任务触发的数据需要检查图片是否需要重新生成如果生成失败syncReportMap里有对应的步骤id但是没有图片数据
String imageFile = syncReportMap.get(step.getReportRecordId()); String imageFile = syncReportMap.get(step.getReportRecordId());
if (StringUtils.isNotEmpty(imageFile)) { if (StringUtils.isNotEmpty(imageFile)) {
step.setRecordImageContent(imageFile); step.setRecordImageContent(imageFile);

View File

@ -47,10 +47,6 @@ public class ChromeUtil {
try { try {
driver = new RemoteWebDriver(new URL(seleniumUrl), options); driver = new RemoteWebDriver(new URL(seleniumUrl), options);
} catch (Exception e) { } catch (Exception e) {
if (driver != null) {
driver.quit();
driver = null;
}
LogUtil.error(e); LogUtil.error(e);
} }
return driver; return driver;
@ -66,6 +62,7 @@ public class ChromeUtil {
for (Map.Entry<String, String> urlEntry : request.getUrlMap().entrySet()) { for (Map.Entry<String, String> urlEntry : request.getUrlMap().entrySet()) {
String id = urlEntry.getKey(); String id = urlEntry.getKey();
String url = urlEntry.getValue(); String url = urlEntry.getValue();
String files = null;
try { try {
driver.get(url); driver.get(url);
driver.manage().window().fullscreen(); driver.manage().window().fullscreen();
@ -77,21 +74,15 @@ public class ChromeUtil {
" imageUrl = chartsCanvas && chartsCanvas.toDataURL('image/png');" + " imageUrl = chartsCanvas && chartsCanvas.toDataURL('image/png');" +
"return imageUrl;" + "return imageUrl;" +
"}"; "}";
String files = ((JavascriptExecutor) driver).executeScript(js).toString(); files = ((JavascriptExecutor) driver).executeScript(js).toString();
if (StringUtils.isNotEmpty(files)) {
returnMap.put(id, files);
}
Thread.sleep(1 * 1000); Thread.sleep(1 * 1000);
} catch (Exception e) { } catch (Exception e) {
LogUtil.error("使用selenium获取图片报错!", e); LogUtil.error("使用selenium获取图片报错!", e);
} }
returnMap.put(id, files);
} }
if (driver != null) {
driver.quit(); driver.quit();
} }
}
return returnMap; return returnMap;
} }
} }

View File

@ -1,12 +1,16 @@
<template> <template>
<div v-loading="loading"> <div v-loading="loading">
<el-card class="ms-test-chart" :style="{height: h + 'px'}" ref="msDrawer"> <el-card class="ms-test-chart" :style="{ height: h + 'px' }" ref="msDrawer">
<el-row class="ms-row"> <el-row class="ms-row">
<p class="tip"><span style="margin-left: 5px"></span> {{ $t('commons.report_statistics.chart') }} </p> <p class="tip">
<span style="margin-left: 5px"></span>
{{ $t("commons.report_statistics.chart") }}
</p>
<div class="ms-test-chart-header" v-if="!readOnly"> <div class="ms-test-chart-header" v-if="!readOnly">
<el-dropdown @command="exportCommand" :hide-on-click="false"> <el-dropdown @command="exportCommand" :hide-on-click="false">
<span class="el-dropdown-link"> <span class="el-dropdown-link">
{{ $t('commons.export') }}<i class="el-icon-arrow-down el-icon--right"></i> {{ $t("commons.export")
}}<i class="el-icon-arrow-down el-icon--right"></i>
</span> </span>
<el-dropdown-menu slot="dropdown"> <el-dropdown-menu slot="dropdown">
<el-dropdown-item command="jpg">JPG</el-dropdown-item> <el-dropdown-item command="jpg">JPG</el-dropdown-item>
@ -14,24 +18,62 @@
</el-dropdown-menu> </el-dropdown-menu>
</el-dropdown> </el-dropdown>
<span style="margin: 0px 10px 10px">|</span> <span style="margin: 0px 10px 10px">|</span>
<el-select v-model="chartType" class="ms-col-type" size="mini" style="width: 100px" @change="generateOption"> <el-select
<el-option :key="t.id" :value="t.id" :label="t.name" v-for="t in charts"/> v-model="chartType"
class="ms-col-type"
size="mini"
style="width: 100px"
@change="generateOption"
>
<el-option
:key="t.id"
:value="t.id"
:label="t.name"
v-for="t in charts"
/>
</el-select> </el-select>
<span style="margin: 0px 10px 10px">|</span> <span style="margin: 0px 10px 10px">|</span>
<el-select v-model="order" class="ms-col-type" size="mini" style="width: 120px" @change="orderCharts"> <el-select
<el-option :key="t.id" :value="t.id" :label="t.name" v-for="t in orders"/> v-model="order"
class="ms-col-type"
size="mini"
style="width: 120px"
@change="orderCharts"
>
<el-option
:key="t.id"
:value="t.id"
:label="t.name"
v-for="t in orders"
/>
</el-select> </el-select>
<span style="margin: 0px 10px 10px">|</span> <span style="margin: 0px 10px 10px">|</span>
<font-awesome-icon v-if="!isFullScreen && showFullScreen" class="report-alt-ico" :icon="['fa', 'expand-alt']" <font-awesome-icon
size="lg" @click="fullScreen"/> v-if="!isFullScreen && showFullScreen"
<font-awesome-icon v-if="isFullScreen && showFullScreen" class="report-alt-ico" :icon="['fa', 'compress-alt']" class="report-alt-ico"
size="lg" @click="unFullScreen"/> :icon="['fa', 'expand-alt']"
size="lg"
@click="fullScreen"
/>
<font-awesome-icon
v-if="isFullScreen && showFullScreen"
class="report-alt-ico"
:icon="['fa', 'compress-alt']"
size="lg"
@click="unFullScreen"
/>
</div> </div>
</el-row> </el-row>
<el-row style="overflow: auto"> <el-row style="overflow: auto">
<ms-chart ref="chart1" v-if="!loading" :options="dataOption" <ms-chart
:style="{width: '100%', height: (h-70) + 'px'}" class="chart-config" :autoresize="true" ref="chart1"
id="picChart"/> v-if="!loading"
:options="dataOption"
:style="{ width: '100%', height: h - 70 + 'px' }"
class="chart-config"
:autoresize="true"
:id="reportId"
/>
</el-row> </el-row>
</el-card> </el-card>
</div> </div>
@ -42,7 +84,7 @@ import MsChart from "metersphere-frontend/src/components/chart/MsChart";
export default { export default {
name: "ReportChart", name: "ReportChart",
components: {MsChart}, components: { MsChart },
props: { props: {
loadOption: {}, loadOption: {},
pieOption: {}, pieOption: {},
@ -51,7 +93,7 @@ export default {
type: String, type: String,
default() { default() {
return "bar"; return "bar";
} },
}, },
chartWidth: Number, chartWidth: Number,
needFullScreen: Boolean, needFullScreen: Boolean,
@ -72,96 +114,118 @@ export default {
type: Boolean, type: Boolean,
default() { default() {
return true; return true;
} },
}, },
charts: [ charts: [
{id: 'bar', name: this.$t('commons.report_statistics.bar')}, { id: "bar", name: this.$t("commons.report_statistics.bar") },
{id: 'pie', name: this.$t('commons.report_statistics.pie')} { id: "pie", name: this.$t("commons.report_statistics.pie") },
], ],
order: "", order: "",
orders: [{id: '', name: this.$t('commons.sort_default')}, { orders: [
id: 'desc', { id: "", name: this.$t("commons.sort_default") },
name: this.$t('commons.report_statistics.desc') {
}, { id: "desc",
id: 'asc', name: this.$t("commons.report_statistics.desc"),
name: this.$t('commons.report_statistics.asc') },
}], {
id: "asc",
name: this.$t("commons.report_statistics.asc"),
},
],
loading: false, loading: false,
options: {}, options: {},
pieItemOption: { pieItemOption: {
dataset: [{ dataset: [
{
source: [ source: [
['Product', 'Sales', 'Price', 'Year'], ["Product", "Sales", "Price", "Year"],
['Cake', 123, 32, 2011], ["Cake", 123, 32, 2011],
['Cereal', 231, 14, 2011], ["Cereal", 231, 14, 2011],
['Tofu', 235, 5, 2011], ["Tofu", 235, 5, 2011],
['Dumpling', 341, 25, 2011], ["Dumpling", 341, 25, 2011],
['Biscuit', 122, 29, 2011], ["Biscuit", 122, 29, 2011],
['Cake', 143, 30, 2012], ["Cake", 143, 30, 2012],
['Cereal', 201, 19, 2012], ["Cereal", 201, 19, 2012],
['Tofu', 255, 7, 2012], ["Tofu", 255, 7, 2012],
['Dumpling', 241, 27, 2012], ["Dumpling", 241, 27, 2012],
['Biscuit', 102, 34, 2012], ["Biscuit", 102, 34, 2012],
['Cake', 153, 28, 2013], ["Cake", 153, 28, 2013],
['Cereal', 181, 21, 2013], ["Cereal", 181, 21, 2013],
['Tofu', 395, 4, 2013], ["Tofu", 395, 4, 2013],
['Dumpling', 281, 31, 2013], ["Dumpling", 281, 31, 2013],
['Biscuit', 92, 39, 2013], ["Biscuit", 92, 39, 2013],
['Cake', 223, 29, 2014], ["Cake", 223, 29, 2014],
['Cereal', 211, 17, 2014], ["Cereal", 211, 17, 2014],
['Tofu', 345, 3, 2014], ["Tofu", 345, 3, 2014],
['Dumpling', 211, 35, 2014], ["Dumpling", 211, 35, 2014],
['Biscuit', 72, 24, 2014], ["Biscuit", 72, 24, 2014],
], ],
}, {
transform: {
type: 'filter',
config: {dimension: 'Year', value: 2011}
}, },
}, { {
transform: { transform: {
type: 'filter', type: "filter",
config: {dimension: 'Year', value: 2012} config: { dimension: "Year", value: 2011 },
} },
}, { },
{
transform: { transform: {
type: 'filter', type: "filter",
config: {dimension: 'Year', value: 2013} config: { dimension: "Year", value: 2012 },
} },
}], },
series: [{ {
type: 'pie', radius: 50, center: ['50%', '25%'], transform: {
datasetIndex: 1 type: "filter",
}, { config: { dimension: "Year", value: 2013 },
type: 'pie', radius: 50, center: ['50%', '50%'], },
datasetIndex: 2 },
}, { ],
type: 'pie', radius: 50, center: ['50%', '75%'], series: [
datasetIndex: 3 {
}], type: "pie",
media: [{ radius: 50,
query: {minAspectRatio: 1}, center: ["50%", "25%"],
datasetIndex: 1,
},
{
type: "pie",
radius: 50,
center: ["50%", "50%"],
datasetIndex: 2,
},
{
type: "pie",
radius: 50,
center: ["50%", "75%"],
datasetIndex: 3,
},
],
media: [
{
query: { minAspectRatio: 1 },
option: { option: {
series: [ series: [
{center: ['25%', '50%']}, { center: ["25%", "50%"] },
{center: ['50%', '50%']}, { center: ["50%", "50%"] },
{center: ['75%', '50%']} { center: ["75%", "50%"] },
] ],
} },
}, { },
{
option: { option: {
series: [ series: [
{center: ['50%', '25%']}, { center: ["50%", "25%"] },
{center: ['50%', '50%']}, { center: ["50%", "50%"] },
{center: ['50%', '75%']} { center: ["50%", "75%"] },
] ],
}
}]
}, },
} },
],
},
};
}, },
created() { created() {
if (this.chartType === 'pie') { if (this.chartType === "pie") {
this.dataOption = this.pieOption; this.dataOption = this.pieOption;
} else { } else {
this.dataOption = this.loadOption; this.dataOption = this.loadOption;
@ -184,53 +248,53 @@ export default {
}, },
methods: { methods: {
countChartWidth() { countChartWidth() {
if (this.chartWidth === 0 || this.chartType === 'bar') { if (this.chartWidth === 0 || this.chartType === "bar") {
this.chartWidthNumber = this.w; this.chartWidthNumber = this.w;
} else { } else {
this.chartWidthNumber = this.chartWidth; this.chartWidthNumber = this.chartWidth;
} }
}, },
orderCharts() { orderCharts() {
this.$emit('orderCharts', this.order); this.$emit("orderCharts", this.order);
}, },
formatData(formatData) { formatData(formatData) {
if (!formatData) { if (!formatData) {
return; return;
} }
if (typeof (formatData.legend) === 'string') { if (typeof formatData.legend === "string") {
formatData.legend = JSON.parse(formatData.legend); formatData.legend = JSON.parse(formatData.legend);
} }
if (typeof (formatData.xaxis) === 'string') { if (typeof formatData.xaxis === "string") {
formatData.xaxis = JSON.parse(formatData.xaxis); formatData.xaxis = JSON.parse(formatData.xaxis);
} }
if (typeof (formatData.xAxis) === 'string') { if (typeof formatData.xAxis === "string") {
formatData.xAxis = JSON.parse(formatData.xAxis); formatData.xAxis = JSON.parse(formatData.xAxis);
} }
if (typeof (formatData.yAxis) === 'string') { if (typeof formatData.yAxis === "string") {
formatData.yAxis = JSON.parse(formatData.yAxis); formatData.yAxis = JSON.parse(formatData.yAxis);
} }
if (typeof (formatData.series) === 'string') { if (typeof formatData.series === "string") {
formatData.series = JSON.parse(formatData.series); formatData.series = JSON.parse(formatData.series);
} }
}, },
generateOption() { generateOption() {
if (this.chartType === 'pie') { if (this.chartType === "pie") {
this.dataOption = this.pieOption; this.dataOption = this.pieOption;
} else { } else {
this.dataOption = this.loadOption; this.dataOption = this.loadOption;
} }
this.formatData(this.dataOption); this.formatData(this.dataOption);
this.dataOption.series.forEach(item => { this.dataOption.series.forEach((item) => {
item.type = this.chartType; item.type = this.chartType;
}); });
// this.reload(); // this.reload();
}, },
reload() { reload() {
this.loading = true this.loading = true;
this.generateOption(); this.generateOption();
this.$nextTick(() => { this.$nextTick(() => {
this.loading = false; this.loading = false;
}) });
}, },
fullScreen() { fullScreen() {
this.originalW = this.w; this.originalW = this.w;
@ -238,22 +302,24 @@ export default {
this.w = document.body.clientWidth - 50; this.w = document.body.clientWidth - 50;
this.h = document.body.clientHeight; this.h = document.body.clientHeight;
this.isFullScreen = true; this.isFullScreen = true;
this.$emit('hidePage', true); this.$emit("hidePage", true);
}, },
unFullScreen() { unFullScreen() {
this.w = this.originalW; this.w = this.originalW;
this.h = this.originalH; this.h = this.originalH;
this.isFullScreen = false; this.isFullScreen = false;
this.$emit('hidePage', false); this.$emit("hidePage", false);
}, },
getImages(command) { getImages(command) {
let imageType = 'image/png'; let imageType = "image/png";
if (command === 'jpg') { if (command === "jpg") {
imageType = 'image/jpg'; imageType = "image/jpg";
} }
let returnImageData = ""; let returnImageData = "";
if (document.getElementById(this.reportId)) { if (document.getElementById(this.reportId)) {
let chartsCanvas = document.getElementById(this.reportId).querySelectorAll('canvas')[0]; let chartsCanvas = document
.getElementById(this.reportId)
.querySelectorAll("canvas")[0];
if (chartsCanvas) { if (chartsCanvas) {
// toDataURL()canvascanvasbase64 // toDataURL()canvascanvasbase64
returnImageData = chartsCanvas && chartsCanvas.toDataURL(imageType); returnImageData = chartsCanvas && chartsCanvas.toDataURL(imageType);
@ -263,46 +329,50 @@ export default {
return returnImageData; return returnImageData;
}, },
exportCommand(command) { exportCommand(command) {
let fileName = 'report_pic.' + command; let fileName = "report_pic." + command;
if (document.getElementById('picChart')) { if (document.getElementById("picChart")) {
let chartsCanvas = document.getElementById('picChart').querySelectorAll('canvas')[0] let chartsCanvas = document
let mime = 'image/png'; .getElementById("picChart")
if (command === 'jpg') { .querySelectorAll("canvas")[0];
mime = 'image/jpg'; let mime = "image/png";
if (command === "jpg") {
mime = "image/jpg";
} }
if (chartsCanvas) { if (chartsCanvas) {
// toDataURL()canvascanvasbase64 // toDataURL()canvascanvasbase64
let imageUrl = chartsCanvas && chartsCanvas.toDataURL(mime) let imageUrl = chartsCanvas && chartsCanvas.toDataURL(mime);
if (navigator.userAgent.indexOf('Trident') > -1) { if (navigator.userAgent.indexOf("Trident") > -1) {
// IE11 // IE11
let arr = imageUrl.split(',') let arr = imageUrl.split(",");
// atob() 使base64 // atob() 使base64
let bstr = atob(arr[1]) let bstr = atob(arr[1]);
let bstrLen = bstr.length let bstrLen = bstr.length;
// Uint8Array, 8 0 // Uint8Array, 8 0
let u8arr = new Uint8Array(bstrLen) let u8arr = new Uint8Array(bstrLen);
while (bstrLen--) { while (bstrLen--) {
// charCodeAt() Unicode // charCodeAt() Unicode
u8arr[bstrLen] = bstr.charCodeAt(bstrLen) u8arr[bstrLen] = bstr.charCodeAt(bstrLen);
} }
// msSaveOrOpenBlob Internet // msSaveOrOpenBlob Internet
window.navigator.msSaveOrOpenBlob(new Blob([u8arr], {type: mime}), fileName); window.navigator.msSaveOrOpenBlob(
new Blob([u8arr], { type: mime }),
fileName
);
} else { } else {
// //
let $a = document.createElement('a') let $a = document.createElement("a");
$a.setAttribute('href', imageUrl) $a.setAttribute("href", imageUrl);
$a.setAttribute('download', fileName) $a.setAttribute("download", fileName);
$a.click() $a.click();
} }
} }
} }
}, },
}, },
} };
</script> </script>
<style scoped> <style scoped>
.ms-test-chart-header { .ms-test-chart-header {
z-index: 999; z-index: 999;
width: 380px; width: 380px;
@ -345,5 +415,4 @@ export default {
:deep(.el-card__body) { :deep(.el-card__body) {
padding: 0px; padding: 0px;
} }
</style> </style>

View File

@ -4,35 +4,50 @@
<div v-if="!reportDetail.nameIsEdit" style="line-height: 30px"> <div v-if="!reportDetail.nameIsEdit" style="line-height: 30px">
<span style="margin-left: 5px">{{ reportDetail.name }}</span> <span style="margin-left: 5px">{{ reportDetail.name }}</span>
<i class="el-icon-edit" @click="editAttachDataName(true)"></i> <i class="el-icon-edit" @click="editAttachDataName(true)"></i>
<i class="el-icon-delete" @click="deleteDetail" style="float: right;margin-top: 6px; margin-right: 10px"></i> <i
class="el-icon-delete"
@click="deleteDetail"
style="float: right; margin-top: 6px; margin-right: 10px"
></i>
</div> </div>
<el-input v-else v-model="reportDetail.name" @blur="editAttachDataName(false)"></el-input> <el-input
v-else
v-model="reportDetail.name"
@blur="editAttachDataName(false)"
></el-input>
</div> </div>
<div class="ms-row"> <div class="ms-row">
<report-chart :report-id="reportDetail.id" :chart-width="pieOption.width" :read-only="true" <report-chart
:need-full-screen="false" :chart-type="chartType" :report-id="reportDetail.id"
ref="analysisChart" :load-option="loadOption" :pie-option="pieOption"/> :chart-width="pieOption.width"
:read-only="true"
:need-full-screen="false"
:chart-type="chartType"
ref="analysisChart"
:load-option="loadOption"
:pie-option="pieOption"
/>
</div> </div>
<div class="ms-row"> <div class="ms-row">
<report-table :full-screen="false" :group-name="options.xaxis" :show-columns="options.yaxis" <report-table
:tableData="tableData"/> :full-screen="false"
:group-name="options.xaxis"
:show-columns="options.yaxis"
:tableData="tableData"
/>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
import ReportChart from "@/business/enterprisereport/components/chart/ReportChart"; import ReportChart from "@/business/enterprisereport/components/chart/ReportChart";
import ReportTable from "@/business/enterprisereport/components/chart/ReportTable"; import ReportTable from "@/business/enterprisereport/components/chart/ReportTable";
export default { export default {
name: "ReportPic", name: "ReportPic",
components: {ReportChart, ReportTable}, components: { ReportChart, ReportTable },
data() { data() {
return { return {
chartType: "bar", chartType: "bar",
loading: false, loading: false,
options: {}, options: {},
@ -42,7 +57,7 @@ export default {
yAxis: {}, yAxis: {},
label: {}, label: {},
tooltip: {}, tooltip: {},
series: [] series: [],
}, },
pieOption: { pieOption: {
legend: {}, legend: {},
@ -61,7 +76,7 @@ export default {
type: Boolean, type: Boolean,
default() { default() {
return false; return false;
} },
}, },
}, },
created() { created() {
@ -80,9 +95,9 @@ export default {
let selectTableData = this.reportDetail.reportRecordData.tableData; let selectTableData = this.reportDetail.reportRecordData.tableData;
let selectOption = this.reportDetail.reportRecordData.selectOption; let selectOption = this.reportDetail.reportRecordData.selectOption;
if (this.reportDetail.reportRecordData.chartType) { if (this.reportDetail.reportRecordData.chartType) {
if (this.reportDetail.reportRecordData.chartType === "\"bar\"") { if (this.reportDetail.reportRecordData.chartType === '"bar"') {
this.chartType = "bar"; this.chartType = "bar";
} else if (this.reportDetail.reportRecordData.chartType === "\"pie\"") { } else if (this.reportDetail.reportRecordData.chartType === '"pie"') {
this.chartType = "pie"; this.chartType = "pie";
} else { } else {
this.chartType = this.reportDetail.reportRecordData.chartType; this.chartType = this.reportDetail.reportRecordData.chartType;
@ -91,16 +106,26 @@ export default {
if (selectOption) { if (selectOption) {
this.options = selectOption; this.options = selectOption;
if (this.options.xaxis) { if (this.options.xaxis) {
if (this.options.xaxis === 'creator') { if (this.options.xaxis === "creator") {
this.options.xaxis = this.$t('commons.report_statistics.report_filter.select_options.creator'); this.options.xaxis = this.$t(
} else if (this.options.xaxis === 'maintainer') { "commons.report_statistics.report_filter.select_options.creator"
this.options.xaxis = this.$t('commons.report_statistics.report_filter.select_options.maintainer'); );
} else if (this.options.xaxis === 'casetype') { } else if (this.options.xaxis === "maintainer") {
this.options.xaxis = this.$t('commons.report_statistics.report_filter.select_options.case_type'); this.options.xaxis = this.$t(
} else if (this.options.xaxis === 'casestatus') { "commons.report_statistics.report_filter.select_options.maintainer"
this.options.xaxis = this.$t('commons.report_statistics.report_filter.select_options.case_status'); );
} else if (this.options.xaxis === 'caselevel') { } else if (this.options.xaxis === "casetype") {
this.options.xaxis = this.$t('commons.report_statistics.report_filter.select_options.case_level'); this.options.xaxis = this.$t(
"commons.report_statistics.report_filter.select_options.case_type"
);
} else if (this.options.xaxis === "casestatus") {
this.options.xaxis = this.$t(
"commons.report_statistics.report_filter.select_options.case_status"
);
} else if (this.options.xaxis === "caselevel") {
this.options.xaxis = this.$t(
"commons.report_statistics.report_filter.select_options.case_level"
);
} }
} }
} }
@ -113,9 +138,9 @@ export default {
this.loadOption.xaxis = barData.xaxis; this.loadOption.xaxis = barData.xaxis;
this.loadOption.series = barData.series; this.loadOption.series = barData.series;
this.loadOption.grid = { this.loadOption.grid = {
bottom: '75px',// bottom: "75px", //
}; };
this.loadOption.series.forEach(item => { this.loadOption.series.forEach((item) => {
item.type = "bar"; item.type = "bar";
}); });
} }
@ -125,13 +150,13 @@ export default {
this.pieOption.series = pieData.series; this.pieOption.series = pieData.series;
this.pieOption.title = pieData.title; this.pieOption.title = pieData.title;
this.pieOption.grid = { this.pieOption.grid = {
bottom: '75px',// bottom: "75px", //
}; };
if (pieData.width) { if (pieData.width) {
this.pieOption.width = pieData.width; this.pieOption.width = pieData.width;
this.chartWidth = pieData.width; this.chartWidth = pieData.width;
} }
this.pieOption.series.forEach(item => { this.pieOption.series.forEach((item) => {
item.type = "pie"; item.type = "pie";
}); });
} }
@ -147,39 +172,50 @@ export default {
if (!formatData) { if (!formatData) {
return; return;
} }
if (typeof (formatData.legend) === 'string') { if (typeof formatData.legend === "string") {
formatData.legend = JSON.parse(formatData.legend); formatData.legend = JSON.parse(formatData.legend);
} }
if (typeof (formatData.xaxis) === 'string') { if (typeof formatData.xaxis === "string") {
formatData.xaxis = JSON.parse(formatData.xaxis); formatData.xaxis = JSON.parse(formatData.xaxis);
} }
if (typeof (formatData.series) === 'string') { if (typeof formatData.series === "string") {
formatData.series = JSON.parse(formatData.series); formatData.series = JSON.parse(formatData.series);
} }
if (typeof (formatData.title) === 'string') { if (typeof formatData.title === "string") {
formatData.title = JSON.parse(formatData.title); formatData.title = JSON.parse(formatData.title);
} }
}, },
initData() { initData() {
this.reportDetail.recordImageContent = this.$refs.analysisChart.getImages("png"); this.reportDetail.recordImageContent =
this.$refs.analysisChart.getImages("png");
}, },
getGroupNameStr(groupName) { getGroupNameStr(groupName) {
if (groupName === 'creator') { if (groupName === "creator") {
return this.$t('commons.report_statistics.report_filter.select_options.creator'); return this.$t(
} else if (groupName === 'maintainer') { "commons.report_statistics.report_filter.select_options.creator"
return this.$t('commons.report_statistics.report_filter.select_options.maintainer'); );
} else if (groupName === 'casetype') { } else if (groupName === "maintainer") {
return this.$t('commons.report_statistics.report_filter.select_options.case_type'); return this.$t(
} else if (groupName === 'casestatus') { "commons.report_statistics.report_filter.select_options.maintainer"
return this.$t('commons.report_statistics.report_filter.select_options.case_status'); );
} else if (groupName === 'caselevel') { } else if (groupName === "casetype") {
return this.$t('commons.report_statistics.report_filter.select_options.case_level'); return this.$t(
"commons.report_statistics.report_filter.select_options.case_type"
);
} else if (groupName === "casestatus") {
return this.$t(
"commons.report_statistics.report_filter.select_options.case_status"
);
} else if (groupName === "caselevel") {
return this.$t(
"commons.report_statistics.report_filter.select_options.case_level"
);
} else { } else {
return ""; return "";
} }
}, },
} },
} };
</script> </script>
<style scoped> <style scoped>