Skip to content

Latest commit

 

History

History
56 lines (35 loc) · 3.5 KB

File metadata and controls

56 lines (35 loc) · 3.5 KB

Xperience Community: Depending field components

Nuget build

When editing content, often developers will want to hide a field's input based on the value of another field. For example, if an article might contain a link to an external site, there will be a checkbox called "Has external link." If the checkbox is not checked, the text input for the external link should be hidden.

This project adds custom form components to Xperience by Kentico which allows developers to configure depending field functionality directly in the UI or code. These form components can be used in content types and widget properties.

Library Version Matrix

Xperience Version Library Version
>= 29.1.0 >= 2.0.0

Components

The project currently contains the following input types with depending field functionality:

  • Text
  • Number
  • Checkbox
  • Dropdown
  • Date time
  • Radio group

Configuring depending fields in the administration

In the Content types application, create two fields in which the visibility of one field depends on another field's value:

Content type fields

For the dependent field, choose a form component from this project, e.g. "Text input with field dependency." You will see two new properties that can be configured for the field:

  • Depends on: The name of the field that determines this field's visibility
  • Expected value: The value of the depending field which will reveal this field

Enter the name of another field in the content type, such as "HasExternalLink" in the above example. When that field's value changes, the current field's visibility will be reevaluated. In the expected value field, enter the string representation of the value required for the field to be shown. For example, if the field depends on a boolean field, the string representation of a checked box is "True."

Content type fields

Configuring depending fields in code

⚠️ The following is redundant as the default visibility attribute VisibleIfEqualToAttribute already offers the same functionality. However this will remain documented in the event that additional functionality is added in the future.

To configure depending widget properties, decorate the depending property with a form component attribute added by this project such as TextInputDependsOnProperty. Set the DependsOn property to the name of another widget property, and Expected value to the string representation of the value that will reveal this property.

In the following example, the text input will appear only if the checkbox is checked:

[CheckBoxComponent(Label = "Has target" , Order = 2)]
public bool HasTarget { get; set; }

[TextInputDependsOnProperty(DependsOn = nameof(HasTarget), ExpectedValue = "True", Label = "Button target", Order = 3)]
public string ButtonTarget { get; set; }