* feat: added checkbox column type * fix: addressed review changes * feat: added filter for checkbox column type * fix: checkbox alignment * fix: horizontal alignement property added for checkbox column type * test: added cypress test and addressed feedback changes * fix: add new property cellComponentHorizontalAlignment * fix: addressed review comments * fix: changed column type order to alphabetical order * refactor: removed unused imports * fix: typings for the dynamic label * fix: addressed review comments * fix: disabled cursor flicker issue * fix: inline editing for checkbox column type * fix: addressed QA callouts * fix: addressed qa callouts * fix: addressed review callouts * fix: horizontal alignment issue * fix: * rebase new property pane changes * cypress test fixes * added support to dynamically change the section name with the help of function * fix: type casting issue for sectionName * fix: addressed review comments * chore: removed unused imports * fix: added prop.hidden comparision in the memoized PropertySection component Co-authored-by: Aishwarya UR <aishwarya@appsmith.com>
87 lines
2.8 KiB
TypeScript
87 lines
2.8 KiB
TypeScript
/***
|
|
* Controls are rendered in the property panel from the property config
|
|
* Controls are higher order components that update a widgets property
|
|
*/
|
|
import { Component } from "react";
|
|
import _ from "lodash";
|
|
import { EditorTheme } from "components/editorComponents/CodeEditor/EditorConfig";
|
|
import { PropertyPaneControlConfig } from "constants/PropertyControlConstants";
|
|
import { CodeEditorExpected } from "components/editorComponents/CodeEditor";
|
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
class BaseControl<P extends ControlProps, S = {}> extends Component<P, S> {
|
|
updateProperty(
|
|
propertyName: string,
|
|
propertyValue: any,
|
|
isUpdatedViaKeyboard?: boolean,
|
|
) {
|
|
if (!_.isNil(this.props.onPropertyChange))
|
|
this.props.onPropertyChange(
|
|
propertyName,
|
|
propertyValue,
|
|
isUpdatedViaKeyboard,
|
|
);
|
|
}
|
|
deleteProperties(propertyPaths: string[]) {
|
|
if (this.props.deleteProperties) {
|
|
this.props.deleteProperties(propertyPaths);
|
|
}
|
|
}
|
|
batchUpdateProperties = (updates: Record<string, unknown>) => {
|
|
if (this.props.onBatchUpdateProperties) {
|
|
this.props.onBatchUpdateProperties(updates);
|
|
}
|
|
};
|
|
static getControlType() {
|
|
return "BASE_CONTROL";
|
|
}
|
|
|
|
// Checks whether a particular value can be displayed UI from JS edit mode
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
static canDisplayValueInUI(config: ControlData, value: any): boolean {
|
|
return false;
|
|
}
|
|
|
|
// Only applicable for JSONFormComputeControl & ComputeTablePropertyControl
|
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
static getInputComputedValue(value: string, widgetName: string): string {
|
|
return "";
|
|
}
|
|
}
|
|
|
|
export interface ControlBuilder<T extends ControlProps> {
|
|
buildPropertyControl(controlProps: T): JSX.Element;
|
|
}
|
|
|
|
export interface ControlProps extends ControlData, ControlFunctions {
|
|
key?: string;
|
|
additionalAutoComplete?: Record<string, Record<string, unknown>>;
|
|
}
|
|
export interface ControlData
|
|
extends Omit<PropertyPaneControlConfig, "additionalAutoComplete" | "label"> {
|
|
propertyValue?: any;
|
|
errorMessage?: string;
|
|
expected?: CodeEditorExpected;
|
|
evaluatedValue: any;
|
|
widgetProperties: any;
|
|
useValidationMessage?: boolean;
|
|
parentPropertyName: string;
|
|
parentPropertyValue: unknown;
|
|
additionalDynamicData: Record<string, Record<string, unknown>>;
|
|
label: string;
|
|
}
|
|
export interface ControlFunctions {
|
|
onPropertyChange?: (
|
|
propertyName: string,
|
|
propertyValue: string,
|
|
isUpdatedViaKeyboard?: boolean,
|
|
) => void;
|
|
onBatchUpdateProperties?: (updates: Record<string, unknown>) => void;
|
|
openNextPanel: (props: any) => void;
|
|
deleteProperties: (propertyPaths: string[]) => void;
|
|
theme: EditorTheme;
|
|
hideEvaluatedValue?: boolean;
|
|
}
|
|
|
|
export default BaseControl;
|