@visactor/vseed 0.1.37 → 0.1.39
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/index.cjs +2 -2
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/builder/builder/buildAdvanced.js +1 -1
- package/dist/esm/builder/builder/buildAdvanced.js.map +1 -1
- package/dist/esm/builder/builder/builder.d.ts +4147 -965
- package/dist/esm/builder/register/all.js +3 -1
- package/dist/esm/builder/register/all.js.map +1 -1
- package/dist/esm/builder/register/chartType/boxplot.d.ts +1 -0
- package/dist/esm/builder/register/chartType/boxplot.js +9 -0
- package/dist/esm/builder/register/chartType/boxplot.js.map +1 -0
- package/dist/esm/builder/register/chartType/histogram.d.ts +1 -0
- package/dist/esm/builder/register/chartType/histogram.js +9 -0
- package/dist/esm/builder/register/chartType/histogram.js.map +1 -0
- package/dist/esm/builder/register/chartType/index.d.ts +2 -0
- package/dist/esm/builder/register/chartType/index.js +3 -1
- package/dist/esm/dataReshape/constant.d.ts +10 -0
- package/dist/esm/dataReshape/constant.js +11 -1
- package/dist/esm/dataReshape/constant.js.map +1 -1
- package/dist/esm/dataReshape/unfoldDimensions.js +2 -2
- package/dist/esm/dataReshape/unfoldDimensions.js.map +1 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.js +2 -2
- package/dist/esm/pipeline/advanced/chart/pipeline/boxplot.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/boxplot.js +33 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/boxplot.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/histogram.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/histogram.js +34 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/histogram.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/index.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipeline/index.js +3 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/boxplot.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/boxplot.js +31 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/boxplot.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/dualAxis.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/dualAxis.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/histogram.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/histogram.js +33 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/histogram.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.d.ts +3 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.js +3 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/boxplot.d.ts +3 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/boxplot.js +80 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/boxplot.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/histogram.d.ts +3 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/histogram.js +78 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/histogram.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/index.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/index.js +3 -1
- package/dist/esm/pipeline/advanced/chart/pipes/index.d.ts +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/index.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/measures/buildMeasures.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/regressionLine/index.d.ts +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/regressionLine/index.js +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/regressionLine/regressionLine.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/regressionLine/regressionLine.js +8 -0
- package/dist/esm/pipeline/advanced/chart/pipes/regressionLine/regressionLine.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/index.d.ts +4 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/index.js +5 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js +96 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js +96 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.js +84 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js +86 -0
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipeline/bar.js +0 -1
- package/dist/esm/pipeline/spec/chart/pipeline/bar.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/boxplot.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipeline/boxplot.js +52 -0
- package/dist/esm/pipeline/spec/chart/pipeline/boxplot.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipeline/dualAxis.js +5 -1
- package/dist/esm/pipeline/spec/chart/pipeline/dualAxis.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/histogram.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipeline/histogram.js +52 -0
- package/dist/esm/pipeline/spec/chart/pipeline/histogram.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipeline/index.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipeline/index.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipes/annotation/annotationAreaBand.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/annotation/annotationPoint.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetBoxplot.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetBoxplot.js +18 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetBoxplot.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetHistogram.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetHistogram.js +18 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/datasetHistogram.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/index.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/dataset/index.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipes/dataset/progressive.js +4 -8
- package/dist/esm/pipeline/spec/chart/pipes/dataset/progressive.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/index.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/index.js +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/boxplot.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/boxplot.js +37 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/boxplot.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/histogram.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/histogram.js +21 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/histogram.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/index.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/index.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipes/init/pivot.js +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/init/pivot.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/label/label.d.ts +15 -4
- package/dist/esm/pipeline/spec/chart/pipes/label/label.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/label/labelDualAxis.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/label/labelPie.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/label/labelScatter.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/legend/pivotColorLegend.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/legend/pivotDiscreteLegend.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/markStyle/pointState.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotColumnDimensions.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotGridStyle.js +49 -14
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotGridStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotIndicators.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotRowDimensions.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/regressionLine/histogramRegressionLine.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/regressionLine/histogramRegressionLine.js +126 -0
- package/dist/esm/pipeline/spec/chart/pipes/regressionLine/histogramRegressionLine.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/regressionLine/index.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/regressionLine/index.js +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/stack/stackCornerRadius.js +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/stack/stackCornerRadius.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/index.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/index.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipBoxplot.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipBoxplot.js +98 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipBoxplot.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipHistogram.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipHistogram.js +69 -0
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipHistogram.js.map +1 -0
- package/dist/esm/pipeline/spec/table/pipes/columns/measuresToColumns.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/indicators/pivotDataConfig.js +1 -2
- package/dist/esm/pipeline/spec/table/pipes/indicators/pivotDataConfig.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/indicators/pivotIndicators.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/init/pivotTable.js +1 -0
- package/dist/esm/pipeline/spec/table/pipes/init/pivotTable.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/init/table.js +1 -0
- package/dist/esm/pipeline/spec/table/pipes/init/table.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/bodyStyle.js +1 -0
- package/dist/esm/pipeline/spec/table/pipes/theme/bodyStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/cornerHeaderStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/frameStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/headerStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/rowHeaderStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/scrollStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/selectionStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/table/pipes/theme/type.d.ts +13 -0
- package/dist/esm/pipeline/spec/table/pipes/theme/type.js +0 -0
- package/dist/esm/pipeline/utils/constant.d.ts +2 -0
- package/dist/esm/pipeline/utils/constant.js +3 -1
- package/dist/esm/pipeline/utils/constant.js.map +1 -1
- package/dist/esm/theme/common/regressionLine.d.ts +4 -0
- package/dist/esm/theme/common/regressionLine.js +16 -0
- package/dist/esm/theme/common/regressionLine.js.map +1 -0
- package/dist/esm/theme/common/table.d.ts +17 -8
- package/dist/esm/theme/common/table.js +11 -8
- package/dist/esm/theme/common/table.js.map +1 -1
- package/dist/esm/theme/dark/dark.js +18 -0
- package/dist/esm/theme/dark/dark.js.map +1 -1
- package/dist/esm/theme/light/light.js +18 -0
- package/dist/esm/theme/light/light.js.map +1 -1
- package/dist/esm/types/advancedVSeed.d.ts +1441 -17
- package/dist/esm/types/advancedVSeed.js +3 -2
- package/dist/esm/types/advancedVSeed.js.map +1 -1
- package/dist/esm/types/chartType/area/zArea.d.ts +9 -0
- package/dist/esm/types/chartType/areaPercent/zAreaPercent.d.ts +9 -0
- package/dist/esm/types/chartType/bar/zBar.d.ts +9 -0
- package/dist/esm/types/chartType/barParallel/zBarParallel.d.ts +9 -0
- package/dist/esm/types/chartType/barPercent/zBarPercent.d.ts +9 -0
- package/dist/esm/types/chartType/boxplot/boxplot.d.ts +144 -0
- package/dist/esm/types/chartType/boxplot/boxplot.js +0 -0
- package/dist/esm/types/chartType/boxplot/index.d.ts +2 -0
- package/dist/esm/types/chartType/boxplot/index.js +1 -0
- package/dist/esm/types/chartType/boxplot/zBoxplot.d.ts +1185 -0
- package/dist/esm/types/chartType/boxplot/zBoxplot.js +30 -0
- package/dist/esm/types/chartType/boxplot/zBoxplot.js.map +1 -0
- package/dist/esm/types/chartType/column/zColumn.d.ts +25 -0
- package/dist/esm/types/chartType/column/zColumn.js +3 -1
- package/dist/esm/types/chartType/column/zColumn.js.map +1 -1
- package/dist/esm/types/chartType/columnParallel/zColumnParallel.d.ts +9 -0
- package/dist/esm/types/chartType/columnPercent/zColumnPercent.d.ts +9 -0
- package/dist/esm/types/chartType/donut/zDonut.d.ts +9 -0
- package/dist/esm/types/chartType/funnel/zFunnel.d.ts +9 -0
- package/dist/esm/types/chartType/histogram/histogram.d.ts +127 -0
- package/dist/esm/types/chartType/histogram/histogram.js +0 -0
- package/dist/esm/types/chartType/histogram/index.d.ts +2 -0
- package/dist/esm/types/chartType/histogram/index.js +1 -0
- package/dist/esm/types/chartType/histogram/zHistogram.d.ts +1377 -0
- package/dist/esm/types/chartType/histogram/zHistogram.js +32 -0
- package/dist/esm/types/chartType/histogram/zHistogram.js.map +1 -0
- package/dist/esm/types/chartType/index.d.ts +3 -0
- package/dist/esm/types/chartType/index.js +2 -0
- package/dist/esm/types/chartType/line/zLine.d.ts +9 -0
- package/dist/esm/types/chartType/pie/zPie.d.ts +9 -0
- package/dist/esm/types/chartType/radar/zRadar.d.ts +9 -0
- package/dist/esm/types/chartType/rose/zRose.d.ts +9 -0
- package/dist/esm/types/chartType/roseParallel/zRoseParallel.d.ts +9 -0
- package/dist/esm/types/chartType/scatter/zScatter.d.ts +9 -0
- package/dist/esm/types/properties/chartType/chartType.d.ts +3 -1
- package/dist/esm/types/properties/chartType/chartType.js +3 -1
- package/dist/esm/types/properties/chartType/chartType.js.map +1 -1
- package/dist/esm/types/properties/config/area.d.ts +4 -0
- package/dist/esm/types/properties/config/bar.d.ts +6 -0
- package/dist/esm/types/properties/config/boxplot.d.ts +326 -0
- package/dist/esm/types/properties/config/boxplot.js +27 -0
- package/dist/esm/types/properties/config/boxplot.js.map +1 -0
- package/dist/esm/types/properties/config/column.d.ts +6 -0
- package/dist/esm/types/properties/config/config.d.ts +697 -0
- package/dist/esm/types/properties/config/config.js +5 -1
- package/dist/esm/types/properties/config/config.js.map +1 -1
- package/dist/esm/types/properties/config/dualAxis.d.ts +2 -0
- package/dist/esm/types/properties/config/funnel.d.ts +2 -0
- package/dist/esm/types/properties/config/heatmap.d.ts +2 -0
- package/dist/esm/types/properties/config/histogram.d.ts +339 -0
- package/dist/esm/types/properties/config/histogram.js +32 -0
- package/dist/esm/types/properties/config/histogram.js.map +1 -0
- package/dist/esm/types/properties/config/index.d.ts +1 -0
- package/dist/esm/types/properties/config/index.js +1 -0
- package/dist/esm/types/properties/config/line.d.ts +2 -0
- package/dist/esm/types/properties/config/pie.d.ts +6 -0
- package/dist/esm/types/properties/config/pivotGrid/pivotGrid.d.ts +2 -0
- package/dist/esm/types/properties/config/pivotGrid/pivotGrid.js +3 -1
- package/dist/esm/types/properties/config/pivotGrid/pivotGrid.js.map +1 -1
- package/dist/esm/types/properties/config/rose.d.ts +4 -0
- package/dist/esm/types/properties/config/scatter.d.ts +2 -0
- package/dist/esm/types/properties/config/whiskers/index.d.ts +3 -0
- package/dist/esm/types/properties/config/whiskers/index.js +5 -0
- package/dist/esm/types/properties/config/whiskers/index.js.map +1 -0
- package/dist/esm/types/properties/encoding/encoding.d.ts +36 -0
- package/dist/esm/types/properties/encoding/measureEncoding.d.ts +1 -1
- package/dist/esm/types/properties/encoding/zEncoding.d.ts +9 -0
- package/dist/esm/types/properties/encoding/zEncoding.js +10 -1
- package/dist/esm/types/properties/encoding/zEncoding.js.map +1 -1
- package/dist/esm/types/properties/index.d.ts +1 -0
- package/dist/esm/types/properties/index.js +1 -0
- package/dist/esm/types/properties/regressionLine/histogramRegressionLine.d.ts +45 -0
- package/dist/esm/types/properties/regressionLine/histogramRegressionLine.js +0 -0
- package/dist/esm/types/properties/regressionLine/index.d.ts +2 -0
- package/dist/esm/types/properties/regressionLine/index.js +1 -0
- package/dist/esm/types/properties/regressionLine/zHistogramRegressionLine.d.ts +11 -0
- package/dist/esm/types/properties/regressionLine/zHistogramRegressionLine.js +17 -0
- package/dist/esm/types/properties/regressionLine/zHistogramRegressionLine.js.map +1 -0
- package/dist/esm/types/properties/theme/customTheme.d.ts +1935 -541
- package/dist/esm/types/vseed.d.ts +2 -2
- package/dist/esm/types/zVseed.d.ts +2717 -0
- package/dist/esm/types/zVseed.js +4 -2
- package/dist/esm/types/zVseed.js.map +1 -1
- package/dist/umd/index.js +1748 -140
- package/dist/umd/index.js.map +1 -1
- package/package.json +6 -4
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerColumn, registerColumnParallel, registerColumnPercent, registerDonut, registerDualAxis, registerFunnel, registerHeatmap, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable } from "./chartType/index.js";
|
|
1
|
+
import { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerBoxplot, registerColumn, registerColumnParallel, registerColumnPercent, registerDonut, registerDualAxis, registerFunnel, registerHeatmap, registerHistogram, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable } from "./chartType/index.js";
|
|
2
2
|
import { registerDarkTheme, registerLightTheme } from "./theme/index.js";
|
|
3
3
|
const registerAll = ()=>{
|
|
4
4
|
registerTable();
|
|
@@ -21,6 +21,8 @@ const registerAll = ()=>{
|
|
|
21
21
|
registerRadar();
|
|
22
22
|
registerFunnel();
|
|
23
23
|
registerHeatmap();
|
|
24
|
+
registerBoxplot();
|
|
25
|
+
registerHistogram();
|
|
24
26
|
registerLightTheme();
|
|
25
27
|
registerDarkTheme();
|
|
26
28
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"builder/register/all.js","sources":["webpack://@visactor/vseed/./src/builder/register/all.ts"],"sourcesContent":["import {\n registerArea,\n registerAreaPercent,\n registerBar,\n registerBarParallel,\n registerBarPercent,\n registerColumn,\n registerColumnParallel,\n registerColumnPercent,\n registerLine,\n registerPie,\n registerDonut,\n registerRose,\n registerRoseParallel,\n registerFunnel,\n registerScatter,\n registerTable,\n registerPivotTable,\n registerHeatmap,\n registerRadar,\n registerDualAxis,\n} from './chartType'\nimport { registerDarkTheme, registerLightTheme } from './theme'\n\nexport const registerAll = () => {\n // table\n registerTable()\n registerPivotTable()\n // cartesian\n registerLine()\n registerColumn()\n registerColumnParallel()\n registerColumnPercent()\n registerBar()\n registerBarParallel()\n registerBarPercent()\n registerArea()\n registerAreaPercent()\n registerScatter()\n registerDualAxis()\n // polar\n registerPie()\n registerDonut()\n registerRose()\n registerRoseParallel()\n registerRadar()\n // other\n registerFunnel()\n registerHeatmap()\n // theme\n registerLightTheme()\n registerDarkTheme()\n}\n"],"names":["registerAll","registerTable","registerPivotTable","registerLine","registerColumn","registerColumnParallel","registerColumnPercent","registerBar","registerBarParallel","registerBarPercent","registerArea","registerAreaPercent","registerScatter","registerDualAxis","registerPie","registerDonut","registerRose","registerRoseParallel","registerRadar","registerFunnel","registerHeatmap","registerLightTheme","registerDarkTheme"],"mappings":";;
|
|
1
|
+
{"version":3,"file":"builder/register/all.js","sources":["webpack://@visactor/vseed/./src/builder/register/all.ts"],"sourcesContent":["import {\n registerArea,\n registerAreaPercent,\n registerBar,\n registerBarParallel,\n registerBarPercent,\n registerColumn,\n registerColumnParallel,\n registerColumnPercent,\n registerLine,\n registerPie,\n registerDonut,\n registerRose,\n registerRoseParallel,\n registerFunnel,\n registerScatter,\n registerTable,\n registerPivotTable,\n registerHeatmap,\n registerRadar,\n registerDualAxis,\n registerBoxplot,\n registerHistogram,\n} from './chartType'\nimport { registerDarkTheme, registerLightTheme } from './theme'\n\nexport const registerAll = () => {\n // table\n registerTable()\n registerPivotTable()\n // cartesian\n registerLine()\n registerColumn()\n registerColumnParallel()\n registerColumnPercent()\n registerBar()\n registerBarParallel()\n registerBarPercent()\n registerArea()\n registerAreaPercent()\n registerScatter()\n registerDualAxis()\n // polar\n registerPie()\n registerDonut()\n registerRose()\n registerRoseParallel()\n registerRadar()\n // other\n registerFunnel()\n registerHeatmap()\n registerBoxplot()\n registerHistogram()\n // theme\n registerLightTheme()\n registerDarkTheme()\n}\n"],"names":["registerAll","registerTable","registerPivotTable","registerLine","registerColumn","registerColumnParallel","registerColumnPercent","registerBar","registerBarParallel","registerBarPercent","registerArea","registerAreaPercent","registerScatter","registerDualAxis","registerPie","registerDonut","registerRose","registerRoseParallel","registerRadar","registerFunnel","registerHeatmap","registerBoxplot","registerHistogram","registerLightTheme","registerDarkTheme"],"mappings":";;AA0BO,MAAMA,cAAc;IAEzBC;IACAC;IAEAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IACAC;IAEAC;IACAC;IACAC;IACAC;IACAC;IAEAC;IACAC;IACAC;IACAC;IAEAC;IACAC;AACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const registerBoxplot: () => void;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { boxplotAdvancedPipeline, boxplotSpecPipeline } from "../../../pipeline/index.js";
|
|
2
|
+
import { Builder } from "../../builder/index.js";
|
|
3
|
+
const registerBoxplot = ()=>{
|
|
4
|
+
Builder._advancedPipelineMap.boxPlot = boxplotAdvancedPipeline;
|
|
5
|
+
Builder._specPipelineMap.boxPlot = boxplotSpecPipeline;
|
|
6
|
+
};
|
|
7
|
+
export { registerBoxplot };
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=boxplot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder/register/chartType/boxplot.js","sources":["webpack://@visactor/vseed/./src/builder/register/chartType/boxplot.ts"],"sourcesContent":["import { boxplotAdvancedPipeline, boxplotSpecPipeline } from '../../../pipeline'\nimport { Builder } from '../../builder'\n\nexport const registerBoxplot = () => {\n Builder._advancedPipelineMap['boxPlot'] = boxplotAdvancedPipeline\n Builder._specPipelineMap['boxPlot'] = boxplotSpecPipeline\n}\n"],"names":["registerBoxplot","Builder","boxplotAdvancedPipeline","boxplotSpecPipeline"],"mappings":";;AAGO,MAAMA,kBAAkB;IAC7BC,QAAQ,oBAAoB,CAA5BA,OAAuC,GAAGC;IAC1CD,QAAQ,gBAAgB,CAAxBA,OAAmC,GAAGE;AACxC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const registerHistogram: () => void;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { histogramAdvancedPipeline, histogramSpecPipeline } from "../../../pipeline/index.js";
|
|
2
|
+
import { Builder } from "../../builder/index.js";
|
|
3
|
+
const registerHistogram = ()=>{
|
|
4
|
+
Builder._advancedPipelineMap.histogram = histogramAdvancedPipeline;
|
|
5
|
+
Builder._specPipelineMap.histogram = histogramSpecPipeline;
|
|
6
|
+
};
|
|
7
|
+
export { registerHistogram };
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=histogram.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder/register/chartType/histogram.js","sources":["webpack://@visactor/vseed/./src/builder/register/chartType/histogram.ts"],"sourcesContent":["import { histogramSpecPipeline, histogramAdvancedPipeline } from '../../../pipeline'\nimport { Builder } from '../../builder'\n\nexport const registerHistogram = () => {\n Builder._advancedPipelineMap['histogram'] = histogramAdvancedPipeline\n Builder._specPipelineMap['histogram'] = histogramSpecPipeline\n}\n"],"names":["registerHistogram","Builder","histogramAdvancedPipeline","histogramSpecPipeline"],"mappings":";;AAGO,MAAMA,oBAAoB;IAC/BC,QAAQ,oBAAoB,CAA5BA,SAAyC,GAAGC;IAC5CD,QAAQ,gBAAgB,CAAxBA,SAAqC,GAAGE;AAC1C"}
|
|
@@ -18,3 +18,5 @@ export { registerRoseParallel } from './roseParallel';
|
|
|
18
18
|
export { registerRadar } from './radar';
|
|
19
19
|
export { registerHeatmap } from './heatmap';
|
|
20
20
|
export { registerFunnel } from './funnel';
|
|
21
|
+
export { registerBoxplot } from './boxplot';
|
|
22
|
+
export { registerHistogram } from './histogram';
|
|
@@ -18,4 +18,6 @@ import { registerRoseParallel } from "./roseParallel.js";
|
|
|
18
18
|
import { registerRadar } from "./radar.js";
|
|
19
19
|
import { registerHeatmap } from "./heatmap.js";
|
|
20
20
|
import { registerFunnel } from "./funnel.js";
|
|
21
|
-
|
|
21
|
+
import { registerBoxplot } from "./boxplot.js";
|
|
22
|
+
import { registerHistogram } from "./histogram.js";
|
|
23
|
+
export { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerBoxplot, registerColumn, registerColumnParallel, registerColumnPercent, registerDonut, registerDualAxis, registerFunnel, registerHeatmap, registerHistogram, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable };
|
|
@@ -16,3 +16,13 @@ export declare const AngleEncoding = "__Dim_Angle__";
|
|
|
16
16
|
export declare const DetailEncoding = "__Dim_Detail__";
|
|
17
17
|
export declare const ColorEncoding = "__Dim_Color__";
|
|
18
18
|
export declare const ColorIdEncoding = "__Dim_ColorId__";
|
|
19
|
+
export declare const Q1MeasureValue = "__Q1__";
|
|
20
|
+
export declare const Q3MeasureValue = "__Q3__";
|
|
21
|
+
export declare const MinMeasureId = "__Min__";
|
|
22
|
+
export declare const MaxMeasureId = "__Max__";
|
|
23
|
+
export declare const OutliersMeasureId = "__Outliers__";
|
|
24
|
+
export declare const MedianMeasureId = "__Meadian__";
|
|
25
|
+
export declare const BinStartMeasureId = "__BinStart__";
|
|
26
|
+
export declare const BinEndMeasureId = "__BinEnd__";
|
|
27
|
+
export declare const BinCountMeasureId = "__BinCount__";
|
|
28
|
+
export declare const BinPercentageMeasureId = "__BinPercentage__";
|
|
@@ -16,6 +16,16 @@ const AngleEncoding = '__Dim_Angle__';
|
|
|
16
16
|
const DetailEncoding = '__Dim_Detail__';
|
|
17
17
|
const ColorEncoding = '__Dim_Color__';
|
|
18
18
|
const ColorIdEncoding = '__Dim_ColorId__';
|
|
19
|
-
|
|
19
|
+
const Q1MeasureValue = '__Q1__';
|
|
20
|
+
const Q3MeasureValue = '__Q3__';
|
|
21
|
+
const MinMeasureId = '__Min__';
|
|
22
|
+
const MaxMeasureId = '__Max__';
|
|
23
|
+
const OutliersMeasureId = '__Outliers__';
|
|
24
|
+
const MedianMeasureId = '__Meadian__';
|
|
25
|
+
const BinStartMeasureId = '__BinStart__';
|
|
26
|
+
const BinEndMeasureId = '__BinEnd__';
|
|
27
|
+
const BinCountMeasureId = '__BinCount__';
|
|
28
|
+
const BinPercentageMeasureId = '__BinPercentage__';
|
|
29
|
+
export { AngleEncoding, BinCountMeasureId, BinEndMeasureId, BinPercentageMeasureId, BinStartMeasureId, ColorEncoding, ColorIdEncoding, DetailEncoding, FoldMeasureId, FoldMeasureName, FoldMeasureValue, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue, FoldXMeasureId, FoldXMeasureValue, FoldYMeasureId, FoldYMeasureValue, MaxMeasureId, MeasureName, MedianMeasureId, MinMeasureId, ORIGINAL_DATA, OutliersMeasureId, Q1MeasureValue, Q3MeasureValue, Separator, XEncoding, YEncoding };
|
|
20
30
|
|
|
21
31
|
//# sourceMappingURL=constant.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dataReshape/constant.js","sources":["webpack://@visactor/vseed/./src/dataReshape/constant.ts"],"sourcesContent":["// Reshape\nexport const ORIGINAL_DATA = '__OriginalData__'\nexport const Separator = '-'\n\n// Measures\nexport const FoldMeasureName = '__MeaName__'\nexport const FoldMeasureId = '__MeaId__'\nexport const FoldMeasureValue = '__MeaValue__'\nexport const MeasureName = FoldMeasureName\n\n// Measures For DualAxis\nexport const FoldPrimaryMeasureValue = '__MeaPrimaryValue__'\nexport const FoldSecondaryMeasureValue = '__MeaSecondaryValue__'\n\n// Measures For Scatter\nexport const FoldXMeasureValue = '__MeaXValue__'\nexport const FoldYMeasureValue = '__MeaYValue__'\nexport const FoldXMeasureId = '__MeaXId__'\nexport const FoldYMeasureId = '__MeaYId__'\n// Encoding\nexport const XEncoding = '__Dim_X__'\nexport const YEncoding = '__Dim_Y__'\nexport const AngleEncoding = '__Dim_Angle__'\nexport const DetailEncoding = '__Dim_Detail__'\nexport const ColorEncoding = '__Dim_Color__'\nexport const ColorIdEncoding = '__Dim_ColorId__'\n"],"names":["ORIGINAL_DATA","Separator","FoldMeasureName","FoldMeasureId","FoldMeasureValue","MeasureName","FoldPrimaryMeasureValue","FoldSecondaryMeasureValue","FoldXMeasureValue","FoldYMeasureValue","FoldXMeasureId","FoldYMeasureId","XEncoding","YEncoding","AngleEncoding","DetailEncoding","ColorEncoding","ColorIdEncoding"],"mappings":"AACO,MAAMA,gBAAgB;AACtB,MAAMC,YAAY;AAGlB,MAAMC,kBAAkB;AACxB,MAAMC,gBAAgB;AACtB,MAAMC,mBAAmB;AACzB,MAAMC,cAAcH;AAGpB,MAAMI,0BAA0B;AAChC,MAAMC,4BAA4B;AAGlC,MAAMC,oBAAoB;AAC1B,MAAMC,oBAAoB;AAC1B,MAAMC,iBAAiB;AACvB,MAAMC,iBAAiB;AAEvB,MAAMC,YAAY;AAClB,MAAMC,YAAY;AAClB,MAAMC,gBAAgB;AACtB,MAAMC,iBAAiB;AACvB,MAAMC,gBAAgB;AACtB,MAAMC,kBAAkB"}
|
|
1
|
+
{"version":3,"file":"dataReshape/constant.js","sources":["webpack://@visactor/vseed/./src/dataReshape/constant.ts"],"sourcesContent":["// Reshape\nexport const ORIGINAL_DATA = '__OriginalData__'\nexport const Separator = '-'\n\n// Measures\nexport const FoldMeasureName = '__MeaName__'\nexport const FoldMeasureId = '__MeaId__'\nexport const FoldMeasureValue = '__MeaValue__'\nexport const MeasureName = FoldMeasureName\n\n// Measures For DualAxis\nexport const FoldPrimaryMeasureValue = '__MeaPrimaryValue__'\nexport const FoldSecondaryMeasureValue = '__MeaSecondaryValue__'\n\n// Measures For Scatter\nexport const FoldXMeasureValue = '__MeaXValue__'\nexport const FoldYMeasureValue = '__MeaYValue__'\nexport const FoldXMeasureId = '__MeaXId__'\nexport const FoldYMeasureId = '__MeaYId__'\n// Encoding\nexport const XEncoding = '__Dim_X__'\nexport const YEncoding = '__Dim_Y__'\nexport const AngleEncoding = '__Dim_Angle__'\nexport const DetailEncoding = '__Dim_Detail__'\nexport const ColorEncoding = '__Dim_Color__'\nexport const ColorIdEncoding = '__Dim_ColorId__'\n\n// Measures For boxPlot\nexport const Q1MeasureValue = '__Q1__'\nexport const Q3MeasureValue = '__Q3__'\nexport const MinMeasureId = '__Min__'\nexport const MaxMeasureId = '__Max__'\nexport const OutliersMeasureId = '__Outliers__'\nexport const MedianMeasureId = '__Meadian__'\n\n// Measures For Histogram\nexport const BinStartMeasureId = '__BinStart__'\nexport const BinEndMeasureId = '__BinEnd__'\nexport const BinCountMeasureId = '__BinCount__'\nexport const BinPercentageMeasureId = '__BinPercentage__'\n"],"names":["ORIGINAL_DATA","Separator","FoldMeasureName","FoldMeasureId","FoldMeasureValue","MeasureName","FoldPrimaryMeasureValue","FoldSecondaryMeasureValue","FoldXMeasureValue","FoldYMeasureValue","FoldXMeasureId","FoldYMeasureId","XEncoding","YEncoding","AngleEncoding","DetailEncoding","ColorEncoding","ColorIdEncoding","Q1MeasureValue","Q3MeasureValue","MinMeasureId","MaxMeasureId","OutliersMeasureId","MedianMeasureId","BinStartMeasureId","BinEndMeasureId","BinCountMeasureId","BinPercentageMeasureId"],"mappings":"AACO,MAAMA,gBAAgB;AACtB,MAAMC,YAAY;AAGlB,MAAMC,kBAAkB;AACxB,MAAMC,gBAAgB;AACtB,MAAMC,mBAAmB;AACzB,MAAMC,cAAcH;AAGpB,MAAMI,0BAA0B;AAChC,MAAMC,4BAA4B;AAGlC,MAAMC,oBAAoB;AAC1B,MAAMC,oBAAoB;AAC1B,MAAMC,iBAAiB;AACvB,MAAMC,iBAAiB;AAEvB,MAAMC,YAAY;AAClB,MAAMC,YAAY;AAClB,MAAMC,gBAAgB;AACtB,MAAMC,iBAAiB;AACvB,MAAMC,gBAAgB;AACtB,MAAMC,kBAAkB;AAGxB,MAAMC,iBAAiB;AACvB,MAAMC,iBAAiB;AACvB,MAAMC,eAAe;AACrB,MAAMC,eAAe;AACrB,MAAMC,oBAAoB;AAC1B,MAAMC,kBAAkB;AAGxB,MAAMC,oBAAoB;AAC1B,MAAMC,kBAAkB;AACxB,MAAMC,oBAAoB;AAC1B,MAAMC,yBAAyB"}
|
|
@@ -27,8 +27,8 @@ const unfoldDimensions = (dataset, dimensions, encoding, options)=>{
|
|
|
27
27
|
applyEncoding(ColorEncoding, colorDimensions, datum, separator);
|
|
28
28
|
applyEncoding(DetailEncoding, detailDimensions, datum, separator);
|
|
29
29
|
if (!colorDimensions.length || !datum[ColorEncoding]) continue;
|
|
30
|
-
const measureId = String(datum[foldMeasureId]);
|
|
31
|
-
const colorItem = String(datum[ColorEncoding]);
|
|
30
|
+
const measureId = String(datum[foldMeasureId] ?? '');
|
|
31
|
+
const colorItem = String(datum[ColorEncoding] ?? '');
|
|
32
32
|
const colorId = colorItemAsId ? colorItem : measureId ? [
|
|
33
33
|
colorItem,
|
|
34
34
|
measureId
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dataReshape/unfoldDimensions.js","sources":["webpack://@visactor/vseed/./src/dataReshape/unfoldDimensions.ts"],"sourcesContent":["import type { Dataset, Datum, Dimension, Encoding, UnfoldInfo } from 'src/types'\nimport { AngleEncoding, XEncoding, YEncoding, ColorEncoding, DetailEncoding, ColorIdEncoding } from './constant'\n\n/**\n * @description 展开并合并视觉通道的维度, 在foldMeasures后合并维度, 所以不需要进行笛卡尔积\n * @param dataset 原始数据集\n * @param dimensions 维度\n * @param encoding 编码\n * @param options\n * @returns\n */\nexport const unfoldDimensions = (\n dataset: Dataset,\n dimensions: Dimension[],\n encoding: Encoding,\n options: {\n foldMeasureId: string\n separator: string\n colorItemAsId: boolean\n },\n): {\n dataset: Dataset\n unfoldInfo: UnfoldInfo\n} => {\n const { foldMeasureId, separator, colorItemAsId } = options\n\n const unfoldInfo: UnfoldInfo = {\n encodingAngle: AngleEncoding,\n encodingX: XEncoding,\n encodingY: YEncoding,\n encodingDetail: DetailEncoding,\n encodingColor: ColorEncoding,\n encodingColorId: ColorIdEncoding,\n\n colorItems: [],\n colorIdMap: {},\n }\n\n // 每个通道对应的维度\n const { color, x, y, detail, angle } = encoding\n const angleDimensions = angle ? dimensions.filter((dim) => angle.includes(dim.id)) : []\n const xDimensions = x ? dimensions.filter((dim) => x.includes(dim.id)) : []\n const yDimensions = y ? dimensions.filter((dim) => y.includes(dim.id)) : []\n const colorDimensions = color ? dimensions.filter((dim) => color.includes(dim.id)) : []\n const detailDimensions = detail ? dimensions.filter((dim) => detail.includes(dim.id)) : []\n\n // 离散图例项\n const colorItems = new Set<string>()\n const colorIdMap: Record<string, string> = {}\n\n // 遍历数据集, 按通道合并维度\n for (let i = 0; i < dataset.length; i++) {\n // 应用编码至Datum上\n const datum = dataset[i]\n\n /**\n * !important 这是全仓库, 最最最重要的五行代码, 贯穿VSeed整个生命周期, 是化繁为简的绝对核心\n * 1. 点睛之笔: 呼应foldMeasures, 此时此刻的datum一定是单点数据, 维度合并不可能造成任何冲突.\n * 2. 数据即通道\n * 3. 利用需要合并的维度, 直接进行join, 即可生成新的维度, 与指标彻底解耦;\n * 4. 以下通道均在一次遍历中完成, 不存在性能问题\n * 5. 以下通道均可放入多个维度\n */\n applyEncoding(AngleEncoding, angleDimensions, datum, separator)\n applyEncoding(XEncoding, xDimensions, datum, separator)\n applyEncoding(YEncoding, yDimensions, datum, separator)\n applyEncoding(ColorEncoding, colorDimensions, datum, separator)\n applyEncoding(DetailEncoding, detailDimensions, datum, separator)\n\n // 处理离散的颜色图例\n if (!colorDimensions.length || !datum[ColorEncoding]) {\n // 无颜色通道, 则跳过\n continue\n }\n const measureId = String(datum[foldMeasureId])\n const colorItem = String(datum[ColorEncoding])\n const colorId = colorItemAsId ? colorItem : measureId ? [colorItem, measureId].join(separator) : colorItem\n datum[ColorIdEncoding] = colorId\n colorIdMap[colorId] = colorItem\n colorItems.add(colorId)\n }\n\n unfoldInfo.colorItems = Array.from(colorItems)\n unfoldInfo.colorIdMap = colorIdMap\n\n return {\n dataset,\n unfoldInfo,\n }\n}\n\n/**\n * @description 应用编码至数据中, 此方法会原地修改数据\n * @param encoding 编码\n * @param dimensions 维度\n * @param datum 数据\n * @param separator 分隔符\n * @returns undefined\n */\nconst applyEncoding = (encoding: string, dimensions: Dimension[], datum: Datum, separator: string) => {\n if (encoding && dimensions.length) {\n datum[encoding] = dimensions.map((dim) => String(datum[dim.id])).join(separator)\n }\n}\n"],"names":["unfoldDimensions","dataset","dimensions","encoding","options","foldMeasureId","separator","colorItemAsId","unfoldInfo","AngleEncoding","XEncoding","YEncoding","DetailEncoding","ColorEncoding","ColorIdEncoding","color","x","y","detail","angle","angleDimensions","dim","xDimensions","yDimensions","colorDimensions","detailDimensions","colorItems","Set","colorIdMap","i","datum","applyEncoding","measureId","String","colorItem","colorId","Array"],"mappings":";AAWO,MAAMA,mBAAmB,CAC9BC,SACAC,YACAC,UACAC;IASA,MAAM,EAAEC,aAAa,EAAEC,SAAS,EAAEC,aAAa,EAAE,GAAGH;IAEpD,MAAMI,aAAyB;QAC7B,eAAeC;QACf,WAAWC;QACX,WAAWC;QACX,gBAAgBC;QAChB,eAAeC;QACf,iBAAiBC;QAEjB,YAAY,EAAE;QACd,YAAY,CAAC;IACf;IAGA,MAAM,EAAEC,KAAK,EAAEC,CAAC,EAAEC,CAAC,EAAEC,MAAM,EAAEC,KAAK,EAAE,GAAGhB;IACvC,MAAMiB,kBAAkBD,QAAQjB,WAAW,MAAM,CAAC,CAACmB,MAAQF,MAAM,QAAQ,CAACE,IAAI,EAAE,KAAK,EAAE;IACvF,MAAMC,cAAcN,IAAId,WAAW,MAAM,CAAC,CAACmB,MAAQL,EAAE,QAAQ,CAACK,IAAI,EAAE,KAAK,EAAE;IAC3E,MAAME,cAAcN,IAAIf,WAAW,MAAM,CAAC,CAACmB,MAAQJ,EAAE,QAAQ,CAACI,IAAI,EAAE,KAAK,EAAE;IAC3E,MAAMG,kBAAkBT,QAAQb,WAAW,MAAM,CAAC,CAACmB,MAAQN,MAAM,QAAQ,CAACM,IAAI,EAAE,KAAK,EAAE;IACvF,MAAMI,mBAAmBP,SAAShB,WAAW,MAAM,CAAC,CAACmB,MAAQH,OAAO,QAAQ,CAACG,IAAI,EAAE,KAAK,EAAE;IAG1F,MAAMK,aAAa,IAAIC;IACvB,MAAMC,aAAqC,CAAC;IAG5C,IAAK,IAAIC,IAAI,GAAGA,IAAI5B,QAAQ,MAAM,EAAE4B,IAAK;QAEvC,MAAMC,QAAQ7B,OAAO,CAAC4B,EAAE;QAUxBE,cAActB,eAAeW,iBAAiBU,OAAOxB;QACrDyB,cAAcrB,WAAWY,aAAaQ,OAAOxB;QAC7CyB,cAAcpB,WAAWY,aAAaO,OAAOxB;QAC7CyB,cAAclB,eAAeW,iBAAiBM,OAAOxB;QACrDyB,cAAcnB,gBAAgBa,kBAAkBK,OAAOxB;QAGvD,IAAI,CAACkB,gBAAgB,MAAM,IAAI,CAACM,KAAK,CAACjB,cAAc,EAElD;QAEF,MAAMmB,YAAYC,OAAOH,KAAK,CAACzB,cAAc;
|
|
1
|
+
{"version":3,"file":"dataReshape/unfoldDimensions.js","sources":["webpack://@visactor/vseed/./src/dataReshape/unfoldDimensions.ts"],"sourcesContent":["import type { Dataset, Datum, Dimension, Encoding, UnfoldInfo } from 'src/types'\nimport { AngleEncoding, XEncoding, YEncoding, ColorEncoding, DetailEncoding, ColorIdEncoding } from './constant'\n\n/**\n * @description 展开并合并视觉通道的维度, 在foldMeasures后合并维度, 所以不需要进行笛卡尔积\n * @param dataset 原始数据集\n * @param dimensions 维度\n * @param encoding 编码\n * @param options\n * @returns\n */\nexport const unfoldDimensions = (\n dataset: Dataset,\n dimensions: Dimension[],\n encoding: Encoding,\n options: {\n foldMeasureId: string\n separator: string\n colorItemAsId: boolean\n },\n): {\n dataset: Dataset\n unfoldInfo: UnfoldInfo\n} => {\n const { foldMeasureId, separator, colorItemAsId } = options\n\n const unfoldInfo: UnfoldInfo = {\n encodingAngle: AngleEncoding,\n encodingX: XEncoding,\n encodingY: YEncoding,\n encodingDetail: DetailEncoding,\n encodingColor: ColorEncoding,\n encodingColorId: ColorIdEncoding,\n\n colorItems: [],\n colorIdMap: {},\n }\n\n // 每个通道对应的维度\n const { color, x, y, detail, angle } = encoding\n const angleDimensions = angle ? dimensions.filter((dim) => angle.includes(dim.id)) : []\n const xDimensions = x ? dimensions.filter((dim) => x.includes(dim.id)) : []\n const yDimensions = y ? dimensions.filter((dim) => y.includes(dim.id)) : []\n const colorDimensions = color ? dimensions.filter((dim) => color.includes(dim.id)) : []\n const detailDimensions = detail ? dimensions.filter((dim) => detail.includes(dim.id)) : []\n\n // 离散图例项\n const colorItems = new Set<string>()\n const colorIdMap: Record<string, string> = {}\n\n // 遍历数据集, 按通道合并维度\n for (let i = 0; i < dataset.length; i++) {\n // 应用编码至Datum上\n const datum = dataset[i]\n\n /**\n * !important 这是全仓库, 最最最重要的五行代码, 贯穿VSeed整个生命周期, 是化繁为简的绝对核心\n * 1. 点睛之笔: 呼应foldMeasures, 此时此刻的datum一定是单点数据, 维度合并不可能造成任何冲突.\n * 2. 数据即通道\n * 3. 利用需要合并的维度, 直接进行join, 即可生成新的维度, 与指标彻底解耦;\n * 4. 以下通道均在一次遍历中完成, 不存在性能问题\n * 5. 以下通道均可放入多个维度\n */\n applyEncoding(AngleEncoding, angleDimensions, datum, separator)\n applyEncoding(XEncoding, xDimensions, datum, separator)\n applyEncoding(YEncoding, yDimensions, datum, separator)\n applyEncoding(ColorEncoding, colorDimensions, datum, separator)\n applyEncoding(DetailEncoding, detailDimensions, datum, separator)\n\n // 处理离散的颜色图例\n if (!colorDimensions.length || !datum[ColorEncoding]) {\n // 无颜色通道, 则跳过\n continue\n }\n const measureId = String(datum[foldMeasureId] ?? '')\n const colorItem = String(datum[ColorEncoding] ?? '')\n const colorId = colorItemAsId ? colorItem : measureId ? [colorItem, measureId].join(separator) : colorItem\n datum[ColorIdEncoding] = colorId\n colorIdMap[colorId] = colorItem\n colorItems.add(colorId)\n }\n\n unfoldInfo.colorItems = Array.from(colorItems)\n unfoldInfo.colorIdMap = colorIdMap\n\n return {\n dataset,\n unfoldInfo,\n }\n}\n\n/**\n * @description 应用编码至数据中, 此方法会原地修改数据\n * @param encoding 编码\n * @param dimensions 维度\n * @param datum 数据\n * @param separator 分隔符\n * @returns undefined\n */\nconst applyEncoding = (encoding: string, dimensions: Dimension[], datum: Datum, separator: string) => {\n if (encoding && dimensions.length) {\n datum[encoding] = dimensions.map((dim) => String(datum[dim.id])).join(separator)\n }\n}\n"],"names":["unfoldDimensions","dataset","dimensions","encoding","options","foldMeasureId","separator","colorItemAsId","unfoldInfo","AngleEncoding","XEncoding","YEncoding","DetailEncoding","ColorEncoding","ColorIdEncoding","color","x","y","detail","angle","angleDimensions","dim","xDimensions","yDimensions","colorDimensions","detailDimensions","colorItems","Set","colorIdMap","i","datum","applyEncoding","measureId","String","colorItem","colorId","Array"],"mappings":";AAWO,MAAMA,mBAAmB,CAC9BC,SACAC,YACAC,UACAC;IASA,MAAM,EAAEC,aAAa,EAAEC,SAAS,EAAEC,aAAa,EAAE,GAAGH;IAEpD,MAAMI,aAAyB;QAC7B,eAAeC;QACf,WAAWC;QACX,WAAWC;QACX,gBAAgBC;QAChB,eAAeC;QACf,iBAAiBC;QAEjB,YAAY,EAAE;QACd,YAAY,CAAC;IACf;IAGA,MAAM,EAAEC,KAAK,EAAEC,CAAC,EAAEC,CAAC,EAAEC,MAAM,EAAEC,KAAK,EAAE,GAAGhB;IACvC,MAAMiB,kBAAkBD,QAAQjB,WAAW,MAAM,CAAC,CAACmB,MAAQF,MAAM,QAAQ,CAACE,IAAI,EAAE,KAAK,EAAE;IACvF,MAAMC,cAAcN,IAAId,WAAW,MAAM,CAAC,CAACmB,MAAQL,EAAE,QAAQ,CAACK,IAAI,EAAE,KAAK,EAAE;IAC3E,MAAME,cAAcN,IAAIf,WAAW,MAAM,CAAC,CAACmB,MAAQJ,EAAE,QAAQ,CAACI,IAAI,EAAE,KAAK,EAAE;IAC3E,MAAMG,kBAAkBT,QAAQb,WAAW,MAAM,CAAC,CAACmB,MAAQN,MAAM,QAAQ,CAACM,IAAI,EAAE,KAAK,EAAE;IACvF,MAAMI,mBAAmBP,SAAShB,WAAW,MAAM,CAAC,CAACmB,MAAQH,OAAO,QAAQ,CAACG,IAAI,EAAE,KAAK,EAAE;IAG1F,MAAMK,aAAa,IAAIC;IACvB,MAAMC,aAAqC,CAAC;IAG5C,IAAK,IAAIC,IAAI,GAAGA,IAAI5B,QAAQ,MAAM,EAAE4B,IAAK;QAEvC,MAAMC,QAAQ7B,OAAO,CAAC4B,EAAE;QAUxBE,cAActB,eAAeW,iBAAiBU,OAAOxB;QACrDyB,cAAcrB,WAAWY,aAAaQ,OAAOxB;QAC7CyB,cAAcpB,WAAWY,aAAaO,OAAOxB;QAC7CyB,cAAclB,eAAeW,iBAAiBM,OAAOxB;QACrDyB,cAAcnB,gBAAgBa,kBAAkBK,OAAOxB;QAGvD,IAAI,CAACkB,gBAAgB,MAAM,IAAI,CAACM,KAAK,CAACjB,cAAc,EAElD;QAEF,MAAMmB,YAAYC,OAAOH,KAAK,CAACzB,cAAc,IAAI;QACjD,MAAM6B,YAAYD,OAAOH,KAAK,CAACjB,cAAc,IAAI;QACjD,MAAMsB,UAAU5B,gBAAgB2B,YAAYF,YAAY;YAACE;YAAWF;SAAU,CAAC,IAAI,CAAC1B,aAAa4B;QACjGJ,KAAK,CAAChB,gBAAgB,GAAGqB;QACzBP,UAAU,CAACO,QAAQ,GAAGD;QACtBR,WAAW,GAAG,CAACS;IACjB;IAEA3B,WAAW,UAAU,GAAG4B,MAAM,IAAI,CAACV;IACnClB,WAAW,UAAU,GAAGoB;IAExB,OAAO;QACL3B;QACAO;IACF;AACF;AAUA,MAAMuB,gBAAgB,CAAC5B,UAAkBD,YAAyB4B,OAAcxB;IAC9E,IAAIH,YAAYD,WAAW,MAAM,EAC/B4B,KAAK,CAAC3B,SAAS,GAAGD,WAAW,GAAG,CAAC,CAACmB,MAAQY,OAAOH,KAAK,CAACT,IAAI,EAAE,CAAC,GAAG,IAAI,CAACf;AAE1E"}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ export { Builder } from './builder';
|
|
|
2
2
|
export { registerAll } from './builder/register/all';
|
|
3
3
|
export { updateAdvanced, updateSpec } from './builder/register/custom';
|
|
4
4
|
export { registerDarkTheme, registerLightTheme, registerCustomTheme } from './builder/register/theme';
|
|
5
|
-
export { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerColumn, registerColumnParallel, registerColumnPercent, registerLine, registerPie, registerDonut, registerRose, registerRoseParallel, registerFunnel, registerScatter, registerTable, registerPivotTable, registerHeatmap, registerRadar, } from './builder/register/chartType';
|
|
5
|
+
export { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerColumn, registerColumnParallel, registerColumnPercent, registerLine, registerPie, registerDonut, registerRose, registerRoseParallel, registerFunnel, registerScatter, registerTable, registerPivotTable, registerHeatmap, registerRadar, registerBoxplot, registerHistogram, registerDualAxis, } from './builder/register/chartType';
|
|
6
6
|
export * from './pipeline';
|
|
7
7
|
export * from './types';
|
|
8
8
|
export * from './dataReshape';
|
package/dist/esm/index.js
CHANGED
|
@@ -2,11 +2,11 @@ import { Builder } from "./builder/index.js";
|
|
|
2
2
|
import { registerAll } from "./builder/register/all.js";
|
|
3
3
|
import { updateAdvanced, updateSpec } from "./builder/register/custom.js";
|
|
4
4
|
import { registerCustomTheme, registerDarkTheme, registerLightTheme } from "./builder/register/theme/index.js";
|
|
5
|
-
import { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerColumn, registerColumnParallel, registerColumnPercent, registerDonut, registerFunnel, registerHeatmap, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable } from "./builder/register/chartType/index.js";
|
|
5
|
+
import { registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerBoxplot, registerColumn, registerColumnParallel, registerColumnPercent, registerDonut, registerDualAxis, registerFunnel, registerHeatmap, registerHistogram, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable } from "./builder/register/chartType/index.js";
|
|
6
6
|
export * from "./pipeline/index.js";
|
|
7
7
|
export * from "./types/index.js";
|
|
8
8
|
export * from "./dataReshape/index.js";
|
|
9
9
|
export * from "./dataSelector/index.js";
|
|
10
10
|
export * from "./theme/index.js";
|
|
11
11
|
export * from "./i18n/index.js";
|
|
12
|
-
export { Builder, registerAll, registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerColumn, registerColumnParallel, registerColumnPercent, registerCustomTheme, registerDarkTheme, registerDonut, registerFunnel, registerHeatmap, registerLightTheme, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable, updateAdvanced, updateSpec };
|
|
12
|
+
export { Builder, registerAll, registerArea, registerAreaPercent, registerBar, registerBarParallel, registerBarPercent, registerBoxplot, registerColumn, registerColumnParallel, registerColumnPercent, registerCustomTheme, registerDarkTheme, registerDonut, registerDualAxis, registerFunnel, registerHeatmap, registerHistogram, registerLightTheme, registerLine, registerPie, registerPivotTable, registerRadar, registerRose, registerRoseParallel, registerScatter, registerTable, updateAdvanced, updateSpec };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { annotation, boxplotConfig, buildMeasures, defaultDimensions, defaultEncodingForBoxplot, defaultMeasureName, defaultMeasures, deleteEncodingForMeasure, deleteTooltipAndLabelDimension, encodingAdapter, encodingForBoxplot, initAdvancedVSeed, markStyle, pivotAdapter, pivotReshapeWithBoxplotEncoding, reshapeWithBoxplotEncoding, sortLegend, theme } from "../pipes/index.js";
|
|
2
|
+
const boxplotAdvancedPipeline = [
|
|
3
|
+
initAdvancedVSeed,
|
|
4
|
+
defaultMeasures,
|
|
5
|
+
defaultDimensions,
|
|
6
|
+
defaultMeasureName,
|
|
7
|
+
boxplotConfig,
|
|
8
|
+
encodingAdapter([
|
|
9
|
+
defaultEncodingForBoxplot,
|
|
10
|
+
buildMeasures
|
|
11
|
+
], [
|
|
12
|
+
encodingForBoxplot,
|
|
13
|
+
buildMeasures,
|
|
14
|
+
deleteEncodingForMeasure([
|
|
15
|
+
'tooltip',
|
|
16
|
+
'label',
|
|
17
|
+
'color'
|
|
18
|
+
]),
|
|
19
|
+
deleteTooltipAndLabelDimension
|
|
20
|
+
]),
|
|
21
|
+
pivotAdapter([
|
|
22
|
+
reshapeWithBoxplotEncoding
|
|
23
|
+
], [
|
|
24
|
+
pivotReshapeWithBoxplotEncoding
|
|
25
|
+
]),
|
|
26
|
+
sortLegend,
|
|
27
|
+
theme,
|
|
28
|
+
markStyle,
|
|
29
|
+
annotation
|
|
30
|
+
];
|
|
31
|
+
export { boxplotAdvancedPipeline };
|
|
32
|
+
|
|
33
|
+
//# sourceMappingURL=boxplot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipeline/boxplot.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipeline/boxplot.ts"],"sourcesContent":["import type { AdvancedPipeline } from 'src/types'\nimport {\n initAdvancedVSeed,\n theme,\n pivotAdapter,\n markStyle,\n annotation,\n sortLegend,\n pivotReshapeWithBoxplotEncoding,\n buildMeasures,\n defaultMeasures,\n defaultDimensions,\n defaultMeasureName,\n encodingAdapter,\n deleteEncodingForMeasure,\n deleteTooltipAndLabelDimension,\n defaultEncodingForBoxplot,\n encodingForBoxplot,\n reshapeWithBoxplotEncoding,\n boxplotConfig,\n} from '../pipes'\n\nexport const boxplotAdvancedPipeline: AdvancedPipeline = [\n initAdvancedVSeed,\n defaultMeasures,\n defaultDimensions,\n defaultMeasureName,\n boxplotConfig,\n\n encodingAdapter(\n [defaultEncodingForBoxplot, buildMeasures],\n [\n encodingForBoxplot,\n buildMeasures,\n deleteEncodingForMeasure(['tooltip', 'label', 'color']),\n deleteTooltipAndLabelDimension,\n ],\n ),\n pivotAdapter([reshapeWithBoxplotEncoding], [pivotReshapeWithBoxplotEncoding]),\n\n sortLegend,\n theme,\n markStyle,\n annotation,\n]\n"],"names":["boxplotAdvancedPipeline","initAdvancedVSeed","defaultMeasures","defaultDimensions","defaultMeasureName","boxplotConfig","encodingAdapter","defaultEncodingForBoxplot","buildMeasures","encodingForBoxplot","deleteEncodingForMeasure","deleteTooltipAndLabelDimension","pivotAdapter","reshapeWithBoxplotEncoding","pivotReshapeWithBoxplotEncoding","sortLegend","theme","markStyle","annotation"],"mappings":";AAsBO,MAAMA,0BAA4C;IACvDC;IACAC;IACAC;IACAC;IACAC;IAEAC,gBACE;QAACC;QAA2BC;KAAc,EAC1C;QACEC;QACAD;QACAE,yBAAyB;YAAC;YAAW;YAAS;SAAQ;QACtDC;KACD;IAEHC,aAAa;QAACC;KAA2B,EAAE;QAACC;KAAgC;IAE5EC;IACAC;IACAC;IACAC;CACD"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { annotation, buildMeasures, defaultDimensions, defaultEncodingForHistogram, defaultMeasureName, defaultMeasures, deleteEncodingForMeasure, deleteTooltipAndLabelDimension, encodingAdapter, encodingForHistogram, histogramConfig, initAdvancedVSeed, markStyle, pivotAdapter, pivotReshapeWithHistogramEncoding, regressionLine, reshapeWithHistogramEncoding, sortLegend, theme } from "../pipes/index.js";
|
|
2
|
+
const histogramAdvancedPipeline = [
|
|
3
|
+
initAdvancedVSeed,
|
|
4
|
+
defaultMeasures,
|
|
5
|
+
defaultDimensions,
|
|
6
|
+
defaultMeasureName,
|
|
7
|
+
histogramConfig,
|
|
8
|
+
encodingAdapter([
|
|
9
|
+
defaultEncodingForHistogram,
|
|
10
|
+
buildMeasures
|
|
11
|
+
], [
|
|
12
|
+
encodingForHistogram,
|
|
13
|
+
buildMeasures,
|
|
14
|
+
deleteEncodingForMeasure([
|
|
15
|
+
'tooltip',
|
|
16
|
+
'label',
|
|
17
|
+
'color'
|
|
18
|
+
]),
|
|
19
|
+
deleteTooltipAndLabelDimension
|
|
20
|
+
]),
|
|
21
|
+
pivotAdapter([
|
|
22
|
+
reshapeWithHistogramEncoding
|
|
23
|
+
], [
|
|
24
|
+
pivotReshapeWithHistogramEncoding
|
|
25
|
+
]),
|
|
26
|
+
sortLegend,
|
|
27
|
+
theme,
|
|
28
|
+
markStyle,
|
|
29
|
+
annotation,
|
|
30
|
+
regressionLine
|
|
31
|
+
];
|
|
32
|
+
export { histogramAdvancedPipeline };
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=histogram.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipeline/histogram.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipeline/histogram.ts"],"sourcesContent":["import type { AdvancedPipeline } from 'src/types'\nimport {\n initAdvancedVSeed,\n theme,\n pivotAdapter,\n histogramConfig,\n markStyle,\n annotation,\n sortLegend,\n pivotReshapeWithHistogramEncoding,\n buildMeasures,\n defaultMeasures,\n defaultDimensions,\n defaultMeasureName,\n encodingAdapter,\n deleteEncodingForMeasure,\n deleteTooltipAndLabelDimension,\n defaultEncodingForHistogram,\n encodingForHistogram,\n reshapeWithHistogramEncoding,\n regressionLine,\n} from '../pipes'\n\nexport const histogramAdvancedPipeline: AdvancedPipeline = [\n initAdvancedVSeed,\n defaultMeasures,\n defaultDimensions,\n defaultMeasureName,\n histogramConfig,\n\n encodingAdapter(\n [defaultEncodingForHistogram, buildMeasures],\n [\n encodingForHistogram,\n buildMeasures,\n deleteEncodingForMeasure(['tooltip', 'label', 'color']),\n deleteTooltipAndLabelDimension,\n ],\n ),\n pivotAdapter([reshapeWithHistogramEncoding], [pivotReshapeWithHistogramEncoding]),\n\n sortLegend,\n theme,\n markStyle,\n annotation,\n regressionLine,\n]\n"],"names":["histogramAdvancedPipeline","initAdvancedVSeed","defaultMeasures","defaultDimensions","defaultMeasureName","histogramConfig","encodingAdapter","defaultEncodingForHistogram","buildMeasures","encodingForHistogram","deleteEncodingForMeasure","deleteTooltipAndLabelDimension","pivotAdapter","reshapeWithHistogramEncoding","pivotReshapeWithHistogramEncoding","sortLegend","theme","markStyle","annotation","regressionLine"],"mappings":";AAuBO,MAAMA,4BAA8C;IACzDC;IACAC;IACAC;IACAC;IACAC;IAEAC,gBACE;QAACC;QAA6BC;KAAc,EAC5C;QACEC;QACAD;QACAE,yBAAyB;YAAC;YAAW;YAAS;SAAQ;QACtDC;KACD;IAEHC,aAAa;QAACC;KAA6B,EAAE;QAACC;KAAkC;IAEhFC;IACAC;IACAC;IACAC;IACAC;CACD"}
|
|
@@ -16,3 +16,5 @@ export { scatterAdvancedPipeline } from './scatter';
|
|
|
16
16
|
export { heatmapAdvancedPipeline } from './heatmap';
|
|
17
17
|
export { radarAdvancedPipeline } from './radar';
|
|
18
18
|
export { dualAxisAdvancedPipeline } from './dualAxis';
|
|
19
|
+
export { boxplotAdvancedPipeline } from './boxplot';
|
|
20
|
+
export { histogramAdvancedPipeline } from './histogram';
|
|
@@ -16,4 +16,6 @@ import { scatterAdvancedPipeline } from "./scatter.js";
|
|
|
16
16
|
import { heatmapAdvancedPipeline } from "./heatmap.js";
|
|
17
17
|
import { radarAdvancedPipeline } from "./radar.js";
|
|
18
18
|
import { dualAxisAdvancedPipeline } from "./dualAxis.js";
|
|
19
|
-
|
|
19
|
+
import { boxplotAdvancedPipeline } from "./boxplot.js";
|
|
20
|
+
import { histogramAdvancedPipeline } from "./histogram.js";
|
|
21
|
+
export { areaAdvancedPipeline, areaPercentAdvancedPipeline, barAdvancedPipeline, barParallelAdvancedPipeline, barPercentAdvancedPipeline, boxplotAdvancedPipeline, columnAdvancedPipeline, columnParallelAdvancedPipeline, columnPercentAdvancedPipeline, donutAdvancedPipeline, dualAxisAdvancedPipeline, funnelAdvancedPipeline, heatmapAdvancedPipeline, histogramAdvancedPipeline, lineAdvancedPipeline, pieAdvancedPipeline, radarAdvancedPipeline, roseAdvancedPipeline, roseParallelAdvancedPipeline, scatterAdvancedPipeline };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { pick } from "remeda";
|
|
2
|
+
import { replaceNullToUndefined } from "../../../../utils/index.js";
|
|
3
|
+
const boxplotConfig = (advancedVSeed, context)=>{
|
|
4
|
+
const { vseed } = context;
|
|
5
|
+
const { chartType } = vseed;
|
|
6
|
+
const result = {
|
|
7
|
+
...advancedVSeed
|
|
8
|
+
};
|
|
9
|
+
const pickedConfig = pick(vseed, [
|
|
10
|
+
'backgroundColor',
|
|
11
|
+
'color',
|
|
12
|
+
'label',
|
|
13
|
+
'legend',
|
|
14
|
+
'tooltip',
|
|
15
|
+
'xAxis',
|
|
16
|
+
'yAxis',
|
|
17
|
+
'crosshairRect',
|
|
18
|
+
'whiskers'
|
|
19
|
+
]);
|
|
20
|
+
const config = replaceNullToUndefined(pickedConfig);
|
|
21
|
+
result.config = {
|
|
22
|
+
...result.config || {},
|
|
23
|
+
[chartType]: {
|
|
24
|
+
...config
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
return result;
|
|
28
|
+
};
|
|
29
|
+
export { boxplotConfig };
|
|
30
|
+
|
|
31
|
+
//# sourceMappingURL=boxplot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/config/boxplot.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/boxplot.ts"],"sourcesContent":["import { pick } from 'remeda'\nimport { replaceNullToUndefined } from 'src/pipeline/utils'\nimport type { AdvancedPipe, AdvancedVSeed, Config } from 'src/types'\n\nexport const boxplotConfig: AdvancedPipe = (advancedVSeed, context) => {\n const { vseed } = context\n const { chartType } = vseed\n const result = {\n ...advancedVSeed,\n }\n\n const pickedConfig = pick(vseed, [\n 'backgroundColor',\n 'color',\n 'label',\n 'legend',\n 'tooltip',\n 'xAxis',\n 'yAxis',\n 'crosshairRect',\n 'whiskers',\n ]) as Config['boxPlot']\n\n const config = replaceNullToUndefined(pickedConfig)\n\n result.config = {\n ...(result.config || {}),\n [chartType]: {\n ...config,\n },\n }\n\n return result as AdvancedVSeed\n}\n"],"names":["boxplotConfig","advancedVSeed","context","vseed","chartType","result","pickedConfig","pick","config","replaceNullToUndefined"],"mappings":";;AAIO,MAAMA,gBAA8B,CAACC,eAAeC;IACzD,MAAM,EAAEC,KAAK,EAAE,GAAGD;IAClB,MAAM,EAAEE,SAAS,EAAE,GAAGD;IACtB,MAAME,SAAS;QACb,GAAGJ,aAAa;IAClB;IAEA,MAAMK,eAAeC,KAAKJ,OAAO;QAC/B;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;KACD;IAED,MAAMK,SAASC,uBAAuBH;IAEtCD,OAAO,MAAM,GAAG;QACd,GAAIA,OAAO,MAAM,IAAI,CAAC,CAAC;QACvB,CAACD,UAAU,EAAE;YACX,GAAGI,MAAM;QACX;IACF;IAEA,OAAOH;AACT"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/config/dualAxis.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/dualAxis.ts"],"sourcesContent":["import { pick } from 'remeda'\nimport { replaceNullToUndefined } from 'src/pipeline/utils'\nimport type { AdvancedPipe, AdvancedVSeed, Config } from 'src/types'\n\nexport const dualAxisConfig: AdvancedPipe = (advancedVSeed, context) => {\n const { vseed } = context\n const { chartType } = vseed\n const result = {\n ...advancedVSeed,\n }\n\n const pickedConfig = pick(vseed, [\n // common\n 'backgroundColor',\n 'color',\n 'label',\n 'legend',\n 'tooltip',\n 'xAxis',\n\n // only for dualAxis\n 'dualChartType',\n 'alignTicks',\n 'primaryYAxis',\n 'secondaryYAxis',\n 'crosshairLine',\n 'crosshairRect',\n\n 'barGapInGroup',\n 'barMaxWidth',\n ]) as Config['dualAxis']\n\n const config = replaceNullToUndefined(pickedConfig)\n\n result.config = {\n ...(result.config || {}),\n [chartType]: {\n ...config,\n },\n }\n\n return result as AdvancedVSeed\n}\n"],"names":["dualAxisConfig","advancedVSeed","context","vseed","chartType","result","pickedConfig","pick","config","replaceNullToUndefined"],"mappings":";;AAIO,MAAMA,iBAA+B,CAACC,eAAeC;IAC1D,MAAM,EAAEC,KAAK,EAAE,GAAGD;IAClB,MAAM,EAAEE,SAAS,EAAE,GAAGD;IACtB,MAAME,SAAS;QACb,GAAGJ,aAAa;IAClB;IAEA,MAAMK,eAAeC,KAAKJ,OAAO;QAE/B;QACA;QACA;QACA;QACA;QACA;QAGA;QACA;QACA;QACA;QACA;QACA;QAEA;QACA;KACD;IAED,MAAMK,SAASC,uBAAuBH;IAEtCD,OAAO,MAAM,GAAG;QACd,GAAIA,OAAO,MAAM,IAAI,CAAC,CAAC;QACvB,CAACD,UAAU,EAAE;YACX,GAAGI,MAAM;QACX;IACF;IAEA,OAAOH;AACT"}
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/config/dualAxis.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/dualAxis.ts"],"sourcesContent":["import { pick } from 'remeda'\nimport { replaceNullToUndefined } from 'src/pipeline/utils'\nimport type { AdvancedPipe, AdvancedVSeed, Config } from 'src/types'\n\nexport const dualAxisConfig: AdvancedPipe = (advancedVSeed, context) => {\n const { vseed } = context\n const { chartType } = vseed\n const result = {\n ...advancedVSeed,\n }\n\n const pickedConfig = pick(vseed, [\n // common\n 'backgroundColor',\n 'color',\n 'label',\n 'legend',\n 'tooltip',\n 'xAxis',\n\n // only for dualAxis\n 'dualChartType',\n 'alignTicks',\n 'primaryYAxis',\n 'secondaryYAxis',\n 'crosshairLine',\n 'crosshairRect',\n\n 'barGapInGroup',\n 'barMaxWidth',\n 'stackCornerRadius',\n ]) as Config['dualAxis']\n\n const config = replaceNullToUndefined(pickedConfig)\n\n result.config = {\n ...(result.config || {}),\n [chartType]: {\n ...config,\n },\n }\n\n return result as AdvancedVSeed\n}\n"],"names":["dualAxisConfig","advancedVSeed","context","vseed","chartType","result","pickedConfig","pick","config","replaceNullToUndefined"],"mappings":";;AAIO,MAAMA,iBAA+B,CAACC,eAAeC;IAC1D,MAAM,EAAEC,KAAK,EAAE,GAAGD;IAClB,MAAM,EAAEE,SAAS,EAAE,GAAGD;IACtB,MAAME,SAAS;QACb,GAAGJ,aAAa;IAClB;IAEA,MAAMK,eAAeC,KAAKJ,OAAO;QAE/B;QACA;QACA;QACA;QACA;QACA;QAGA;QACA;QACA;QACA;QACA;QACA;QAEA;QACA;QACA;KACD;IAED,MAAMK,SAASC,uBAAuBH;IAEtCD,OAAO,MAAM,GAAG;QACd,GAAIA,OAAO,MAAM,IAAI,CAAC,CAAC;QACvB,CAACD,UAAU,EAAE;YACX,GAAGI,MAAM;QACX;IACF;IAEA,OAAOH;AACT"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { pick } from "remeda";
|
|
2
|
+
import { replaceNullToUndefined } from "../../../../utils/index.js";
|
|
3
|
+
const histogramConfig = (advancedVSeed, context)=>{
|
|
4
|
+
const { vseed } = context;
|
|
5
|
+
const { chartType } = vseed;
|
|
6
|
+
const result = {
|
|
7
|
+
...advancedVSeed
|
|
8
|
+
};
|
|
9
|
+
const pickedConfig = pick(vseed, [
|
|
10
|
+
'backgroundColor',
|
|
11
|
+
'color',
|
|
12
|
+
'label',
|
|
13
|
+
'legend',
|
|
14
|
+
'tooltip',
|
|
15
|
+
'xAxis',
|
|
16
|
+
'yAxis',
|
|
17
|
+
'crosshairRect',
|
|
18
|
+
'binCount',
|
|
19
|
+
'binStep',
|
|
20
|
+
'binValueType'
|
|
21
|
+
]);
|
|
22
|
+
const config = replaceNullToUndefined(pickedConfig);
|
|
23
|
+
result.config = {
|
|
24
|
+
...result.config || {},
|
|
25
|
+
[chartType]: {
|
|
26
|
+
...config
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
return result;
|
|
30
|
+
};
|
|
31
|
+
export { histogramConfig };
|
|
32
|
+
|
|
33
|
+
//# sourceMappingURL=histogram.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/config/histogram.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/histogram.ts"],"sourcesContent":["import { pick } from 'remeda'\nimport { replaceNullToUndefined } from 'src/pipeline/utils'\nimport type { AdvancedPipe, AdvancedVSeed, Config } from 'src/types'\n\nexport const histogramConfig: AdvancedPipe = (advancedVSeed, context) => {\n const { vseed } = context\n const { chartType } = vseed\n const result = {\n ...advancedVSeed,\n }\n\n const pickedConfig = pick(vseed, [\n 'backgroundColor',\n 'color',\n 'label',\n 'legend',\n 'tooltip',\n 'xAxis',\n 'yAxis',\n 'crosshairRect',\n 'binCount',\n 'binStep',\n 'binValueType',\n ]) as Config['histogram']\n\n const config = replaceNullToUndefined(pickedConfig)\n\n result.config = {\n ...(result.config || {}),\n [chartType]: {\n ...config,\n },\n }\n\n return result as AdvancedVSeed\n}\n"],"names":["histogramConfig","advancedVSeed","context","vseed","chartType","result","pickedConfig","pick","config","replaceNullToUndefined"],"mappings":";;AAIO,MAAMA,kBAAgC,CAACC,eAAeC;IAC3D,MAAM,EAAEC,KAAK,EAAE,GAAGD;IAClB,MAAM,EAAEE,SAAS,EAAE,GAAGD;IACtB,MAAME,SAAS;QACb,GAAGJ,aAAa;IAClB;IAEA,MAAMK,eAAeC,KAAKJ,OAAO;QAC/B;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;KACD;IAED,MAAMK,SAASC,uBAAuBH;IAEtCD,OAAO,MAAM,GAAG;QACd,GAAIA,OAAO,MAAM,IAAI,CAAC,CAAC;QACvB,CAACD,UAAU,EAAE;YACX,GAAGI,MAAM;QACX;IACF;IAEA,OAAOH;AACT"}
|
|
@@ -3,7 +3,9 @@ import { columnConfig } from './column';
|
|
|
3
3
|
import { pieConfig } from './pie';
|
|
4
4
|
import { dualAxisConfig } from './dualAxis';
|
|
5
5
|
import { scatterConfig } from './scatter';
|
|
6
|
-
|
|
6
|
+
import { histogramConfig } from './histogram';
|
|
7
|
+
import { boxplotConfig } from './boxplot';
|
|
8
|
+
export { lineConfig, columnConfig, pieConfig, dualAxisConfig, scatterConfig, histogramConfig, boxplotConfig };
|
|
7
9
|
export declare const areaConfig: import("../../../../..").AdvancedPipe;
|
|
8
10
|
export declare const areaPercentConfig: import("../../../../..").AdvancedPipe;
|
|
9
11
|
export declare const barConfig: import("../../../../..").AdvancedPipe;
|
|
@@ -3,6 +3,8 @@ import { columnConfig } from "./column.js";
|
|
|
3
3
|
import { pieConfig } from "./pie.js";
|
|
4
4
|
import { dualAxisConfig } from "./dualAxis.js";
|
|
5
5
|
import { scatterConfig } from "./scatter.js";
|
|
6
|
+
import { histogramConfig } from "./histogram.js";
|
|
7
|
+
import { boxplotConfig } from "./boxplot.js";
|
|
6
8
|
const areaConfig = lineConfig;
|
|
7
9
|
const areaPercentConfig = lineConfig;
|
|
8
10
|
const barConfig = columnConfig;
|
|
@@ -16,6 +18,6 @@ const roseParallelConfig = pieConfig;
|
|
|
16
18
|
const radarConfig = pieConfig;
|
|
17
19
|
const funnelConfig = pieConfig;
|
|
18
20
|
const heatmapConfig = pieConfig;
|
|
19
|
-
export { areaConfig, areaPercentConfig, barConfig, barParallelConfig, barPercentConfig, columnConfig, columnParallelConfig, columnPercentConfig, donutConfig, dualAxisConfig, funnelConfig, heatmapConfig, lineConfig, pieConfig, radarConfig, roseConfig, roseParallelConfig, scatterConfig };
|
|
21
|
+
export { areaConfig, areaPercentConfig, barConfig, barParallelConfig, barPercentConfig, boxplotConfig, columnConfig, columnParallelConfig, columnPercentConfig, donutConfig, dualAxisConfig, funnelConfig, heatmapConfig, histogramConfig, lineConfig, pieConfig, radarConfig, roseConfig, roseParallelConfig, scatterConfig };
|
|
20
22
|
|
|
21
23
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/config/index.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/index.ts"],"sourcesContent":["import { lineConfig } from './line'\nimport { columnConfig } from './column'\nimport { pieConfig } from './pie'\nimport { dualAxisConfig } from './dualAxis'\nimport { scatterConfig } from './scatter'\n\nexport { lineConfig, columnConfig, pieConfig, dualAxisConfig, scatterConfig }\n\n// area\nexport const areaConfig = lineConfig\nexport const areaPercentConfig = lineConfig\n\n// bar\nexport const barConfig = columnConfig\nexport const barParallelConfig = columnConfig\nexport const barPercentConfig = columnConfig\n\n// column\nexport const columnParallelConfig = columnConfig\nexport const columnPercentConfig = columnConfig\n\n// donut, rose\nexport const donutConfig = pieConfig\nexport const roseConfig = pieConfig\nexport const roseParallelConfig = pieConfig\nexport const radarConfig = pieConfig\n\n// funnel, heatmap\nexport const funnelConfig = pieConfig\nexport const heatmapConfig = pieConfig\n"],"names":["areaConfig","lineConfig","areaPercentConfig","barConfig","columnConfig","barParallelConfig","barPercentConfig","columnParallelConfig","columnPercentConfig","donutConfig","pieConfig","roseConfig","roseParallelConfig","radarConfig","funnelConfig","heatmapConfig"],"mappings":"
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/config/index.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/config/index.ts"],"sourcesContent":["import { lineConfig } from './line'\nimport { columnConfig } from './column'\nimport { pieConfig } from './pie'\nimport { dualAxisConfig } from './dualAxis'\nimport { scatterConfig } from './scatter'\nimport { histogramConfig } from './histogram'\nimport { boxplotConfig } from './boxplot'\n\nexport { lineConfig, columnConfig, pieConfig, dualAxisConfig, scatterConfig, histogramConfig, boxplotConfig }\n\n// area\nexport const areaConfig = lineConfig\nexport const areaPercentConfig = lineConfig\n\n// bar\nexport const barConfig = columnConfig\nexport const barParallelConfig = columnConfig\nexport const barPercentConfig = columnConfig\n\n// column\nexport const columnParallelConfig = columnConfig\nexport const columnPercentConfig = columnConfig\n\n// donut, rose\nexport const donutConfig = pieConfig\nexport const roseConfig = pieConfig\nexport const roseParallelConfig = pieConfig\nexport const radarConfig = pieConfig\n\n// funnel, heatmap\nexport const funnelConfig = pieConfig\nexport const heatmapConfig = pieConfig\n"],"names":["areaConfig","lineConfig","areaPercentConfig","barConfig","columnConfig","barParallelConfig","barPercentConfig","columnParallelConfig","columnPercentConfig","donutConfig","pieConfig","roseConfig","roseParallelConfig","radarConfig","funnelConfig","heatmapConfig"],"mappings":";;;;;;;AAWO,MAAMA,aAAaC;AACnB,MAAMC,oBAAoBD;AAG1B,MAAME,YAAYC;AAClB,MAAMC,oBAAoBD;AAC1B,MAAME,mBAAmBF;AAGzB,MAAMG,uBAAuBH;AAC7B,MAAMI,sBAAsBJ;AAG5B,MAAMK,cAAcC;AACpB,MAAMC,aAAaD;AACnB,MAAME,qBAAqBF;AAC3B,MAAMG,cAAcH;AAGpB,MAAMI,eAAeJ;AACrB,MAAMK,gBAAgBL"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { unique } from "remeda";
|
|
2
|
+
import { MeasureName } from "../../../../../dataReshape/index.js";
|
|
3
|
+
import { findAllMeasures } from "../../../../utils/index.js";
|
|
4
|
+
import { addColorToEncoding } from "./color/index.js";
|
|
5
|
+
const defaultEncodingForBoxplot = (advancedVSeed)=>{
|
|
6
|
+
const { measures: vseedMeasures = [], dimensions = [] } = advancedVSeed;
|
|
7
|
+
const measures = findAllMeasures(vseedMeasures);
|
|
8
|
+
const encoding = {};
|
|
9
|
+
generateDefaultDimensionEncoding(dimensions, encoding);
|
|
10
|
+
generateDefaultMeasureEncoding(measures, encoding);
|
|
11
|
+
return {
|
|
12
|
+
...advancedVSeed,
|
|
13
|
+
encoding
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
const encodingForBoxplot = (advancedVSeed)=>{
|
|
17
|
+
const { measures: vseedMeasures = [], dimensions = [] } = advancedVSeed;
|
|
18
|
+
const measures = findAllMeasures(vseedMeasures);
|
|
19
|
+
const hasDimensionEncoding = dimensions.some((item)=>item.encoding);
|
|
20
|
+
const hasMeasureEncoding = measures.some((item)=>item.encoding);
|
|
21
|
+
const encoding = {};
|
|
22
|
+
if (hasDimensionEncoding) generateDimensionEncoding(dimensions, encoding, measures.length > 1);
|
|
23
|
+
else generateDefaultDimensionEncoding(dimensions, encoding);
|
|
24
|
+
if (hasMeasureEncoding) generateMeasureEncoding(measures, encoding);
|
|
25
|
+
else generateDefaultMeasureEncoding(measures, encoding);
|
|
26
|
+
if ((!encoding.value || encoding.value.length <= 1) && encoding.color && encoding.color.length > 1) encoding.color = encoding.color.filter((c)=>c !== MeasureName);
|
|
27
|
+
return {
|
|
28
|
+
...advancedVSeed,
|
|
29
|
+
encoding
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
const generateDefaultDimensionEncoding = (dimensions, encoding)=>{
|
|
33
|
+
const onlyMeasureName = 1 === dimensions.length && dimensions.find((item)=>item.id === MeasureName);
|
|
34
|
+
const uniqueDimIds = unique(dimensions.map((d)=>d.id));
|
|
35
|
+
encoding.x = uniqueDimIds.slice(0, 1);
|
|
36
|
+
encoding.color = uniqueDimIds.slice(onlyMeasureName ? 0 : 1);
|
|
37
|
+
encoding.tooltip = uniqueDimIds.filter((d)=>d !== MeasureName);
|
|
38
|
+
encoding.label = [];
|
|
39
|
+
encoding.row = [];
|
|
40
|
+
encoding.column = [];
|
|
41
|
+
};
|
|
42
|
+
const generateDimensionEncoding = (dimensions, encoding, isMultiMeasure)=>{
|
|
43
|
+
encoding.x = unique(dimensions.filter((item)=>'xAxis' === item.encoding).map((item)=>item.id));
|
|
44
|
+
if (0 === encoding.x.length) encoding.x = [
|
|
45
|
+
dimensions[0].id
|
|
46
|
+
];
|
|
47
|
+
addColorToEncoding(dimensions, encoding, isMultiMeasure);
|
|
48
|
+
encoding.tooltip = unique(dimensions.map((item)=>item.id));
|
|
49
|
+
encoding.tooltip = encoding.tooltip.filter((d)=>d !== MeasureName);
|
|
50
|
+
encoding.label = unique(dimensions.filter((item)=>'label' === item.encoding).map((item)=>item.id));
|
|
51
|
+
encoding.label = encoding.label.filter((d)=>d !== MeasureName);
|
|
52
|
+
};
|
|
53
|
+
const generateDefaultMeasureEncoding = (measures, encoding)=>{
|
|
54
|
+
encoding.value = unique(measures.filter((item)=>'value' === item.encoding || !item.encoding).map((item)=>item.id));
|
|
55
|
+
};
|
|
56
|
+
const generateMeasureEncoding = (measures, encoding)=>{
|
|
57
|
+
encoding.value = unique(measures.filter((item)=>'value' === item.encoding || !item.encoding).map((item)=>item.id));
|
|
58
|
+
encoding.q1 = unique(measures.filter((item)=>'q1' === item.encoding).map((item)=>item.id));
|
|
59
|
+
encoding.median = unique(measures.filter((item)=>'median' === item.encoding).map((item)=>item.id));
|
|
60
|
+
encoding.q3 = unique(measures.filter((item)=>'q3' === item.encoding).map((item)=>item.id));
|
|
61
|
+
encoding.min = unique(measures.filter((item)=>'min' === item.encoding).map((item)=>item.id));
|
|
62
|
+
encoding.max = unique(measures.filter((item)=>'max' === item.encoding).map((item)=>item.id));
|
|
63
|
+
encoding.outliers = unique(measures.filter((item)=>'outliers' === item.encoding).map((item)=>item.id));
|
|
64
|
+
const color = unique(measures.filter((item)=>'color' === item.encoding).map((item)=>item.id));
|
|
65
|
+
if (color.length > 0) encoding.color = color;
|
|
66
|
+
const label = unique(measures.filter((item)=>'label' === item.encoding).map((item)=>item.id));
|
|
67
|
+
encoding.label = unique([
|
|
68
|
+
...encoding.label || [],
|
|
69
|
+
...label
|
|
70
|
+
]);
|
|
71
|
+
const tooltip = unique(measures.filter((item)=>'tooltip' === item.encoding).map((item)=>item.id));
|
|
72
|
+
encoding.tooltip = unique([
|
|
73
|
+
...encoding.tooltip || [],
|
|
74
|
+
...label,
|
|
75
|
+
...tooltip
|
|
76
|
+
]);
|
|
77
|
+
};
|
|
78
|
+
export { defaultEncodingForBoxplot, encodingForBoxplot };
|
|
79
|
+
|
|
80
|
+
//# sourceMappingURL=boxplot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/encoding/boxplot.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/encoding/boxplot.ts"],"sourcesContent":["import { unique } from 'remeda'\nimport { MeasureName } from 'src/dataReshape'\nimport { findAllMeasures } from 'src/pipeline/utils'\nimport type { AdvancedPipe, Dimension, Dimensions, Encoding, Measure, Measures } from 'src/types'\nimport { addColorToEncoding } from './color'\n\nexport const defaultEncodingForBoxplot: AdvancedPipe = (advancedVSeed) => {\n const { measures: vseedMeasures = [], dimensions = [] } = advancedVSeed\n const measures = findAllMeasures(vseedMeasures)\n const encoding: Encoding = {}\n generateDefaultDimensionEncoding(dimensions, encoding)\n generateDefaultMeasureEncoding(measures, encoding)\n return { ...advancedVSeed, encoding }\n}\n\nexport const encodingForBoxplot: AdvancedPipe = (advancedVSeed) => {\n const { measures: vseedMeasures = [], dimensions = [] } = advancedVSeed\n const measures = findAllMeasures(vseedMeasures)\n\n const hasDimensionEncoding = dimensions.some((item: Dimension) => item.encoding)\n const hasMeasureEncoding = measures.some((item: Measure) => item.encoding)\n const encoding: Encoding = {}\n\n if (hasDimensionEncoding) {\n generateDimensionEncoding(dimensions, encoding, measures.length > 1)\n } else {\n generateDefaultDimensionEncoding(dimensions, encoding)\n }\n\n if (hasMeasureEncoding) {\n generateMeasureEncoding(measures, encoding)\n } else {\n generateDefaultMeasureEncoding(measures, encoding)\n }\n\n if ((!encoding.value || encoding.value.length <= 1) && encoding.color && encoding.color.length > 1) {\n encoding.color = encoding.color.filter((c) => c !== MeasureName)\n }\n\n return { ...advancedVSeed, encoding }\n}\n\n/**\n * --------------------维度--------------------\n */\nconst generateDefaultDimensionEncoding = (dimensions: Dimensions, encoding: Encoding) => {\n const onlyMeasureName = dimensions.length === 1 && dimensions.find((item) => item.id === MeasureName)\n const uniqueDimIds = unique(dimensions.map((d) => d.id))\n encoding.x = uniqueDimIds.slice(0, 1) // 第一个维度放置于X轴\n encoding.color = uniqueDimIds.slice(onlyMeasureName ? 0 : 1) // 第二个之后的维度用于颜色\n encoding.tooltip = uniqueDimIds.filter((d) => d !== MeasureName) // 展示指标名称之外的所有维度\n encoding.label = [] // 默认不展示标签\n encoding.row = [] // 默认不进行行透视\n encoding.column = [] // 默认不进行列透视\n}\nconst generateDimensionEncoding = (dimensions: Dimensions, encoding: Encoding, isMultiMeasure: boolean) => {\n // x\n encoding.x = unique(dimensions.filter((item) => item.encoding === 'xAxis').map((item) => item.id))\n if (encoding.x.length === 0) {\n encoding.x = [dimensions[0].id]\n }\n\n // color\n addColorToEncoding(dimensions, encoding, isMultiMeasure)\n\n // tooltip\n encoding.tooltip = unique(dimensions.map((item) => item.id))\n encoding.tooltip = encoding.tooltip.filter((d) => d !== MeasureName)\n\n // label\n encoding.label = unique(dimensions.filter((item) => item.encoding === 'label').map((item) => item.id))\n encoding.label = encoding.label.filter((d) => d !== MeasureName)\n}\n\n/**\n * --------------------指标--------------------\n */\nconst generateDefaultMeasureEncoding = (measures: Measures, encoding: Encoding) => {\n encoding.value = unique(measures.filter((item) => item.encoding === 'value' || !item.encoding).map((item) => item.id))\n}\nconst generateMeasureEncoding = (measures: Measures, encoding: Encoding) => {\n // y\n encoding.value = unique(measures.filter((item) => item.encoding === 'value' || !item.encoding).map((item) => item.id))\n encoding.q1 = unique(measures.filter((item) => item.encoding === 'q1').map((item) => item.id))\n encoding.median = unique(measures.filter((item) => item.encoding === 'median').map((item) => item.id))\n encoding.q3 = unique(measures.filter((item) => item.encoding === 'q3').map((item) => item.id))\n encoding.min = unique(measures.filter((item) => item.encoding === 'min').map((item) => item.id))\n encoding.max = unique(measures.filter((item) => item.encoding === 'max').map((item) => item.id))\n encoding.outliers = unique(measures.filter((item) => item.encoding === 'outliers').map((item) => item.id))\n // color\n const color = unique(measures.filter((item) => item.encoding === 'color').map((item) => item.id))\n if (color.length > 0) {\n encoding.color = color\n }\n\n // label\n const label = unique(measures.filter((item) => item.encoding === 'label').map((item) => item.id))\n encoding.label = unique([...(encoding.label || []), ...label])\n\n // tooltip\n const tooltip = unique(measures.filter((item) => item.encoding === 'tooltip').map((item) => item.id))\n encoding.tooltip = unique([...(encoding.tooltip || []), ...label, ...tooltip])\n}\n"],"names":["defaultEncodingForBoxplot","advancedVSeed","vseedMeasures","dimensions","measures","findAllMeasures","encoding","generateDefaultDimensionEncoding","generateDefaultMeasureEncoding","encodingForBoxplot","hasDimensionEncoding","item","hasMeasureEncoding","generateDimensionEncoding","generateMeasureEncoding","c","MeasureName","onlyMeasureName","uniqueDimIds","unique","d","isMultiMeasure","addColorToEncoding","color","label","tooltip"],"mappings":"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"}
|