@mantine/core
Version:
React components library focused on usability, accessibility and developer experience
57 lines (56 loc) • 3.06 kB
TypeScript
import { BoxProps, ElementProps, Factory, MantineColor, MantineRadius, MantineSize, StylesApiProps } from '../../core';
export type SegmentedControlStylesNames = 'root' | 'input' | 'label' | 'control' | 'indicator' | 'innerLabel';
export type SegmentedControlCssVariables = {
root: '--sc-radius' | '--sc-color' | '--sc-font-size' | '--sc-padding' | '--sc-shadow' | '--sc-transition-duration' | '--sc-transition-timing-function';
};
export interface SegmentedControlItem {
value: string;
label: React.ReactNode;
disabled?: boolean;
}
export interface SegmentedControlProps extends BoxProps, StylesApiProps<SegmentedControlFactory>, ElementProps<'div', 'onChange'> {
/** Data based on which controls are rendered */
data: (string | SegmentedControlItem)[];
/** Controlled component value */
value?: string;
/** Uncontrolled component default value */
defaultValue?: string;
/** Called when value changes */
onChange?: (value: string) => void;
/** Determines whether the component is disabled */
disabled?: boolean;
/** Name of the radio group, by default random name is generated */
name?: string;
/** Determines whether the component should take 100% width of its parent, `false` by default */
fullWidth?: boolean;
/** Key of `theme.colors` or any valid CSS color, changes color of indicator, by default color is based on current color scheme */
color?: MantineColor;
/** Controls `font-size`, `padding` and `height` properties, `'sm'` by default */
size?: MantineSize | (string & {});
/** Key of `theme.radius` or any valid CSS value to set `border-radius`, numbers are converted to rem, `theme.defaultRadius` by default */
radius?: MantineRadius;
/** Indicator `transition-duration` in ms, set `0` to turn off transitions, `200` by default */
transitionDuration?: number;
/** Indicator `transition-timing-function` property, `ease` by default */
transitionTimingFunction?: string;
/** Determines in which orientation component id displayed, `'horizontal'` by default */
orientation?: 'vertical' | 'horizontal';
/** Determines whether the value can be changed */
readOnly?: boolean;
/** Determines whether text color should depend on `background-color` of the indicator. If luminosity of the `color` prop is less than `theme.luminosityThreshold`, then `theme.white` will be used for text color, otherwise `theme.black`. Overrides `theme.autoContrast`. */
autoContrast?: boolean;
/** Determines whether there should be borders between items, `true` by default */
withItemsBorders?: boolean;
}
export type SegmentedControlFactory = Factory<{
props: SegmentedControlProps;
ref: HTMLDivElement;
stylesNames: SegmentedControlStylesNames;
vars: SegmentedControlCssVariables;
}>;
export declare const SegmentedControl: import("../../core").MantineComponent<{
props: SegmentedControlProps;
ref: HTMLDivElement;
stylesNames: SegmentedControlStylesNames;
vars: SegmentedControlCssVariables;
}>;