UNPKG

matrix-react-sdk

Version:
102 lines (99 loc) 14.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _languageHandler = require("../../../languageHandler"); var _QuestionDialog = _interopRequireDefault(require("./QuestionDialog")); var _Spinner = _interopRequireDefault(require("../elements/Spinner")); var _Heading = _interopRequireDefault(require("../typography/Heading")); /* Copyright 2024 New Vector Ltd. Copyright 2019 Michael Telatynski <7t3chguy@gmail.com> Copyright 2016 Aviral Dasgupta SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ const REPOS = ["element-hq/element-web", "element-hq/matrix-react-sdk", "matrix-org/matrix-js-sdk"]; class ChangelogDialog extends _react.default.Component { constructor(props) { super(props); this.state = {}; } async fetchChanges(repo, oldVersion, newVersion) { const url = `https://riot.im/github/repos/${repo}/compare/${oldVersion}...${newVersion}`; try { const res = await fetch(url); if (!res.ok) { this.setState({ [repo]: res.statusText }); return; } const body = await res.json(); this.setState({ [repo]: body.commits }); } catch (err) { this.setState({ [repo]: err instanceof Error ? err.message : (0, _languageHandler._t)("error|unknown") }); } } componentDidMount() { const version = this.props.newVersion.split("-"); const version2 = this.props.version.split("-"); if (version == null || version2 == null) return; // parse versions of form: [vectorversion]-react-[react-sdk-version]-js-[js-sdk-version] for (let i = 0; i < REPOS.length; i++) { const oldVersion = version2[2 * i]; const newVersion = version[2 * i]; this.fetchChanges(REPOS[i], oldVersion, newVersion); } } elementsForCommit(commit) { return /*#__PURE__*/_react.default.createElement("li", { key: commit.sha, className: "mx_ChangelogDialog_li" }, /*#__PURE__*/_react.default.createElement("a", { href: commit.html_url, target: "_blank", rel: "noreferrer noopener" }, commit.commit.message.split("\n")[0])); } render() { const logs = REPOS.map(repo => { let content; if (this.state[repo] == null) { content = /*#__PURE__*/_react.default.createElement(_Spinner.default, { key: repo }); } else if (typeof this.state[repo] === "string") { content = (0, _languageHandler._t)("update|error_unable_load_commit", { msg: this.state[repo] }); } else { content = this.state[repo].map(this.elementsForCommit); } return /*#__PURE__*/_react.default.createElement("div", { key: repo }, /*#__PURE__*/_react.default.createElement(_Heading.default, { as: "h2", size: "4" }, repo), /*#__PURE__*/_react.default.createElement("ul", null, content)); }); const content = /*#__PURE__*/_react.default.createElement("div", { className: "mx_ChangelogDialog_content" }, this.props.version == null || this.props.newVersion == null ? /*#__PURE__*/_react.default.createElement("h2", null, (0, _languageHandler._t)("update|unavailable")) : logs); return /*#__PURE__*/_react.default.createElement(_QuestionDialog.default, { title: (0, _languageHandler._t)("update|changelog"), description: content, button: (0, _languageHandler._t)("action|update"), onFinished: this.props.onFinished }); } } exports.default = ChangelogDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_languageHandler","_QuestionDialog","_Spinner","_Heading","REPOS","ChangelogDialog","React","Component","constructor","props","state","fetchChanges","repo","oldVersion","newVersion","url","res","fetch","ok","setState","statusText","body","json","commits","err","Error","message","_t","componentDidMount","version","split","version2","i","length","elementsForCommit","commit","default","createElement","key","sha","className","href","html_url","target","rel","render","logs","map","content","msg","as","size","title","description","button","onFinished","exports"],"sources":["../../../../src/components/views/dialogs/ChangelogDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2019 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2016 Aviral Dasgupta\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 QuestionDialog from \"./QuestionDialog\";\nimport Spinner from \"../elements/Spinner\";\nimport Heading from \"../typography/Heading\";\n\ninterface IProps {\n    newVersion: string;\n    version: string;\n    onFinished: (success: boolean) => void;\n}\n\ntype State = Partial<Record<(typeof REPOS)[number], null | string | Commit[]>>;\n\ninterface Commit {\n    sha: string;\n    html_url: string;\n    commit: {\n        message: string;\n    };\n}\n\nconst REPOS = [\"element-hq/element-web\", \"element-hq/matrix-react-sdk\", \"matrix-org/matrix-js-sdk\"] as const;\n\nexport default class ChangelogDialog extends React.Component<IProps, State> {\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {};\n    }\n\n    private async fetchChanges(repo: (typeof REPOS)[number], oldVersion: string, newVersion: string): Promise<void> {\n        const url = `https://riot.im/github/repos/${repo}/compare/${oldVersion}...${newVersion}`;\n\n        try {\n            const res = await fetch(url);\n\n            if (!res.ok) {\n                this.setState({ [repo]: res.statusText });\n                return;\n            }\n\n            const body = await res.json();\n            this.setState({ [repo]: body.commits });\n        } catch (err) {\n            this.setState({ [repo]: err instanceof Error ? err.message : _t(\"error|unknown\") });\n        }\n    }\n\n    public componentDidMount(): void {\n        const version = this.props.newVersion.split(\"-\");\n        const version2 = this.props.version.split(\"-\");\n        if (version == null || version2 == null) return;\n        // parse versions of form: [vectorversion]-react-[react-sdk-version]-js-[js-sdk-version]\n        for (let i = 0; i < REPOS.length; i++) {\n            const oldVersion = version2[2 * i];\n            const newVersion = version[2 * i];\n            this.fetchChanges(REPOS[i], oldVersion, newVersion);\n        }\n    }\n\n    private elementsForCommit(commit: Commit): JSX.Element {\n        return (\n            <li key={commit.sha} className=\"mx_ChangelogDialog_li\">\n                <a href={commit.html_url} target=\"_blank\" rel=\"noreferrer noopener\">\n                    {commit.commit.message.split(\"\\n\")[0]}\n                </a>\n            </li>\n        );\n    }\n\n    public render(): React.ReactNode {\n        const logs = REPOS.map((repo) => {\n            let content;\n            if (this.state[repo] == null) {\n                content = <Spinner key={repo} />;\n            } else if (typeof this.state[repo] === \"string\") {\n                content = _t(\"update|error_unable_load_commit\", {\n                    msg: this.state[repo],\n                });\n            } else {\n                content = (this.state[repo] as Commit[]).map(this.elementsForCommit);\n            }\n            return (\n                <div key={repo}>\n                    <Heading as=\"h2\" size=\"4\">\n                        {repo}\n                    </Heading>\n                    <ul>{content}</ul>\n                </div>\n            );\n        });\n\n        const content = (\n            <div className=\"mx_ChangelogDialog_content\">\n                {this.props.version == null || this.props.newVersion == null ? (\n                    <h2>{_t(\"update|unavailable\")}</h2>\n                ) : (\n                    logs\n                )}\n            </div>\n        );\n\n        return (\n            <QuestionDialog\n                title={_t(\"update|changelog\")}\n                description={content}\n                button={_t(\"action|update\")}\n                onFinished={this.props.onFinished}\n            />\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}