@visactor/vseed 0.3.1 → 0.3.3
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 +1 -1
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/esm/builder/builder/builder.d.ts +1176 -0
- package/dist/esm/dataReshape/constant.d.ts +1 -0
- package/dist/esm/dataReshape/constant.js +2 -1
- package/dist/esm/dataReshape/constant.js.map +1 -1
- package/dist/esm/dataReshape/dataReshapeByEncoding.d.ts +1 -1
- package/dist/esm/dataReshape/dataReshapeByEncoding.js.map +1 -1
- package/dist/esm/dataReshape/foldMeasures.js +12 -11
- package/dist/esm/dataReshape/foldMeasures.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipeline/scatter.js +3 -1
- package/dist/esm/pipeline/advanced/chart/pipeline/scatter.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/column.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/column.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/heatmap.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/heatmap.js +31 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/heatmap.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/histogram.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/histogram.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.d.ts +2 -2
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.js +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/index.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/line.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/line.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/pie.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/pie.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/config/scatter.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/config/scatter.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/dimensions/addPivotDimensionsForScatter.d.ts +2 -0
- package/dist/esm/pipeline/advanced/chart/pipes/dimensions/addPivotDimensionsForScatter.js +29 -0
- package/dist/esm/pipeline/advanced/chart/pipes/dimensions/addPivotDimensionsForScatter.js.map +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/dimensions/index.d.ts +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/dimensions/index.js +1 -0
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/bar.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/bar.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/boxplot.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/boxplot.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/column.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/column.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/dualAxis.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/dualAxis.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/funnel.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/funnel.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/heatmap.js +2 -6
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/heatmap.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/histogram.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/histogram.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/line.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/line.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/pie.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/pie.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/radar.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/radar.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/rose.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/rose.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/scatter.js +14 -4
- package/dist/esm/pipeline/advanced/chart/pipes/encoding/scatter.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.js +16 -24
- package/dist/esm/pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.js +7 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.js +10 -6
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.js +12 -3
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.js +4 -2
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js +2 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithScatterEncoding.js +5 -2
- package/dist/esm/pipeline/advanced/chart/pipes/reshape/reshapeWithScatterEncoding.js.map +1 -1
- package/dist/esm/pipeline/advanced/table/pipes/default/defaultDimensions.js.map +1 -1
- package/dist/esm/pipeline/advanced/table/pipes/default/defaultMeasures.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/area.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/area.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/areaPercent.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/areaPercent.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/bar.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/bar.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/barParallel.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/barParallel.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/barPercent.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/barPercent.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/column.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/column.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/columnParallel.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/columnParallel.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/columnPercent.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/columnPercent.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/donut.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/donut.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/dualAxis.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/dualAxis.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/funnel.js +3 -2
- package/dist/esm/pipeline/spec/chart/pipeline/funnel.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/heatmap.js +8 -5
- package/dist/esm/pipeline/spec/chart/pipeline/heatmap.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/histogram.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/histogram.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/line.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/line.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/pie.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/pie.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipeline/scatter.js +3 -1
- package/dist/esm/pipeline/spec/chart/pipeline/scatter.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/axes/xBand.js +2 -2
- package/dist/esm/pipeline/spec/chart/pipes/axes/xBand.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/axes/yBand.js +2 -2
- package/dist/esm/pipeline/spec/chart/pipes/axes/yBand.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/brush/brush.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/brush/brush.js +37 -0
- package/dist/esm/pipeline/spec/chart/pipes/brush/brush.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/brush/index.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/brush/index.js +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/color/colorAdapter.js +3 -3
- package/dist/esm/pipeline/spec/chart/pipes/color/colorAdapter.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/color/index.d.ts +0 -1
- package/dist/esm/pipeline/spec/chart/pipes/color/index.js +1 -2
- package/dist/esm/pipeline/spec/chart/pipes/dual/adjustXField.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/dual/adjustXField.js +17 -0
- package/dist/esm/pipeline/spec/chart/pipes/dual/adjustXField.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/dual/dualChartType.js +3 -5
- package/dist/esm/pipeline/spec/chart/pipes/dual/dualChartType.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/dual/index.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/dual/index.js +2 -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/label/label.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/label/label.js +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/label/label.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/legend/colorLegend.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/legend/pivotColorLegend.js +2 -2
- package/dist/esm/pipeline/spec/chart/pipes/legend/pivotColorLegend.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/markStyle/cellStyle.js +17 -8
- package/dist/esm/pipeline/spec/chart/pipes/markStyle/cellStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/heatmapColorDomain.d.ts +2 -0
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/heatmapColorDomain.js +18 -0
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/heatmapColorDomain.js.map +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/index.d.ts +1 -0
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/index.js +2 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotAxisStyle.js +13 -7
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotAxisStyle.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotColumnDimensions.js +12 -3
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotColumnDimensions.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotGridStyle.js +2 -2
- 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 +12 -3
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotRowDimensions.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotTitle.js +4 -2
- package/dist/esm/pipeline/spec/chart/pipes/pivotChart/pivotTitle.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltip.d.ts +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltip.js +14 -8
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltip.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipBoxplot.js +8 -2
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipBoxplot.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipDualAxis.js +2 -2
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipDualAxis.js.map +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipScatter.d.ts +1 -1
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipScatter.js +9 -2
- package/dist/esm/pipeline/spec/chart/pipes/tooltip/tooltipScatter.js.map +1 -1
- package/dist/esm/pipeline/utils/chatType.js +24 -4
- package/dist/esm/pipeline/utils/chatType.js.map +1 -1
- package/dist/esm/pipeline/utils/measures/typeGuard.d.ts +1 -1
- package/dist/esm/pipeline/utils/measures/typeGuard.js +30 -6
- package/dist/esm/pipeline/utils/measures/typeGuard.js.map +1 -1
- package/dist/esm/theme/common/axes.js +0 -4
- package/dist/esm/theme/common/axes.js.map +1 -1
- package/dist/esm/theme/common/brush.d.ts +3 -0
- package/dist/esm/theme/common/brush.js +21 -0
- package/dist/esm/theme/common/brush.js.map +1 -0
- package/dist/esm/theme/common/heatmapCell.js +4 -2
- package/dist/esm/theme/common/heatmapCell.js.map +1 -1
- package/dist/esm/theme/common/index.d.ts +1 -0
- package/dist/esm/theme/common/index.js +1 -0
- package/dist/esm/theme/common/label.d.ts +18 -0
- package/dist/esm/theme/common/label.js +9 -1
- package/dist/esm/theme/common/label.js.map +1 -1
- package/dist/esm/theme/dark/dark.js +4 -2
- package/dist/esm/theme/dark/dark.js.map +1 -1
- package/dist/esm/theme/light/light.js +4 -2
- package/dist/esm/theme/light/light.js.map +1 -1
- package/dist/esm/types/advancedVSeed.d.ts +392 -0
- package/dist/esm/types/chartType/area/area.d.ts +6 -1
- package/dist/esm/types/chartType/area/zArea.d.ts +4 -0
- package/dist/esm/types/chartType/area/zArea.js +2 -1
- package/dist/esm/types/chartType/area/zArea.js.map +1 -1
- package/dist/esm/types/chartType/areaPercent/areaPercent.d.ts +6 -1
- package/dist/esm/types/chartType/areaPercent/zAreaPercent.d.ts +4 -0
- package/dist/esm/types/chartType/areaPercent/zAreaPercent.js +2 -1
- package/dist/esm/types/chartType/areaPercent/zAreaPercent.js.map +1 -1
- package/dist/esm/types/chartType/bar/bar.d.ts +6 -1
- package/dist/esm/types/chartType/bar/zBar.d.ts +4 -0
- package/dist/esm/types/chartType/bar/zBar.js +2 -1
- package/dist/esm/types/chartType/bar/zBar.js.map +1 -1
- package/dist/esm/types/chartType/barParallel/barParallel.d.ts +6 -1
- package/dist/esm/types/chartType/barParallel/zBarParallel.d.ts +4 -0
- package/dist/esm/types/chartType/barParallel/zBarParallel.js +2 -1
- package/dist/esm/types/chartType/barParallel/zBarParallel.js.map +1 -1
- package/dist/esm/types/chartType/barPercent/barPercent.d.ts +6 -1
- package/dist/esm/types/chartType/barPercent/zBarPercent.d.ts +4 -0
- package/dist/esm/types/chartType/barPercent/zBarPercent.js +2 -1
- package/dist/esm/types/chartType/barPercent/zBarPercent.js.map +1 -1
- package/dist/esm/types/chartType/boxPlot/boxPlot.d.ts +6 -1
- package/dist/esm/types/chartType/boxPlot/zBoxPlot.d.ts +4 -0
- package/dist/esm/types/chartType/boxPlot/zBoxPlot.js +2 -1
- package/dist/esm/types/chartType/boxPlot/zBoxPlot.js.map +1 -1
- package/dist/esm/types/chartType/column/column.d.ts +6 -1
- package/dist/esm/types/chartType/column/zColumn.d.ts +4 -0
- package/dist/esm/types/chartType/column/zColumn.js +2 -1
- package/dist/esm/types/chartType/column/zColumn.js.map +1 -1
- package/dist/esm/types/chartType/columnParallel/columnParallel.d.ts +6 -1
- package/dist/esm/types/chartType/columnParallel/zColumnParallel.d.ts +4 -0
- package/dist/esm/types/chartType/columnParallel/zColumnParallel.js +2 -1
- package/dist/esm/types/chartType/columnParallel/zColumnParallel.js.map +1 -1
- package/dist/esm/types/chartType/columnPercent/columnPercent.d.ts +6 -1
- package/dist/esm/types/chartType/columnPercent/zColumnPercent.d.ts +4 -0
- package/dist/esm/types/chartType/columnPercent/zColumnPercent.js +2 -1
- package/dist/esm/types/chartType/columnPercent/zColumnPercent.js.map +1 -1
- package/dist/esm/types/chartType/donut/donut.d.ts +6 -0
- package/dist/esm/types/chartType/donut/zDonut.d.ts +4 -0
- package/dist/esm/types/chartType/donut/zDonut.js +2 -1
- package/dist/esm/types/chartType/donut/zDonut.js.map +1 -1
- package/dist/esm/types/chartType/dualAxis/dualAxis.d.ts +6 -1
- package/dist/esm/types/chartType/dualAxis/zDualAxis.d.ts +4 -0
- package/dist/esm/types/chartType/dualAxis/zDualAxis.js +2 -1
- package/dist/esm/types/chartType/dualAxis/zDualAxis.js.map +1 -1
- package/dist/esm/types/chartType/funnel/funnel.d.ts +6 -0
- package/dist/esm/types/chartType/funnel/zFunnel.d.ts +4 -0
- package/dist/esm/types/chartType/funnel/zFunnel.js +2 -1
- package/dist/esm/types/chartType/funnel/zFunnel.js.map +1 -1
- package/dist/esm/types/chartType/heatmap/heatmap.d.ts +6 -0
- package/dist/esm/types/chartType/heatmap/zHeatmap.d.ts +4 -0
- package/dist/esm/types/chartType/heatmap/zHeatmap.js +2 -1
- package/dist/esm/types/chartType/heatmap/zHeatmap.js.map +1 -1
- package/dist/esm/types/chartType/histogram/histogram.d.ts +6 -1
- package/dist/esm/types/chartType/histogram/zHistogram.d.ts +4 -0
- package/dist/esm/types/chartType/histogram/zHistogram.js +2 -1
- package/dist/esm/types/chartType/histogram/zHistogram.js.map +1 -1
- package/dist/esm/types/chartType/line/line.d.ts +6 -1
- package/dist/esm/types/chartType/line/zLine.d.ts +4 -0
- package/dist/esm/types/chartType/line/zLine.js +2 -1
- package/dist/esm/types/chartType/line/zLine.js.map +1 -1
- package/dist/esm/types/chartType/pie/pie.d.ts +6 -0
- package/dist/esm/types/chartType/pie/zPie.d.ts +4 -0
- package/dist/esm/types/chartType/pie/zPie.js +2 -1
- package/dist/esm/types/chartType/pie/zPie.js.map +1 -1
- package/dist/esm/types/chartType/radar/radar.d.ts +6 -0
- package/dist/esm/types/chartType/radar/zRadar.d.ts +4 -0
- package/dist/esm/types/chartType/radar/zRadar.js +2 -1
- package/dist/esm/types/chartType/radar/zRadar.js.map +1 -1
- package/dist/esm/types/chartType/rose/rose.d.ts +6 -0
- package/dist/esm/types/chartType/rose/zRose.d.ts +4 -0
- package/dist/esm/types/chartType/rose/zRose.js +2 -1
- package/dist/esm/types/chartType/rose/zRose.js.map +1 -1
- package/dist/esm/types/chartType/roseParallel/roseParallel.d.ts +6 -0
- package/dist/esm/types/chartType/roseParallel/zRoseParallel.d.ts +4 -0
- package/dist/esm/types/chartType/roseParallel/zRoseParallel.js +2 -1
- package/dist/esm/types/chartType/roseParallel/zRoseParallel.js.map +1 -1
- package/dist/esm/types/chartType/scatter/scatter.d.ts +6 -1
- package/dist/esm/types/chartType/scatter/zScatter.d.ts +4 -0
- package/dist/esm/types/chartType/scatter/zScatter.js +2 -1
- package/dist/esm/types/chartType/scatter/zScatter.js.map +1 -1
- package/dist/esm/types/properties/brush/brush.d.ts +13 -0
- package/dist/esm/types/properties/brush/brush.js +0 -0
- package/dist/esm/types/properties/brush/index.d.ts +4 -0
- package/dist/esm/types/properties/brush/index.js +2 -0
- package/dist/esm/types/properties/brush/zBrush.d.ts +19 -0
- package/dist/esm/types/properties/brush/zBrush.js +21 -0
- package/dist/esm/types/properties/brush/zBrush.js.map +1 -0
- package/dist/esm/types/properties/config/area.d.ts +26 -0
- package/dist/esm/types/properties/config/area.js +3 -1
- package/dist/esm/types/properties/config/area.js.map +1 -1
- package/dist/esm/types/properties/config/bar.d.ts +39 -0
- package/dist/esm/types/properties/config/bar.js +3 -1
- package/dist/esm/types/properties/config/bar.js.map +1 -1
- package/dist/esm/types/properties/config/column.d.ts +39 -0
- package/dist/esm/types/properties/config/column.js +3 -1
- package/dist/esm/types/properties/config/column.js.map +1 -1
- package/dist/esm/types/properties/config/config.d.ts +196 -0
- package/dist/esm/types/properties/config/heatmap/heatmap.d.ts +4 -0
- package/dist/esm/types/properties/config/heatmap/zHeatmap.d.ts +1 -0
- package/dist/esm/types/properties/config/heatmap/zHeatmap.js +2 -1
- package/dist/esm/types/properties/config/heatmap/zHeatmap.js.map +1 -1
- package/dist/esm/types/properties/config/heatmap.d.ts +14 -0
- package/dist/esm/types/properties/config/heatmap.js +3 -1
- package/dist/esm/types/properties/config/heatmap.js.map +1 -1
- package/dist/esm/types/properties/config/histogram.d.ts +13 -0
- package/dist/esm/types/properties/config/histogram.js +3 -1
- package/dist/esm/types/properties/config/histogram.js.map +1 -1
- package/dist/esm/types/properties/config/line.d.ts +13 -0
- package/dist/esm/types/properties/config/line.js +3 -1
- package/dist/esm/types/properties/config/line.js.map +1 -1
- package/dist/esm/types/properties/config/pie.d.ts +39 -0
- package/dist/esm/types/properties/config/pie.js +3 -1
- package/dist/esm/types/properties/config/pie.js.map +1 -1
- package/dist/esm/types/properties/config/scatter.d.ts +13 -0
- package/dist/esm/types/properties/config/scatter.js +3 -1
- package/dist/esm/types/properties/config/scatter.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/theme/customTheme.d.ts +392 -0
- package/dist/esm/types/zVseed.d.ts +80 -0
- package/dist/umd/index.js +528 -187
- package/dist/umd/index.js.map +1 -1
- package/package.json +3 -3
- package/dist/esm/pipeline/spec/chart/pipes/color/colorCellStyleFill.d.ts +0 -2
- package/dist/esm/pipeline/spec/chart/pipes/color/colorCellStyleFill.js +0 -17
- package/dist/esm/pipeline/spec/chart/pipes/color/colorCellStyleFill.js.map +0 -1
|
@@ -1,40 +1,32 @@
|
|
|
1
1
|
import { clone } from "remeda";
|
|
2
|
-
import {
|
|
3
|
-
import { ensureParentIdInitialized, isCommonMeasureEncoding } from "./utils.js";
|
|
2
|
+
import { isCommonMeasureEncoding } from "./utils.js";
|
|
4
3
|
const buildMeasuresForScatter = (advancedVSeed)=>{
|
|
5
4
|
const { measures = [] } = advancedVSeed;
|
|
6
|
-
const
|
|
7
|
-
const parentIds = [];
|
|
5
|
+
const encodedMeasures = [];
|
|
8
6
|
for(let index = 0; index < measures.length; index++){
|
|
9
7
|
const item = measures[index];
|
|
10
8
|
const encoding = item.encoding;
|
|
11
|
-
const parentId = item.parentId || DEFAULT_PARENT_ID;
|
|
12
9
|
const isYAxis = 'yAxis' === encoding;
|
|
13
10
|
const isXAxis = 'xAxis' === encoding;
|
|
14
11
|
const isOtherEncoding = item.encoding && isCommonMeasureEncoding(encoding);
|
|
15
|
-
|
|
16
|
-
if (
|
|
17
|
-
else if (isXAxis) measuresByView[parentId].push(item);
|
|
12
|
+
if (isYAxis) encodedMeasures.push(item);
|
|
13
|
+
else if (isXAxis) encodedMeasures.push(item);
|
|
18
14
|
else if (!isOtherEncoding && 'size' !== encoding) {
|
|
19
|
-
const xCount =
|
|
15
|
+
const xCount = encodedMeasures.filter((m)=>'xAxis' === m.encoding).length;
|
|
20
16
|
item.encoding = 0 === xCount ? 'xAxis' : 'yAxis';
|
|
21
|
-
|
|
17
|
+
encodedMeasures.push(item);
|
|
22
18
|
}
|
|
23
19
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
];
|
|
35
|
-
}
|
|
36
|
-
return basicMeasures;
|
|
37
|
-
}).filter((m)=>m.length > 0);
|
|
20
|
+
const xCount = encodedMeasures.filter((m)=>'xAxis' === m.encoding).length;
|
|
21
|
+
const yCount = encodedMeasures.filter((m)=>'yAxis' === m.encoding).length;
|
|
22
|
+
if (0 === yCount && xCount > 0) {
|
|
23
|
+
const cloneMeasure = clone(encodedMeasures[0]);
|
|
24
|
+
cloneMeasure.encoding = 'yAxis';
|
|
25
|
+
encodedMeasures.push(cloneMeasure);
|
|
26
|
+
}
|
|
27
|
+
advancedVSeed.reshapeMeasures = encodedMeasures.length > 0 ? [
|
|
28
|
+
encodedMeasures
|
|
29
|
+
] : [];
|
|
38
30
|
return advancedVSeed;
|
|
39
31
|
};
|
|
40
32
|
export { buildMeasuresForScatter };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.ts"],"sourcesContent":["import type { AdvancedPipe, MeasureEncoding,
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/measures/buildMeasuresForScatter.ts"],"sourcesContent":["import type { AdvancedPipe, MeasureEncoding, ScatterMeasure } from 'src/types'\nimport { clone } from 'remeda'\nimport { isCommonMeasureEncoding } from './utils'\n\nexport const buildMeasuresForScatter: AdvancedPipe = (advancedVSeed) => {\n const { measures = [] } = advancedVSeed\n const encodedMeasures: ScatterMeasure[] = []\n\n for (let index = 0; index < measures.length; index++) {\n const item = measures[index]\n const encoding = item.encoding\n const isYAxis = encoding === 'yAxis'\n const isXAxis = encoding === 'xAxis'\n const isOtherEncoding = item.encoding && isCommonMeasureEncoding(encoding as MeasureEncoding)\n\n if (isYAxis) {\n encodedMeasures.push(item as ScatterMeasure)\n } else if (isXAxis) {\n encodedMeasures.push(item as ScatterMeasure)\n } else if (!isOtherEncoding && encoding !== 'size') {\n const xCount = encodedMeasures.filter((m) => m.encoding === 'xAxis').length\n item.encoding = xCount === 0 ? 'xAxis' : 'yAxis'\n encodedMeasures.push(item as ScatterMeasure)\n }\n }\n\n const xCount = encodedMeasures.filter((m) => m.encoding === 'xAxis').length\n const yCount = encodedMeasures.filter((m) => m.encoding === 'yAxis').length\n\n if (yCount === 0 && xCount > 0) {\n const cloneMeasure = clone(encodedMeasures[0])\n cloneMeasure.encoding = 'yAxis'\n encodedMeasures.push(cloneMeasure)\n }\n\n advancedVSeed.reshapeMeasures = encodedMeasures.length > 0 ? [encodedMeasures] : []\n\n return advancedVSeed\n}\n"],"names":["buildMeasuresForScatter","advancedVSeed","measures","encodedMeasures","index","item","encoding","isYAxis","isXAxis","isOtherEncoding","isCommonMeasureEncoding","xCount","m","yCount","cloneMeasure","clone"],"mappings":";;AAIO,MAAMA,0BAAwC,CAACC;IACpD,MAAM,EAAEC,WAAW,EAAE,EAAE,GAAGD;IAC1B,MAAME,kBAAoC,EAAE;IAE5C,IAAK,IAAIC,QAAQ,GAAGA,QAAQF,SAAS,MAAM,EAAEE,QAAS;QACpD,MAAMC,OAAOH,QAAQ,CAACE,MAAM;QAC5B,MAAME,WAAWD,KAAK,QAAQ;QAC9B,MAAME,UAAUD,AAAa,YAAbA;QAChB,MAAME,UAAUF,AAAa,YAAbA;QAChB,MAAMG,kBAAkBJ,KAAK,QAAQ,IAAIK,wBAAwBJ;QAEjE,IAAIC,SACFJ,gBAAgB,IAAI,CAACE;aAChB,IAAIG,SACTL,gBAAgB,IAAI,CAACE;aAChB,IAAI,CAACI,mBAAmBH,AAAa,WAAbA,UAAqB;YAClD,MAAMK,SAASR,gBAAgB,MAAM,CAAC,CAACS,IAAMA,AAAe,YAAfA,EAAE,QAAQ,EAAc,MAAM;YAC3EP,KAAK,QAAQ,GAAGM,AAAW,MAAXA,SAAe,UAAU;YACzCR,gBAAgB,IAAI,CAACE;QACvB;IACF;IAEA,MAAMM,SAASR,gBAAgB,MAAM,CAAC,CAACS,IAAMA,AAAe,YAAfA,EAAE,QAAQ,EAAc,MAAM;IAC3E,MAAMC,SAASV,gBAAgB,MAAM,CAAC,CAACS,IAAMA,AAAe,YAAfA,EAAE,QAAQ,EAAc,MAAM;IAE3E,IAAIC,AAAW,MAAXA,UAAgBF,SAAS,GAAG;QAC9B,MAAMG,eAAeC,MAAMZ,eAAe,CAAC,EAAE;QAC7CW,aAAa,QAAQ,GAAG;QACxBX,gBAAgB,IAAI,CAACW;IACvB;IAEAb,cAAc,eAAe,GAAGE,gBAAgB,MAAM,GAAG,IAAI;QAACA;KAAgB,GAAG,EAAE;IAEnF,OAAOF;AACT"}
|
package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.ts"],"sourcesContent":["import { boxplot } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\nimport {\n FoldMeasureId,\n FoldMeasureName,\n LowerWhisker,\n MedianMeasureId,\n OutliersMeasureId,\n Q1MeasureValue,\n Q3MeasureValue,\n Separator,\n unfoldDimensions,\n UpperWhisker,\n} from 'src/dataReshape'\nimport { DEFAULT_PARENT_ID, revisedBoxPlotFieldKey } from 'src/pipeline/utils'\nimport type {
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithBoxplotEncoding.ts"],"sourcesContent":["import { boxplot } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\nimport {\n FoldMeasureId,\n FoldMeasureName,\n LowerWhisker,\n MedianMeasureId,\n OutliersMeasureId,\n Q1MeasureValue,\n Q3MeasureValue,\n Separator,\n unfoldDimensions,\n UpperWhisker,\n} from 'src/dataReshape'\nimport { DEFAULT_PARENT_ID, revisedBoxPlotFieldKey } from 'src/pipeline/utils'\nimport type {\n AdvancedPipe,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Datum,\n Dimension,\n Encoding,\n Measure,\n} from 'src/types'\n\nexport const pivotReshapeWithBoxplotEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n const chartConfig = config?.[chartType as 'boxPlot']\n const whiskers = chartConfig?.whiskers\n\n const rowColumnFields = uniqueBy(\n dimensions.filter((dim: Dimension) => dim.encoding === 'row' || dim.encoding === 'column'),\n (item: Dimension) => item.id,\n )\n const datasets: Dataset = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measureGroup: Measure[], index: number) => {\n const groupId = measureGroup[0].parentId ?? DEFAULT_PARENT_ID\n let newDatasets: any[] = []\n let foldInfo: any = {}\n let unfoldInfo: any = {}\n const validEncodingIds = (encoding.value || []).filter((id: string) =>\n measureGroup.find((field) => field.id === id),\n )\n\n if (validEncodingIds.length) {\n const boxPlotDataList: Dataset = []\n validEncodingIds.forEach((f: string) => {\n const m = measureGroup.find((m) => m.id === f)\n const boxPlotData = boxplot(dataset, {\n field: f,\n groupField: [\n ...(encoding.x ?? []),\n ...(encoding.color ?? []),\n ...rowColumnFields.map((item: Dimension) => item.id),\n ] as string[],\n whiskers,\n outputNames: {\n q1: Q1MeasureValue,\n q3: Q3MeasureValue,\n lowerWhisker: LowerWhisker,\n upperWhisker: UpperWhisker,\n median: MedianMeasureId,\n outliers: OutliersMeasureId,\n },\n }) as Dataset\n\n boxPlotData.forEach((datum: Datum) => {\n datum[FoldMeasureId] = f\n datum[FoldMeasureName] = m?.alias ?? f\n datum[revisedBoxPlotFieldKey(Q1MeasureValue, groupId)] = datum[Q1MeasureValue]\n datum[revisedBoxPlotFieldKey(Q3MeasureValue, groupId)] = datum[Q3MeasureValue]\n datum[revisedBoxPlotFieldKey(LowerWhisker, groupId)] = datum[LowerWhisker]\n datum[revisedBoxPlotFieldKey(UpperWhisker, groupId)] = datum[UpperWhisker]\n datum[revisedBoxPlotFieldKey(MedianMeasureId, groupId)] = datum[MedianMeasureId]\n datum[revisedBoxPlotFieldKey(OutliersMeasureId, groupId)] = datum[OutliersMeasureId]\n })\n\n boxPlotDataList.push(...boxPlotData)\n })\n const res = unfoldDimensions(boxPlotDataList, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d: Datum) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (\n encoding.q1?.length &&\n encoding.q3?.length &&\n encoding.min?.length &&\n encoding.max?.length &&\n encoding.median?.length\n ) {\n const res = unfoldDimensions(dataset, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((datum: Datum) => {\n datum[UpperWhisker] = datum[encoding.max![0]]\n datum[revisedBoxPlotFieldKey(Q1MeasureValue, groupId)] = datum[encoding.max![0]]\n datum[LowerWhisker] = datum[encoding.min![0]]\n datum[revisedBoxPlotFieldKey(LowerWhisker, groupId)] = datum[encoding.min![0]]\n datum[Q1MeasureValue] = datum[encoding.q1![0]]\n datum[revisedBoxPlotFieldKey(Q1MeasureValue, groupId)] = datum[encoding.q1![0]]\n datum[Q3MeasureValue] = datum[encoding.q3![0]]\n datum[revisedBoxPlotFieldKey(Q3MeasureValue, groupId)] = datum[encoding.q3![0]]\n datum[MedianMeasureId] = datum[encoding.median![0]]\n datum[revisedBoxPlotFieldKey(MedianMeasureId, groupId)] = datum[encoding.median![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = {}\n unfoldInfo = res.unfoldInfo\n }\n\n const reshapeInfo = {\n id: `${groupId}`,\n index,\n foldInfo,\n unfoldInfo,\n }\n datasets.push(newDatasets)\n datasetReshapeInfo.push(reshapeInfo)\n })\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithBoxplotEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","reshapeMeasures","dimensions","uniqDims","uniqueBy","item","chartConfig","whiskers","rowColumnFields","dim","datasets","datasetReshapeInfo","measureGroup","index","groupId","DEFAULT_PARENT_ID","newDatasets","foldInfo","unfoldInfo","validEncodingIds","id","field","boxPlotDataList","f","m","boxPlotData","boxplot","Q1MeasureValue","Q3MeasureValue","LowerWhisker","UpperWhisker","MedianMeasureId","OutliersMeasureId","datum","FoldMeasureId","FoldMeasureName","revisedBoxPlotFieldKey","res","unfoldDimensions","Separator","d","reshapeInfo"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { unique, uniqueBy } from "remeda";
|
|
2
|
-
import { FoldPrimaryMeasureValue, FoldSecondaryMeasureValue, dataReshapeByEncoding } from "../../../../../dataReshape/index.js";
|
|
2
|
+
import { DimAxisType, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue, dataReshapeByEncoding } from "../../../../../dataReshape/index.js";
|
|
3
3
|
import { DEFAULT_DUAL_CHART_TYPE } from "../../../../../index.js";
|
|
4
4
|
import { getColorMeasureId } from "../../../../spec/chart/pipes/index.js";
|
|
5
5
|
const pivotReshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
@@ -31,6 +31,9 @@ const pivotReshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
|
31
31
|
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
32
32
|
omitIds: allMeasuresIds
|
|
33
33
|
});
|
|
34
|
+
primaryResult.dataset.forEach((row)=>{
|
|
35
|
+
row[DimAxisType] = 'primaryYAxis';
|
|
36
|
+
});
|
|
34
37
|
datasets.push(primaryResult.dataset);
|
|
35
38
|
foldInfoList.push(primaryResult.foldInfo);
|
|
36
39
|
unfoldInfoList.push(primaryResult.unfoldInfo);
|
|
@@ -42,6 +45,9 @@ const pivotReshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
|
42
45
|
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
43
46
|
omitIds: allMeasuresIds
|
|
44
47
|
});
|
|
48
|
+
secondaryResult.dataset.forEach((row)=>{
|
|
49
|
+
row[DimAxisType] = 'secondaryYAxis';
|
|
50
|
+
});
|
|
45
51
|
datasets.push(secondaryResult.dataset);
|
|
46
52
|
foldInfoList.push(secondaryResult.foldInfo);
|
|
47
53
|
unfoldInfoList.push(secondaryResult.unfoldInfo);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.ts"],"sourcesContent":["import { uniqueBy, unique } from 'remeda'\nimport { dataReshapeByEncoding, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue } from 'src/dataReshape'\nimport { DEFAULT_DUAL_CHART_TYPE } from 'src/index'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Dimension,\n DualAxisMeasure,\n Encoding,\n FoldInfo,\n Measure,\n Measures,\n UnfoldInfo,\n} from 'src/types'\n\nexport const pivotReshapeWithDualEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding, chartType } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const allMeasuresIds = reshapeMeasures.flatMap((measureGroup) => measureGroup.map((m) => m.id))\n\n const datasetList: Dataset[] = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measures: Measures, index) => {\n const foldInfoList: FoldInfo[] = []\n const unfoldInfoList: UnfoldInfo[] = []\n\n const datasets: Dataset[] = []\n const primaryMeasures = measures.filter((m) => m.encoding === 'primaryYAxis')\n const secondaryMeasures = measures.filter((m) => m.encoding === 'secondaryYAxis')\n const primaryChartTypes: string[] = unique(primaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n const secondaryChartTypes: string[] = unique(secondaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n\n if (!primaryChartTypes.length) {\n primaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.primary)\n }\n\n if (!secondaryChartTypes.length) {\n secondaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.secondary)\n }\n\n primaryChartTypes.forEach((chartType) => {\n const primaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n primaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldPrimaryMeasureValue}${index}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n datasets.push(primaryResult.dataset)\n foldInfoList.push(primaryResult.foldInfo)\n unfoldInfoList.push(primaryResult.unfoldInfo)\n })\n\n secondaryChartTypes.forEach((chartType) => {\n const secondaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n secondaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldSecondaryMeasureValue}${index}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n datasets.push(secondaryResult.dataset)\n foldInfoList.push(secondaryResult.foldInfo)\n unfoldInfoList.push(secondaryResult.unfoldInfo)\n })\n\n const unfoldInfo: UnfoldInfo = {\n ...unfoldInfoList[0],\n colorItems: unfoldInfoList.flatMap((d) => d.colorItems),\n colorIdMap: unfoldInfoList.reduce((prev, cur) => ({ ...prev, ...cur.colorIdMap }), {}),\n }\n\n const reshapeInfo = {\n id: `${chartType}-${index}`,\n index,\n foldInfo: foldInfoList[0],\n foldInfoList: foldInfoList,\n unfoldInfo: unfoldInfo,\n }\n\n datasetReshapeInfo.push(reshapeInfo)\n datasetList.push(datasets.flat(2))\n })\n\n return {\n ...result,\n dataset: datasetList,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithDualEncoding","advancedVSeed","context","result","vseed","dataset","encoding","chartType","reshapeMeasures","dimensions","allMeasuresIds","measureGroup","m","datasetList","datasetReshapeInfo","measures","index","foldInfoList","unfoldInfoList","datasets","primaryMeasures","secondaryMeasures","primaryChartTypes","unique","secondaryChartTypes","DEFAULT_DUAL_CHART_TYPE","primaryResult","dataReshapeByEncoding","uniqueBy","item","FoldPrimaryMeasureValue","getColorMeasureId","secondaryResult","FoldSecondaryMeasureValue","unfoldInfo","d","prev","cur","reshapeInfo"],"mappings":";;;;
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithDualEncoding.ts"],"sourcesContent":["import { uniqueBy, unique } from 'remeda'\nimport { dataReshapeByEncoding, DimAxisType, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue } from 'src/dataReshape'\nimport { DEFAULT_DUAL_CHART_TYPE } from 'src/index'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Datum,\n Dimension,\n DualAxisMeasure,\n Encoding,\n FoldInfo,\n Measure,\n Measures,\n UnfoldInfo,\n} from 'src/types'\n\nexport const pivotReshapeWithDualEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding, chartType } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const allMeasuresIds = reshapeMeasures.flatMap((measureGroup: Measures) => measureGroup.map((m) => m.id))\n\n const datasetList: Dataset[] = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measures: Measures, index: number) => {\n const foldInfoList: FoldInfo[] = []\n const unfoldInfoList: UnfoldInfo[] = []\n\n const datasets: Dataset[] = []\n const primaryMeasures = measures.filter((m) => m.encoding === 'primaryYAxis')\n const secondaryMeasures = measures.filter((m) => m.encoding === 'secondaryYAxis')\n const primaryChartTypes: string[] = unique(primaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n const secondaryChartTypes: string[] = unique(secondaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n\n if (!primaryChartTypes.length) {\n primaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.primary)\n }\n\n if (!secondaryChartTypes.length) {\n secondaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.secondary)\n }\n\n primaryChartTypes.forEach((chartType) => {\n const primaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n primaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldPrimaryMeasureValue}${index}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n primaryResult.dataset.forEach((row: Datum) => {\n row[DimAxisType] = 'primaryYAxis'\n })\n\n datasets.push(primaryResult.dataset)\n foldInfoList.push(primaryResult.foldInfo)\n unfoldInfoList.push(primaryResult.unfoldInfo)\n })\n\n secondaryChartTypes.forEach((chartType) => {\n const secondaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n secondaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldSecondaryMeasureValue}${index}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n secondaryResult.dataset.forEach((row: Datum) => {\n row[DimAxisType] = 'secondaryYAxis'\n })\n\n datasets.push(secondaryResult.dataset)\n foldInfoList.push(secondaryResult.foldInfo)\n unfoldInfoList.push(secondaryResult.unfoldInfo)\n })\n\n const unfoldInfo: UnfoldInfo = {\n ...unfoldInfoList[0],\n colorItems: unfoldInfoList.flatMap((d) => d.colorItems),\n colorIdMap: unfoldInfoList.reduce((prev, cur) => ({ ...prev, ...cur.colorIdMap }), {}),\n }\n\n const reshapeInfo = {\n id: `${chartType}-${index}`,\n index,\n foldInfo: foldInfoList[0],\n foldInfoList: foldInfoList,\n unfoldInfo: unfoldInfo,\n }\n\n datasetReshapeInfo.push(reshapeInfo)\n datasetList.push(datasets.flat(2))\n })\n\n return {\n ...result,\n dataset: datasetList,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithDualEncoding","advancedVSeed","context","result","vseed","dataset","encoding","chartType","reshapeMeasures","dimensions","allMeasuresIds","measureGroup","m","datasetList","datasetReshapeInfo","measures","index","foldInfoList","unfoldInfoList","datasets","primaryMeasures","secondaryMeasures","primaryChartTypes","unique","secondaryChartTypes","DEFAULT_DUAL_CHART_TYPE","primaryResult","dataReshapeByEncoding","uniqueBy","item","FoldPrimaryMeasureValue","getColorMeasureId","row","DimAxisType","secondaryResult","FoldSecondaryMeasureValue","unfoldInfo","d","prev","cur","reshapeInfo"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithEncoding.ts"],"sourcesContent":["import { uniqueBy } from 'remeda'\nimport { dataReshapeByEncoding, FoldMeasureValue } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_PARENT_ID } from 'src/pipeline/utils/constant'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Dimension,\n Encoding,\n Measure,\n} from 'src/types'\n\nexport const pivotReshapeWithEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n\n const allMeasuresIds = reshapeMeasures.flatMap((measureGroup) => measureGroup.map((m) => m.id))\n\n const datasets: Dataset = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measures, index) => {\n if (!measures) {\n return\n }\n const groupId = measures[0].parentId ?? DEFAULT_PARENT_ID\n const {\n dataset: newSubDataset,\n foldInfo,\n unfoldInfo,\n } = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(measures, (item: Measure) => item.id),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldMeasureValue}${groupId}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n const reshapeInfo = {\n id: `${groupId}`,\n index,\n foldInfo,\n unfoldInfo,\n }\n datasets.push(newSubDataset)\n datasetReshapeInfo.push(reshapeInfo)\n })\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithEncoding","advancedVSeed","context","result","vseed","dataset","encoding","reshapeMeasures","dimensions","allMeasuresIds","measureGroup","m","datasets","datasetReshapeInfo","measures","index","groupId","DEFAULT_PARENT_ID","newSubDataset","foldInfo","unfoldInfo","dataReshapeByEncoding","uniqueBy","item","FoldMeasureValue","getColorMeasureId","reshapeInfo"],"mappings":";;;;AAeO,MAAMA,2BAAyC,CAACC,eAAeC;IACpE,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAE,GAAGD;IACpB,MAAM,EAAEE,QAAQ,EAAE,GAAGL;IACrB,MAAMM,kBAAkBN,cAAc,eAAe,IAAI,EAAE;IAC3D,MAAMO,aAAaP,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IAEpF,MAAMQ,iBAAiBF,gBAAgB,OAAO,CAAC,CAACG,
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithEncoding.ts"],"sourcesContent":["import { uniqueBy } from 'remeda'\nimport { dataReshapeByEncoding, FoldMeasureValue } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_PARENT_ID } from 'src/pipeline/utils/constant'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Dimension,\n Encoding,\n Measure,\n} from 'src/types'\n\nexport const pivotReshapeWithEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n\n const allMeasuresIds = reshapeMeasures.flatMap((measureGroup: Measure[]) => measureGroup.map((m) => m.id))\n\n const datasets: Dataset = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measures: Measure[], index: number) => {\n if (!measures) {\n return\n }\n const groupId = measures[0].parentId ?? DEFAULT_PARENT_ID\n const {\n dataset: newSubDataset,\n foldInfo,\n unfoldInfo,\n } = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(measures, (item: Measure) => item.id),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: `${FoldMeasureValue}${groupId}`,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n const reshapeInfo = {\n id: `${groupId}`,\n index,\n foldInfo,\n unfoldInfo,\n }\n datasets.push(newSubDataset)\n datasetReshapeInfo.push(reshapeInfo)\n })\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithEncoding","advancedVSeed","context","result","vseed","dataset","encoding","reshapeMeasures","dimensions","allMeasuresIds","measureGroup","m","datasets","datasetReshapeInfo","measures","index","groupId","DEFAULT_PARENT_ID","newSubDataset","foldInfo","unfoldInfo","dataReshapeByEncoding","uniqueBy","item","FoldMeasureValue","getColorMeasureId","reshapeInfo"],"mappings":";;;;AAeO,MAAMA,2BAAyC,CAACC,eAAeC;IACpE,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAE,GAAGD;IACpB,MAAM,EAAEE,QAAQ,EAAE,GAAGL;IACrB,MAAMM,kBAAkBN,cAAc,eAAe,IAAI,EAAE;IAC3D,MAAMO,aAAaP,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IAEpF,MAAMQ,iBAAiBF,gBAAgB,OAAO,CAAC,CAACG,eAA4BA,aAAa,GAAG,CAAC,CAACC,IAAMA,EAAE,EAAE;IAExG,MAAMC,WAAoB,EAAE;IAC5B,MAAMC,qBAAyC,EAAE;IAEjDN,gBAAgB,OAAO,CAAC,CAACO,UAAqBC;QAC5C,IAAI,CAACD,UACH;QAEF,MAAME,UAAUF,QAAQ,CAAC,EAAE,CAAC,QAAQ,IAAIG;QACxC,MAAM,EACJ,SAASC,aAAa,EACtBC,QAAQ,EACRC,UAAU,EACX,GAAGC,sBACFhB,SACAiB,SAASd,YAAY,CAACe,OAAoBA,KAAK,EAAE,GACjDD,SAASR,UAAU,CAACS,OAAkBA,KAAK,EAAE,GAC7CjB,UACA;YACE,eAAe;YACf,kBAAkB,GAAGkB,mBAAmBR,SAAS;YACjD,gBAAgBS,kBAAkBxB,eAAgCG;YAClE,SAASK;QACX;QAGF,MAAMiB,cAAc;YAClB,IAAI,GAAGV,SAAS;YAChBD;YACAI;YACAC;QACF;QACAR,SAAS,IAAI,CAACM;QACdL,mBAAmB,IAAI,CAACa;IAC1B;IAEA,OAAO;QACL,GAAGvB,MAAM;QACT,SAASS;QACT,oBAAoBC;IACtB;AACF"}
|
|
@@ -83,7 +83,8 @@ const pivotReshapeWithHistogramEncoding = (advancedVSeed, context)=>{
|
|
|
83
83
|
} else if (encoding.x0?.length && encoding.x1?.length && encoding.y?.length) {
|
|
84
84
|
const res = dataReshapeByEncoding(dataset, uniqueBy(dimensions, (item)=>item.id), subMeasures.filter((item)=>encoding.y?.includes(item.id)).slice(0, 1), encoding, {
|
|
85
85
|
colorItemAsId: false,
|
|
86
|
-
colorMeasureId
|
|
86
|
+
colorMeasureId,
|
|
87
|
+
omitIds: []
|
|
87
88
|
});
|
|
88
89
|
res.dataset.forEach((datum)=>{
|
|
89
90
|
datum[BinStartMeasureId] = datum[encoding.x0[0]];
|
package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.ts"],"sourcesContent":["import { bin } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\nimport {\n BinCountMeasureId,\n BinEndMeasureId,\n BinPercentageMeasureId,\n BinStartMeasureId,\n dataReshapeByEncoding,\n FoldMeasureId,\n FoldMeasureName,\n FoldMeasureValue,\n Separator,\n unfoldDimensions,\n} from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_PARENT_ID } from 'src/pipeline/utils'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Datum,\n Dimension,\n Encoding,\n FoldInfo,\n} from 'src/types'\n\nexport const pivotReshapeWithHistogramEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const colorMeasureId = getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed)\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n const chartConfig = config?.[chartType as 'histogram']\n const binCount = chartConfig?.binCount\n const binStep = chartConfig?.binStep\n const binValueType = chartConfig?.binValueType\n\n const rowColumnFields = uniqueBy(\n dimensions.filter((dim: Dimension) => dim.encoding === 'row' || dim.encoding === 'column'),\n (item: Dimension) => item.id,\n )\n\n const datasets: Dataset = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((subMeasures, index) => {\n if (!subMeasures) {\n return\n }\n const groupId = subMeasures[0].id ?? DEFAULT_PARENT_ID\n\n let newDatasets: any[] = []\n let foldInfo: FoldInfo = {\n foldMap: {},\n measureId: FoldMeasureId,\n measureName: FoldMeasureName,\n measureValue: FoldMeasureValue,\n statistics: {\n max: -Infinity,\n min: Infinity,\n sum: 0,\n count: 0,\n colorMin: Infinity,\n colorMax: -Infinity,\n },\n }\n let unfoldInfo: any = {}\n\n if (encoding.value?.length) {\n const valueField = encoding.value[0]\n const m = subMeasures.find((m) => m.id === valueField)\n const binData = bin(dataset, {\n field: valueField,\n groupField: [...(encoding.x ?? []), ...(encoding.color ?? [])] as string[],\n facetField: rowColumnFields.map((item: Dimension) => item.id),\n bins: binCount,\n step: binStep,\n outputNames: {\n x0: BinStartMeasureId,\n x1: BinEndMeasureId,\n count: BinCountMeasureId,\n percentage: BinPercentageMeasureId,\n },\n }) as Dataset\n\n binData.forEach((datum: Datum) => {\n datum[FoldMeasureId] = valueField\n datum[FoldMeasureName] = m?.alias ?? valueField\n const valueNumber = binValueType === 'percentage' ? +datum[BinPercentageMeasureId] : +datum[BinCountMeasureId]\n datum[FoldMeasureValue] = valueNumber\n datum[valueField] = valueNumber\n\n foldInfo.statistics.min = Math.min(foldInfo.statistics.min, valueNumber)\n foldInfo.statistics.max = Math.max(foldInfo.statistics.max, valueNumber)\n foldInfo.statistics.sum += valueNumber\n foldInfo.statistics.count++\n })\n if (m?.id) {\n foldInfo.foldMap[m?.id] = m?.alias\n }\n\n const res = unfoldDimensions(binData, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (encoding.x0?.length && encoding.x1?.length && encoding.y?.length) {\n const res = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n subMeasures.filter((item) => encoding.y?.includes(item.id)).slice(0, 1),\n encoding as Encoding,\n {\n colorItemAsId: false,\n colorMeasureId,\n },\n )\n\n res.dataset.forEach((datum) => {\n datum[BinStartMeasureId] = datum[encoding.x0![0]]\n datum[BinEndMeasureId] = datum[encoding.x1![0]]\n datum[FoldMeasureId] = datum[encoding.y![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = res.foldInfo\n unfoldInfo = res.unfoldInfo\n }\n\n const reshapeInfo = {\n id: `${groupId}`,\n index,\n foldInfo,\n unfoldInfo,\n }\n datasets.push(newDatasets)\n datasetReshapeInfo.push(reshapeInfo)\n })\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithHistogramEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","reshapeMeasures","dimensions","colorMeasureId","getColorMeasureId","uniqDims","uniqueBy","item","chartConfig","binCount","binStep","binValueType","rowColumnFields","dim","datasets","datasetReshapeInfo","subMeasures","index","groupId","DEFAULT_PARENT_ID","newDatasets","foldInfo","FoldMeasureId","FoldMeasureName","FoldMeasureValue","Infinity","unfoldInfo","valueField","m","binData","bin","BinStartMeasureId","BinEndMeasureId","BinCountMeasureId","BinPercentageMeasureId","datum","valueNumber","Math","res","unfoldDimensions","Separator","d","dataReshapeByEncoding","reshapeInfo"],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithHistogramEncoding.ts"],"sourcesContent":["import { bin } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\nimport {\n BinCountMeasureId,\n BinEndMeasureId,\n BinPercentageMeasureId,\n BinStartMeasureId,\n dataReshapeByEncoding,\n FoldMeasureId,\n FoldMeasureName,\n FoldMeasureValue,\n Separator,\n unfoldDimensions,\n} from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_PARENT_ID } from 'src/pipeline/utils'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Datum,\n Dimension,\n Encoding,\n FoldInfo,\n Measure,\n} from 'src/types'\n\nexport const pivotReshapeWithHistogramEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const colorMeasureId = getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed)\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n const chartConfig = config?.[chartType as 'histogram']\n const binCount = chartConfig?.binCount\n const binStep = chartConfig?.binStep\n const binValueType = chartConfig?.binValueType\n\n const rowColumnFields = uniqueBy(\n dimensions.filter((dim: Dimension) => dim.encoding === 'row' || dim.encoding === 'column'),\n (item: Dimension) => item.id,\n )\n\n const datasets: Dataset = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((subMeasures: Measure[], index: number) => {\n if (!subMeasures) {\n return\n }\n const groupId = subMeasures[0].id ?? DEFAULT_PARENT_ID\n\n let newDatasets: any[] = []\n let foldInfo: FoldInfo = {\n foldMap: {},\n measureId: FoldMeasureId,\n measureName: FoldMeasureName,\n measureValue: FoldMeasureValue,\n statistics: {\n max: -Infinity,\n min: Infinity,\n sum: 0,\n count: 0,\n colorMin: Infinity,\n colorMax: -Infinity,\n },\n }\n let unfoldInfo: any = {}\n\n if (encoding.value?.length) {\n const valueField = encoding.value[0]\n const m = subMeasures.find((m: Measure) => m.id === valueField)\n const binData = bin(dataset, {\n field: valueField,\n groupField: [...(encoding.x ?? []), ...(encoding.color ?? [])] as string[],\n facetField: rowColumnFields.map((item: Dimension) => item.id),\n bins: binCount,\n step: binStep,\n outputNames: {\n x0: BinStartMeasureId,\n x1: BinEndMeasureId,\n count: BinCountMeasureId,\n percentage: BinPercentageMeasureId,\n },\n }) as Dataset\n\n binData.forEach((datum: Datum) => {\n datum[FoldMeasureId] = valueField\n datum[FoldMeasureName] = m?.alias ?? valueField\n const valueNumber = binValueType === 'percentage' ? +datum[BinPercentageMeasureId] : +datum[BinCountMeasureId]\n datum[FoldMeasureValue] = valueNumber\n datum[valueField] = valueNumber\n\n foldInfo.statistics.min = Math.min(foldInfo.statistics.min, valueNumber)\n foldInfo.statistics.max = Math.max(foldInfo.statistics.max, valueNumber)\n foldInfo.statistics.sum += valueNumber\n foldInfo.statistics.count++\n })\n if (m?.id) {\n foldInfo.foldMap[m?.id] = m?.alias\n }\n\n const res = unfoldDimensions(binData, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d: Datum) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (encoding.x0?.length && encoding.x1?.length && encoding.y?.length) {\n const res = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n subMeasures.filter((item: Measure) => encoding.y?.includes(item.id)).slice(0, 1),\n encoding as Encoding,\n {\n colorItemAsId: false,\n colorMeasureId,\n omitIds: [],\n },\n )\n\n res.dataset.forEach((datum: Datum) => {\n datum[BinStartMeasureId] = datum[encoding.x0![0]]\n datum[BinEndMeasureId] = datum[encoding.x1![0]]\n datum[FoldMeasureId] = datum[encoding.y![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = res.foldInfo\n unfoldInfo = res.unfoldInfo\n }\n\n const reshapeInfo = {\n id: `${groupId}`,\n index,\n foldInfo,\n unfoldInfo,\n }\n datasets.push(newDatasets)\n datasetReshapeInfo.push(reshapeInfo)\n })\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithHistogramEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","reshapeMeasures","dimensions","colorMeasureId","getColorMeasureId","uniqDims","uniqueBy","item","chartConfig","binCount","binStep","binValueType","rowColumnFields","dim","datasets","datasetReshapeInfo","subMeasures","index","groupId","DEFAULT_PARENT_ID","newDatasets","foldInfo","FoldMeasureId","FoldMeasureName","FoldMeasureValue","Infinity","unfoldInfo","valueField","m","binData","bin","BinStartMeasureId","BinEndMeasureId","BinCountMeasureId","BinPercentageMeasureId","datum","valueNumber","Math","res","unfoldDimensions","Separator","d","dataReshapeByEncoding","reshapeInfo"],"mappings":"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"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { unique } from "remeda";
|
|
2
|
+
import { FoldXMeasureId, FoldXMeasureValue, FoldYMeasureId, FoldYMeasureValue, ORIGINAL_DATA, dataReshapeByEncoding } from "../../../../../dataReshape/index.js";
|
|
2
3
|
import { getColorMeasureId } from "../../../../spec/chart/pipes/index.js";
|
|
3
4
|
const pivotReshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
4
5
|
const result = {
|
|
@@ -9,7 +10,8 @@ const pivotReshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
9
10
|
const { encoding, chartType } = advancedVSeed;
|
|
10
11
|
const reshapeMeasures = advancedVSeed.reshapeMeasures ?? [];
|
|
11
12
|
const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? [];
|
|
12
|
-
|
|
13
|
+
let allMeasuresIds = unique(reshapeMeasures.flatMap((measureGroup)=>measureGroup.map((m)=>m.id)));
|
|
14
|
+
if (encoding?.size?.length) allMeasuresIds = allMeasuresIds.filter((mId)=>!encoding.size.includes(mId));
|
|
13
15
|
const datasetList = [];
|
|
14
16
|
const datasetReshapeInfo = [];
|
|
15
17
|
reshapeMeasures.forEach((measures, index)=>{
|
|
@@ -20,6 +22,7 @@ const pivotReshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
20
22
|
const yMeasures = measures.filter((m)=>'yAxis' === m.encoding);
|
|
21
23
|
const xResult = dataReshapeByEncoding(dataset, dimensions, xMeasures, encoding, {
|
|
22
24
|
foldMeasureValue: `${FoldXMeasureValue}${index}`,
|
|
25
|
+
foldMeasureId: FoldXMeasureId,
|
|
23
26
|
colorItemAsId: true,
|
|
24
27
|
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
25
28
|
omitIds: allMeasuresIds
|
|
@@ -29,6 +32,7 @@ const pivotReshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
29
32
|
unfoldInfoList.push(xResult.unfoldInfo);
|
|
30
33
|
const yResult = dataReshapeByEncoding(dataset, dimensions, yMeasures, encoding, {
|
|
31
34
|
foldMeasureValue: `${FoldYMeasureValue}${index}`,
|
|
35
|
+
foldMeasureId: FoldYMeasureId,
|
|
32
36
|
colorItemAsId: true,
|
|
33
37
|
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
34
38
|
omitIds: allMeasuresIds
|
|
@@ -52,10 +56,10 @@ const pivotReshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
52
56
|
unfoldInfo: unfoldInfo
|
|
53
57
|
};
|
|
54
58
|
datasetReshapeInfo.push(reshapeInfo);
|
|
55
|
-
datasetList.push(datasets[0].
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
+
datasetList.push(datasets[0].flatMap((d)=>datasets[1].filter((yDatum)=>yDatum[ORIGINAL_DATA] === d[ORIGINAL_DATA]).map((yDatum)=>({
|
|
60
|
+
...d,
|
|
61
|
+
...yDatum
|
|
62
|
+
}))));
|
|
59
63
|
});
|
|
60
64
|
return {
|
|
61
65
|
...result,
|
package/dist/esm/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.ts"],"sourcesContent":["import { dataReshapeByEncoding
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/pivotReshapeWithScatterEncoding.ts"],"sourcesContent":["import { unique } from 'remeda'\nimport {\n dataReshapeByEncoding,\n FoldXMeasureId,\n FoldXMeasureValue,\n FoldYMeasureId,\n FoldYMeasureValue,\n ORIGINAL_DATA,\n} from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n DatasetReshapeInfo,\n Datum,\n Encoding,\n FoldInfo,\n Measure,\n UnfoldInfo,\n} from 'src/types'\n\nexport const pivotReshapeWithScatterEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding, chartType } = advancedVSeed\n const reshapeMeasures = advancedVSeed.reshapeMeasures ?? []\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n let allMeasuresIds = unique(reshapeMeasures.flatMap((measureGroup: Measure[]) => measureGroup.map((m) => m.id)))\n\n if (encoding?.size?.length) {\n allMeasuresIds = allMeasuresIds.filter((mId: string) => !encoding.size!.includes(mId))\n }\n\n const datasetList: Dataset[] = []\n const datasetReshapeInfo: DatasetReshapeInfo = []\n\n reshapeMeasures.forEach((measures: Measure[], index: number) => {\n const foldInfoList: FoldInfo[] = []\n const unfoldInfoList: UnfoldInfo[] = []\n\n const datasets: Dataset[] = []\n const xMeasures = measures.filter((m) => m.encoding === 'xAxis')\n const yMeasures = measures.filter((m) => m.encoding === 'yAxis')\n\n const xResult = dataReshapeByEncoding(dataset, dimensions, xMeasures, encoding as Encoding, {\n foldMeasureValue: `${FoldXMeasureValue}${index}`,\n foldMeasureId: FoldXMeasureId,\n colorItemAsId: true,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n })\n\n datasets.push(xResult.dataset)\n foldInfoList.push(xResult.foldInfo)\n unfoldInfoList.push(xResult.unfoldInfo)\n\n const yResult = dataReshapeByEncoding(dataset, dimensions, yMeasures, encoding as Encoding, {\n foldMeasureValue: `${FoldYMeasureValue}${index}`,\n foldMeasureId: FoldYMeasureId,\n colorItemAsId: true,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n })\n\n datasets.push(yResult.dataset)\n foldInfoList.push(yResult.foldInfo)\n unfoldInfoList.push(yResult.unfoldInfo)\n\n const unfoldInfo: UnfoldInfo = {\n ...unfoldInfoList[0],\n colorItems: unfoldInfoList.flatMap((d) => d.colorItems),\n colorIdMap: unfoldInfoList.reduce((prev, cur) => ({ ...prev, ...cur.colorIdMap }), {}),\n }\n\n const reshapeInfo = {\n id: `${chartType}-${index}`,\n index,\n foldInfo: foldInfoList[0],\n foldInfoList: foldInfoList,\n unfoldInfo: unfoldInfo,\n }\n\n datasetReshapeInfo.push(reshapeInfo)\n datasetList.push(\n datasets[0].flatMap((d: Datum) => {\n return datasets[1]\n .filter((yDatum: Datum) => {\n return yDatum[ORIGINAL_DATA] === d[ORIGINAL_DATA]\n })\n .map((yDatum: Datum) => {\n return {\n ...d,\n ...yDatum,\n }\n })\n }),\n )\n })\n\n return {\n ...result,\n dataset: datasetList,\n datasetReshapeInfo: datasetReshapeInfo,\n }\n}\n"],"names":["pivotReshapeWithScatterEncoding","advancedVSeed","context","result","vseed","dataset","encoding","chartType","reshapeMeasures","dimensions","allMeasuresIds","unique","measureGroup","m","mId","datasetList","datasetReshapeInfo","measures","index","foldInfoList","unfoldInfoList","datasets","xMeasures","yMeasures","xResult","dataReshapeByEncoding","FoldXMeasureValue","FoldXMeasureId","getColorMeasureId","yResult","FoldYMeasureValue","FoldYMeasureId","unfoldInfo","d","prev","cur","reshapeInfo","yDatum","ORIGINAL_DATA"],"mappings":";;;AAuBO,MAAMA,kCAAgD,CAACC,eAAeC;IAC3E,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAE,GAAGD;IACpB,MAAM,EAAEE,QAAQ,EAAEC,SAAS,EAAE,GAAGN;IAChC,MAAMO,kBAAkBP,cAAc,eAAe,IAAI,EAAE;IAC3D,MAAMQ,aAAaR,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IACpF,IAAIS,iBAAiBC,OAAOH,gBAAgB,OAAO,CAAC,CAACI,eAA4BA,aAAa,GAAG,CAAC,CAACC,IAAMA,EAAE,EAAE;IAE7G,IAAIP,UAAU,MAAM,QAClBI,iBAAiBA,eAAe,MAAM,CAAC,CAACI,MAAgB,CAACR,SAAS,IAAI,CAAE,QAAQ,CAACQ;IAGnF,MAAMC,cAAyB,EAAE;IACjC,MAAMC,qBAAyC,EAAE;IAEjDR,gBAAgB,OAAO,CAAC,CAACS,UAAqBC;QAC5C,MAAMC,eAA2B,EAAE;QACnC,MAAMC,iBAA+B,EAAE;QAEvC,MAAMC,WAAsB,EAAE;QAC9B,MAAMC,YAAYL,SAAS,MAAM,CAAC,CAACJ,IAAMA,AAAe,YAAfA,EAAE,QAAQ;QACnD,MAAMU,YAAYN,SAAS,MAAM,CAAC,CAACJ,IAAMA,AAAe,YAAfA,EAAE,QAAQ;QAEnD,MAAMW,UAAUC,sBAAsBpB,SAASI,YAAYa,WAAWhB,UAAsB;YAC1F,kBAAkB,GAAGoB,oBAAoBR,OAAO;YAChD,eAAeS;YACf,eAAe;YACf,gBAAgBC,kBAAkB3B,eAAgCG;YAClE,SAASM;QACX;QAEAW,SAAS,IAAI,CAACG,QAAQ,OAAO;QAC7BL,aAAa,IAAI,CAACK,QAAQ,QAAQ;QAClCJ,eAAe,IAAI,CAACI,QAAQ,UAAU;QAEtC,MAAMK,UAAUJ,sBAAsBpB,SAASI,YAAYc,WAAWjB,UAAsB;YAC1F,kBAAkB,GAAGwB,oBAAoBZ,OAAO;YAChD,eAAea;YACf,eAAe;YACf,gBAAgBH,kBAAkB3B,eAAgCG;YAClE,SAASM;QACX;QAEAW,SAAS,IAAI,CAACQ,QAAQ,OAAO;QAC7BV,aAAa,IAAI,CAACU,QAAQ,QAAQ;QAClCT,eAAe,IAAI,CAACS,QAAQ,UAAU;QAEtC,MAAMG,aAAyB;YAC7B,GAAGZ,cAAc,CAAC,EAAE;YACpB,YAAYA,eAAe,OAAO,CAAC,CAACa,IAAMA,EAAE,UAAU;YACtD,YAAYb,eAAe,MAAM,CAAC,CAACc,MAAMC,MAAS;oBAAE,GAAGD,IAAI;oBAAE,GAAGC,IAAI,UAAU;gBAAC,IAAI,CAAC;QACtF;QAEA,MAAMC,cAAc;YAClB,IAAI,GAAG7B,UAAU,CAAC,EAAEW,OAAO;YAC3BA;YACA,UAAUC,YAAY,CAAC,EAAE;YACzB,cAAcA;YACd,YAAYa;QACd;QAEAhB,mBAAmB,IAAI,CAACoB;QACxBrB,YAAY,IAAI,CACdM,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,CAACY,IACZZ,QAAQ,CAAC,EAAE,CACf,MAAM,CAAC,CAACgB,SACAA,MAAM,CAACC,cAAc,KAAKL,CAAC,CAACK,cAAc,EAElD,GAAG,CAAC,CAACD,SACG;oBACL,GAAGJ,CAAC;oBACJ,GAAGI,MAAM;gBACX;IAIV;IAEA,OAAO;QACL,GAAGlC,MAAM;QACT,SAASY;QACT,oBAAoBC;IACtB;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.ts"],"sourcesContent":["import {\n FoldMeasureId,\n FoldMeasureName,\n LowerWhisker,\n MedianMeasureId,\n OutliersMeasureId,\n Q1MeasureValue,\n Q3MeasureValue,\n Separator,\n unfoldDimensions,\n UpperWhisker,\n} from 'src/dataReshape'\nimport type { AdvancedPipe, ColumnParallel, Dataset, Dimension, Encoding } from 'src/types'\nimport { boxplot } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\n\nexport const reshapeWithBoxplotEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config, measures = [] } = advancedVSeed\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n\n const whiskers = config?.[chartType as 'boxPlot']?.whiskers\n\n let newDatasets: any[] = []\n let foldInfo: any = {}\n let unfoldInfo: any = {}\n\n if (encoding.value?.length) {\n const boxPlotDataList: Dataset = []\n encoding.value.forEach((f) => {\n const m = measures.find((m) => m.id === f)\n const boxPlotData = boxplot(dataset, {\n field: f,\n groupField: [...(encoding.x ?? []), ...(encoding.color ?? [])] as string[],\n whiskers,\n outputNames: {\n q1: Q1MeasureValue,\n q3: Q3MeasureValue,\n lowerWhisker: LowerWhisker,\n upperWhisker: UpperWhisker,\n median: MedianMeasureId,\n outliers: OutliersMeasureId,\n },\n }) as Dataset\n\n boxPlotData.forEach((datum) => {\n datum[FoldMeasureId] = f\n datum[FoldMeasureName] = m?.alias ?? f\n })\n boxPlotDataList.push(...boxPlotData)\n })\n const res = unfoldDimensions(boxPlotDataList, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (\n encoding.q1?.length &&\n encoding.q3?.length &&\n encoding.min?.length &&\n encoding.max?.length &&\n encoding.median?.length\n ) {\n const res = unfoldDimensions(dataset, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((datum) => {\n datum[UpperWhisker] = datum[encoding.max![0]]\n datum[LowerWhisker] = datum[encoding.min![0]]\n datum[Q1MeasureValue] = datum[encoding.q1![0]]\n datum[Q3MeasureValue] = datum[encoding.q3![0]]\n datum[MedianMeasureId] = datum[encoding.median![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = {}\n unfoldInfo = res.unfoldInfo\n }\n\n return {\n ...result,\n dataset: newDatasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo,\n unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithBoxplotEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","measures","dimensions","uniqDims","uniqueBy","item","whiskers","newDatasets","foldInfo","unfoldInfo","boxPlotDataList","f","m","boxPlotData","boxplot","Q1MeasureValue","Q3MeasureValue","LowerWhisker","UpperWhisker","MedianMeasureId","OutliersMeasureId","datum","FoldMeasureId","FoldMeasureName","res","unfoldDimensions","Separator","d","String"],"mappings":";;;AAgBO,MAAMA,6BAA2C,CAACC,eAAeC;IACtE,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAEC,SAAS,EAAE,GAAGF;IAC/B,MAAM,EAAEG,WAAW,CAAC,CAAC,EAAEC,MAAM,EAAEC,WAAW,EAAE,EAAE,GAAGR;IACjD,MAAMS,aAAaT,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IACpF,MAAMU,WAAWC,SAASF,YAAY,CAACG,OAAoBA,KAAK,EAAE;IAElE,MAAMC,WAAWN,QAAQ,CAACF,UAAuB,EAAE;IAEnD,IAAIS,cAAqB,EAAE;IAC3B,IAAIC,WAAgB,CAAC;IACrB,IAAIC,aAAkB,CAAC;IAEvB,IAAIV,SAAS,KAAK,EAAE,QAAQ;QAC1B,MAAMW,kBAA2B,EAAE;QACnCX,SAAS,KAAK,CAAC,OAAO,CAAC,CAACY;YACtB,MAAMC,IAAIX,SAAS,IAAI,CAAC,CAACW,IAAMA,EAAE,EAAE,KAAKD;YACxC,MAAME,cAAcC,QAAQjB,SAAS;gBACnC,OAAOc;gBACP,YAAY;uBAAKZ,SAAS,CAAC,IAAI,EAAE;uBAAOA,SAAS,KAAK,IAAI,EAAE;iBAAE;gBAC9DO;gBACA,aAAa;oBACX,IAAIS;oBACJ,IAAIC;oBACJ,cAAcC;oBACd,cAAcC;oBACd,QAAQC;oBACR,UAAUC;gBACZ;YACF;YAEAP,YAAY,OAAO,CAAC,CAACQ;gBACnBA,KAAK,CAACC,cAAc,GAAGX;gBACvBU,KAAK,CAACE,gBAAgB,GAAGX,GAAG,SAASD;YACvC;YACAD,gBAAgB,IAAI,IAAIG;QAC1B;QACA,MAAMW,MAAMC,iBAAiBf,iBAAiBP,UAAUJ,UAAsB;YAC5E,eAAeuB;YACf,WAAWI;YACX,eAAe;QACjB;QAEAF,IAAI,OAAO,CAAC,OAAO,CAAC,CAACG;YACnBpB,YAAY,IAAI,CAACoB;QACnB;QACAlB,aAAae,IAAI,UAAU;IAC7B,OAAO,IACLzB,SAAS,EAAE,EAAE,UACbA,SAAS,EAAE,EAAE,UACbA,SAAS,GAAG,EAAE,UACdA,SAAS,GAAG,EAAE,UACdA,SAAS,MAAM,EAAE,QACjB;QACA,MAAMyB,MAAMC,iBAAiB5B,SAASM,UAAUJ,UAAsB;YACpE,eAAeuB;YACf,WAAWI;YACX,eAAe;QACjB;QAEAF,IAAI,OAAO,CAAC,OAAO,CAAC,CAACH;YACnBA,KAAK,CAACH,aAAa,GAAGG,KAAK,CAACtB,SAAS,GAAI,CAAC,EAAE,CAAC;YAC7CsB,KAAK,CAACJ,aAAa,GAAGI,KAAK,CAACtB,SAAS,GAAI,CAAC,EAAE,CAAC;YAC7CsB,KAAK,CAACN,eAAe,GAAGM,KAAK,CAACtB,SAAS,EAAG,CAAC,EAAE,CAAC;YAC9CsB,KAAK,CAACL,eAAe,GAAGK,KAAK,CAACtB,SAAS,EAAG,CAAC,EAAE,CAAC;YAC9CsB,KAAK,CAACF,gBAAgB,GAAGE,KAAK,CAACtB,SAAS,MAAO,CAAC,EAAE,CAAC;QACrD;QAEAQ,cAAciB,IAAI,OAAO;QACzBhB,WAAW,CAAC;QACZC,aAAae,IAAI,UAAU;IAC7B;IAEA,OAAO;QACL,GAAG7B,MAAM;QACT,SAASY;QACT,oBAAoB;YAClB;gBACE,IAAIqB,OAAO9B;gBACX,OAAO;gBACPU;gBACAC;YACF;SACD;IACH;AACF"}
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithBoxplotEncoding.ts"],"sourcesContent":["import {\n FoldMeasureId,\n FoldMeasureName,\n LowerWhisker,\n MedianMeasureId,\n OutliersMeasureId,\n Q1MeasureValue,\n Q3MeasureValue,\n Separator,\n unfoldDimensions,\n UpperWhisker,\n} from 'src/dataReshape'\nimport type { AdvancedPipe, ColumnParallel, Dataset, Datum, Dimension, Encoding } from 'src/types'\nimport { boxplot } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\n\nexport const reshapeWithBoxplotEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config, measures = [] } = advancedVSeed\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n\n const whiskers = config?.[chartType as 'boxPlot']?.whiskers\n\n let newDatasets: any[] = []\n let foldInfo: any = {}\n let unfoldInfo: any = {}\n\n if (encoding.value?.length) {\n const boxPlotDataList: Dataset = []\n encoding.value.forEach((f) => {\n const m = measures.find((m) => m.id === f)\n const boxPlotData = boxplot(dataset, {\n field: f,\n groupField: [...(encoding.x ?? []), ...(encoding.color ?? [])] as string[],\n whiskers,\n outputNames: {\n q1: Q1MeasureValue,\n q3: Q3MeasureValue,\n lowerWhisker: LowerWhisker,\n upperWhisker: UpperWhisker,\n median: MedianMeasureId,\n outliers: OutliersMeasureId,\n },\n }) as Dataset\n\n boxPlotData.forEach((datum: Datum) => {\n datum[FoldMeasureId] = f\n datum[FoldMeasureName] = m?.alias ?? f\n })\n boxPlotDataList.push(...boxPlotData)\n })\n const res = unfoldDimensions(boxPlotDataList, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d: Datum) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (\n encoding.q1?.length &&\n encoding.q3?.length &&\n encoding.min?.length &&\n encoding.max?.length &&\n encoding.median?.length\n ) {\n const res = unfoldDimensions(dataset, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((datum: Datum) => {\n datum[UpperWhisker] = datum[encoding.max![0]]\n datum[LowerWhisker] = datum[encoding.min![0]]\n datum[Q1MeasureValue] = datum[encoding.q1![0]]\n datum[Q3MeasureValue] = datum[encoding.q3![0]]\n datum[MedianMeasureId] = datum[encoding.median![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = {}\n unfoldInfo = res.unfoldInfo\n }\n\n return {\n ...result,\n dataset: newDatasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo,\n unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithBoxplotEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","measures","dimensions","uniqDims","uniqueBy","item","whiskers","newDatasets","foldInfo","unfoldInfo","boxPlotDataList","f","m","boxPlotData","boxplot","Q1MeasureValue","Q3MeasureValue","LowerWhisker","UpperWhisker","MedianMeasureId","OutliersMeasureId","datum","FoldMeasureId","FoldMeasureName","res","unfoldDimensions","Separator","d","String"],"mappings":";;;AAgBO,MAAMA,6BAA2C,CAACC,eAAeC;IACtE,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAEC,SAAS,EAAE,GAAGF;IAC/B,MAAM,EAAEG,WAAW,CAAC,CAAC,EAAEC,MAAM,EAAEC,WAAW,EAAE,EAAE,GAAGR;IACjD,MAAMS,aAAaT,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IACpF,MAAMU,WAAWC,SAASF,YAAY,CAACG,OAAoBA,KAAK,EAAE;IAElE,MAAMC,WAAWN,QAAQ,CAACF,UAAuB,EAAE;IAEnD,IAAIS,cAAqB,EAAE;IAC3B,IAAIC,WAAgB,CAAC;IACrB,IAAIC,aAAkB,CAAC;IAEvB,IAAIV,SAAS,KAAK,EAAE,QAAQ;QAC1B,MAAMW,kBAA2B,EAAE;QACnCX,SAAS,KAAK,CAAC,OAAO,CAAC,CAACY;YACtB,MAAMC,IAAIX,SAAS,IAAI,CAAC,CAACW,IAAMA,EAAE,EAAE,KAAKD;YACxC,MAAME,cAAcC,QAAQjB,SAAS;gBACnC,OAAOc;gBACP,YAAY;uBAAKZ,SAAS,CAAC,IAAI,EAAE;uBAAOA,SAAS,KAAK,IAAI,EAAE;iBAAE;gBAC9DO;gBACA,aAAa;oBACX,IAAIS;oBACJ,IAAIC;oBACJ,cAAcC;oBACd,cAAcC;oBACd,QAAQC;oBACR,UAAUC;gBACZ;YACF;YAEAP,YAAY,OAAO,CAAC,CAACQ;gBACnBA,KAAK,CAACC,cAAc,GAAGX;gBACvBU,KAAK,CAACE,gBAAgB,GAAGX,GAAG,SAASD;YACvC;YACAD,gBAAgB,IAAI,IAAIG;QAC1B;QACA,MAAMW,MAAMC,iBAAiBf,iBAAiBP,UAAUJ,UAAsB;YAC5E,eAAeuB;YACf,WAAWI;YACX,eAAe;QACjB;QAEAF,IAAI,OAAO,CAAC,OAAO,CAAC,CAACG;YACnBpB,YAAY,IAAI,CAACoB;QACnB;QACAlB,aAAae,IAAI,UAAU;IAC7B,OAAO,IACLzB,SAAS,EAAE,EAAE,UACbA,SAAS,EAAE,EAAE,UACbA,SAAS,GAAG,EAAE,UACdA,SAAS,GAAG,EAAE,UACdA,SAAS,MAAM,EAAE,QACjB;QACA,MAAMyB,MAAMC,iBAAiB5B,SAASM,UAAUJ,UAAsB;YACpE,eAAeuB;YACf,WAAWI;YACX,eAAe;QACjB;QAEAF,IAAI,OAAO,CAAC,OAAO,CAAC,CAACH;YACnBA,KAAK,CAACH,aAAa,GAAGG,KAAK,CAACtB,SAAS,GAAI,CAAC,EAAE,CAAC;YAC7CsB,KAAK,CAACJ,aAAa,GAAGI,KAAK,CAACtB,SAAS,GAAI,CAAC,EAAE,CAAC;YAC7CsB,KAAK,CAACN,eAAe,GAAGM,KAAK,CAACtB,SAAS,EAAG,CAAC,EAAE,CAAC;YAC9CsB,KAAK,CAACL,eAAe,GAAGK,KAAK,CAACtB,SAAS,EAAG,CAAC,EAAE,CAAC;YAC9CsB,KAAK,CAACF,gBAAgB,GAAGE,KAAK,CAACtB,SAAS,MAAO,CAAC,EAAE,CAAC;QACrD;QAEAQ,cAAciB,IAAI,OAAO;QACzBhB,WAAW,CAAC;QACZC,aAAae,IAAI,UAAU;IAC7B;IAEA,OAAO;QACL,GAAG7B,MAAM;QACT,SAASY;QACT,oBAAoB;YAClB;gBACE,IAAIqB,OAAO9B;gBACX,OAAO;gBACPU;gBACAC;YACF;SACD;IACH;AACF"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { unique, uniqueBy } from "remeda";
|
|
2
|
-
import { FoldPrimaryMeasureValue, FoldSecondaryMeasureValue, dataReshapeByEncoding } from "../../../../../dataReshape/index.js";
|
|
2
|
+
import { DimAxisType, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue, dataReshapeByEncoding } from "../../../../../dataReshape/index.js";
|
|
3
3
|
import { getColorMeasureId } from "../../../../spec/chart/pipes/index.js";
|
|
4
4
|
import { DEFAULT_DUAL_CHART_TYPE } from "../../../../utils/chatType.js";
|
|
5
5
|
const reshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
@@ -11,6 +11,7 @@ const reshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
|
11
11
|
const { encoding, chartType } = advancedVSeed;
|
|
12
12
|
const measures = advancedVSeed.reshapeMeasures?.[0] ?? [];
|
|
13
13
|
const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? [];
|
|
14
|
+
const allMeasuresIds = measures.map((m)=>m.id);
|
|
14
15
|
const foldInfoList = [];
|
|
15
16
|
const unfoldInfoList = [];
|
|
16
17
|
const datasets = [];
|
|
@@ -24,7 +25,11 @@ const reshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
|
24
25
|
const primaryResult = dataReshapeByEncoding(dataset, uniqueBy(dimensions, (item)=>item.id), uniqueBy(primaryMeasures.filter((m)=>m.chartType === chartType), (item)=>item.id), encoding, {
|
|
25
26
|
colorItemAsId: false,
|
|
26
27
|
foldMeasureValue: FoldPrimaryMeasureValue,
|
|
27
|
-
colorMeasureId: getColorMeasureId(advancedVSeed, vseed)
|
|
28
|
+
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
29
|
+
omitIds: allMeasuresIds
|
|
30
|
+
});
|
|
31
|
+
primaryResult.dataset.forEach((row)=>{
|
|
32
|
+
row[DimAxisType] = 'primaryYAxis';
|
|
28
33
|
});
|
|
29
34
|
datasets.push(primaryResult.dataset);
|
|
30
35
|
foldInfoList.push(primaryResult.foldInfo);
|
|
@@ -34,7 +39,11 @@ const reshapeWithDualEncoding = (advancedVSeed, context)=>{
|
|
|
34
39
|
const secondaryResult = dataReshapeByEncoding(dataset, uniqueBy(dimensions, (item)=>item.id), uniqueBy(secondaryMeasures.filter((m)=>m.chartType === chartType), (item)=>item.id), encoding, {
|
|
35
40
|
colorItemAsId: false,
|
|
36
41
|
foldMeasureValue: FoldSecondaryMeasureValue,
|
|
37
|
-
colorMeasureId: getColorMeasureId(advancedVSeed, vseed)
|
|
42
|
+
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
43
|
+
omitIds: allMeasuresIds
|
|
44
|
+
});
|
|
45
|
+
secondaryResult.dataset.forEach((row)=>{
|
|
46
|
+
row[DimAxisType] = 'secondaryYAxis';
|
|
38
47
|
});
|
|
39
48
|
datasets.push(secondaryResult.dataset);
|
|
40
49
|
foldInfoList.push(secondaryResult.foldInfo);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.ts"],"sourcesContent":["import { uniqueBy, unique } from 'remeda'\nimport { dataReshapeByEncoding, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_DUAL_CHART_TYPE } from 'src/pipeline/utils/chatType'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n Dimension,\n DualAxisMeasure,\n Encoding,\n FoldInfo,\n Measure,\n UnfoldInfo,\n} from 'src/types'\n\nexport const reshapeWithDualEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding, chartType } = advancedVSeed\n const measures = (advancedVSeed.reshapeMeasures?.[0] ?? []) as Measure[]\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n\n const foldInfoList: FoldInfo[] = []\n const unfoldInfoList: UnfoldInfo[] = []\n\n const datasets: Dataset[] = []\n const primaryMeasures = measures.filter((m) => m.encoding === 'primaryYAxis')\n const secondaryMeasures = measures.filter((m) => m.encoding === 'secondaryYAxis')\n const primaryChartTypes: string[] = unique(primaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n const secondaryChartTypes: string[] = unique(secondaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n\n if (!primaryChartTypes.length) {\n primaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.primary)\n }\n\n if (!secondaryChartTypes.length) {\n secondaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.secondary)\n }\n\n primaryChartTypes.forEach((chartType) => {\n const primaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n primaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: FoldPrimaryMeasureValue,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n },\n )\n\n datasets.push(primaryResult.dataset)\n foldInfoList.push(primaryResult.foldInfo)\n unfoldInfoList.push(primaryResult.unfoldInfo)\n })\n\n secondaryChartTypes.forEach((chartType) => {\n const secondaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n secondaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: FoldSecondaryMeasureValue,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n },\n )\n\n datasets.push(secondaryResult.dataset)\n foldInfoList.push(secondaryResult.foldInfo)\n unfoldInfoList.push(secondaryResult.unfoldInfo)\n })\n\n const unfoldInfo: UnfoldInfo = {\n ...unfoldInfoList[0],\n colorItems: unfoldInfoList.flatMap((d) => d.colorItems),\n colorIdMap: unfoldInfoList.reduce((prev, cur) => ({ ...prev, ...cur.colorIdMap }), {}),\n }\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo: foldInfoList[0],\n foldInfoList: foldInfoList,\n unfoldInfo: unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithDualEncoding","advancedVSeed","context","result","vseed","dataset","encoding","chartType","measures","dimensions","foldInfoList","unfoldInfoList","datasets","primaryMeasures","
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithDualEncoding.ts"],"sourcesContent":["import { uniqueBy, unique } from 'remeda'\nimport { dataReshapeByEncoding, DimAxisType, FoldPrimaryMeasureValue, FoldSecondaryMeasureValue } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport { DEFAULT_DUAL_CHART_TYPE } from 'src/pipeline/utils/chatType'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n Datum,\n Dimension,\n DualAxisMeasure,\n Encoding,\n FoldInfo,\n Measure,\n UnfoldInfo,\n} from 'src/types'\n\nexport const reshapeWithDualEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset } = vseed as ColumnParallel\n const { encoding, chartType } = advancedVSeed\n const measures = (advancedVSeed.reshapeMeasures?.[0] ?? []) as Measure[]\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const allMeasuresIds = measures.map((m: Measure) => m.id)\n\n const foldInfoList: FoldInfo[] = []\n const unfoldInfoList: UnfoldInfo[] = []\n\n const datasets: Dataset[] = []\n const primaryMeasures = measures.filter((m) => m.encoding === 'primaryYAxis')\n const secondaryMeasures = measures.filter((m) => m.encoding === 'secondaryYAxis')\n const primaryChartTypes: string[] = unique(primaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n const secondaryChartTypes: string[] = unique(secondaryMeasures.map((m) => (m as DualAxisMeasure).chartType!))\n\n if (!primaryChartTypes.length) {\n primaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.primary)\n }\n\n if (!secondaryChartTypes.length) {\n secondaryChartTypes.push(DEFAULT_DUAL_CHART_TYPE.secondary)\n }\n\n primaryChartTypes.forEach((chartType) => {\n const primaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n primaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: FoldPrimaryMeasureValue,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n primaryResult.dataset.forEach((row: Datum) => {\n row[DimAxisType] = 'primaryYAxis'\n })\n\n datasets.push(primaryResult.dataset)\n foldInfoList.push(primaryResult.foldInfo)\n unfoldInfoList.push(primaryResult.unfoldInfo)\n })\n\n secondaryChartTypes.forEach((chartType) => {\n const secondaryResult = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n uniqueBy(\n secondaryMeasures.filter((m) => (m as DualAxisMeasure).chartType! === chartType),\n (item: Measure) => item.id,\n ),\n encoding as Encoding,\n {\n colorItemAsId: false,\n foldMeasureValue: FoldSecondaryMeasureValue,\n colorMeasureId: getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed),\n omitIds: allMeasuresIds,\n },\n )\n\n secondaryResult.dataset.forEach((row: Datum) => {\n row[DimAxisType] = 'secondaryYAxis'\n })\n\n datasets.push(secondaryResult.dataset)\n foldInfoList.push(secondaryResult.foldInfo)\n unfoldInfoList.push(secondaryResult.unfoldInfo)\n })\n\n const unfoldInfo: UnfoldInfo = {\n ...unfoldInfoList[0],\n colorItems: unfoldInfoList.flatMap((d) => d.colorItems),\n colorIdMap: unfoldInfoList.reduce((prev, cur) => ({ ...prev, ...cur.colorIdMap }), {}),\n }\n\n return {\n ...result,\n dataset: datasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo: foldInfoList[0],\n foldInfoList: foldInfoList,\n unfoldInfo: unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithDualEncoding","advancedVSeed","context","result","vseed","dataset","encoding","chartType","measures","dimensions","allMeasuresIds","m","foldInfoList","unfoldInfoList","datasets","primaryMeasures","secondaryMeasures","primaryChartTypes","unique","secondaryChartTypes","DEFAULT_DUAL_CHART_TYPE","primaryResult","dataReshapeByEncoding","uniqueBy","item","FoldPrimaryMeasureValue","getColorMeasureId","row","DimAxisType","secondaryResult","FoldSecondaryMeasureValue","unfoldInfo","d","prev","cur","String"],"mappings":"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"}
|
|
@@ -7,11 +7,13 @@ const reshapeWithEncoding = (advancedVSeed, context)=>{
|
|
|
7
7
|
};
|
|
8
8
|
const { vseed } = context;
|
|
9
9
|
const { dataset, chartType } = vseed;
|
|
10
|
-
const { encoding } = advancedVSeed;
|
|
10
|
+
const { encoding, reshapeMeasures = [] } = advancedVSeed;
|
|
11
|
+
const allMeasuresIds = (reshapeMeasures[0] ?? []).map((m)=>m.id);
|
|
11
12
|
const colorMeasureId = getColorMeasureId(advancedVSeed, vseed);
|
|
12
13
|
const { dataset: newDatasets, foldInfo, unfoldInfo } = dataReshapeByEncoding(dataset, uniqueBy(advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? [], (item)=>item.id), uniqueBy(advancedVSeed.reshapeMeasures?.[0] ?? [], (item)=>item.id), encoding, {
|
|
13
14
|
colorItemAsId: false,
|
|
14
|
-
colorMeasureId
|
|
15
|
+
colorMeasureId,
|
|
16
|
+
omitIds: allMeasuresIds
|
|
15
17
|
});
|
|
16
18
|
return {
|
|
17
19
|
...result,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.ts"],"sourcesContent":["import { uniqueBy } from 'remeda'\nimport { dataReshapeByEncoding } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport type { AdvancedPipe, AdvancedVSeed, ColumnParallel, Dimension, Encoding, Measure } from 'src/types'\n\nexport const reshapeWithEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding } = advancedVSeed\n\n const colorMeasureId = getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed)\n const {\n dataset: newDatasets,\n foldInfo,\n unfoldInfo,\n } = dataReshapeByEncoding(\n dataset,\n uniqueBy(advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? [], (item: Dimension) => item.id),\n uniqueBy(advancedVSeed.reshapeMeasures?.[0] ?? [], (item: Measure) => item.id),\n encoding as Encoding,\n {\n colorItemAsId: false,\n colorMeasureId,\n },\n )\n\n return {\n ...result,\n dataset: newDatasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo,\n unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","colorMeasureId","getColorMeasureId","newDatasets","foldInfo","unfoldInfo","dataReshapeByEncoding","uniqueBy","item","String"],"mappings":";;;AAKO,MAAMA,sBAAoC,CAACC,eAAeC;IAC/D,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAEC,SAAS,EAAE,GAAGF;IAC/B,MAAM,EAAEG,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithEncoding.ts"],"sourcesContent":["import { uniqueBy } from 'remeda'\nimport { dataReshapeByEncoding } from 'src/dataReshape'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes'\nimport type { AdvancedPipe, AdvancedVSeed, ColumnParallel, Dimension, Encoding, Measure } from 'src/types'\n\nexport const reshapeWithEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding, reshapeMeasures = [] } = advancedVSeed\n const allMeasuresIds = (reshapeMeasures[0] ?? []).map((m: Measure) => m.id)\n\n const colorMeasureId = getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed)\n const {\n dataset: newDatasets,\n foldInfo,\n unfoldInfo,\n } = dataReshapeByEncoding(\n dataset,\n uniqueBy(advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? [], (item: Dimension) => item.id),\n uniqueBy(advancedVSeed.reshapeMeasures?.[0] ?? [], (item: Measure) => item.id),\n encoding as Encoding,\n {\n colorItemAsId: false,\n colorMeasureId,\n omitIds: allMeasuresIds,\n },\n )\n\n return {\n ...result,\n dataset: newDatasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo,\n unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","reshapeMeasures","allMeasuresIds","m","colorMeasureId","getColorMeasureId","newDatasets","foldInfo","unfoldInfo","dataReshapeByEncoding","uniqueBy","item","String"],"mappings":";;;AAKO,MAAMA,sBAAoC,CAACC,eAAeC;IAC/D,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAEC,SAAS,EAAE,GAAGF;IAC/B,MAAM,EAAEG,QAAQ,EAAEC,kBAAkB,EAAE,EAAE,GAAGP;IAC3C,MAAMQ,iBAAkBD,AAAAA,CAAAA,eAAe,CAAC,EAAE,IAAI,EAAC,EAAG,GAAG,CAAC,CAACE,IAAeA,EAAE,EAAE;IAE1E,MAAMC,iBAAiBC,kBAAkBX,eAAgCG;IACzE,MAAM,EACJ,SAASS,WAAW,EACpBC,QAAQ,EACRC,UAAU,EACX,GAAGC,sBACFX,SACAY,SAAShB,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE,EAAE,CAACiB,OAAoBA,KAAK,EAAE,GACxGD,SAAShB,cAAc,eAAe,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,CAACiB,OAAkBA,KAAK,EAAE,GAC7EX,UACA;QACE,eAAe;QACfI;QACA,SAASF;IACX;IAGF,OAAO;QACL,GAAGN,MAAM;QACT,SAASU;QACT,oBAAoB;YAClB;gBACE,IAAIM,OAAOb;gBACX,OAAO;gBACPQ;gBACAC;YACF;SACD;IACH;AACF"}
|
|
@@ -74,7 +74,8 @@ const reshapeWithHistogramEncoding = (advancedVSeed, context)=>{
|
|
|
74
74
|
} else if (encoding.x0?.length && encoding.x1?.length && encoding.y?.length) {
|
|
75
75
|
const res = dataReshapeByEncoding(dataset, uniqueBy(dimensions, (item)=>item.id), measures.filter((item)=>encoding.y?.includes(item.id)).slice(0, 1), encoding, {
|
|
76
76
|
colorItemAsId: false,
|
|
77
|
-
colorMeasureId
|
|
77
|
+
colorMeasureId,
|
|
78
|
+
omitIds: []
|
|
78
79
|
});
|
|
79
80
|
res.dataset.forEach((datum)=>{
|
|
80
81
|
datum[BinStartMeasureId] = datum[encoding.x0[0]];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.ts"],"sourcesContent":["import {\n BinCountMeasureId,\n BinEndMeasureId,\n BinPercentageMeasureId,\n BinStartMeasureId,\n dataReshapeByEncoding,\n FoldMeasureId,\n FoldMeasureName,\n FoldMeasureValue,\n Separator,\n unfoldDimensions,\n} from 'src/dataReshape'\nimport type {
|
|
1
|
+
{"version":3,"file":"pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.js","sources":["webpack://@visactor/vseed/./src/pipeline/advanced/chart/pipes/reshape/reshapeWithHistogramEncoding.ts"],"sourcesContent":["import {\n BinCountMeasureId,\n BinEndMeasureId,\n BinPercentageMeasureId,\n BinStartMeasureId,\n dataReshapeByEncoding,\n FoldMeasureId,\n FoldMeasureName,\n FoldMeasureValue,\n Separator,\n unfoldDimensions,\n} from 'src/dataReshape'\nimport type {\n AdvancedPipe,\n AdvancedVSeed,\n ColumnParallel,\n Dataset,\n Datum,\n Dimension,\n Encoding,\n FoldInfo,\n Measure,\n} from 'src/types'\nimport { bin } from '@visactor/vdataset'\nimport { uniqueBy } from 'remeda'\nimport { getColorMeasureId } from 'src/pipeline/spec/chart/pipes/color/colorAdapter'\n\nexport const reshapeWithHistogramEncoding: AdvancedPipe = (advancedVSeed, context) => {\n const result = { ...advancedVSeed }\n const { vseed } = context\n const { dataset, chartType } = vseed as ColumnParallel\n const { encoding = {}, config, measures = [] } = advancedVSeed\n const dimensions = advancedVSeed.reshapeDimensions ?? advancedVSeed.dimensions ?? []\n const uniqDims = uniqueBy(dimensions, (item: Dimension) => item.id)\n const chartConfig = config?.[chartType as 'histogram']\n const binCount = chartConfig?.binCount\n const binStep = chartConfig?.binStep\n const binValueType = chartConfig?.binValueType\n\n let newDatasets: any[] = []\n let foldInfo: FoldInfo = {\n foldMap: {},\n measureId: FoldMeasureId,\n measureName: FoldMeasureName,\n measureValue: FoldMeasureValue,\n statistics: {\n max: -Infinity,\n min: Infinity,\n sum: 0,\n count: 0,\n colorMin: Infinity,\n colorMax: -Infinity,\n },\n }\n let unfoldInfo: any = {}\n\n const colorMeasureId = getColorMeasureId(advancedVSeed as AdvancedVSeed, vseed)\n\n if (encoding.value?.length) {\n const valueField = encoding.value[0]\n const m = measures.find((m: Measure) => m.id === valueField)\n const binData = bin(dataset, {\n field: valueField,\n groupField: [...(encoding.x ?? []), ...(encoding.color ?? [])] as string[],\n bins: binCount,\n step: binStep,\n outputNames: {\n x0: BinStartMeasureId,\n x1: BinEndMeasureId,\n count: BinCountMeasureId,\n percentage: BinPercentageMeasureId,\n },\n }) as Dataset\n\n binData.forEach((datum: Datum) => {\n datum[FoldMeasureId] = valueField\n datum[FoldMeasureName] = m?.alias ?? valueField\n const valueNumber = binValueType === 'percentage' ? +datum[BinPercentageMeasureId] : +datum[BinCountMeasureId]\n datum[FoldMeasureValue] = valueNumber\n datum[valueField] = valueNumber\n foldInfo.statistics.min = Math.min(foldInfo.statistics.min, valueNumber)\n foldInfo.statistics.max = Math.max(foldInfo.statistics.max, valueNumber)\n foldInfo.statistics.sum += valueNumber\n foldInfo.statistics.count++\n })\n if (m?.id) {\n foldInfo.foldMap[m?.id] = m?.alias\n }\n\n const res = unfoldDimensions(binData, uniqDims, encoding as Encoding, {\n foldMeasureId: FoldMeasureId,\n separator: Separator,\n colorItemAsId: false,\n })\n\n res.dataset.forEach((d: Datum) => {\n newDatasets.push(d)\n })\n unfoldInfo = res.unfoldInfo\n } else if (encoding.x0?.length && encoding.x1?.length && encoding.y?.length) {\n const res = dataReshapeByEncoding(\n dataset,\n uniqueBy(dimensions, (item: Dimension) => item.id),\n measures.filter((item: Measure) => encoding.y?.includes(item.id)).slice(0, 1),\n encoding as Encoding,\n {\n colorItemAsId: false,\n colorMeasureId,\n omitIds: [],\n },\n )\n\n res.dataset.forEach((datum: Datum) => {\n datum[BinStartMeasureId] = datum[encoding.x0![0]]\n datum[BinEndMeasureId] = datum[encoding.x1![0]]\n })\n\n newDatasets = res.dataset\n foldInfo = res.foldInfo\n unfoldInfo = res.unfoldInfo\n }\n\n return {\n ...result,\n dataset: newDatasets,\n datasetReshapeInfo: [\n {\n id: String(chartType),\n index: 0,\n foldInfo,\n unfoldInfo,\n },\n ],\n }\n}\n"],"names":["reshapeWithHistogramEncoding","advancedVSeed","context","result","vseed","dataset","chartType","encoding","config","measures","dimensions","uniqDims","uniqueBy","item","chartConfig","binCount","binStep","binValueType","newDatasets","foldInfo","FoldMeasureId","FoldMeasureName","FoldMeasureValue","Infinity","unfoldInfo","colorMeasureId","getColorMeasureId","valueField","m","binData","bin","BinStartMeasureId","BinEndMeasureId","BinCountMeasureId","BinPercentageMeasureId","datum","valueNumber","Math","res","unfoldDimensions","Separator","d","dataReshapeByEncoding","String"],"mappings":";;;;AA2BO,MAAMA,+BAA6C,CAACC,eAAeC;IACxE,MAAMC,SAAS;QAAE,GAAGF,aAAa;IAAC;IAClC,MAAM,EAAEG,KAAK,EAAE,GAAGF;IAClB,MAAM,EAAEG,OAAO,EAAEC,SAAS,EAAE,GAAGF;IAC/B,MAAM,EAAEG,WAAW,CAAC,CAAC,EAAEC,MAAM,EAAEC,WAAW,EAAE,EAAE,GAAGR;IACjD,MAAMS,aAAaT,cAAc,iBAAiB,IAAIA,cAAc,UAAU,IAAI,EAAE;IACpF,MAAMU,WAAWC,SAASF,YAAY,CAACG,OAAoBA,KAAK,EAAE;IAClE,MAAMC,cAAcN,QAAQ,CAACF,UAAyB;IACtD,MAAMS,WAAWD,aAAa;IAC9B,MAAME,UAAUF,aAAa;IAC7B,MAAMG,eAAeH,aAAa;IAElC,IAAII,cAAqB,EAAE;IAC3B,IAAIC,WAAqB;QACvB,SAAS,CAAC;QACV,WAAWC;QACX,aAAaC;QACb,cAAcC;QACd,YAAY;YACV,KAAK,CAACC;YACN,KAAKA;YACL,KAAK;YACL,OAAO;YACP,UAAUA;YACV,UAAU,CAACA;QACb;IACF;IACA,IAAIC,aAAkB,CAAC;IAEvB,MAAMC,iBAAiBC,kBAAkBzB,eAAgCG;IAEzE,IAAIG,SAAS,KAAK,EAAE,QAAQ;QAC1B,MAAMoB,aAAapB,SAAS,KAAK,CAAC,EAAE;QACpC,MAAMqB,IAAInB,SAAS,IAAI,CAAC,CAACmB,IAAeA,EAAE,EAAE,KAAKD;QACjD,MAAME,UAAUC,IAAIzB,SAAS;YAC3B,OAAOsB;YACP,YAAY;mBAAKpB,SAAS,CAAC,IAAI,EAAE;mBAAOA,SAAS,KAAK,IAAI,EAAE;aAAE;YAC9D,MAAMQ;YACN,MAAMC;YACN,aAAa;gBACX,IAAIe;gBACJ,IAAIC;gBACJ,OAAOC;gBACP,YAAYC;YACd;QACF;QAEAL,QAAQ,OAAO,CAAC,CAACM;YACfA,KAAK,CAACf,cAAc,GAAGO;YACvBQ,KAAK,CAACd,gBAAgB,GAAGO,GAAG,SAASD;YACrC,MAAMS,cAAcnB,AAAiB,iBAAjBA,eAAgC,CAACkB,KAAK,CAACD,uBAAuB,GAAG,CAACC,KAAK,CAACF,kBAAkB;YAC9GE,KAAK,CAACb,iBAAiB,GAAGc;YAC1BD,KAAK,CAACR,WAAW,GAAGS;YACpBjB,SAAS,UAAU,CAAC,GAAG,GAAGkB,KAAK,GAAG,CAAClB,SAAS,UAAU,CAAC,GAAG,EAAEiB;YAC5DjB,SAAS,UAAU,CAAC,GAAG,GAAGkB,KAAK,GAAG,CAAClB,SAAS,UAAU,CAAC,GAAG,EAAEiB;YAC5DjB,SAAS,UAAU,CAAC,GAAG,IAAIiB;YAC3BjB,SAAS,UAAU,CAAC,KAAK;QAC3B;QACA,IAAIS,GAAG,IACLT,SAAS,OAAO,CAACS,GAAG,GAAG,GAAGA,GAAG;QAG/B,MAAMU,MAAMC,iBAAiBV,SAASlB,UAAUJ,UAAsB;YACpE,eAAea;YACf,WAAWoB;YACX,eAAe;QACjB;QAEAF,IAAI,OAAO,CAAC,OAAO,CAAC,CAACG;YACnBvB,YAAY,IAAI,CAACuB;QACnB;QACAjB,aAAac,IAAI,UAAU;IAC7B,OAAO,IAAI/B,SAAS,EAAE,EAAE,UAAUA,SAAS,EAAE,EAAE,UAAUA,SAAS,CAAC,EAAE,QAAQ;QAC3E,MAAM+B,MAAMI,sBACVrC,SACAO,SAASF,YAAY,CAACG,OAAoBA,KAAK,EAAE,GACjDJ,SAAS,MAAM,CAAC,CAACI,OAAkBN,SAAS,CAAC,EAAE,SAASM,KAAK,EAAE,GAAG,KAAK,CAAC,GAAG,IAC3EN,UACA;YACE,eAAe;YACfkB;YACA,SAAS,EAAE;QACb;QAGFa,IAAI,OAAO,CAAC,OAAO,CAAC,CAACH;YACnBA,KAAK,CAACJ,kBAAkB,GAAGI,KAAK,CAAC5B,SAAS,EAAG,CAAC,EAAE,CAAC;YACjD4B,KAAK,CAACH,gBAAgB,GAAGG,KAAK,CAAC5B,SAAS,EAAG,CAAC,EAAE,CAAC;QACjD;QAEAW,cAAcoB,IAAI,OAAO;QACzBnB,WAAWmB,IAAI,QAAQ;QACvBd,aAAac,IAAI,UAAU;IAC7B;IAEA,OAAO;QACL,GAAGnC,MAAM;QACT,SAASe;QACT,oBAAoB;YAClB;gBACE,IAAIyB,OAAOrC;gBACX,OAAO;gBACPa;gBACAK;YACF;SACD;IACH;AACF"}
|
|
@@ -12,6 +12,7 @@ const reshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
12
12
|
const measures = reshapeMeasures?.[0] ?? [];
|
|
13
13
|
const foldInfoList = [];
|
|
14
14
|
const unfoldInfoList = [];
|
|
15
|
+
const sizeEncodingIds = encoding?.size ?? [];
|
|
15
16
|
const datasets = [];
|
|
16
17
|
const xMeasures = measures.filter((m)=>'xAxis' === m.encoding);
|
|
17
18
|
const yMeasures = measures.filter((m)=>'yAxis' === m.encoding);
|
|
@@ -19,7 +20,8 @@ const reshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
19
20
|
foldMeasureValue: FoldXMeasureValue,
|
|
20
21
|
foldMeasureId: FoldXMeasureId,
|
|
21
22
|
colorItemAsId: true,
|
|
22
|
-
colorMeasureId: getColorMeasureId(advancedVSeed, vseed)
|
|
23
|
+
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
24
|
+
omitIds: xMeasures.map((m)=>m.id).filter((id)=>!sizeEncodingIds.includes(id))
|
|
23
25
|
});
|
|
24
26
|
datasets.push(xResult.dataset);
|
|
25
27
|
foldInfoList.push(xResult.foldInfo);
|
|
@@ -28,7 +30,8 @@ const reshapeWithScatterEncoding = (advancedVSeed, context)=>{
|
|
|
28
30
|
foldMeasureValue: FoldYMeasureValue,
|
|
29
31
|
foldMeasureId: FoldYMeasureId,
|
|
30
32
|
colorItemAsId: true,
|
|
31
|
-
colorMeasureId: getColorMeasureId(advancedVSeed, vseed)
|
|
33
|
+
colorMeasureId: getColorMeasureId(advancedVSeed, vseed),
|
|
34
|
+
omitIds: yMeasures.map((m)=>m.id).filter((id)=>!sizeEncodingIds.includes(id))
|
|
32
35
|
});
|
|
33
36
|
datasets[0] = yResult.dataset;
|
|
34
37
|
foldInfoList.push(yResult.foldInfo);
|