import * as React from 'react'; import { DefaultPalette, Slider, Stack, IStackStyles, IStackTokens, IStackItemStyles } from '@fluentui/react'; // Non-mutating styles definition const stackItemStyles: IStackItemStyles = { root: { alignItems: 'center', background: DefaultPalette.themePrimary, color: DefaultPalette.white, display: 'flex', height: 50, justifyContent: 'center', overflow: 'hidden', }, }; const nonShrinkingStackItemStyles: IStackItemStyles = { root: { alignItems: 'center', background: DefaultPalette.themePrimary, color: DefaultPalette.white, display: 'flex', height: 50, justifyContent: 'center', overflow: 'hidden', width: 500, }, }; // Tokens definition const outerStackTokens: IStackTokens = { childrenGap: 5 }; const innerStackTokens: IStackTokens = { childrenGap: 5, padding: 10, }; export const HorizontalStackShrinkExample: React.FunctionComponent = () => { const [stackWidth, setStackWidth] = React.useState(100); // Mutating styles definition const stackStyles: IStackStyles = { root: { background: DefaultPalette.themeTertiary, overflow: 'hidden', width: `${stackWidth}%`, }, }; return ( I shrink I shrink I don't shrink I shrink ); };