summaryrefslogtreecommitdiff
path: root/web/share
diff options
context:
space:
mode:
Diffstat (limited to 'web/share')
-rw-r--r--web/share/js/kvm/msd.js50
-rw-r--r--web/share/js/tools.js12
2 files changed, 28 insertions, 34 deletions
diff --git a/web/share/js/kvm/msd.js b/web/share/js/kvm/msd.js
index 8eff82ae..ae8867be 100644
--- a/web/share/js/kvm/msd.js
+++ b/web/share/js/kvm/msd.js
@@ -44,9 +44,9 @@ export function Msd() {
tools.el.setOnClick($("msd-download-button"), __clickDownloadButton);
tools.el.setOnClick($("msd-remove-button"), __clickRemoveButton);
- tools.radio.setOnClick("msd-mode-radio", __clickModeRadio);
+ tools.radio.setOnClick("msd-mode-radio", () => __sendParam("cdrom", tools.radio.getValue("msd-mode-radio")));
- tools.el.setOnClick($("msd-rw-switch"), __clickRwSwitch);
+ tools.el.setOnClick($("msd-rw-switch"), () => __sendParam("rw", $("msd-rw-switch").checked));
tools.el.setOnClick($("msd-select-new-button"), __toggleSelectSub);
$("msd-new-file").onchange = __selectNewFile;
@@ -95,14 +95,6 @@ export function Msd() {
});
};
- var __clickModeRadio = function() {
- __sendParam("cdrom", tools.radio.getValue("msd-mode-radio"));
- };
-
- var __clickRwSwitch = function() {
- __sendParam("rw", $("msd-rw-switch").checked);
- };
-
var __sendParam = function(name, value) {
let http = tools.makeRequest("POST", `/api/msd/set_params?${name}=${encodeURIComponent(value)}`, function() {
if (http.readyState === 4) {
@@ -232,18 +224,25 @@ export function Msd() {
};
var __applyState = function() {
- __applyStateFeatures();
__applyStateStatus();
let s = __state;
let online = (s && s.online);
+ if (s) {
+ tools.feature.setEnabled($("msd-dropdown"), s.enabled);
+ tools.feature.setEnabled($("msd-reset-button"), s.enabled);
+ }
+ tools.hidden.setVisible($("msd-message-offline"), (s && !s.online));
+ tools.hidden.setVisible($("msd-message-image-broken"), (online && s.drive.image && !s.drive.image.complete && !s.storage.uploading));
+ tools.hidden.setVisible($("msd-message-too-big-for-cdrom"), (online && s.drive.cdrom && s.drive.image && s.drive.image.size >= 2359296000));
+ tools.hidden.setVisible($("msd-message-out-of-storage"), (online && s.drive.image && !s.drive.image.in_storage));
+ tools.hidden.setVisible($("msd-message-rw-enabled"), (online && s.drive.rw));
+ tools.hidden.setVisible($("msd-message-another-user-uploads"), (online && s.storage.uploading && !__http));
+ tools.hidden.setVisible($("msd-message-downloads"), (online && s.storage.downloading));
+
if (online) {
- let size_str = tools.formatSize(s.storage.parts[""].size);
- let used = s.storage.parts[""].size - s.storage.parts[""].free;
- let used_str = tools.formatSize(used);
- let percent = used / s.storage.parts[""].size * 100;
- tools.progress.setValue($("msd-storage-progress"), `Storage: ${used_str} of ${size_str}`, percent);
+ tools.progress.setSizeOf($("msd-storage-progress"), "Storage: %s", s.storage.parts[""].size, s.storage.parts[""].free);
} else {
tools.progress.setValue($("msd-storage-progress"), "Storage: unavailable", 0);
}
@@ -279,8 +278,7 @@ export function Msd() {
$("msd-uploading-size").innerHTML = ((online && s.storage.uploading) ? tools.formatSize(s.storage.uploading.size) : "");
if (online) {
if (s.storage.uploading) {
- let percent = Math.round(s.storage.uploading.written * 100 / s.storage.uploading.size);
- tools.progress.setValue($("msd-uploading-progress"), `${percent}%`, percent);
+ tools.progress.setPercentOf($("msd-uploading-progress"), s.storage.uploading.size, s.storage.uploading.written);
} else if (!__http) {
tools.progress.setValue($("msd-uploading-progress"), "Waiting for upload (press UPLOAD button) ...", 0);
}
@@ -291,22 +289,6 @@ export function Msd() {
}
};
- var __applyStateFeatures = function() {
- let s = __state;
- let online = (s && s.online);
- if (s) {
- tools.feature.setEnabled($("msd-dropdown"), s.enabled);
- tools.feature.setEnabled($("msd-reset-button"), s.enabled);
- }
- tools.hidden.setVisible($("msd-message-offline"), (s && !s.online));
- tools.hidden.setVisible($("msd-message-image-broken"), (online && s.drive.image && !s.drive.image.complete && !s.storage.uploading));
- tools.hidden.setVisible($("msd-message-too-big-for-cdrom"), (online && s.drive.cdrom && s.drive.image && s.drive.image.size >= 2359296000));
- tools.hidden.setVisible($("msd-message-out-of-storage"), (online && s.drive.image && !s.drive.image.in_storage));
- tools.hidden.setVisible($("msd-message-rw-enabled"), (online && s.drive.rw));
- tools.hidden.setVisible($("msd-message-another-user-uploads"), (online && s.storage.uploading && !__http));
- tools.hidden.setVisible($("msd-message-downloads"), (online && s.storage.downloading));
- };
-
var __applyStateStatus = function() {
let s = __state;
let online = (s && s.online);
diff --git a/web/share/js/tools.js b/web/share/js/tools.js
index ca31f1f8..07c8da19 100644
--- a/web/share/js/tools.js
+++ b/web/share/js/tools.js
@@ -300,6 +300,18 @@ export var tools = new function() {
el.setAttribute("data-label", title);
$(`${el.id}-value`).style.width = `${percent}%`;
},
+ "setPercentOf": function(el, max, value) {
+ let percent = Math.round(value * 100 / max);
+ self.progress.setValue(el, `${percent}%`, percent);
+ },
+ "setSizeOf": function(el, title, size, free) {
+ let size_str = self.formatSize(size);
+ let used = size - free;
+ let used_str = self.formatSize(used);
+ let percent = used / size * 100;
+ title = title.replace("%s", `${used_str} of ${size_str}`);
+ self.progress.setValue(el, title, percent);
+ },
};
};