Skip to content

Commit

Permalink
fix: remove flicker in AccordionItem (carbon-design-system#9818)
Browse files Browse the repository at this point in the history
Removes the flickering effect when using AccordionItem as a controlled
component

Closes carbon-design-system#9818
  • Loading branch information
cesardlinx committed Oct 4, 2023
1 parent bb67d1c commit 4c6065f
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 8 deletions.
45 changes: 44 additions & 1 deletion packages/react/src/components/Accordion/Accordion.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

/* eslint-disable no-console */

import React from 'react';
import React, { useState } from 'react';
import {
default as Accordion,
AccordionItem,
Expand Down Expand Up @@ -108,6 +108,49 @@ export const _WithLayer = () => (
</WithLayer>
);

export const Controlled = () => {
const [open, setOpen] = useState(false);
return (
<Accordion>
<AccordionItem
title="Section 1 title"
open={open}
onHeadingClick={({ isOpen }) => setOpen(isOpen)}>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.
</p>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat.
</p>
</AccordionItem>
</Accordion>
);
};

export const Skeleton = (args) => (
<AccordionSkeleton open count={4} {...args} />
);
Expand Down
7 changes: 0 additions & 7 deletions packages/react/src/components/Accordion/AccordionItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,6 @@ function AccordionItem({
...rest
}: PropsWithChildren<AccordionItemProps>) {
const [isOpen, setIsOpen] = useState(open);
const [prevIsOpen, setPrevIsOpen] = useState(open);
const [animation, setAnimation] = useState('');
const accordionState = useContext(AccordionContext);

Expand All @@ -138,12 +137,6 @@ function AccordionItem({

const Toggle = renderToggle || renderExpando; // remove renderExpando in next major release

if (open !== prevIsOpen) {
setAnimation(isOpen ? 'collapsing' : 'expanding');
setIsOpen(open);
setPrevIsOpen(open);
}

// When the AccordionItem heading is clicked, toggle the open state of the
// panel
function onClick(event) {
Expand Down

0 comments on commit 4c6065f

Please sign in to comment.