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 | 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 1x 3x 1x 1x 1x 1x 1x | import { memo, type ReactNode } from 'react';
import { ComponentSwitchItem } from './component-switch-item/ComponentSwitchItem';
import { ComponentSwitchContext } from './ComponentSwitch.context';
import { type ComponentSwitchItemValue } from './ComponentSwitch.types';
export interface ComponentSwitchProps {
/** Currently active child item value. */
readonly value?: ComponentSwitchItemValue | null;
/** Component switch items. */
readonly children?: ReactNode;
}
const ComponentSwitchBase = memo(function ComponentSwitch({ value = null, children = null }: ComponentSwitchProps) {
return <ComponentSwitchContext.Provider value={value}>{children}</ComponentSwitchContext.Provider>;
});
export const ComponentSwitch = Object.assign(ComponentSwitchBase, {
Item: ComponentSwitchItem,
});
|