Skip to content

Commit

Permalink
Introduce optional fillValue property on DataSeries
Browse files Browse the repository at this point in the history
  • Loading branch information
philschoefer committed Nov 30, 2023
1 parent 55a5127 commit 97fbd72
Show file tree
Hide file tree
Showing 3 changed files with 126 additions and 4 deletions.
1 change: 1 addition & 0 deletions packages/polaris-viz-core/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ export interface DataSeries {
name?: string;
metadata?: {[key: string]: any};
styleOverride?: StyleOverride;
fillValue?: number | null;
}

interface StyleOverride {
Expand Down
9 changes: 5 additions & 4 deletions packages/polaris-viz/src/utilities/fillMissingDataPoints.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import type {DataSeries} from '@shopify/polaris-viz-core';

export function fillMissingDataPoints(dataSeries: DataSeries[]) {
const areAnyComparrison = dataSeries.some(
const areAnyComparison = dataSeries.some(
({isComparison}) => isComparison === true,
);

if (areAnyComparrison) {
if (areAnyComparison) {
return dataSeries;
}

Expand All @@ -27,10 +27,11 @@ export function fillMissingDataPoints(dataSeries: DataSeries[]) {
return dataSeries.map((series, index) => {
const newData = [...allKeys].map((key) => {
const dataValue = dataValueMap[index];

const fillValue =
series.fillValue !== undefined ? series.fillValue : null;
return {
key,
value: dataValue == null ? null : dataValue[key] ?? null,
value: dataValue == null ? null : dataValue[key] ?? fillValue,
};
});
return {...series, data: newData};
Expand Down
120 changes: 120 additions & 0 deletions packages/polaris-viz/src/utilities/tests/fillMissingDataPoints.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,126 @@ describe('fillMissingDataPoints', () => {
]);
});

it('fills data with null by default', () => {
const mockData = [
{
name: 'Canada',
data: [
{key: 'Mice', value: 13.28},
{key: 'Dogs', value: 23.43},
{key: 'Cats', value: 6.64},
{key: 'Birds', value: 54.47},
],
},
{
name: 'China',
data: [
{key: 'Snakes', value: 0},
{key: 'Dogs', value: 0},
],
},
];

const result = fillMissingDataPoints(mockData);

expect(result).toMatchObject(
expect.arrayContaining([
expect.objectContaining({
data: expect.arrayContaining([
expect.objectContaining({
value: null,
}),
]),
}),
]),
);
});

it('fills data with provided fill value when defined on series', () => {
const mockData = [
{
name: 'Canada',
data: [
{key: 'Mice', value: 13.28},
{key: 'Dogs', value: 23.43},
{key: 'Cats', value: 6.64},
{key: 'Birds', value: 54.47},
],
},
{
name: 'China',
data: [
{key: 'Snakes', value: 10},
{key: 'Dogs', value: 10},
],
fillValue: 0,
},
];

const result = fillMissingDataPoints(mockData);

expect(result).toMatchObject(
expect.arrayContaining([
expect.objectContaining({
data: expect.arrayContaining([
expect.objectContaining({
value: 0,
}),
]),
}),
]),
);
});

it('fills data with fill value for provided series only', () => {
const mockData = [
{
name: 'Canada',
data: [
{key: 'Mice', value: 13.28},
{key: 'Dogs', value: 23.43},
{key: 'Cats', value: 6.64},
{key: 'Birds', value: 54.47},
],
fillValue: null,
},
{
name: 'China',
data: [
{key: 'Snakes', value: 10},
{key: 'Dogs', value: 10},
],
fillValue: 0,
},
];

const result = fillMissingDataPoints(mockData);

expect(result).toMatchObject(
expect.arrayContaining([
expect.objectContaining({
data: expect.arrayContaining([
expect.objectContaining({
value: 0,
}),
]),
}),
]),
);

expect(result).toMatchObject(
expect.arrayContaining([
expect.objectContaining({
data: expect.arrayContaining([
expect.objectContaining({
value: null,
}),
]),
}),
]),
);
});

it('returns the original data series if any are comparison', () => {
const mockData = [
{
Expand Down

0 comments on commit 97fbd72

Please sign in to comment.