diff --git a/www/index.css b/www/index.css
index 6b688fdb..f42df951 100644
--- a/www/index.css
+++ b/www/index.css
@@ -457,3 +457,13 @@ body {
color: #d0d0d0;
}
}
+
+#alert {
+ position: absolute;
+ z-index: 1001;
+ height: 2em;
+ line-height: 2em;
+ width: 100%;
+ background-color: red;
+ text-align: center;
+}
diff --git a/www/index.html b/www/index.html
index 27cf709d..fa280671 100644
--- a/www/index.html
+++ b/www/index.html
@@ -76,6 +76,8 @@
+
Download OpenWrt Firmware for your Device
diff --git a/www/index.js b/www/index.js
index 68af9bb5..389c6578 100644
--- a/www/index.js
+++ b/www/index.js
@@ -35,6 +35,16 @@ function htmlToElement(html) {
return e.content.firstChild;
}
+function showAlert(message) {
+ $("#alert").innerText = String(message);
+ show("#alert");
+}
+
+function hideAlert(message) {
+ hide("#alert");
+ $("#alert").innerText = "";
+}
+
function getModelTitles(titles) {
return titles.map((e) => {
if (e.title) {
@@ -239,8 +249,18 @@ function translate(lang) {
apply(current_language, current_language_json);
} else {
fetch("langs/" + new_lang + ".json")
- .then((obj) => obj.json())
- .then((mapping) => apply(new_lang, mapping));
+ .then((obj) => {
+ if (obj.status == 200) {
+ hideAlert();
+ return obj.json();
+ } else {
+ showAlert(`Failed to fetch ${obj.uri}`);
+ }
+ })
+ .then((mapping) => apply(new_lang, mapping))
+ .catch((err) => {
+ showAlert(err);
+ });
}
}
@@ -673,7 +693,12 @@ function changeModel(version, overview, title) {
cache: "no-cache",
})
.then((obj) => {
- return obj.json();
+ if (obj.status == 200) {
+ hideAlert();
+ return obj.json();
+ } else {
+ showAlert(`Failed to fetch ${obj.uri}`);
+ }
})
.then((mobj) => {
mobj["id"] = entry.id;
@@ -685,7 +710,8 @@ function changeModel(version, overview, title) {
id: entry.id,
target: entry.target,
};
- });
+ })
+ .catch((err) => showAlert(err));
} else {
updateImages();
current_device = {};
@@ -723,16 +749,24 @@ function setup_uci_defaults() {
let link = icon.getAttribute("data-link");
let textarea = $("#uci-defaults-content");
icon.onclick = function () {
- fetch(link).then((response) => {
- response.text().then((text) => {
+ fetch(link)
+ .then((obj) => {
+ if (obj.status == 200) {
+ hideAlert();
+ return obj.text();
+ } else {
+ showAlert(`Failed to fetch ${obj.uri}`);
+ }
+ })
+ .then((text) => {
// toggle text
if (textarea.value.indexOf(text) != -1) {
textarea.value = textarea.value.replace(text, "");
} else {
textarea.value = textarea.value + text;
}
- });
- });
+ })
+ .catch((err) => showAlert(err));
};
}
@@ -785,7 +819,8 @@ async function init() {
image_url_override: obj.image_url_override,
default_version: obj.stable_version,
};
- });
+ })
+ .catch((err) => showAlert(err));
if (!config.versions) {
config.versions = upstream_config.versions;
@@ -816,7 +851,12 @@ async function init() {
let overview_url = `${config.overview_urls[version]}/.overview.json`;
fetch(overview_url, { cache: "no-cache" })
.then((obj) => {
- return obj.json();
+ if (obj.status == 200) {
+ hideAlert();
+ return obj.json();
+ } else {
+ showAlert(`Failed to fetch ${obj.uri}`);
+ }
})
.then((obj) => {
var dups = {};
@@ -877,7 +917,8 @@ async function init() {
// trigger update of current selected model
$("#models").onfocus();
- });
+ })
+ .catch((err) => showAlert(err));
});
setup_uci_defaults();