UNPKG

@pnp/spfx-property-controls

Version:

Reusable property pane controls for SharePoint Framework solutions

110 lines 4.55 kB
import * as React from 'react'; import * as ReactDom from 'react-dom'; import { PropertyPaneFieldType } from '@microsoft/sp-property-pane'; import PropertyFieldViewPickerHost from './PropertyFieldViewPickerHost'; /** * Represents a PropertyFieldViewPicker object */ class PropertyFieldViewPickerBuilder { onPropertyChange(propertyPath, oldValue, newValue) { } // eslint-disable-line @typescript-eslint/no-explicit-any /** * Constructor method */ constructor(_targetProperty, _properties) { this.type = PropertyPaneFieldType.Custom; this.deferredValidationTime = 200; this.disabled = false; this.disableReactivePropertyChanges = false; this.render = this.render.bind(this); this.targetProperty = _targetProperty; this.properties = _properties; this.properties.onDispose = this.dispose; this.properties.onRender = this.render; this.label = _properties.label; this.context = _properties.context; this.webAbsoluteUrl = _properties.webAbsoluteUrl; this.listId = _properties.listId; this.selectedView = _properties.selectedView; this.orderBy = _properties.orderBy; this.onPropertyChange = _properties.onPropertyChange; this.customProperties = _properties.properties; this.key = _properties.key; this.viewsToExclude = _properties.viewsToExclude; this.filter = _properties.filter; this.onGetErrorMessage = _properties.onGetErrorMessage; this.onViewsRetrieved = _properties.onViewsRetrieved; if (_properties.disabled === true) { this.disabled = _properties.disabled; } if (_properties.deferredValidationTime) { this.deferredValidationTime = _properties.deferredValidationTime; } } /** * Renders the SPViewPicker field content */ render(elem, ctx, changeCallback) { const componentProps = { label: this.label, targetProperty: this.targetProperty, context: this.context, webAbsoluteUrl: this.webAbsoluteUrl, listId: this.listId, orderBy: this.orderBy, onDispose: this.dispose, onRender: this.render, onChange: changeCallback, onPropertyChange: this.onPropertyChange, properties: this.customProperties, key: this.key, disabled: this.disabled, onGetErrorMessage: this.onGetErrorMessage, deferredValidationTime: this.deferredValidationTime, viewsToExclude: this.viewsToExclude, filter: this.filter, onViewsRetrieved: this.onViewsRetrieved }; // Single selector componentProps.selectedView = this.selectedView; const element = React.createElement(PropertyFieldViewPickerHost, componentProps); // Calls the REACT content generator ReactDom.render(element, elem); } /** * Disposes the current object */ dispose(_elem) { // no-op; } } /** * Helper method to create a SPView Picker on the PropertyPane. * @param targetProperty - Target property the SharePoint view picker is associated to. * @param properties - Strongly typed SPView Picker properties. */ export function PropertyFieldViewPicker(targetProperty, properties) { //Create an internal properties object from the given properties const newProperties = { label: properties.label, targetProperty: targetProperty, context: properties.context, listId: properties.listId, selectedView: typeof properties.selectedView === 'string' ? properties.selectedView : null, onPropertyChange: properties.onPropertyChange, properties: properties.properties, onDispose: null, onRender: null, key: properties.key, disabled: properties.disabled, viewsToExclude: properties.viewsToExclude, webAbsoluteUrl: properties.webAbsoluteUrl, filter: properties.filter, onGetErrorMessage: properties.onGetErrorMessage, deferredValidationTime: properties.deferredValidationTime, onViewsRetrieved: properties.onViewsRetrieved }; //Calls the PropertyFieldViewPicker builder object //This object will simulate a PropertyFieldCustom to manage his rendering process return new PropertyFieldViewPickerBuilder(targetProperty, newProperties); } //# sourceMappingURL=PropertyFieldViewPicker.js.map