UNPKG

matrix-react-sdk

Version:
161 lines (156 loc) 24.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; exports.tEmoji = tEmoji; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _sasEmoji = _interopRequireDefault(require("@matrix-org/spec/sas-emoji.json")); var _languageHandler = require("../../../languageHandler"); var _EncryptionInfo = require("../right_panel/EncryptionInfo"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _FontManager = require("../../../utils/FontManager"); /* Copyright 2024 New Vector Ltd. Copyright 2019 Vector Creations Ltd SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const SasEmojiMap = new Map(_sasEmoji.default.map(({ description, translated_descriptions: translations }) => [description.toLowerCase(), { description, // Normalize the translation keys translations: Object.keys(translations).reduce((o, k) => { for (const key of (0, _languageHandler.getNormalizedLanguageKeys)(k)) { o[key] = translations[k]; } return o; }, {}) }])); /** * Translate given EmojiMapping into the target locale * @param mapping - the given EmojiMapping to translate * @param locale - the BCP 47 locale to translate to, will fall back to English as the base locale for Matrix SAS Emoji. */ function tEmoji(mapping, locale) { const name = mapping[1]; const emoji = SasEmojiMap.get(name.toLowerCase()); if (!emoji) { console.warn("Emoji not found for translation", name); return name; } for (const key of (0, _languageHandler.getNormalizedLanguageKeys)(locale)) { if (!!emoji.translations[key]) { return emoji.translations[key]; } } return emoji.description; } class VerificationShowSas extends _react.default.Component { constructor(props) { super(props); (0, _defineProperty2.default)(this, "onMatchClick", () => { this.setState({ pending: true }); this.props.onDone(); }); (0, _defineProperty2.default)(this, "onDontMatchClick", () => { this.setState({ cancelling: true }); this.props.onCancel(); }); this.state = { pending: false }; // As this component is also used before login (during complete security), // also make sure we have a working emoji font to display the SAS emojis here. // This is also done from LoggedInView. (0, _FontManager.fixupColorFonts)(); } render() { const locale = (0, _languageHandler.getUserLanguage)(); let sasDisplay; let sasCaption; if (this.props.sas.emoji) { const emojiBlocks = this.props.sas.emoji.map((emoji, i) => /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_emojiSas_block", key: i }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_emojiSas_emoji" }, emoji[0]), /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_emojiSas_label" }, tEmoji(emoji, locale)))); sasDisplay = /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_emojiSas" }, emojiBlocks.slice(0, 4), /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_emojiSas_break" }), emojiBlocks.slice(4)); sasCaption = this.props.isSelf ? (0, _languageHandler._t)("encryption|verification|sas_emoji_caption_self") : (0, _languageHandler._t)("encryption|verification|sas_emoji_caption_user"); } else if (this.props.sas.decimal) { const numberBlocks = this.props.sas.decimal.map((num, i) => /*#__PURE__*/_react.default.createElement("span", { key: i }, num)); sasDisplay = /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_decimalSas" }, numberBlocks); sasCaption = this.props.isSelf ? (0, _languageHandler._t)("encryption|verification|sas_caption_self") : (0, _languageHandler._t)("encryption|verification|sas_caption_user"); } else { return /*#__PURE__*/_react.default.createElement("div", null, (0, _languageHandler._t)("encryption|verification|unsupported_method"), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { kind: "primary", onClick: this.props.onCancel }, (0, _languageHandler._t)("action|cancel"))); } let confirm; if (this.state.pending && this.props.isSelf) { let text; // device shouldn't be null in this situation but it can be, eg. if the device is // logged out during verification const otherDevice = this.props.otherDeviceDetails; if (otherDevice) { text = (0, _languageHandler._t)("encryption|verification|waiting_other_device_details", { deviceName: otherDevice.displayName, deviceId: otherDevice.deviceId }); } else { text = (0, _languageHandler._t)("encryption|verification|waiting_other_device"); } confirm = /*#__PURE__*/_react.default.createElement("p", null, text); } else if (this.state.pending || this.state.cancelling) { let text; if (this.state.pending) { const { displayName } = this.props; text = (0, _languageHandler._t)("encryption|verification|waiting_other_user", { displayName }); } else { text = (0, _languageHandler._t)("encryption|verification|cancelling"); } confirm = /*#__PURE__*/_react.default.createElement(_EncryptionInfo.PendingActionSpinner, { text: text }); } else { confirm = /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas_buttonRow" }, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onDontMatchClick, kind: "danger" }, (0, _languageHandler._t)("encryption|verification|sas_no_match")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { onClick: this.onMatchClick, kind: "primary" }, (0, _languageHandler._t)("encryption|verification|sas_match"))); } return /*#__PURE__*/_react.default.createElement("div", { className: "mx_VerificationShowSas" }, /*#__PURE__*/_react.default.createElement("p", null, sasCaption), sasDisplay, /*#__PURE__*/_react.default.createElement("p", null, this.props.isSelf ? "" : (0, _languageHandler._t)("encryption|verification|in_person")), confirm); } } exports.default = VerificationShowSas; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_sasEmoji","_languageHandler","_EncryptionInfo","_AccessibleButton","_FontManager","SasEmojiMap","Map","SasEmoji","map","description","translated_descriptions","translations","toLowerCase","Object","keys","reduce","o","k","key","getNormalizedLanguageKeys","tEmoji","mapping","locale","name","emoji","get","console","warn","VerificationShowSas","React","Component","constructor","props","_defineProperty2","default","setState","pending","onDone","cancelling","onCancel","state","fixupColorFonts","render","getUserLanguage","sasDisplay","sasCaption","sas","emojiBlocks","i","createElement","className","slice","isSelf","_t","decimal","numberBlocks","num","kind","onClick","confirm","text","otherDevice","otherDeviceDetails","deviceName","displayName","deviceId","PendingActionSpinner","onDontMatchClick","onMatchClick","exports"],"sources":["../../../../src/components/views/verification/VerificationShowSas.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 Vector Creations 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\";\nimport { Device } from \"matrix-js-sdk/src/matrix\";\nimport { GeneratedSas, EmojiMapping } from \"matrix-js-sdk/src/crypto-api\";\nimport SasEmoji from \"@matrix-org/spec/sas-emoji.json\";\n\nimport { _t, getNormalizedLanguageKeys, getUserLanguage } from \"../../../languageHandler\";\nimport { PendingActionSpinner } from \"../right_panel/EncryptionInfo\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { fixupColorFonts } from \"../../../utils/FontManager\";\n\ninterface IProps {\n    pending?: boolean;\n    displayName?: string; // required if pending is true\n\n    /** Details of the other device involved in the verification, if known */\n    otherDeviceDetails?: Device;\n\n    onDone: () => void;\n    onCancel: () => void;\n    sas: GeneratedSas;\n    isSelf?: boolean;\n    inDialog?: boolean; // whether this component is being shown in a dialog and to use DialogButtons\n}\n\ninterface IState {\n    pending: boolean;\n    cancelling?: boolean;\n}\n\nconst SasEmojiMap = new Map<\n    string, // lowercase\n    {\n        description: string;\n        translations: {\n            [normalizedLanguageKey: string]: string;\n        };\n    }\n>(\n    SasEmoji.map(({ description, translated_descriptions: translations }) => [\n        description.toLowerCase(),\n        {\n            description,\n            // Normalize the translation keys\n            translations: Object.keys(translations).reduce<Record<string, string>>((o, k) => {\n                for (const key of getNormalizedLanguageKeys(k)) {\n                    o[key] = translations[k as keyof typeof translations]!;\n                }\n                return o;\n            }, {}),\n        },\n    ]),\n);\n\n/**\n * Translate given EmojiMapping into the target locale\n * @param mapping - the given EmojiMapping to translate\n * @param locale - the BCP 47 locale to translate to, will fall back to English as the base locale for Matrix SAS Emoji.\n */\nexport function tEmoji(mapping: EmojiMapping, locale: string): string {\n    const name = mapping[1];\n    const emoji = SasEmojiMap.get(name.toLowerCase());\n    if (!emoji) {\n        console.warn(\"Emoji not found for translation\", name);\n        return name;\n    }\n\n    for (const key of getNormalizedLanguageKeys(locale)) {\n        if (!!emoji.translations[key]) {\n            return emoji.translations[key];\n        }\n    }\n\n    return emoji.description;\n}\n\nexport default class VerificationShowSas extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            pending: false,\n        };\n\n        // As this component is also used before login (during complete security),\n        // also make sure we have a working emoji font to display the SAS emojis here.\n        // This is also done from LoggedInView.\n        fixupColorFonts();\n    }\n\n    private onMatchClick = (): void => {\n        this.setState({ pending: true });\n        this.props.onDone();\n    };\n\n    private onDontMatchClick = (): void => {\n        this.setState({ cancelling: true });\n        this.props.onCancel();\n    };\n\n    public render(): React.ReactNode {\n        const locale = getUserLanguage();\n\n        let sasDisplay;\n        let sasCaption;\n        if (this.props.sas.emoji) {\n            const emojiBlocks = this.props.sas.emoji.map((emoji, i) => (\n                <div className=\"mx_VerificationShowSas_emojiSas_block\" key={i}>\n                    <div className=\"mx_VerificationShowSas_emojiSas_emoji\">{emoji[0]}</div>\n                    <div className=\"mx_VerificationShowSas_emojiSas_label\">{tEmoji(emoji, locale)}</div>\n                </div>\n            ));\n            sasDisplay = (\n                <div className=\"mx_VerificationShowSas_emojiSas\">\n                    {emojiBlocks.slice(0, 4)}\n                    <div className=\"mx_VerificationShowSas_emojiSas_break\" />\n                    {emojiBlocks.slice(4)}\n                </div>\n            );\n            sasCaption = this.props.isSelf\n                ? _t(\"encryption|verification|sas_emoji_caption_self\")\n                : _t(\"encryption|verification|sas_emoji_caption_user\");\n        } else if (this.props.sas.decimal) {\n            const numberBlocks = this.props.sas.decimal.map((num, i) => <span key={i}>{num}</span>);\n            sasDisplay = <div className=\"mx_VerificationShowSas_decimalSas\">{numberBlocks}</div>;\n            sasCaption = this.props.isSelf\n                ? _t(\"encryption|verification|sas_caption_self\")\n                : _t(\"encryption|verification|sas_caption_user\");\n        } else {\n            return (\n                <div>\n                    {_t(\"encryption|verification|unsupported_method\")}\n                    <AccessibleButton kind=\"primary\" onClick={this.props.onCancel}>\n                        {_t(\"action|cancel\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        let confirm;\n        if (this.state.pending && this.props.isSelf) {\n            let text;\n            // device shouldn't be null in this situation but it can be, eg. if the device is\n            // logged out during verification\n            const otherDevice = this.props.otherDeviceDetails;\n            if (otherDevice) {\n                text = _t(\"encryption|verification|waiting_other_device_details\", {\n                    deviceName: otherDevice.displayName,\n                    deviceId: otherDevice.deviceId,\n                });\n            } else {\n                text = _t(\"encryption|verification|waiting_other_device\");\n            }\n            confirm = <p>{text}</p>;\n        } else if (this.state.pending || this.state.cancelling) {\n            let text;\n            if (this.state.pending) {\n                const { displayName } = this.props;\n                text = _t(\"encryption|verification|waiting_other_user\", { displayName });\n            } else {\n                text = _t(\"encryption|verification|cancelling\");\n            }\n            confirm = <PendingActionSpinner text={text} />;\n        } else {\n            confirm = (\n                <div className=\"mx_VerificationShowSas_buttonRow\">\n                    <AccessibleButton onClick={this.onDontMatchClick} kind=\"danger\">\n                        {_t(\"encryption|verification|sas_no_match\")}\n                    </AccessibleButton>\n                    <AccessibleButton onClick={this.onMatchClick} kind=\"primary\">\n                        {_t(\"encryption|verification|sas_match\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        return (\n            <div className=\"mx_VerificationShowSas\">\n                <p>{sasCaption}</p>\n                {sasDisplay}\n                <p>{this.props.isSelf ? \"\" : _t(\"encryption|verification|in_person\")}</p>\n                {confirm}\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}