All files / libs/ext/react/components/src/lib/component-switch/component-switch-item ComponentSwitchItem.tsx

100% Statements 22/22
100% Branches 5/5
100% Functions 0/0
100% Lines 22/22

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 231x 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;
});