Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 4x 4x 4x 4x 4x 4x 4x 4x 1x | import { Fragment, memo, type ReactNode } from 'react';
import { useComponentSwitchContext } from '../ComponentSwitch.context';
import { type ComponentSwitchItemValue } from '../ComponentSwitch.types';
export interface ComponentSwitchItemProps {
/** Render children if this value matches the value of the parent ComponentSwitch. */
readonly value: ComponentSwitchItemValue | ComponentSwitchItemValue[];
/** Children to render. */
readonly children?: ReactNode;
}
export const ComponentSwitchItem = memo(function ComponentSwitchItem({
value,
children = null,
}: ComponentSwitchItemProps) {
const activeValue = useComponentSwitchContext();
const isActive = Array.isArray(value) ? activeValue !== null && value.includes(activeValue) : value === activeValue;
return isActive ? <Fragment>{children}</Fragment> : null;
});
|