Composition functionality for Fluent UI
This functionality is in the experimental stage and should never be used in production as APIs might change before final release.
Currently supported only by functional components in @fluentui/react-northstar
.
To import compose
and use:
import { Button } from '@fluentui/react-northstar';
import { compose } from '@fluentui/react-compose';
const PrimaryButton = compose(Button, {
className: 'ui-primary-button',
displayName: 'PrimaryButton',
mapPropsToStylesProps: props => ({ compact: props.compact }),
handledProps: ['compact'],
overrideStyles: true,
});
className
overrides aclassName
that we will be assigned to theroot
slot of a componentdisplayName
modifies a React'sdisplayName
for component, it will be also used as a selector for styles overrides in your thememapPropsToStylesProps
passes additional design terms to styles functionshandledProps
is an array of props that will not be bypassed to the component's root slotoverrideStyles
indicates should the component will use only its own styles or will merge those with parent's