UNPKG

@pnp/spfx-property-controls

Version:

Reusable property pane controls for SharePoint Framework solutions

147 lines 6.74 kB
import * as React from 'react'; import * as ReactDom from 'react-dom'; import { PropertyPaneFieldType } from '@microsoft/sp-property-pane'; import PropertyFieldColumnPickerHost from './PropertyFieldColumnPickerHost'; import { IPropertyFieldRenderOption, IColumnReturnProperty } from './IPropertyFieldColumnPicker'; import PropertyFieldColumnMultiPickerHost from './PropertyFieldColumnMultiPickerHost'; import PropertyFieldColumnMultiPickerDropdownHost from './PropertyFieldColumnMultiPickerDropdownHost'; /** * Represents a PropertyFieldColumnPicker object */ class PropertyFieldColumnPickerBuilder { onPropertyChange(propertyPath, oldValue, newValue) { } // eslint-disable-line @typescript-eslint/no-explicit-any /** * Constructor method */ constructor(_targetProperty, _properties) { this.type = PropertyPaneFieldType.Custom; this.displayHiddenColumns = false; this.columnReturnProperty = IColumnReturnProperty.Id; this.multiSelect = false; this.renderFieldAs = IPropertyFieldRenderOption["Choice Group"]; this.deferredValidationTime = 200; this.disabled = 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.selectedColumn = _properties.selectedColumn; this.selectedColumns = _properties.selectedColumns; this.orderBy = _properties.orderBy; this.onPropertyChange = _properties.onPropertyChange; this.customProperties = _properties.properties; this.key = _properties.key; this.columnsToExclude = _properties.columnsToExclude; this.displayHiddenColumns = _properties.displayHiddenColumns; this.columnReturnProperty = _properties.columnReturnProperty; this.renderFieldAs = _properties.renderFieldAs; this.multiSelect = _properties.multiSelect; this.filter = _properties.filter; this.onGetErrorMessage = _properties.onGetErrorMessage; this.onColumnsRetrieved = _properties.onColumnsRetrieved; if (_properties.disabled === true) { this.disabled = _properties.disabled; } if (_properties.deferredValidationTime) { this.deferredValidationTime = _properties.deferredValidationTime; } } /** * Renders the SPColumnPicker 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, columnsToExclude: this.columnsToExclude, displayHiddenColumns: this.displayHiddenColumns, columnReturnProperty: this.columnReturnProperty, renderFieldAs: this.renderFieldAs, multiSelect: this.multiSelect, filter: this.filter, onColumnsRetrieved: this.onColumnsRetrieved }; // Check if the multi or single select component has to get loaded if (this.multiSelect) { // Multiple selector componentProps.selectedColumns = this.selectedColumns; if (this.renderFieldAs === IPropertyFieldRenderOption["Choice Group"]) { const element = React.createElement(PropertyFieldColumnMultiPickerHost, componentProps); // Calls the REACT content generator ReactDom.render(element, elem); } else { const element = React.createElement(PropertyFieldColumnMultiPickerDropdownHost, componentProps); // Calls the REACT content generator ReactDom.render(element, elem); } } else { // Single selector componentProps.selectedColumn = this.selectedColumn; const element = React.createElement(PropertyFieldColumnPickerHost, componentProps); // Calls the REACT content generator ReactDom.render(element, elem); } } /** * Disposes the current object */ dispose(_elem) { ReactDom.unmountComponentAtNode(_elem); } } /** * Helper method to create a SPColumn Picker on the PropertyPane. * @param targetProperty - Target property the SharePoint column picker is associated to. * @param properties - Strongly typed SPColumn Picker properties. */ export function PropertyFieldColumnPicker(targetProperty, properties) { //Create an internal properties object from the given properties const newProperties = { label: properties.label, targetProperty: targetProperty, context: properties.context, listId: properties.listId, selectedColumn: typeof properties.selectedColumn === 'string' ? properties.selectedColumn : null, selectedColumns: Array.isArray(properties.selectedColumn) ? properties.selectedColumn : null, onPropertyChange: properties.onPropertyChange, properties: properties.properties, onDispose: null, onRender: null, key: properties.key, disabled: properties.disabled, columnsToExclude: properties.columnsToExclude, displayHiddenColumns: properties.displayHiddenColumns, columnReturnProperty: properties.columnReturnProperty, renderFieldAs: properties.renderFieldAs, multiSelect: properties.multiSelect, webAbsoluteUrl: properties.webAbsoluteUrl, filter: properties.filter, onGetErrorMessage: properties.onGetErrorMessage, deferredValidationTime: properties.deferredValidationTime, onColumnsRetrieved: properties.onColumnsRetrieved }; //Calls the PropertyFieldColumnPicker builder object //This object will simulate a PropertyFieldCustom to manage his rendering process return new PropertyFieldColumnPickerBuilder(targetProperty, newProperties); } //# sourceMappingURL=PropertyFieldColumnPicker.js.map