Umbraco UI Builder can dynamically build a filter dialog choosing appropriate editor views for you based on a basic property configuration. Properties of a number or date types will become range pickers and enums. Properties with options defined will become select/checkbox lists and all other properties will become text input filters.
Defining filterable properties
Defining filterable properties is controlled via the collections configuration.
AddFilterableProperty(Lambda filterablePropertyExpression, Lambda filterConfig = null) : CollectionConfigBuilder<TEntityType>
Adds the given property to the filterable properties collection.
Copy // Example
collectionConfig .AddFilterableProperty(p => p . FirstName , filterConfig => filterConfig
// ...
);
Changing the label of a filterable property
SetLabel(string label) : FilterablePropertyConfigBuilder<TEntityType, TValueType>
Copy // Example
filterConfig .SetLabel( "First Name" );
Adding a description to a filterable property
SetDescription(string description) : FilterablePropertyConfigBuilder<TEntityType, TValueType>
Copy // Example
filterConfig .SetDescription( "The first name of the person" );
Defining basic options for a filterable property
SetOptions(IDictionary<TValueType, string> options) : FilterablePropertyConfigBuilder<TEntityType, TValueType>
Copy // Example
filterConfig .SetOptions( new Dictionary < string , string > {
{ "Option1" , "Option One" } ,
{ "Option2" , "Option Two" }
});
Defining options with custom compare clauses for a filterable property
AddOption(object key, string label, Lambda compareExpression) : FilterablePropertyConfigBuilder<TEntityType, TValueType>
Copy // Example
filterConfig .AddOption( "Option1" , "Option One" , (val) => val != "Option Two" );
Configuring the mode of a filterable property
For filterable properties with options you can configure whether the options should be multiple or single choice.
SetMode(FilterMode mode) : FilterablePropertyConfigBuilder<TEntityType, TValueType>
Copy // Example
filterConfig .SetMode( FilterMode . MultipleChoice );