withCustomDecorator()
Home > @gooddata/sdk-ui-dashboard > IAttributeFiltersCustomizer > withCustomDecorator
IAttributeFiltersCustomizer.withCustomDecorator() method
Register a factory for attribute filter decorator providers.
Signature:
withCustomDecorator(providerFactory: (next: AttributeFilterComponentProvider) => OptionalAttributeFilterComponentProvider): IAttributeFiltersCustomizer;
Parameters
Parameter | Type | Description |
---|---|---|
providerFactory | (next: AttributeFilterComponentProvider) => OptionalAttributeFilterComponentProvider | factory |
Returns:
Remarks
Decorators are a way to add customizations or embellishments on top of an existing component. Decorators are more complex to write because they need to work with the component they should decorate and add 'something' on top of that component.
This is best illustrated on an example:
Example
withCustomDecorator((next) => {
return (filter) => {
if (some_condition_to_prevent_decoration) {
return undefined;
}
// Make sure you call this outside the component render function,
// otherwise a new instance of the decorated component is created on each re-render.
const Decorated = next(filter);
function MyCustomDecorator(props) {
return (
<div>
<p>My Custom Decoration</p>
<Decorated {...props} />
</div>
)
}
return MyCustomDecorator;
}
})
The above shows how to register a decorator that will use some condition to determine whether particular attribute filter is eligible for decoration.
Note: the factory function that you specify will be called immediately at the registration time. The provider that it returns will be called at render time.