matrix-react-sdk
Version:
SDK for matrix.org using React
186 lines (184 loc) • 27.1 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _KeyboardShortcuts = require("../../../accessibility/KeyboardShortcuts");
var _KeyBindingsManager = require("../../../KeyBindingsManager");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2018-2024 New Vector Ltd.
Copyright 2015, 2016 OpenMarket Ltd
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
var Phases = /*#__PURE__*/function (Phases) {
Phases["Display"] = "display";
Phases["Edit"] = "edit";
return Phases;
}(Phases || {});
class EditableText extends _react.default.Component {
constructor(props) {
super(props);
// we track value as an JS object field rather than in React state
// as React doesn't play nice with contentEditable.
(0, _defineProperty2.default)(this, "value", "");
(0, _defineProperty2.default)(this, "placeholder", false);
(0, _defineProperty2.default)(this, "editableDiv", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "showPlaceholder", show => {
if (!this.editableDiv.current) return;
if (show) {
this.editableDiv.current.textContent = this.props.placeholder;
this.editableDiv.current.setAttribute("class", this.props.className + " " + this.props.placeholderClassName);
this.placeholder = true;
this.value = "";
} else {
this.editableDiv.current.textContent = this.value;
this.editableDiv.current.setAttribute("class", this.props.className);
this.placeholder = false;
}
});
(0, _defineProperty2.default)(this, "cancelEdit", () => {
this.setState({
phase: Phases.Display
});
this.value = this.props.initialValue;
this.showPlaceholder(!this.value);
this.onValueChanged(false);
this.editableDiv.current?.blur();
});
(0, _defineProperty2.default)(this, "onValueChanged", shouldSubmit => {
this.props.onValueChanged?.(this.value, shouldSubmit);
});
(0, _defineProperty2.default)(this, "onKeyDown", ev => {
if (this.placeholder) {
this.showPlaceholder(false);
}
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.Enter:
ev.stopPropagation();
ev.preventDefault();
break;
}
});
(0, _defineProperty2.default)(this, "onKeyUp", ev => {
if (!ev.target.textContent) {
this.showPlaceholder(true);
} else if (!this.placeholder) {
this.value = ev.target.textContent ?? "";
}
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
switch (action) {
case _KeyboardShortcuts.KeyBindingAction.Escape:
this.cancelEdit();
break;
case _KeyboardShortcuts.KeyBindingAction.Enter:
this.onFinish(ev);
break;
}
});
(0, _defineProperty2.default)(this, "onClickDiv", () => {
if (!this.props.editable) return;
this.setState({
phase: Phases.Edit
});
});
(0, _defineProperty2.default)(this, "onFocus", ev => {
const node = ev.target.childNodes[0];
if (node) {
const range = document.createRange();
range.setStart(node, 0);
range.setEnd(node, ev.target.childNodes.length);
const sel = window.getSelection();
sel.removeAllRanges();
sel.addRange(range);
}
});
(0, _defineProperty2.default)(this, "onFinish", (ev, shouldSubmit = false) => {
// eslint-disable-next-line @typescript-eslint/no-this-alias
const self = this;
const action = (0, _KeyBindingsManager.getKeyBindingsManager)().getAccessibilityAction(ev);
const submit = action === _KeyboardShortcuts.KeyBindingAction.Enter || shouldSubmit;
this.setState({
phase: Phases.Display
}, () => {
if (this.value !== this.props.initialValue) {
self.onValueChanged(submit);
}
});
});
(0, _defineProperty2.default)(this, "onBlur", ev => {
const sel = window.getSelection();
sel.removeAllRanges();
if (this.props.blurToCancel) {
this.cancelEdit();
} else {
this.onFinish(ev, this.props.blurToSubmit);
}
this.showPlaceholder(!this.value);
});
this.state = {
phase: Phases.Display
};
}
componentDidUpdate(prevProps) {
if (prevProps.initialValue !== this.props.initialValue) {
this.value = this.props.initialValue;
if (this.editableDiv.current) {
this.showPlaceholder(!this.value);
}
}
}
componentDidMount() {
this.value = this.props.initialValue;
if (this.editableDiv.current) {
this.showPlaceholder(!this.value);
}
}
render() {
const {
className,
editable,
initialValue,
label,
labelClassName
} = this.props;
let editableEl;
if (!editable || this.state.phase === Phases.Display && (label || labelClassName) && !this.value) {
// show the label
editableEl = /*#__PURE__*/_react.default.createElement("div", {
className: className + " " + labelClassName,
onClick: this.onClickDiv
}, label || initialValue);
} else {
// show the content editable div, but manually manage its contents as react and contentEditable don't play nice together
editableEl = /*#__PURE__*/_react.default.createElement("div", {
ref: this.editableDiv,
contentEditable: true,
className: className,
onKeyDown: this.onKeyDown,
onKeyUp: this.onKeyUp,
onFocus: this.onFocus,
onBlur: this.onBlur
});
}
return editableEl;
}
}
exports.default = EditableText;
(0, _defineProperty2.default)(EditableText, "defaultProps", {
onValueChanged() {},
initialValue: "",
label: "",
placeholder: "",
editable: true,
className: "mx_EditableText",
placeholderClassName: "mx_EditableText_placeholder",
blurToSubmit: false
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KeyboardShortcuts","_KeyBindingsManager","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Phases","EditableText","React","Component","constructor","props","_defineProperty2","createRef","show","editableDiv","current","textContent","placeholder","setAttribute","className","placeholderClassName","value","setState","phase","Display","initialValue","showPlaceholder","onValueChanged","blur","shouldSubmit","ev","action","getKeyBindingsManager","getAccessibilityAction","KeyBindingAction","Enter","stopPropagation","preventDefault","target","Escape","cancelEdit","onFinish","editable","Edit","node","childNodes","range","document","createRange","setStart","setEnd","length","sel","window","getSelection","removeAllRanges","addRange","self","submit","blurToCancel","blurToSubmit","state","componentDidUpdate","prevProps","componentDidMount","render","label","labelClassName","editableEl","createElement","onClick","onClickDiv","ref","contentEditable","onKeyDown","onKeyUp","onFocus","onBlur","exports"],"sources":["../../../../src/components/views/elements/EditableText.tsx"],"sourcesContent":["/*\nCopyright 2018-2024 New Vector Ltd.\nCopyright 2015, 2016 OpenMarket Ltd\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { createRef } from \"react\";\n\nimport { KeyBindingAction } from \"../../../accessibility/KeyboardShortcuts\";\nimport { getKeyBindingsManager } from \"../../../KeyBindingsManager\";\n\nenum Phases {\n    Display = \"display\",\n    Edit = \"edit\",\n}\n\ninterface IProps {\n    onValueChanged?: (value: string, shouldSubmit: boolean) => void;\n    initialValue: string;\n    label: string;\n    placeholder: string;\n    className: string;\n    labelClassName?: string;\n    placeholderClassName: string;\n    // Overrides blurToSubmit if true\n    blurToCancel?: boolean;\n    // Will cause onValueChanged(value, true) to fire on blur\n    blurToSubmit: boolean;\n    editable: boolean;\n}\n\ninterface IState {\n    phase: Phases;\n}\n\nexport default class EditableText extends React.Component<IProps, IState> {\n    // we track value as an JS object field rather than in React state\n    // as React doesn't play nice with contentEditable.\n    public value = \"\";\n    private placeholder = false;\n    private editableDiv = createRef<HTMLDivElement>();\n\n    public static defaultProps: Partial<IProps> = {\n        onValueChanged() {},\n        initialValue: \"\",\n        label: \"\",\n        placeholder: \"\",\n        editable: true,\n        className: \"mx_EditableText\",\n        placeholderClassName: \"mx_EditableText_placeholder\",\n        blurToSubmit: false,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            phase: Phases.Display,\n        };\n    }\n\n    public componentDidUpdate(prevProps: Readonly<IProps>): void {\n        if (prevProps.initialValue !== this.props.initialValue) {\n            this.value = this.props.initialValue;\n            if (this.editableDiv.current) {\n                this.showPlaceholder(!this.value);\n            }\n        }\n    }\n\n    public componentDidMount(): void {\n        this.value = this.props.initialValue;\n        if (this.editableDiv.current) {\n            this.showPlaceholder(!this.value);\n        }\n    }\n\n    private showPlaceholder = (show: boolean): void => {\n        if (!this.editableDiv.current) return;\n        if (show) {\n            this.editableDiv.current.textContent = this.props.placeholder;\n            this.editableDiv.current.setAttribute(\n                \"class\",\n                this.props.className + \" \" + this.props.placeholderClassName,\n            );\n            this.placeholder = true;\n            this.value = \"\";\n        } else {\n            this.editableDiv.current.textContent = this.value;\n            this.editableDiv.current.setAttribute(\"class\", this.props.className);\n            this.placeholder = false;\n        }\n    };\n\n    private cancelEdit = (): void => {\n        this.setState({\n            phase: Phases.Display,\n        });\n        this.value = this.props.initialValue;\n        this.showPlaceholder(!this.value);\n        this.onValueChanged(false);\n        this.editableDiv.current?.blur();\n    };\n\n    private onValueChanged = (shouldSubmit: boolean): void => {\n        this.props.onValueChanged?.(this.value, shouldSubmit);\n    };\n\n    private onKeyDown = (ev: React.KeyboardEvent<HTMLDivElement>): void => {\n        if (this.placeholder) {\n            this.showPlaceholder(false);\n        }\n\n        const action = getKeyBindingsManager().getAccessibilityAction(ev);\n        switch (action) {\n            case KeyBindingAction.Enter:\n                ev.stopPropagation();\n                ev.preventDefault();\n                break;\n        }\n    };\n\n    private onKeyUp = (ev: React.KeyboardEvent<HTMLDivElement>): void => {\n        if (!(ev.target as HTMLDivElement).textContent) {\n            this.showPlaceholder(true);\n        } else if (!this.placeholder) {\n            this.value = (ev.target as HTMLDivElement).textContent ?? \"\";\n        }\n\n        const action = getKeyBindingsManager().getAccessibilityAction(ev);\n        switch (action) {\n            case KeyBindingAction.Escape:\n                this.cancelEdit();\n                break;\n            case KeyBindingAction.Enter:\n                this.onFinish(ev);\n                break;\n        }\n    };\n\n    private onClickDiv = (): void => {\n        if (!this.props.editable) return;\n\n        this.setState({\n            phase: Phases.Edit,\n        });\n    };\n\n    private onFocus = (ev: React.FocusEvent<HTMLDivElement>): void => {\n        const node = ev.target.childNodes[0];\n        if (node) {\n            const range = document.createRange();\n            range.setStart(node, 0);\n            range.setEnd(node, ev.target.childNodes.length);\n\n            const sel = window.getSelection()!;\n            sel.removeAllRanges();\n            sel.addRange(range);\n        }\n    };\n\n    private onFinish = (\n        ev: React.KeyboardEvent<HTMLDivElement> | React.FocusEvent<HTMLDivElement>,\n        shouldSubmit = false,\n    ): void => {\n        // eslint-disable-next-line @typescript-eslint/no-this-alias\n        const self = this;\n        const action = getKeyBindingsManager().getAccessibilityAction(ev as React.KeyboardEvent);\n        const submit = action === KeyBindingAction.Enter || shouldSubmit;\n        this.setState(\n            {\n                phase: Phases.Display,\n            },\n            () => {\n                if (this.value !== this.props.initialValue) {\n                    self.onValueChanged(submit);\n                }\n            },\n        );\n    };\n\n    private onBlur = (ev: React.FocusEvent<HTMLDivElement>): void => {\n        const sel = window.getSelection()!;\n        sel.removeAllRanges();\n\n        if (this.props.blurToCancel) {\n            this.cancelEdit();\n        } else {\n            this.onFinish(ev, this.props.blurToSubmit);\n        }\n\n        this.showPlaceholder(!this.value);\n    };\n\n    public render(): React.ReactNode {\n        const { className, editable, initialValue, label, labelClassName } = this.props;\n        let editableEl;\n\n        if (!editable || (this.state.phase === Phases.Display && (label || labelClassName) && !this.value)) {\n            // show the label\n            editableEl = (\n                <div className={className + \" \" + labelClassName} onClick={this.onClickDiv}>\n                    {label || initialValue}\n                </div>\n            );\n        } else {\n            // show the content editable div, but manually manage its contents as react and contentEditable don't play nice together\n            editableEl = (\n                <div\n                    ref={this.editableDiv}\n                    contentEditable={true}\n                    className={className}\n                    onKeyDown={this.onKeyDown}\n                    onKeyUp={this.onKeyUp}\n                    onFocus={this.onFocus}\n                    onBlur={this.onBlur}\n                />\n            );\n        }\n\n        return editableEl;\n    }\n}\n"],"mappings":"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","ignoreList":[]}