matrix-react-sdk
Version:
SDK for matrix.org using React
84 lines (80 loc) • 13.3 kB
JavaScript
;
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 React = _react;
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _ContextMenu = _interopRequireDefault(require("../../structures/ContextMenu"));
var _Field = _interopRequireDefault(require("../elements/Field"));
var _DialPad = _interopRequireDefault(require("../voip/DialPad"));
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 2021 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 DialpadContextMenu extends React.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "numberEntryFieldRef", /*#__PURE__*/(0, _react.createRef)());
(0, _defineProperty2.default)(this, "onDigitPress", (digit, ev) => {
this.props.call.sendDtmfDigit(digit);
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, "onCancelClick", () => {
this.props.onFinished();
});
(0, _defineProperty2.default)(this, "onKeyDown", ev => {
// Prevent Backspace and Delete keys from functioning in the entry field
if (ev.code === "Backspace" || ev.code === "Delete") {
ev.preventDefault();
}
});
(0, _defineProperty2.default)(this, "onChange", ev => {
this.setState({
value: ev.target.value
});
});
this.state = {
value: ""
};
}
render() {
return /*#__PURE__*/React.createElement(_ContextMenu.default, this.props, /*#__PURE__*/React.createElement("div", {
className: "mx_DialPadContextMenuWrapper"
}, /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(_AccessibleButton.default, {
className: "mx_DialPadContextMenu_cancel",
onClick: this.onCancelClick
})), /*#__PURE__*/React.createElement("div", {
className: "mx_DialPadContextMenu_header"
}, /*#__PURE__*/React.createElement(_Field.default, {
ref: this.numberEntryFieldRef,
className: "mx_DialPadContextMenu_dialled",
value: this.state.value,
autoFocus: true,
onKeyDown: this.onKeyDown,
onChange: this.onChange
})), /*#__PURE__*/React.createElement("div", {
className: "mx_DialPadContextMenu_dialPad"
}, /*#__PURE__*/React.createElement(_DialPad.default, {
onDigitPress: this.onDigitPress,
hasDial: false
}))));
}
}
exports.default = DialpadContextMenu;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","React","_AccessibleButton","_interopRequireDefault","_ContextMenu","_Field","_DialPad","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DialpadContextMenu","Component","constructor","props","_defineProperty2","createRef","digit","ev","sendDtmfDigit","setState","value","state","type","numberEntryFieldRef","current","focus","onFinished","code","preventDefault","target","render","createElement","className","onClick","onCancelClick","ref","autoFocus","onKeyDown","onChange","onDigitPress","hasDial","exports"],"sources":["../../../../src/components/views/context_menus/DialpadContextMenu.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 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 * as React from \"react\";\nimport { createRef } from \"react\";\nimport { MatrixCall } from \"matrix-js-sdk/src/webrtc/call\";\n\nimport AccessibleButton, { ButtonEvent } from \"../elements/AccessibleButton\";\nimport ContextMenu, { IProps as IContextMenuProps } from \"../../structures/ContextMenu\";\nimport Field from \"../elements/Field\";\nimport DialPad from \"../voip/DialPad\";\n\ninterface IProps extends IContextMenuProps {\n    call: MatrixCall;\n}\n\ninterface IState {\n    value: string;\n}\n\nexport default class DialpadContextMenu extends React.Component<IProps, IState> {\n    private numberEntryFieldRef: React.RefObject<Field> = createRef();\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            value: \"\",\n        };\n    }\n\n    public onDigitPress = (digit: string, ev: ButtonEvent): void => {\n        this.props.call.sendDtmfDigit(digit);\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 onCancelClick = (): void => {\n        this.props.onFinished();\n    };\n\n    public onKeyDown = (ev: React.KeyboardEvent): void => {\n        // Prevent Backspace and Delete keys from functioning in the entry field\n        if (ev.code === \"Backspace\" || ev.code === \"Delete\") {\n            ev.preventDefault();\n        }\n    };\n\n    public onChange = (ev: React.ChangeEvent<HTMLInputElement>): void => {\n        this.setState({ value: ev.target.value });\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <ContextMenu {...this.props}>\n                <div className=\"mx_DialPadContextMenuWrapper\">\n                    <div>\n                        <AccessibleButton className=\"mx_DialPadContextMenu_cancel\" onClick={this.onCancelClick} />\n                    </div>\n                    <div className=\"mx_DialPadContextMenu_header\">\n                        <Field\n                            ref={this.numberEntryFieldRef}\n                            className=\"mx_DialPadContextMenu_dialled\"\n                            value={this.state.value}\n                            autoFocus={true}\n                            onKeyDown={this.onKeyDown}\n                            onChange={this.onChange}\n                        />\n                    </div>\n                    <div className=\"mx_DialPadContextMenu_dialPad\">\n                        <DialPad onDigitPress={this.onDigitPress} hasDial={false} />\n                    </div>\n                </div>\n            </ContextMenu>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}