Issue
I have a list of items and each item of the list have a button that opens a modal.
My problem is that I think I've done something wrong because when I click to "open a modal" it do not work. I've made it work but it was opening all modals at the same time and I could not find out how to fix it.
Here my sandbox with all code: https://codesandbox.io/s/modal-on-list-sjw7u?file=/src/components/TopBar.tsx
My list of items is at the class MetricsDetailsPage
on the sandbox and the part that I call the modal on this class is done like this:
<FiltersAddition
dimension={dimension}
isModalOpen={isShowing}
toggle={toggle}
/>
<Button onClick={toggle}> Instantiate </Button>
My issue is that if you open the "https://sjw7u.csb.app/metric/test" on my code sandbox and click on "Instantiate" button you will see the modals are being duplicated for each item on the list, and I want to show just the modal of the clicked item (so one at the time).
Solution
In the future, rather include the relevant, problematic code in the question.
The issue is that you are including the modal in each iteration and there is no parent state to control which modal is being displayed at a time.
I suggest you modify the hook and use it from a shared parent state:
import { useState } from 'react';
import { IDimension } from '../model/metric';
const useModal = () => {
// store which has been selected
const [selected, setSelected] = useState<IDimension>();
const [isShowing, setIsShowing] = useState<boolean>(false);
const open = (dimension: IDimension) => {
setSelected(dimension);
setIsShowing(true);
};
const close = () => {
setSelected(null);
setIsShowing(false);
};
return {
isShowing,
open,
close,
selected
};
};
export default useModal;
Then move your modal outside the loop:
<TableBody>
{metric?.dimensions.map((dimension) => (
<TableRow key={dimension.name}>
<TableCell>{dimension.name}</TableCell>
<TableCell>{dimension.value_type}</TableCell>
<TableCell>{dimension.doc ? dimension.doc : 'No description available'}</TableCell>
<TableCell>
<Button onClick={() => open(dimension)}> Instantiate </Button>
</TableCell>
</TableRow>
))}
</TableBody>
</Table>
{/* outside the loop */}
<FiltersAddition dimension={selected} isModalOpen={isShowing} close={close} />
Answered By - Samuel Goldenbaum
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.