OPEN TO WORK

Available for new opportunities! Let's build something amazing together.

How to let custom property pane fields enable the apply button in SharePoint Framework

Fields Property Pane SPFx
post

This post is over a year old, some of this information may be out of date.

Since the SharePoint Framework v1.2.0 release; it is now possible to let your custom property pane fields trigger the apply button in non-reactive property panes. Before this release, you had to implement your own logic to re-render the contents of your web part or use the reactive property pane.

So, what changed?

In the previous versions, the onRender method of your custom property pane field had two arguments:

  • The HTML element
  • Context
Show image Old onRender method
Old onRender method

Since version 1.2.0 a new argument has been added:

  • Change callback function
Show image onRender method since v1.2.0
onRender method since v1.2.0

This is a callback function which gets provided to your custom field by the property pane. You can make use of this to let the property pane know a change happened in one of your custom fields. If you use this in combination with a non-reactive property pane (that is the property pane with an apply button at the bottom) it will trigger the button to get enabled.

Show me the code

Code snippet of my onRender method:

/**
* @function
* Renders the custom field
*/
private render(elem: HTMLElement, ctx?, changeCallback?: (targetProperty: string, value: any) => void): void {
const props: ISampleInsecurePasswordHostProps = {
key: this.properties.key,
label: typeof this.label === "undefined" ? null : this.label,
description: typeof this.description === "undefined" ? null : this.description,
initialValue: typeof this.initialValue === "undefined" ? null : this.initialValue,
properties: this.properties,
targetProperty: this.targetProperty,
onRender: this.render,
onChanged: changeCallback,
onDispose: this.dispose,
onPropertyChange: this.onPropertyChange
};
// Construct the JSX properties
const element: React.ReactElement<ISampleInsecurePasswordProps> = React.createElement(SampleInsecurePasswordHost, props);
// Calls the REACT content generator
ReactDom.render(element, elem);
}

Code snippet of my method where I store my new property value:

private notifyAfterValidate(oldValue: string, newValue: string) {
this.props.properties[this.props.targetProperty] = newValue;
this.props.onPropertyChange(this.props.targetProperty, oldValue, newValue);
// Trigger the onChanged callback
if (typeof this.props.onChanged !== "undefined") {
this.props.onChanged(this.props.targetProperty, newValue);
}
}

Result

Show image Example of a custom field that triggers the apply button
Example of a custom field that triggers the apply button

The sample code of this custom field can be found here: InsecurePasswordPropertyField.ts gist.

BTW: it is really not a good idea to store a password in the property pane. This is just created as an example to show that it is really a different field.

Related articles

Report issues or make changes on GitHub

Found a typo or issue in this article? Visit the GitHub repository to make changes or submit a bug report.

Comments

Elio Struyf

Solutions Architect & Developer Expert

Loading...

Let's build together

Manage content in VS Code

Present from VS Code