aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/EditableView.tsx
diff options
context:
space:
mode:
authorusodhi <61431818+usodhi@users.noreply.github.com>2021-02-25 15:36:49 -0500
committerusodhi <61431818+usodhi@users.noreply.github.com>2021-02-25 15:36:49 -0500
commit95451a2eb0871856b946fff8a14ca0c385af5f1b (patch)
tree90c18c68c4e077d63dd3286d527b243ac6cdc501 /src/client/views/EditableView.tsx
parent02bceed486ecb03b94c757ae669f69912f282cdd (diff)
parent17ee7f6f1f61a079ec79b71aebc65abfd72ec32a (diff)
merging
Diffstat (limited to 'src/client/views/EditableView.tsx')
-rw-r--r--src/client/views/EditableView.tsx59
1 files changed, 14 insertions, 45 deletions
diff --git a/src/client/views/EditableView.tsx b/src/client/views/EditableView.tsx
index 828a2eb78..f1cecd272 100644
--- a/src/client/views/EditableView.tsx
+++ b/src/client/views/EditableView.tsx
@@ -3,8 +3,6 @@ import { action, observable } from 'mobx';
import { observer } from 'mobx-react';
import * as Autosuggest from 'react-autosuggest';
import { ObjectField } from '../../fields/ObjectField';
-import { SchemaHeaderField } from '../../fields/SchemaHeaderField';
-import { DragManager } from '../util/DragManager';
import "./EditableView.scss";
export interface EditableProps {
@@ -12,16 +10,13 @@ export interface EditableProps {
* Called to get the initial value for editing
* */
GetValue(): string | undefined;
-
/**
* Called to apply changes
* @param value - The string entered by the user to set the value to
* @returns `true` if setting the value was successful, `false` otherwise
* */
SetValue(value: string, shiftDown?: boolean, enterKey?: boolean): boolean;
-
OnFillDown?(value: string): void;
-
OnTab?(shift?: boolean): void;
OnEmpty?(): void;
@@ -45,15 +40,12 @@ export interface EditableProps {
};
oneLine?: boolean;
editing?: boolean;
- onClick?: (e: React.MouseEvent) => boolean;
isEditingCallback?: (isEditing: boolean) => void;
menuCallback?: (x: number, y: number) => void;
textCallback?: (char: string) => boolean;
showMenuOnLoad?: boolean;
- HeadingObject?: SchemaHeaderField | undefined;
toggle?: () => void;
- color?: string | undefined;
- onDrop?: any;
+ background?: string | undefined;
placeholder?: string;
fullWidth?: boolean; // used in PropertiesView to make the whole key:value input box clickable
}
@@ -65,6 +57,8 @@ export interface EditableProps {
*/
@observer
export class EditableView extends React.Component<EditableProps> {
+ private _ref = React.createRef<HTMLDivElement>();
+ private _inputref = React.createRef<HTMLInputElement>();
@observable _editing: boolean = false;
constructor(props: EditableProps) {
@@ -72,17 +66,6 @@ export class EditableView extends React.Component<EditableProps> {
this._editing = this.props.editing ? true : false;
}
- // @action
- // componentDidUpdate(nextProps: EditableProps) {
- // // this is done because when autosuggest is turned on, the suggestions are passed in as a prop,
- // // so when the suggestions are passed in, and no editing prop is passed in, it used to set it
- // // to false. this will no longer do so -syip
- // if (nextProps.editing && nextProps.editing !== this._editing) {
- // this._editing = nextProps.editing;
- // EditableView.loadId = "";
- // }
- // }
-
@action
componentDidUpdate() {
if (this._editing && this.props.editing === false) {
@@ -92,19 +75,10 @@ export class EditableView extends React.Component<EditableProps> {
}
}
- @action
- componentDidMount() {
- if (this._ref.current && this.props.onDrop) {
- DragManager.MakeDropTarget(this._ref.current, this.props.onDrop.bind(this));
- }
- }
- @action
componentWillUnmount() {
this._inputref.current?.value && this.finalizeEdit(this._inputref.current.value, false, true, false);
}
- _didShow = false;
-
@action
onKeyDown = (e: React.KeyboardEvent<HTMLInputElement>) => {
switch (e.key) {
@@ -150,7 +124,7 @@ export class EditableView extends React.Component<EditableProps> {
e.nativeEvent.stopPropagation();
if (this._ref.current && this.props.showMenuOnLoad) {
this.props.menuCallback?.(this._ref.current.getBoundingClientRect().x, this._ref.current.getBoundingClientRect().y);
- } else if (!this.props.onClick?.(e)) {
+ } else {
this._editing = true;
this.props.isEditingCallback?.(true);
}
@@ -159,7 +133,7 @@ export class EditableView extends React.Component<EditableProps> {
}
@action
- private finalizeEdit(value: string, shiftDown: boolean, lostFocus: boolean, enterKey: boolean) {
+ finalizeEdit(value: string, shiftDown: boolean, lostFocus: boolean, enterKey: boolean) {
if (this.props.SetValue(value, shiftDown, enterKey)) {
this._editing = false;
this.props.isEditingCallback?.(false,);
@@ -173,9 +147,7 @@ export class EditableView extends React.Component<EditableProps> {
}
}
- stopPropagation(e: React.SyntheticEvent) {
- e.stopPropagation();
- }
+ stopPropagation(e: React.SyntheticEvent) { e.stopPropagation(); }
@action
setIsFocused = (value: boolean) => {
@@ -184,8 +156,6 @@ export class EditableView extends React.Component<EditableProps> {
return wasFocused !== this._editing;
}
- _ref = React.createRef<HTMLDivElement>();
- _inputref = React.createRef<HTMLInputElement>();
renderEditor() {
return this.props.autosuggestProps
? <Autosuggest
@@ -204,14 +174,13 @@ export class EditableView extends React.Component<EditableProps> {
}}
/>
: <input className="editableView-input" ref={this._inputref}
+ style={{ display: this.props.display, fontSize: this.props.fontSize, minWidth: 20, background: this.props.background }}
+ placeholder={this.props.placeholder}
+ onBlur={e => this.finalizeEdit(e.currentTarget.value, false, true, false)}
defaultValue={this.props.GetValue()}
- onKeyDown={this.onKeyDown}
autoFocus={true}
- onKeyPress={e => e.stopPropagation()}
- onBlur={e => this.finalizeEdit(e.currentTarget.value, false, true, false)}
- onPointerDown={this.stopPropagation} onClick={this.stopPropagation} onPointerUp={this.stopPropagation}
- style={{ display: this.props.display, fontSize: this.props.fontSize, minWidth: 20 }}
- placeholder={this.props.placeholder}
+ onKeyDown={this.onKeyDown}
+ onKeyPress={this.stopPropagation} onPointerDown={this.stopPropagation} onClick={this.stopPropagation} onPointerUp={this.stopPropagation}
/>;
}
@@ -226,13 +195,13 @@ export class EditableView extends React.Component<EditableProps> {
</div> :
this.renderEditor();
}
- setTimeout(() => this.props.autosuggestProps?.resetValue(), 0);
+ setTimeout(() => this.props.autosuggestProps?.resetValue());
return this.props.contents instanceof ObjectField ? (null) :
<div className={`editableView-container-editing${this.props.oneLine ? "-oneLine" : ""}`} ref={this._ref}
style={{ display: this.props.display, textOverflow: this.props.overflow, minHeight: "17px", whiteSpace: "nowrap", height: this.props.height || "auto", maxHeight: this.props.maxHeight }}
onClick={this.onClick} placeholder={this.props.placeholder}>
- <span style={{ fontStyle: this.props.fontStyle, fontSize: this.props.fontSize }} >{
- this.props.contents ? this.props.contents?.valueOf() : this.props.placeholder?.valueOf()}
+ <span style={{ fontStyle: this.props.fontStyle, fontSize: this.props.fontSize }} >
+ {this.props.contents ? this.props.contents?.valueOf() : this.props.placeholder?.valueOf()}
</span>
</div>;
}