Skip to content

Commit

Permalink
Fix bar chart animation when sign changes
Browse files Browse the repository at this point in the history
  • Loading branch information
carysmills committed Dec 13, 2024
1 parent 5c8bc0f commit a875d17
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 5 deletions.
24 changes: 23 additions & 1 deletion packages/polaris-viz/src/components/BarChart/stories/data.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,33 @@
import React, {useState} from 'react';
import type {DataSeries} from '@shopify/polaris-viz-core';
import type {Story} from '@storybook/react';

import type {BarChartProps} from '../BarChart';
import {BarChart} from '../BarChart';

export const Template: Story<BarChartProps> = (args: BarChartProps) => {
return <BarChart {...args} />;
const [firstValNegative, setFirstValNegative] = useState(false);
const data = [
{
name: 'Breakfast',
data: [
{key: 'Monday', value: firstValNegative ? -20 : 3},
{key: 'Tuesday', value: firstValNegative ? -100 : 50},
{key: 'Wednesday', value: firstValNegative ? 100 : 3},
{key: 'Thursday', value: 8},
{key: 'Friday', value: 50},
{key: 'Saturday', value: 0},
{key: 'Sunday', value: 0.1},
],
},
];

return (
<React.Fragment>
<button onClick={() => setFirstValNegative(!firstValNegative)}>change data</button>
<BarChart {...args} data={data} />
</React.Fragment>
);
};

export const DEFAULT_DATA: DataSeries[] = [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import {
DataType,
getRoundedRectPath,
useTheme,
usePrevious,
} from '@shopify/polaris-viz-core';

import {useBarSpringConfig} from '../../../../hooks/useBarSpringConfig';
Expand Down Expand Up @@ -69,15 +70,31 @@ export const VerticalBar = memo(function Bar({
const springConfig = useBarSpringConfig({animationDelay});
const rotate = `${treatAsNegative ? 'rotate(180)' : 'rotate(0)'}`;

const prevValue = usePrevious(rawValue);
const signIsChanging =
prevValue == null ? false : Math.sign(prevValue) !== Math.sign(rawValue);

const {pathD, transform} = useSpring({
from: {
pathD: getPath(1, width),
transform: `translate(0 ${zeroPosition}) ${rotate}`,
},
to: {
pathD: getPath(height, width),
transform: `translate(0 ${yPosition}) ${rotate}`,
},
to: signIsChanging
? [
{
pathD: getPath(0, width),
transform: `translate(0 ${zeroPosition}) ${rotate}`,
immediate: true,
},
{
pathD: getPath(height, width),
transform: `translate(0 ${yPosition}) ${rotate}`,
},
]
: {
pathD: getPath(height, width),
transform: `translate(0 ${yPosition}) ${rotate}`,
},
...springConfig,
});

Expand Down

0 comments on commit a875d17

Please sign in to comment.