UNPKG

matrix-react-sdk

Version:
186 lines (184 loc) 27.1 kB
"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":[]}