matrix-react-sdk
Version:
SDK for matrix.org using React
117 lines (114 loc) • 13.2 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 = _interopRequireDefault(require("react"));
var _Spinner = _interopRequireDefault(require("./Spinner"));
var _EditableText = _interopRequireDefault(require("./EditableText"));
/*
Copyright 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.
*/
/**
* A component which wraps an EditableText, with a spinner while updates take
* place.
*
* Parent components should supply an 'onSubmit' callback which returns a
* promise; a spinner is shown until the promise resolves.
*
* The parent can also supply a 'getInitialValue' callback, which works in a
* similarly asynchronous way. If this is not provided, the initial value is
* taken from the 'initialValue' property.
*/
class EditableTextContainer extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "unmounted", false);
(0, _defineProperty2.default)(this, "onValueChanged", (value, shouldSubmit) => {
if (!shouldSubmit) {
return;
}
this.setState({
busy: true,
errorString: null
});
this.props.onSubmit(value).then(() => {
if (this.unmounted) {
return;
}
this.setState({
busy: false,
value: value
});
}, error => {
if (this.unmounted) {
return;
}
this.setState({
errorString: error.toString(),
busy: false
});
});
});
this.state = {
busy: false,
errorString: null,
value: props.initialValue ?? ""
};
}
async componentDidMount() {
// use whatever was given in the initialValue property.
if (this.props.getInitialValue === undefined) return;
this.setState({
busy: true
});
try {
const initialValue = await this.props.getInitialValue();
if (this.unmounted) return;
this.setState({
busy: false,
value: initialValue
});
} catch (error) {
if (this.unmounted) return;
this.setState({
errorString: error instanceof Error ? error.message : String(error),
busy: false
});
}
}
componentWillUnmount() {
this.unmounted = true;
}
render() {
if (this.state.busy) {
return /*#__PURE__*/_react.default.createElement(_Spinner.default, null);
} else if (this.state.errorString) {
return /*#__PURE__*/_react.default.createElement("div", {
className: "error"
}, this.state.errorString);
} else {
return /*#__PURE__*/_react.default.createElement(_EditableText.default, {
initialValue: this.state.value,
placeholder: this.props.placeholder,
onValueChanged: this.onValueChanged,
blurToSubmit: this.props.blurToSubmit
});
}
}
}
exports.default = EditableTextContainer;
(0, _defineProperty2.default)(EditableTextContainer, "defaultProps", {
initialValue: "",
placeholder: "",
blurToSubmit: false,
onSubmit: () => {
return Promise.resolve();
}
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_Spinner","_EditableText","EditableTextContainer","React","Component","constructor","props","_defineProperty2","default","value","shouldSubmit","setState","busy","errorString","onSubmit","then","unmounted","error","toString","state","initialValue","componentDidMount","getInitialValue","undefined","Error","message","String","componentWillUnmount","render","createElement","className","placeholder","onValueChanged","blurToSubmit","exports","Promise","resolve"],"sources":["../../../../src/components/views/elements/EditableTextContainer.tsx"],"sourcesContent":["/*\nCopyright 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 from \"react\";\n\nimport Spinner from \"./Spinner\";\nimport EditableText from \"./EditableText\";\n\ninterface IProps {\n    /* callback to retrieve the initial value. */\n    getInitialValue?: () => Promise<string>;\n\n    /* initial value; used if getInitialValue is not given */\n    initialValue?: string;\n\n    /* placeholder text to use when the value is empty (and not being\n     * edited) */\n    placeholder?: string;\n\n    /* callback to update the value. Called with a single argument: the new\n     * value. */\n    onSubmit: (value: string) => Promise<{} | void>;\n\n    /* should the input submit when focus is lost? */\n    blurToSubmit?: boolean;\n}\n\ninterface IState {\n    busy: boolean;\n    errorString: string | null;\n    value: string;\n}\n\n/**\n * A component which wraps an EditableText, with a spinner while updates take\n * place.\n *\n * Parent components should supply an 'onSubmit' callback which returns a\n * promise; a spinner is shown until the promise resolves.\n *\n * The parent can also supply a 'getInitialValue' callback, which works in a\n * similarly asynchronous way. If this is not provided, the initial value is\n * taken from the 'initialValue' property.\n */\nexport default class EditableTextContainer extends React.Component<IProps, IState> {\n    private unmounted = false;\n    public static defaultProps: Partial<IProps> = {\n        initialValue: \"\",\n        placeholder: \"\",\n        blurToSubmit: false,\n        onSubmit: () => {\n            return Promise.resolve();\n        },\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            busy: false,\n            errorString: null,\n            value: props.initialValue ?? \"\",\n        };\n    }\n\n    public async componentDidMount(): Promise<void> {\n        // use whatever was given in the initialValue property.\n        if (this.props.getInitialValue === undefined) return;\n\n        this.setState({ busy: true });\n        try {\n            const initialValue = await this.props.getInitialValue();\n            if (this.unmounted) return;\n            this.setState({\n                busy: false,\n                value: initialValue,\n            });\n        } catch (error) {\n            if (this.unmounted) return;\n            this.setState({\n                errorString: error instanceof Error ? error.message : String(error),\n                busy: false,\n            });\n        }\n    }\n\n    public componentWillUnmount(): void {\n        this.unmounted = true;\n    }\n\n    private onValueChanged = (value: string, shouldSubmit: boolean): void => {\n        if (!shouldSubmit) {\n            return;\n        }\n\n        this.setState({\n            busy: true,\n            errorString: null,\n        });\n\n        this.props.onSubmit(value).then(\n            () => {\n                if (this.unmounted) {\n                    return;\n                }\n                this.setState({\n                    busy: false,\n                    value: value,\n                });\n            },\n            (error) => {\n                if (this.unmounted) {\n                    return;\n                }\n                this.setState({\n                    errorString: error.toString(),\n                    busy: false,\n                });\n            },\n        );\n    };\n\n    public render(): React.ReactNode {\n        if (this.state.busy) {\n            return <Spinner />;\n        } else if (this.state.errorString) {\n            return <div className=\"error\">{this.state.errorString}</div>;\n        } else {\n            return (\n                <EditableText\n                    initialValue={this.state.value}\n                    placeholder={this.props.placeholder}\n                    onValueChanged={this.onValueChanged}\n                    blurToSubmit={this.props.blurToSubmit}\n                />\n            );\n        }\n    }\n}\n"],"mappings":"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","ignoreList":[]}