matrix-react-sdk
Version:
SDK for matrix.org using React
121 lines (115 loc) • 18.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 _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _Field = _interopRequireDefault(require("../elements/Field"));
var _DialPad = _interopRequireDefault(require("./DialPad"));
var _DialPadBackspaceButton = _interopRequireDefault(require("../elements/DialPadBackspaceButton"));
var _LegacyCallHandler = _interopRequireDefault(require("../../../LegacyCallHandler"));
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 2020 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class DialpadModal extends _react.default.PureComponent {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "numberEntryFieldRef", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "onCancelClick", () => {
this.props.onFinished(false);
});
(0, _defineProperty2.default)(this, "onChange", ev => {
this.setState({
value: ev.target.value
});
});
(0, _defineProperty2.default)(this, "onFormSubmit", ev => {
ev.preventDefault();
this.onDialPress();
});
(0, _defineProperty2.default)(this, "onDigitPress", (digit, ev) => {
this.setState({
value: this.state.value + digit
});
// Keep the number field focused so that keyboard entry is still available.
// However, don't focus if this wasn't the result of directly clicking on the button,
// i.e someone using keyboard navigation.
if (ev.type === "click") {
this.numberEntryFieldRef.current?.focus();
}
});
(0, _defineProperty2.default)(this, "onDeletePress", ev => {
if (this.state.value.length === 0) return;
this.setState({
value: this.state.value.slice(0, -1)
});
// Keep the number field focused so that keyboard entry is still available
// However, don't focus if this wasn't the result of directly clicking on the button,
// i.e someone using keyboard navigation.
if (ev.type === "click") {
this.numberEntryFieldRef.current?.focus();
}
});
(0, _defineProperty2.default)(this, "onDialPress", async () => {
_LegacyCallHandler.default.instance.dialNumber(this.state.value);
this.props.onFinished(true);
});
this.state = {
value: ""
};
}
render() {
const backspaceButton = /*#__PURE__*/_react.default.createElement(_DialPadBackspaceButton.default, {
onBackspacePress: this.onDeletePress
});
// Only show the backspace button if the field has content
let dialPadField;
if (this.state.value.length !== 0) {
dialPadField = /*#__PURE__*/_react.default.createElement(_Field.default, {
ref: this.numberEntryFieldRef,
className: "mx_DialPadModal_field",
id: "dialpad_number",
value: this.state.value,
autoFocus: true,
onChange: this.onChange,
postfixComponent: backspaceButton
});
} else {
dialPadField = /*#__PURE__*/_react.default.createElement(_Field.default, {
ref: this.numberEntryFieldRef,
className: "mx_DialPadModal_field",
id: "dialpad_number",
value: this.state.value,
autoFocus: true,
onChange: this.onChange
});
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_DialPadModal"
}, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: "mx_DialPadModal_cancel",
onClick: this.onCancelClick
})), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_DialPadModal_header"
}, /*#__PURE__*/_react.default.createElement("form", {
onSubmit: this.onFormSubmit
}, dialPadField)), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_DialPadModal_dialPad"
}, /*#__PURE__*/_react.default.createElement(_DialPad.default, {
hasDial: true,
onDigitPress: this.onDigitPress,
onDeletePress: this.onDeletePress,
onDialPress: this.onDialPress
})));
}
}
exports.default = DialpadModal;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_AccessibleButton","_interopRequireDefault","_Field","_DialPad","_DialPadBackspaceButton","_LegacyCallHandler","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DialpadModal","React","PureComponent","constructor","props","_defineProperty2","createRef","onFinished","ev","setState","value","target","preventDefault","onDialPress","digit","state","type","numberEntryFieldRef","current","focus","length","slice","LegacyCallHandler","instance","dialNumber","render","backspaceButton","createElement","onBackspacePress","onDeletePress","dialPadField","ref","className","id","autoFocus","onChange","postfixComponent","onClick","onCancelClick","onSubmit","onFormSubmit","hasDial","onDigitPress","exports"],"sources":["../../../../src/components/views/voip/DialPadModal.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 The Matrix.org Foundation C.I.C.\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, SyntheticEvent } from \"react\";\n\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\nimport Field from \"../elements/Field\";\nimport DialPad from \"./DialPad\";\nimport DialPadBackspaceButton from \"../elements/DialPadBackspaceButton\";\nimport LegacyCallHandler from \"../../../LegacyCallHandler\";\n\ninterface IProps {\n    onFinished: (dialled: boolean) => void;\n}\n\ninterface IState {\n    value: string;\n}\n\nexport default class DialpadModal extends React.PureComponent<IProps, IState> {\n    private numberEntryFieldRef: React.RefObject<Field> = createRef();\n\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            value: \"\",\n        };\n    }\n\n    public onCancelClick = (): void => {\n        this.props.onFinished(false);\n    };\n\n    public onChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ value: ev.target.value });\n    };\n\n    public onFormSubmit = (ev: SyntheticEvent): void => {\n        ev.preventDefault();\n        this.onDialPress();\n    };\n\n    public onDigitPress = (digit: string, ev: ButtonEvent): void => {\n        this.setState({ value: this.state.value + digit });\n\n        // Keep the number field focused so that keyboard entry is still available.\n        // However, don't focus if this wasn't the result of directly clicking on the button,\n        // i.e someone using keyboard navigation.\n        if (ev.type === \"click\") {\n            this.numberEntryFieldRef.current?.focus();\n        }\n    };\n\n    public onDeletePress = (ev: ButtonEvent): void => {\n        if (this.state.value.length === 0) return;\n        this.setState({ value: this.state.value.slice(0, -1) });\n\n        // Keep the number field focused so that keyboard entry is still available\n        // However, don't focus if this wasn't the result of directly clicking on the button,\n        // i.e someone using keyboard navigation.\n        if (ev.type === \"click\") {\n            this.numberEntryFieldRef.current?.focus();\n        }\n    };\n\n    public onDialPress = async (): Promise<void> => {\n        LegacyCallHandler.instance.dialNumber(this.state.value);\n        this.props.onFinished(true);\n    };\n\n    public render(): React.ReactNode {\n        const backspaceButton = <DialPadBackspaceButton onBackspacePress={this.onDeletePress} />;\n\n        // Only show the backspace button if the field has content\n        let dialPadField;\n        if (this.state.value.length !== 0) {\n            dialPadField = (\n                <Field\n                    ref={this.numberEntryFieldRef}\n                    className=\"mx_DialPadModal_field\"\n                    id=\"dialpad_number\"\n                    value={this.state.value}\n                    autoFocus={true}\n                    onChange={this.onChange}\n                    postfixComponent={backspaceButton}\n                />\n            );\n        } else {\n            dialPadField = (\n                <Field\n                    ref={this.numberEntryFieldRef}\n                    className=\"mx_DialPadModal_field\"\n                    id=\"dialpad_number\"\n                    value={this.state.value}\n                    autoFocus={true}\n                    onChange={this.onChange}\n                />\n            );\n        }\n\n        return (\n            <div className=\"mx_DialPadModal\">\n                <div>\n                    <AccessibleButton className=\"mx_DialPadModal_cancel\" onClick={this.onCancelClick} />\n                </div>\n                <div className=\"mx_DialPadModal_header\">\n                    <form onSubmit={this.onFormSubmit}>{dialPadField}</form>\n                </div>\n                <div className=\"mx_DialPadModal_dialPad\">\n                    <DialPad\n                        hasDial={true}\n                        onDigitPress={this.onDigitPress}\n                        onDeletePress={this.onDeletePress}\n                        onDialPress={this.onDialPress}\n                    />\n                </div>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}