matrix-react-sdk
Version:
SDK for matrix.org using React
117 lines (114 loc) • 17.2 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 = _interopRequireDefault(require("react"));
var _languageHandler = require("../../../languageHandler");
var _SetupEncryptionStore = require("../../../stores/SetupEncryptionStore");
var _SetupEncryptionBody = _interopRequireDefault(require("./SetupEncryptionBody"));
var _AccessibleButton = _interopRequireDefault(require("../../views/elements/AccessibleButton"));
var _CompleteSecurityBody = _interopRequireDefault(require("../../views/auth/CompleteSecurityBody"));
var _AuthPage = _interopRequireDefault(require("../../views/auth/AuthPage"));
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
/*
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 CompleteSecurity extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onStoreUpdate", () => {
const store = _SetupEncryptionStore.SetupEncryptionStore.sharedInstance();
this.setState({
phase: store.phase,
lostKeys: store.lostKeys()
});
});
(0, _defineProperty2.default)(this, "onSkipClick", () => {
const store = _SetupEncryptionStore.SetupEncryptionStore.sharedInstance();
store.skip();
});
const _store = _SetupEncryptionStore.SetupEncryptionStore.sharedInstance();
_store.on("update", this.onStoreUpdate);
_store.start();
this.state = {
phase: _store.phase,
lostKeys: _store.lostKeys()
};
}
componentWillUnmount() {
const store = _SetupEncryptionStore.SetupEncryptionStore.sharedInstance();
store.off("update", this.onStoreUpdate);
store.stop();
}
render() {
const {
phase,
lostKeys
} = this.state;
let icon;
let title;
if (phase === _SetupEncryptionStore.Phase.Loading) {
return null;
} else if (phase === _SetupEncryptionStore.Phase.Intro) {
if (lostKeys) {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_warning"
});
title = (0, _languageHandler._t)("encryption|verification|after_new_login|unable_to_verify");
} else {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_warning"
});
title = (0, _languageHandler._t)("encryption|verification|after_new_login|verify_this_device");
}
} else if (phase === _SetupEncryptionStore.Phase.Done) {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_verified"
});
title = (0, _languageHandler._t)("encryption|verification|after_new_login|device_verified");
} else if (phase === _SetupEncryptionStore.Phase.ConfirmSkip) {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_warning"
});
title = (0, _languageHandler._t)("common|are_you_sure");
} else if (phase === _SetupEncryptionStore.Phase.Busy) {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_warning"
});
title = (0, _languageHandler._t)("encryption|verification|after_new_login|verify_this_device");
} else if (phase === _SetupEncryptionStore.Phase.ConfirmReset) {
icon = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CompleteSecurity_headerIcon mx_E2EIcon_warning"
});
title = (0, _languageHandler._t)("encryption|verification|after_new_login|reset_confirmation");
} else if (phase === _SetupEncryptionStore.Phase.Finished) {
// SetupEncryptionBody will take care of calling onFinished, we don't need to do anything
} else {
throw new Error(`Unknown phase ${phase}`);
}
const forceVerification = _SdkConfig.default.get("force_verification");
let skipButton;
if (!forceVerification && (phase === _SetupEncryptionStore.Phase.Intro || phase === _SetupEncryptionStore.Phase.ConfirmReset)) {
skipButton = /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onSkipClick,
className: "mx_CompleteSecurity_skip",
"aria-label": (0, _languageHandler._t)("encryption|verification|after_new_login|skip_verification")
});
}
return /*#__PURE__*/_react.default.createElement(_AuthPage.default, null, /*#__PURE__*/_react.default.createElement(_CompleteSecurityBody.default, null, /*#__PURE__*/_react.default.createElement("h1", {
className: "mx_CompleteSecurity_header"
}, icon, title, skipButton), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CompleteSecurity_body"
}, /*#__PURE__*/_react.default.createElement(_SetupEncryptionBody.default, {
onFinished: this.props.onFinished
}))));
}
}
exports.default = CompleteSecurity;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_SetupEncryptionStore","_SetupEncryptionBody","_AccessibleButton","_CompleteSecurityBody","_AuthPage","_SdkConfig","CompleteSecurity","React","Component","constructor","props","_defineProperty2","default","store","SetupEncryptionStore","sharedInstance","setState","phase","lostKeys","skip","on","onStoreUpdate","start","state","componentWillUnmount","off","stop","render","icon","title","Phase","Loading","Intro","createElement","className","_t","Done","ConfirmSkip","Busy","ConfirmReset","Finished","Error","forceVerification","SdkConfig","get","skipButton","onClick","onSkipClick","onFinished","exports"],"sources":["../../../../src/components/structures/auth/CompleteSecurity.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 from \"react\";\n\nimport { _t } from \"../../../languageHandler\";\nimport { SetupEncryptionStore, Phase } from \"../../../stores/SetupEncryptionStore\";\nimport SetupEncryptionBody from \"./SetupEncryptionBody\";\nimport AccessibleButton from \"../../views/elements/AccessibleButton\";\nimport CompleteSecurityBody from \"../../views/auth/CompleteSecurityBody\";\nimport AuthPage from \"../../views/auth/AuthPage\";\nimport SdkConfig from \"../../../SdkConfig\";\n\ninterface IProps {\n    onFinished: () => void;\n}\n\ninterface IState {\n    phase?: Phase;\n    lostKeys: boolean;\n}\n\nexport default class CompleteSecurity extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n        const store = SetupEncryptionStore.sharedInstance();\n        store.on(\"update\", this.onStoreUpdate);\n        store.start();\n        this.state = { phase: store.phase, lostKeys: store.lostKeys() };\n    }\n\n    private onStoreUpdate = (): void => {\n        const store = SetupEncryptionStore.sharedInstance();\n        this.setState({ phase: store.phase, lostKeys: store.lostKeys() });\n    };\n\n    private onSkipClick = (): void => {\n        const store = SetupEncryptionStore.sharedInstance();\n        store.skip();\n    };\n\n    public componentWillUnmount(): void {\n        const store = SetupEncryptionStore.sharedInstance();\n        store.off(\"update\", this.onStoreUpdate);\n        store.stop();\n    }\n\n    public render(): React.ReactNode {\n        const { phase, lostKeys } = this.state;\n        let icon;\n        let title;\n\n        if (phase === Phase.Loading) {\n            return null;\n        } else if (phase === Phase.Intro) {\n            if (lostKeys) {\n                icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_warning\" />;\n                title = _t(\"encryption|verification|after_new_login|unable_to_verify\");\n            } else {\n                icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_warning\" />;\n                title = _t(\"encryption|verification|after_new_login|verify_this_device\");\n            }\n        } else if (phase === Phase.Done) {\n            icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_verified\" />;\n            title = _t(\"encryption|verification|after_new_login|device_verified\");\n        } else if (phase === Phase.ConfirmSkip) {\n            icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_warning\" />;\n            title = _t(\"common|are_you_sure\");\n        } else if (phase === Phase.Busy) {\n            icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_warning\" />;\n            title = _t(\"encryption|verification|after_new_login|verify_this_device\");\n        } else if (phase === Phase.ConfirmReset) {\n            icon = <span className=\"mx_CompleteSecurity_headerIcon mx_E2EIcon_warning\" />;\n            title = _t(\"encryption|verification|after_new_login|reset_confirmation\");\n        } else if (phase === Phase.Finished) {\n            // SetupEncryptionBody will take care of calling onFinished, we don't need to do anything\n        } else {\n            throw new Error(`Unknown phase ${phase}`);\n        }\n\n        const forceVerification = SdkConfig.get(\"force_verification\");\n\n        let skipButton;\n        if (!forceVerification && (phase === Phase.Intro || phase === Phase.ConfirmReset)) {\n            skipButton = (\n                <AccessibleButton\n                    onClick={this.onSkipClick}\n                    className=\"mx_CompleteSecurity_skip\"\n                    aria-label={_t(\"encryption|verification|after_new_login|skip_verification\")}\n                />\n            );\n        }\n\n        return (\n            <AuthPage>\n                <CompleteSecurityBody>\n                    <h1 className=\"mx_CompleteSecurity_header\">\n                        {icon}\n                        {title}\n                        {skipButton}\n                    </h1>\n                    <div className=\"mx_CompleteSecurity_body\">\n                        <SetupEncryptionBody onFinished={this.props.onFinished} />\n                    </div>\n                </CompleteSecurityBody>\n            </AuthPage>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}