summaryrefslogtreecommitdiff
path: root/web
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2023-03-18 17:51:04 +0200
committerMaxim Devaev <[email protected]>2023-03-18 17:51:04 +0200
commit097dbc517df4fcfb8d37d958744b1eb1f0e8d8b6 (patch)
treed3e5406ffb3de06a7cf2f6e44c5dc1c811ad4a74 /web
parent94d2f20d1f23a04493e3bf36eb2ab83a4ece4c82 (diff)
refactoring
Diffstat (limited to 'web')
-rw-r--r--web/share/js/kvm/msd.js50
-rw-r--r--web/share/js/tools.js26
2 files changed, 38 insertions, 38 deletions
diff --git a/web/share/js/kvm/msd.js b/web/share/js/kvm/msd.js
index 3a968db0..3eb646cf 100644
--- a/web/share/js/kvm/msd.js
+++ b/web/share/js/kvm/msd.js
@@ -342,38 +342,24 @@ export function Msd() {
}
let s = __state;
- let selected_index = 0;
- let index = 1;
+ let selected = "";
for (let name of Object.keys(s.storage.images).sort()) {
- let image = s.storage.images[name];
-
- if (!tools.browser.is_mobile) {
- let separator = new Option("\u2500".repeat(30), false, false);
- separator.disabled = true;
- separator.className = "comment";
- el.options[index] = separator;
- ++index;
- }
-
- let option = new Option(name, name, false, false);
- el.options[index] = option;
+ tools.selector.addSeparator(el);
+ tools.selector.addOption(el, name, name);
+ tools.selector.addComment(el, __makeImageSelectorInfo(s.storage.images[name]));
if (s.drive.image && s.drive.image.name === name && s.drive.image.in_storage) {
- selected_index = index;
+ selected = name;
}
- ++index;
-
- el.options[index] = __makeImageSelectorInfo(image);
- ++index;
}
if (s.drive.image && !s.drive.image.in_storage) {
- el.options[index] = new Option(s.drive.image.name, "", false, false);
- el.options[index + 1] = __makeImageSelectorInfo(s.drive.image);
- selected_index = el.options.length - 2;
+ selected = ".__external";
+ tools.selector.addOption(el, s.drive.image.name, selected);
+ tools.selector.addComment(el, __makeImageSelectorInfo(s.drive.image));
}
- el.selectedIndex = selected_index;
+ el.value = selected;
};
var __makeImageSelectorInfo = function(image) {
@@ -382,15 +368,10 @@ export function Msd() {
if (image.in_storage !== undefined && !image.in_storage) {
title += ", out of storage";
}
-
let dt = new Date(image.mod_ts * 1000);
dt = new Date(dt.getTime() - (dt.getTimezoneOffset() * 60000));
title += " \u2500 " + dt.toISOString().slice(0, -8).replaceAll("-", ".").replace("T", "-");
-
- let el = new Option(title, "", false, false);
- el.disabled = true;
- el.className = "comment";
- return el;
+ return title;
};
var __applyStatePartSelector = function() {
@@ -400,17 +381,15 @@ export function Msd() {
}
for (let name of Object.keys(__state.storage.parts).sort()) {
if (name != "" && __state.storage.parts[name].writable) {
- el.add(new Option(name, name, false, false));
+ tools.selector.addOption(el, name, name);
}
}
- console.log(el.options);
tools.hidden.setVisible($("msd-new-part"), (el.options.length > 1));
};
var __prepareSelector = function(el, first) {
let s = __state;
let online = (s && s.online);
-
if (!online) {
el.options.length = 1; // Cleanup
return false;
@@ -418,12 +397,7 @@ export function Msd() {
if (s.storage.uploading || s.storage.downloading) {
return false;
}
-
- if (el.options.length === 0) {
- el.options[0] = new Option(`\u2500 ${first} \u2500`, "", false, false);
- } else {
- el.options.length = 1;
- }
+ tools.selector.initDefault(el, first, "");
return true;
};
diff --git a/web/share/js/tools.js b/web/share/js/tools.js
index 789c4b12..4d082eea 100644
--- a/web/share/js/tools.js
+++ b/web/share/js/tools.js
@@ -251,6 +251,32 @@ export var tools = new function() {
};
};
+ self.selector = new function() {
+ return {
+ "initDefault": function(el, title, value) {
+ if (el.options.length === 0) {
+ self.selector.addOption(el, `\u2500 ${title} \u2500`, value);
+ } else {
+ el.options.length = 1;
+ }
+ },
+ "addOption": function(el, title, value) {
+ el.add(new Option(title, value, false, false));
+ },
+ "addComment": function(el, title) {
+ let option = new Option(title, ".".repeat(30), false, false); // Kinda magic value
+ option.disabled = true;
+ option.className = "comment";
+ el.add(option);
+ },
+ "addSeparator": function(el) {
+ if (!self.browser.is_mobile) {
+ self.selector.addComment(el, "\u2500".repeat(30));
+ }
+ },
+ };
+ };
+
self.progress = new function() {
return {
"setValue": function(el, title, percent) {