forked from github/dataease
Merge branch 'dev-v2' into pr@dev-v2@fixDatasource
This commit is contained in:
commit
2bc4eabc4b
@ -4,7 +4,6 @@
|
|||||||
<a href="https://www.gnu.org/licenses/gpl-3.0.html"><img src="https://img.shields.io/github/license/dataease/dataease?color=%231890FF" alt="License: GPL v3"></a>
|
<a href="https://www.gnu.org/licenses/gpl-3.0.html"><img src="https://img.shields.io/github/license/dataease/dataease?color=%231890FF" alt="License: GPL v3"></a>
|
||||||
<a href="https://app.codacy.com/gh/dataease/dataease?utm_source=github.com&utm_medium=referral&utm_content=dataease/dataease&utm_campaign=Badge_Grade_Dashboard"><img src="https://app.codacy.com/project/badge/Grade/da67574fd82b473992781d1386b937ef" alt="Codacy"></a>
|
<a href="https://app.codacy.com/gh/dataease/dataease?utm_source=github.com&utm_medium=referral&utm_content=dataease/dataease&utm_campaign=Badge_Grade_Dashboard"><img src="https://app.codacy.com/project/badge/Grade/da67574fd82b473992781d1386b937ef" alt="Codacy"></a>
|
||||||
<a href="https://github.com/dataease/dataease"><img src="https://img.shields.io/github/stars/dataease/dataease?color=%231890FF&style=flat-square" alt="Stars"></a>
|
<a href="https://github.com/dataease/dataease"><img src="https://img.shields.io/github/stars/dataease/dataease?color=%231890FF&style=flat-square" alt="Stars"></a>
|
||||||
<a href="https://app.fossa.com/projects/git%2Bgithub.com%2F1dataease%2Fdataease?ref=badge_shield"><img src="https://app.fossa.com/api/projects/git%2Bgithub.com%2Fdataease%2Fdataease.svg?type=shield" alt="FOSSA Status"></a>
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|说明|
|
|说明|
|
||||||
@ -16,9 +15,7 @@
|
|||||||
|
|
||||||
DataEase 是开源的数据可视化分析工具,帮助用户快速分析数据并洞察业务趋势,从而实现业务的改进与优化。DataEase 支持丰富的数据源连接,能够通过拖拉拽方式快速制作图表,并可以方便的与他人分享。
|
DataEase 是开源的数据可视化分析工具,帮助用户快速分析数据并洞察业务趋势,从而实现业务的改进与优化。DataEase 支持丰富的数据源连接,能够通过拖拉拽方式快速制作图表,并可以方便的与他人分享。
|
||||||
|
|
||||||
**DataEase 的工作原理:**
|
data:image/s3,"s3://crabby-images/f162b/f162bfeeeff6b4c637cd345c9647312fbab4c639" alt="DataEase 概览图"
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/40196/401964ecb193f63c51aeb384c4db7f022778983d" alt="image"
|
|
||||||
|
|
||||||
**DataEase 的优势:**
|
**DataEase 的优势:**
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ const switchValue = computed({
|
|||||||
:effect="themes"
|
:effect="themes"
|
||||||
size="small"
|
size="small"
|
||||||
v-model="switchValue"
|
v-model="switchValue"
|
||||||
@click.stop="e => onSwitchChange(e)"
|
@click.stop="onSwitchChange"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -63,5 +63,18 @@ const switchValue = computed({
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
padding-right: 8px;
|
padding-right: 8px;
|
||||||
flex-grow: 1;
|
flex-grow: 1;
|
||||||
|
:deep(.ed-switch.is-checked .ed-switch__core > .ed-switch__action) {
|
||||||
|
left: calc(100% - 12px);
|
||||||
|
}
|
||||||
|
:deep(span.ed-switch__core) {
|
||||||
|
min-width: 24px;
|
||||||
|
border: none;
|
||||||
|
height: 6px;
|
||||||
|
border-radius: 3px;
|
||||||
|
.ed-switch__action {
|
||||||
|
left: 0;
|
||||||
|
box-shadow: 0 2px 4px rgba(31, 35, 41, 0.12);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -577,7 +577,11 @@ export const dvMainStore = defineStore('dataVisualization', {
|
|||||||
} else {
|
} else {
|
||||||
viewInfo[propertyInfo.custom][propertyInfo.property] = propertyInfo.value
|
viewInfo[propertyInfo.custom][propertyInfo.property] = propertyInfo.value
|
||||||
}
|
}
|
||||||
useEmitt().emitter.emit('renderChart-' + viewId, viewInfo)
|
if (['tablePageMode', 'tablePageSize'].includes(propertyInfo.subProp)) {
|
||||||
|
useEmitt().emitter.emit('calcData-' + viewId, viewInfo)
|
||||||
|
} else {
|
||||||
|
useEmitt().emitter.emit('renderChart-' + viewId, viewInfo)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
this.componentData.forEach(component => {
|
this.componentData.forEach(component => {
|
||||||
|
@ -83,6 +83,11 @@ const checkDialog = () => {
|
|||||||
haveDialog = true
|
haveDialog = true
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
document.querySelectorAll('.ed-popover').forEach(element => {
|
||||||
|
if (window.getComputedStyle(element).getPropertyValue('display') != 'none') {
|
||||||
|
haveDialog = true
|
||||||
|
}
|
||||||
|
})
|
||||||
// 富文本单框
|
// 富文本单框
|
||||||
if (document.querySelector('.tox-dialog-wrap')) {
|
if (document.querySelector('.tox-dialog-wrap')) {
|
||||||
haveDialog = true
|
haveDialog = true
|
||||||
|
@ -5,7 +5,7 @@ import {
|
|||||||
import { Line as G2Line, LineOptions } from '@antv/g2plot/esm/plots/line'
|
import { Line as G2Line, LineOptions } from '@antv/g2plot/esm/plots/line'
|
||||||
import { getPadding } from '../../common/common_antv'
|
import { getPadding } from '../../common/common_antv'
|
||||||
import { flow, hexColorToRGBA, parseJson } from '@/views/chart/components/js/util'
|
import { flow, hexColorToRGBA, parseJson } from '@/views/chart/components/js/util'
|
||||||
import { cloneDeep } from 'lodash-es'
|
import { cloneDeep, isEmpty } from 'lodash-es'
|
||||||
import { valueFormatter } from '@/views/chart/components/js/formatter'
|
import { valueFormatter } from '@/views/chart/components/js/formatter'
|
||||||
import {
|
import {
|
||||||
LINE_AXIS_TYPE,
|
LINE_AXIS_TYPE,
|
||||||
@ -214,11 +214,67 @@ export class Line extends G2PlotChartView<LineOptions, G2Line> {
|
|||||||
return tmpOptions
|
return tmpOptions
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected configTooltip(chart: Chart, options: LineOptions): LineOptions {
|
||||||
|
const customAttr: DeepPartial<ChartAttr> = parseJson(chart.customAttr)
|
||||||
|
const tooltipAttr = customAttr.tooltip
|
||||||
|
if (!tooltipAttr.show) {
|
||||||
|
return {
|
||||||
|
...options,
|
||||||
|
tooltip: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const xAxisExt = chart.xAxisExt
|
||||||
|
const formatterMap = tooltipAttr.seriesTooltipFormatter
|
||||||
|
?.filter(i => i.show)
|
||||||
|
.reduce((pre, next) => {
|
||||||
|
pre[next.id] = next
|
||||||
|
return pre
|
||||||
|
}, {}) as Record<string, SeriesFormatter>
|
||||||
|
const tooltip: LineOptions['tooltip'] = {
|
||||||
|
showTitle: true,
|
||||||
|
customItems(originalItems) {
|
||||||
|
if (!tooltipAttr.seriesTooltipFormatter?.length) {
|
||||||
|
return originalItems
|
||||||
|
}
|
||||||
|
const head = originalItems[0]
|
||||||
|
// 非原始数据
|
||||||
|
if (!head.data.quotaList) {
|
||||||
|
return originalItems
|
||||||
|
}
|
||||||
|
const result = []
|
||||||
|
originalItems
|
||||||
|
.filter(item => formatterMap[item.data.quotaList[0].id])
|
||||||
|
.forEach(item => {
|
||||||
|
const formatter = formatterMap[item.data.quotaList[0].id]
|
||||||
|
const value = valueFormatter(parseFloat(item.value as string), formatter.formatterCfg)
|
||||||
|
let name = isEmpty(formatter.chartShowName) ? formatter.name : formatter.chartShowName
|
||||||
|
if (xAxisExt?.length > 0) {
|
||||||
|
name = item.data.category
|
||||||
|
}
|
||||||
|
result.push({ ...item, name, value })
|
||||||
|
})
|
||||||
|
head.data.dynamicTooltipValue?.forEach(item => {
|
||||||
|
const formatter = formatterMap[item.fieldId]
|
||||||
|
if (formatter) {
|
||||||
|
const value = valueFormatter(parseFloat(item.value), formatter.formatterCfg)
|
||||||
|
const name = isEmpty(formatter.chartShowName) ? formatter.name : formatter.chartShowName
|
||||||
|
result.push({ color: 'grey', name, value })
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
...options,
|
||||||
|
tooltip
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected setupOptions(chart: Chart, options: LineOptions): LineOptions {
|
protected setupOptions(chart: Chart, options: LineOptions): LineOptions {
|
||||||
return flow(
|
return flow(
|
||||||
this.configTheme,
|
this.configTheme,
|
||||||
this.configLabel,
|
this.configLabel,
|
||||||
this.configMultiSeriesTooltip,
|
this.configTooltip,
|
||||||
this.configBasicStyle,
|
this.configBasicStyle,
|
||||||
this.configCustomColors,
|
this.configCustomColors,
|
||||||
this.configLegend,
|
this.configLegend,
|
||||||
|
@ -108,18 +108,21 @@ const renderChartFromDialog = (viewInfo: Chart, chartDataInfo) => {
|
|||||||
chartData.value = chartDataInfo
|
chartData.value = chartDataInfo
|
||||||
renderChart(viewInfo, false)
|
renderChart(viewInfo, false)
|
||||||
}
|
}
|
||||||
const renderChart = (view: Chart, resetPageInfo: boolean) => {
|
const renderChart = (viewInfo: Chart, resetPageInfo: boolean) => {
|
||||||
if (!view) {
|
if (!viewInfo) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// view 为引用对象 需要存库 view.data 直接赋值会导致保存不必要的数据
|
// view 为引用对象 需要存库 view.data 直接赋值会导致保存不必要的数据
|
||||||
const chart = {
|
const chart = {
|
||||||
...defaultsDeep(view, cloneDeep(BASE_VIEW_CONFIG)),
|
...defaultsDeep(viewInfo, cloneDeep(BASE_VIEW_CONFIG)),
|
||||||
data: chartData.value
|
data: chartData.value
|
||||||
} as ChartObj
|
} as ChartObj
|
||||||
setupPage(chart, resetPageInfo)
|
setupPage(chart, resetPageInfo)
|
||||||
myChart?.destroy()
|
myChart?.destroy()
|
||||||
const chartView = chartViewManager.getChartView(view.render, view.type) as S2ChartView<any>
|
const chartView = chartViewManager.getChartView(
|
||||||
|
viewInfo.render,
|
||||||
|
viewInfo.type
|
||||||
|
) as S2ChartView<any>
|
||||||
myChart = chartView.drawChart({
|
myChart = chartView.drawChart({
|
||||||
container: containerId,
|
container: containerId,
|
||||||
chart: toRaw(chart),
|
chart: toRaw(chart),
|
||||||
|
Loading…
Reference in New Issue
Block a user