matrix-react-sdk
Version:
SDK for matrix.org using React
120 lines (117 loc) • 18.3 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 _Field = _interopRequireDefault(require("../elements/Field"));
var _languageHandler = require("../../../languageHandler");
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons"));
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 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.
*/
class TextInputDialog extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "field", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "onOk", async ev => {
ev.preventDefault();
if (!this.field.current) return;
if (this.props.validator) {
this.setState({
busy: true
});
await this.field.current.validate({
allowEmpty: false
});
if (!this.field.current.state.valid) {
this.field.current.focus();
this.field.current.validate({
allowEmpty: false,
focused: true
});
this.setState({
busy: false
});
return;
}
}
this.props.onFinished(true, this.state.value);
});
(0, _defineProperty2.default)(this, "onCancel", () => {
this.props.onFinished(false);
});
(0, _defineProperty2.default)(this, "onChange", ev => {
this.setState({
value: ev.target.value
});
});
(0, _defineProperty2.default)(this, "onValidate", async fieldState => {
const result = await this.props.validator(fieldState);
this.setState({
valid: !!result.valid
});
return result;
});
this.state = {
value: this.props.value,
busy: false,
valid: false
};
}
componentDidMount() {
if (this.props.focus) {
// Set the cursor at the end of the text input
// this._field.current.value = this.props.value;
this.field.current?.focus();
}
}
render() {
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
className: "mx_TextInputDialog",
onFinished: this.props.onFinished,
title: this.props.title,
fixedWidth: this.props.fixedWidth
}, /*#__PURE__*/_react.default.createElement("form", {
onSubmit: this.onOk
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dialog_content"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_TextInputDialog_label"
}, /*#__PURE__*/_react.default.createElement("label", {
htmlFor: "textinput"
}, " ", this.props.description, " ")), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Field.default, {
className: "mx_TextInputDialog_input",
ref: this.field,
type: "text",
label: this.props.placeholder,
value: this.state.value,
onChange: this.onChange,
onValidate: this.props.validator ? this.onValidate : undefined
})))), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
primaryButton: this.state.busy ? (0, _languageHandler._t)(this.props.busyMessage) : this.props.button,
disabled: this.state.busy,
onPrimaryButtonClick: this.onOk,
onCancel: this.onCancel,
hasCancel: this.props.hasCancel
}));
}
}
exports.default = TextInputDialog;
(0, _defineProperty2.default)(TextInputDialog, "defaultProps", {
title: "",
value: "",
description: "",
busyMessage: (0, _languageHandler._td)("common|loading"),
focus: true,
hasCancel: true
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Field","_interopRequireDefault","_languageHandler","_BaseDialog","_DialogButtons","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","TextInputDialog","React","Component","constructor","props","_defineProperty2","createRef","ev","preventDefault","field","current","validator","setState","busy","validate","allowEmpty","state","valid","focus","focused","onFinished","value","target","fieldState","result","componentDidMount","render","createElement","className","title","fixedWidth","onSubmit","onOk","htmlFor","description","ref","type","label","placeholder","onChange","onValidate","undefined","primaryButton","_t","busyMessage","button","disabled","onPrimaryButtonClick","onCancel","hasCancel","exports","_td"],"sources":["../../../../src/components/views/dialogs/TextInputDialog.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, { ChangeEvent, createRef } from \"react\";\n\nimport Field from \"../elements/Field\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\nimport { IFieldState, IValidationResult } from \"../elements/Validation\";\nimport BaseDialog from \"./BaseDialog\";\nimport DialogButtons from \"../elements/DialogButtons\";\n\ninterface IProps {\n    title: string;\n    description: React.ReactNode;\n    value: string;\n    placeholder?: string;\n    button?: string;\n    busyMessage: TranslationKey;\n    focus: boolean;\n    hasCancel: boolean;\n    validator?: (fieldState: IFieldState) => Promise<IValidationResult>; // result of withValidation\n    fixedWidth?: boolean;\n    onFinished(ok?: false, text?: void): void;\n    onFinished(ok: true, text: string): void;\n}\n\ninterface IState {\n    value: string;\n    busy: boolean;\n    valid: boolean;\n}\n\nexport default class TextInputDialog extends React.Component<IProps, IState> {\n    private field = createRef<Field>();\n\n    public static defaultProps: Partial<IProps> = {\n        title: \"\",\n        value: \"\",\n        description: \"\",\n        busyMessage: _td(\"common|loading\"),\n        focus: true,\n        hasCancel: true,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            value: this.props.value,\n            busy: false,\n            valid: false,\n        };\n    }\n\n    public componentDidMount(): void {\n        if (this.props.focus) {\n            // Set the cursor at the end of the text input\n            // this._field.current.value = this.props.value;\n            this.field.current?.focus();\n        }\n    }\n\n    private onOk = async (ev: React.FormEvent): Promise<void> => {\n        ev.preventDefault();\n        if (!this.field.current) return;\n        if (this.props.validator) {\n            this.setState({ busy: true });\n            await this.field.current.validate({ allowEmpty: false });\n\n            if (!this.field.current.state.valid) {\n                this.field.current.focus();\n                this.field.current.validate({ allowEmpty: false, focused: true });\n                this.setState({ busy: false });\n                return;\n            }\n        }\n        this.props.onFinished(true, this.state.value);\n    };\n\n    private onCancel = (): void => {\n        this.props.onFinished(false);\n    };\n\n    private onChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({\n            value: ev.target.value,\n        });\n    };\n\n    private onValidate = async (fieldState: IFieldState): Promise<IValidationResult> => {\n        const result = await this.props.validator!(fieldState);\n        this.setState({\n            valid: !!result.valid,\n        });\n        return result;\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <BaseDialog\n                className=\"mx_TextInputDialog\"\n                onFinished={this.props.onFinished}\n                title={this.props.title}\n                fixedWidth={this.props.fixedWidth}\n            >\n                <form onSubmit={this.onOk}>\n                    <div className=\"mx_Dialog_content\">\n                        <div className=\"mx_TextInputDialog_label\">\n                            <label htmlFor=\"textinput\"> {this.props.description} </label>\n                        </div>\n                        <div>\n                            <Field\n                                className=\"mx_TextInputDialog_input\"\n                                ref={this.field}\n                                type=\"text\"\n                                label={this.props.placeholder}\n                                value={this.state.value}\n                                onChange={this.onChange}\n                                onValidate={this.props.validator ? this.onValidate : undefined}\n                            />\n                        </div>\n                    </div>\n                </form>\n                <DialogButtons\n                    primaryButton={this.state.busy ? _t(this.props.busyMessage) : this.props.button}\n                    disabled={this.state.busy}\n                    onPrimaryButtonClick={this.onOk}\n                    onCancel={this.onCancel}\n                    hasCancel={this.props.hasCancel}\n                />\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}