UNPKG

office-ui-fabric-react

Version:

Reusable React components for building experiences for Microsoft 365.

186 lines (185 loc) 5.83 kB
import * as React from 'react'; import { SliderBase } from './Slider.base'; import { IStyle, ITheme } from '../../Styling'; import { IStyleFunctionOrObject, IRefObject } from '../../Utilities'; /** * {@docCategory Slider} */ export interface ISlider { value: number | undefined; focus: () => void; range: [number, number] | undefined; } /** * {@docCategory Slider} */ export interface ISliderProps extends React.ClassAttributes<SliderBase> { /** * Optional callback to access the ISlider interface. Use this instead of ref for accessing * the public methods and properties of the component. */ componentRef?: IRefObject<ISlider>; /** * Call to provide customized styling that will layer on top of the variant rules. */ styles?: IStyleFunctionOrObject<ISliderStyleProps, ISliderStyles>; /** * Theme provided by High-Order Component. */ theme?: ITheme; /** * Description label of the Slider */ label?: string; /** * The initial value of the Slider. Use this if you intend for the Slider to be an uncontrolled component. * This value is mutually exclusive to value. Use one or the other. */ defaultValue?: number; /** * The initial value of the Slider. Use this if you intend to pass in a new value as a result of onChange events. * This value is mutually exclusive to defaultValue. Use one or the other. */ value?: number; /** * The initial lower value of the Slider if ranged is true. Use this if you intend for the Slider to be an * uncontrolled component. This value is mutually exclusive to lowerValue. Use one or the other. */ defaultLowerValue?: number; /** * The initial lower value of the Slider if ranged is true. Use this if you intend to pass in a new value as a * result of onChange events. This value is mutually exclusive to defaultLowerValue. Use one or the other. */ lowerValue?: number; /** * The min value of the Slider * @defaultvalue 0 */ min?: number; /** * The max value of the Slider * @defaultvalue 10 */ max?: number; /** * The difference between the two adjacent values of the Slider * @defaultvalue 1 */ step?: number; /** * Whether to show the value on the right of the Slider. * @defaultvalue true */ showValue?: boolean; /** * Callback when the value has been changed. * If `ranged` is true, `value` is the upper value, and `range` contains the lower and upper bounds of the range. */ onChange?: (value: number, range?: [number, number]) => void; /** * Callback on mouse up or touch end */ onChanged?: (event: MouseEvent | TouchEvent | KeyboardEvent, value: number) => void; /** * A description of the Slider for the benefit of screen readers. */ ariaLabel?: string; /** * If `ranged` is true, display two thumbs that allow the lower and upper bounds of a range to be selected. * The lower bound is defined by `lowerValue`, and the upper bound is defined by `value`. */ ranged?: boolean; /** * A text description of the Slider number value for the benefit of screen readers. * This should be used when the Slider number value is not accurately represented by a number. */ ariaValueText?: (value: number) => string; /** * Optional flag to render the slider vertically. Defaults to rendering horizontal. */ vertical?: boolean; /** * Optional flag to render the Slider as disabled. * @defaultvalue false */ disabled?: boolean; /** * Optional flag to decide that thumb will snap to closest value while moving the slider * @defaultvalue false */ snapToStep?: boolean; /** * Optional className to attach to the slider root element. */ className?: string; /** * Optional mixin for additional props on the thumb button within the slider. */ buttonProps?: React.HTMLAttributes<HTMLButtonElement>; /** * Optional function to format the slider value. */ valueFormat?: (value: number) => string; /** * Optional flag to attach the origin of slider to zero. Helpful when the range include negatives. * @defaultvalue false */ originFromZero?: boolean; } /** * {@docCategory Slider} */ export declare type ISliderStyleProps = Required<Pick<ISliderProps, 'theme'>> & Pick<ISliderProps, 'className' | 'disabled' | 'vertical' | 'ranged'> & { showTransitions?: boolean; showValue?: boolean; titleLabelClassName?: string; }; /** * {@docCategory Slider} */ export interface ISliderStyles { /** * Style set for the root element. */ root: IStyle; /** * Style set for the title label above the slider. */ titleLabel: IStyle; /** * Style set for the container of the slider. */ container: IStyle; /** * Style set for the actual box containting interactive elements of the slider. */ slideBox: IStyle; /** * Style set for element that contains all the lines. */ line: IStyle; /** * Style set for thumb of the slider. */ thumb: IStyle; /** * Style set for both active and inactive sections of the line. */ lineContainer: IStyle; /** * Style set for active portion of the line. */ activeSection: IStyle; /** * Style set for inactive portion of the line. */ inactiveSection: IStyle; /** * Style set for value label on right/below of the slider. */ valueLabel: IStyle; /** * Style set for tick on 0 on number line. This element only shows up when originFromZero prop is true. */ zeroTick: IStyle; }