From 338e9b412ecc68e3a1d841c809262dc06b153c17 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 16:39:48 +0100 Subject: [PATCH 1/7] fix(pie-doughnut-chart): have one source of datasourceItems on code --- .../pie-doughnut-chart-web/src/hooks/data.ts | 36 +++++++++++++++++-- 1 file changed, 33 insertions(+), 3 deletions(-) diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts index bea9f03cfe..18b56b3e2f 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts @@ -1,4 +1,4 @@ -import { ValueStatus } from "mendix"; +import { ObjectItem, ValueStatus } from "mendix"; import { useEffect, useMemo, useState } from "react"; import { ensure } from "@mendix/pluggable-widgets-tools"; import Big from "big.js"; @@ -87,10 +87,40 @@ export const usePieChartDataSeries = ({ hoverinfo: pieChartData.some(({ itemHoverText }) => itemHoverText !== undefined && itemHoverText !== "") ? "text" : "none", - dataSourceItems: seriesDataSource.items ?? [], + dataSourceItems: sortDatasourceItems( + seriesDataSource.items ?? [], + seriesSortOrder, + seriesSortAttribute + ), onClick } ], - [customSeriesOptions, holeRadius, pieChartData, onClick, seriesDataSource.items] + [ + customSeriesOptions, + holeRadius, + pieChartData, + onClick, + seriesDataSource.items, + seriesSortAttribute, + seriesSortOrder + ] ); }; + +function sortDatasourceItems( + items: ObjectItem[], + seriesSortOrder: "asc" | "desc", + seriesSortAttribute: PieChartContainerProps["seriesSortAttribute"] +) { + const sortedItems = [...items].sort((firstItem, secondItem) => { + const first = seriesSortAttribute?.get(firstItem).value; + const second = seriesSortAttribute?.get(secondItem).value; + return compareAttrValuesAsc(first, second); + }); + + if (seriesSortOrder === "desc") { + sortedItems.reverse(); + } + + return sortedItems; +} From 0d128cfb27e25513ae116b477db0db47689cef84 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 16:40:44 +0100 Subject: [PATCH 2/7] fix(charts): add pointNumbers as indices to fix issue with multiple indices at one pie chart item --- packages/shared/charts/src/components/ChartView.tsx | 5 +++-- packages/shared/charts/src/components/types.ts | 1 + 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/packages/shared/charts/src/components/ChartView.tsx b/packages/shared/charts/src/components/ChartView.tsx index 1c9197a5cb..5958391e3a 100644 --- a/packages/shared/charts/src/components/ChartView.tsx +++ b/packages/shared/charts/src/components/ChartView.tsx @@ -29,10 +29,11 @@ export const ChartView = ({ const handleChartClick = useCallback>( event => { // As this is click handler, this event has single, "clicked" point, so we can destruct. - const [{ curveNumber, pointIndex, pointIndices, pointNumber }] = event.points; + const [{ curveNumber, pointIndex, pointIndices, pointNumber, pointNumbers }] = event.points; const index = pointIndex ?? pointNumber; + const indices = pointIndices ?? pointNumbers; + const itemIndex = getItemIndex(index, indices); const { dataSourceItems, onClick } = data[curveNumber]; - const itemIndex = getItemIndex(index, pointIndices); const item = dataSourceItems[itemIndex]; onClick?.(item); }, diff --git a/packages/shared/charts/src/components/types.ts b/packages/shared/charts/src/components/types.ts index ef5c2fcaaf..273e120ce9 100644 --- a/packages/shared/charts/src/components/types.ts +++ b/packages/shared/charts/src/components/types.ts @@ -5,6 +5,7 @@ declare module "plotly.js" { interface PlotDatum { /** This array appears on only when aggregation is used */ pointIndices?: number[]; + pointNumbers?: number[]; } } export type ExtraTraceProps = { From 4a21ee5231513b9370170e3282314d93ecd69cb9 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 16:41:20 +0100 Subject: [PATCH 3/7] chore(pie-doughnut-chart): update changelog --- packages/pluggableWidgets/pie-doughnut-chart-web/CHANGELOG.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/CHANGELOG.md b/packages/pluggableWidgets/pie-doughnut-chart-web/CHANGELOG.md index 7100231074..3d47b50d9d 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/CHANGELOG.md +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/CHANGELOG.md @@ -6,6 +6,10 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), ## [Unreleased] +### Fixed + +- We fixed an issue on pie chart onClick when multiple points are added to the same item. + ## [5.1.0] - 2024-10-28 ### Changed From 609f0a429185ea796e2ec74e38114c47075ddeaa Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 16:42:34 +0100 Subject: [PATCH 4/7] fix(pie-doughnut-chart): fix onCLick with microflow issue without datasource context --- .../pluggableWidgets/pie-doughnut-chart-web/src/PieChart.xml | 2 +- .../pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts | 2 +- .../pie-doughnut-chart-web/typings/PieChartProps.d.ts | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/PieChart.xml b/packages/pluggableWidgets/pie-doughnut-chart-web/src/PieChart.xml index 292392e558..1cd92d2f82 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/PieChart.xml +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/PieChart.xml @@ -117,7 +117,7 @@ - + On click action diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts index 18b56b3e2f..b2e9dcb857 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts @@ -71,7 +71,7 @@ export const usePieChartDataSeries = ({ tooltipHoverText ]); - const onClick = useMemo(() => (onClickAction ? () => executeAction(onClickAction) : undefined), [onClickAction]); + const onClick = onClickAction ? (item: ObjectItem) => executeAction(onClickAction?.get(item)) : undefined; return useMemo( () => [ diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/typings/PieChartProps.d.ts b/packages/pluggableWidgets/pie-doughnut-chart-web/typings/PieChartProps.d.ts index 6122ca08b7..bd451b2979 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/typings/PieChartProps.d.ts +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/typings/PieChartProps.d.ts @@ -4,7 +4,7 @@ * @author Mendix Widgets Framework Team */ import { ComponentType, CSSProperties, ReactNode } from "react"; -import { ActionValue, ListValue, ListAttributeValue, ListExpressionValue } from "mendix"; +import { ListValue, ListActionValue, ListAttributeValue, ListExpressionValue } from "mendix"; import { Big } from "big.js"; export type SeriesSortOrderEnum = "asc" | "desc"; @@ -34,7 +34,7 @@ export interface PieChartContainerProps { width: number; heightUnit: HeightUnitEnum; height: number; - onClickAction?: ActionValue; + onClickAction?: ListActionValue; enableThemeConfig: boolean; customLayout: string; customConfigurations: string; From bce1b1eba0baaf16a3eb290296f4a495c15484e5 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 17:06:25 +0100 Subject: [PATCH 5/7] test(pie-doughnut-chart): update unit tests --- .../src/__tests__/PieChart.spec.tsx | 21 ++++++++++++++++++- .../pie-doughnut-chart-web/src/hooks/data.ts | 2 +- 2 files changed, 21 insertions(+), 2 deletions(-) diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/__tests__/PieChart.spec.tsx b/packages/pluggableWidgets/pie-doughnut-chart-web/src/__tests__/PieChart.spec.tsx index 73c75b0464..345e681fa8 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/__tests__/PieChart.spec.tsx +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/__tests__/PieChart.spec.tsx @@ -82,6 +82,10 @@ describe("The PieChart widget", () => { seriesSortAttribute.get = jest .fn() .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()); const pieChart = renderPieChart({ seriesSortAttribute }); @@ -97,6 +101,10 @@ describe("The PieChart widget", () => { seriesSortAttribute.get = jest .fn() .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()); const pieChart = renderPieChart({ seriesSortAttribute, seriesSortOrder: "desc" }); @@ -127,10 +135,21 @@ function setupBasicAttributes(): Partial { const seriesColorAttribute = listExp(() => "name"); seriesColorAttribute.get = jest.fn().mockReturnValueOnce(dynamic("red")).mockReturnValueOnce(dynamic("blue")); + const seriesSortAttribute = new ListAttributeValueBuilder().build(); + seriesSortAttribute.get = jest + .fn() + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(15)).build()) + .mockReturnValueOnce(new EditableValueBuilder().withValue(new Big(20)).build()); + return { seriesColorAttribute, seriesDataSource, seriesName, - seriesValueAttribute + seriesValueAttribute, + seriesSortAttribute }; } diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts index b2e9dcb857..5ef7320cde 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/hooks/data.ts @@ -111,7 +111,7 @@ function sortDatasourceItems( items: ObjectItem[], seriesSortOrder: "asc" | "desc", seriesSortAttribute: PieChartContainerProps["seriesSortAttribute"] -) { +): ObjectItem[] { const sortedItems = [...items].sort((firstItem, secondItem) => { const first = seriesSortAttribute?.get(firstItem).value; const second = seriesSortAttribute?.get(secondItem).value; From a7f0cc28aadd8f365a92efb60a6799dc30b31535 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Thu, 5 Dec 2024 17:07:17 +0100 Subject: [PATCH 6/7] chore(pie-doughnut-chart): bump patch version --- packages/pluggableWidgets/pie-doughnut-chart-web/package.json | 2 +- .../pluggableWidgets/pie-doughnut-chart-web/src/package.xml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/package.json b/packages/pluggableWidgets/pie-doughnut-chart-web/package.json index abbff87942..2fb7a059b1 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/package.json +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/package.json @@ -1,7 +1,7 @@ { "name": "@mendix/pie-doughnut-chart-web", "widgetName": "PieChart", - "version": "5.1.0", + "version": "5.1.1", "description": "Shows data in a pie format graph.", "copyright": "© Mendix Technology BV 2023. All rights reserved.", "license": "Apache-2.0", diff --git a/packages/pluggableWidgets/pie-doughnut-chart-web/src/package.xml b/packages/pluggableWidgets/pie-doughnut-chart-web/src/package.xml index dba0da8683..1756a0eba9 100644 --- a/packages/pluggableWidgets/pie-doughnut-chart-web/src/package.xml +++ b/packages/pluggableWidgets/pie-doughnut-chart-web/src/package.xml @@ -1,6 +1,6 @@ - + From 26669efcf7d7062f419391d2a4d3ded8aa4408d8 Mon Sep 17 00:00:00 2001 From: Samuel Reichert Date: Wed, 11 Dec 2024 15:18:54 +0100 Subject: [PATCH 7/7] chore(charts-web): bump patch version --- packages/pluggableWidgets/charts-web/package.json | 2 +- packages/pluggableWidgets/charts-web/src/package.xml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/pluggableWidgets/charts-web/package.json b/packages/pluggableWidgets/charts-web/package.json index e4ab4c329f..463c256e09 100644 --- a/packages/pluggableWidgets/charts-web/package.json +++ b/packages/pluggableWidgets/charts-web/package.json @@ -1,6 +1,6 @@ { "name": "@mendix/charts-web", - "version": "5.1.0", + "version": "5.1.1", "description": "Chart widgets collection for data visualization", "license": "Apache-2.0", "private": false, diff --git a/packages/pluggableWidgets/charts-web/src/package.xml b/packages/pluggableWidgets/charts-web/src/package.xml index 46fb92e8e6..53f8598821 100644 --- a/packages/pluggableWidgets/charts-web/src/package.xml +++ b/packages/pluggableWidgets/charts-web/src/package.xml @@ -1,6 +1,6 @@ - +