Handle errors when fetching commits for changelog
It's possible to get errors when fetching commits (for example, if the rate limit is exceeded), so this will handle the error case and display it instead of an infinite spinner. Signed-off-by: J. Ryan Stinnett <jryans@gmail.com>pull/21833/head
parent
37256d2976
commit
fd94dc686f
|
@ -36,8 +36,12 @@ export default class ChangelogDialog extends React.Component {
|
||||||
for (let i=0; i<REPOS.length; i++) {
|
for (let i=0; i<REPOS.length; i++) {
|
||||||
const oldVersion = version2[2*i];
|
const oldVersion = version2[2*i];
|
||||||
const newVersion = version[2*i];
|
const newVersion = version[2*i];
|
||||||
request(`https://api.github.com/repos/${REPOS[i]}/compare/${oldVersion}...${newVersion}`, (a, b, body) => {
|
const url = `https://api.github.com/repos/${REPOS[i]}/compare/${oldVersion}...${newVersion}`;
|
||||||
if (body == null) return;
|
request(url, (err, response, body) => {
|
||||||
|
if (response.statusCode < 200 || response.statusCode >= 300) {
|
||||||
|
this.setState({ [REPOS[i]]: response.statusText });
|
||||||
|
return;
|
||||||
|
}
|
||||||
this.setState({[REPOS[i]]: JSON.parse(body).commits});
|
this.setState({[REPOS[i]]: JSON.parse(body).commits});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -58,13 +62,20 @@ export default class ChangelogDialog extends React.Component {
|
||||||
const QuestionDialog = sdk.getComponent('dialogs.QuestionDialog');
|
const QuestionDialog = sdk.getComponent('dialogs.QuestionDialog');
|
||||||
|
|
||||||
const logs = REPOS.map(repo => {
|
const logs = REPOS.map(repo => {
|
||||||
if (this.state[repo] == null) return <Spinner key={repo} />;
|
let content;
|
||||||
|
if (this.state[repo] == null) {
|
||||||
|
content = <Spinner key={repo} />;
|
||||||
|
} else if (typeof this.state[repo] === "string") {
|
||||||
|
content = _t("Unable to load commit detail: %(msg)s", {
|
||||||
|
msg: this.state[repo],
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
content = this.state[repo].map(this._elementsForCommit);
|
||||||
|
}
|
||||||
return (
|
return (
|
||||||
<div key={repo}>
|
<div key={repo}>
|
||||||
<h2>{repo}</h2>
|
<h2>{repo}</h2>
|
||||||
<ul>
|
<ul>{content}</ul>
|
||||||
{this.state[repo].map(this._elementsForCommit)}
|
|
||||||
</ul>
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
|
@ -889,6 +889,7 @@
|
||||||
"What GitHub issue are these logs for?": "What GitHub issue are these logs for?",
|
"What GitHub issue are these logs for?": "What GitHub issue are these logs for?",
|
||||||
"Notes:": "Notes:",
|
"Notes:": "Notes:",
|
||||||
"Send logs": "Send logs",
|
"Send logs": "Send logs",
|
||||||
|
"Unable to load commit detail: %(msg)s": "Unable to load commit detail: %(msg)s",
|
||||||
"Unavailable": "Unavailable",
|
"Unavailable": "Unavailable",
|
||||||
"Changelog": "Changelog",
|
"Changelog": "Changelog",
|
||||||
"Create a new chat or reuse an existing one": "Create a new chat or reuse an existing one",
|
"Create a new chat or reuse an existing one": "Create a new chat or reuse an existing one",
|
||||||
|
|
Loading…
Reference in New Issue