diff --git a/copyparty/web/browser.css b/copyparty/web/browser.css
index 690d629c..96f160d7 100644
--- a/copyparty/web/browser.css
+++ b/copyparty/web/browser.css
@@ -69,8 +69,8 @@ body {
border-color: #fc0;
}
#toast.err {
- background: #b00;
- border-color: #f00;
+ background: #900;
+ border-color: #d06;
}
#tt.b {
padding: 0 2em;
diff --git a/copyparty/web/browser.js b/copyparty/web/browser.js
index 772657ed..5967d0fe 100644
--- a/copyparty/web/browser.js
+++ b/copyparty/web/browser.js
@@ -285,7 +285,7 @@ var mpl = (function () {
r.os_ctl = !r.os_ctl && have_mctl;
bcfg_set('au_os_ctl', r.os_ctl);
if (!have_mctl)
- alert('need firefox 82+ or chrome 73+');
+ toast.err(5, 'need firefox 82+ or chrome 73+');
};
ebi('au_osd_cv').onclick = function (e) {
@@ -1353,7 +1353,7 @@ function play(tid, is_ev, seek, call_depth) {
return true;
}
catch (ex) {
- alert('playback failed: ' + ex);
+ toast.err(0, 'playback failed: ' + ex);
}
setclass(oid, 'play');
setTimeout(next_song, 500);
@@ -1495,7 +1495,7 @@ var fileman = (function () {
ev(e);
var sel = msel.getsel();
if (sel.length !== 1)
- return alert('select exactly 1 item to rename');
+ return toast.err(3, 'select exactly 1 item to rename');
var src = sel[0].vp;
if (src.endsWith('/'))
@@ -1507,7 +1507,7 @@ var fileman = (function () {
var fn = prompt('new filename:', ofn);
if (!fn || fn == ofn)
- return toast.warn(1000, 'rename aborted');
+ return toast.warn(1, 'rename aborted');
var dst = base + fn;
@@ -1517,10 +1517,10 @@ var fileman = (function () {
if (this.status !== 200) {
var msg = this.responseText;
- toast.err(2000, 'rename failed:
' + msg);
+ toast.err(9, 'rename failed:\n' + msg);
return;
}
- toast.ok(2000, 'rename OK');
+ toast.ok(2, 'rename OK');
treectl.goto(get_evpath());
}
var xhr = new XMLHttpRequest();
@@ -1538,7 +1538,7 @@ var fileman = (function () {
vps.push(sel[a].vp);
if (!sel.length)
- return alert('select at least 1 item to delete');
+ return toast.err(3, 'select at least 1 item to delete');
if (!confirm('===== DANGER =====\nDELETE these ' + vps.length + ' items?\n\n' + vps.join('\n')))
return;
@@ -1551,11 +1551,11 @@ var fileman = (function () {
vp = vps.shift();
if (!vp) {
- toast.ok(2000, 'delete OK');
+ toast.ok(2, 'delete OK');
treectl.goto(get_evpath());
return;
}
- toast.inf(2000, 'deleting ' + (vps.length + 1) + ' items
' + vp);
+ toast.inf(2, 'deleting ' + (vps.length + 1) + ' items\n\n' + vp);
xhr.open('GET', vp + '?delete', true);
xhr.onreadystatechange = delete_cb;
@@ -1567,7 +1567,7 @@ var fileman = (function () {
if (this.status !== 200) {
var msg = this.responseText;
- toast.err(2000, 'delete failed:
' + msg);
+ toast.err(9, 'delete failed:\n' + msg);
return;
}
deleter();
@@ -1581,7 +1581,7 @@ var fileman = (function () {
vps = [];
if (!sel.length)
- return alert('select at least 1 item to cut');
+ return toast.err(3, 'select at least 1 item to cut');
for (var a = 0; a < sel.length; a++) {
vps.push(sel[a].vp);
@@ -1592,7 +1592,7 @@ var fileman = (function () {
cl.add(inv ? 'c2' : 'c1');
}
- toast.inf(1000, 'cut ' + sel.length + ' items');
+ toast.inf(1, 'cut ' + sel.length + ' items');
jwrite('fman_clip', vps);
r.tx(1);
};
@@ -1600,7 +1600,7 @@ var fileman = (function () {
r.paste = function (e) {
ev(e);
if (!r.clip.length)
- return alert('first cut some files/folders to paste\n\nnote: you can cut/paste across different browser tabs');
+ return toast.err(5, 'first cut some files/folders to paste\n\nnote: you can cut/paste across different browser tabs');
var req = [],
exists = [],
@@ -1637,12 +1637,12 @@ var fileman = (function () {
vp = req.shift();
if (!vp) {
- toast.ok(2000, 'paste OK');
+ toast.ok(2, 'paste OK');
treectl.goto(get_evpath());
r.tx(srcdir);
return;
}
- toast.inf(2000, 'pasting ' + (req.length + 1) + ' items
' + vp);
+ toast.inf(2, 'pasting ' + (req.length + 1) + ' items\n\n' + vp);
var dst = get_evpath() + vp.split('/').slice(-1)[0];
@@ -1656,7 +1656,7 @@ var fileman = (function () {
if (this.status !== 200) {
var msg = this.responseText;
- toast.err(2000, 'paste failed:
' + msg);
+ toast.err(9, 'paste failed:\n' + msg);
return;
}
paster();
@@ -2535,7 +2535,7 @@ var treectl = (function () {
return;
if (this.status !== 200) {
- alert("http " + this.status + ": " + this.responseText);
+ toast.err(0, "recvtree, http " + this.status + ": " + this.responseText);
return;
}
@@ -2657,7 +2657,7 @@ var treectl = (function () {
return;
if (this.status !== 200) {
- alert("http " + this.status + ": " + this.responseText);
+ toast.err(0, "recvls, http " + this.status + ": " + this.responseText);
return;
}
diff --git a/copyparty/web/md.css b/copyparty/web/md.css
index 6d13194c..ed373361 100644
--- a/copyparty/web/md.css
+++ b/copyparty/web/md.css
@@ -52,8 +52,8 @@ html, body {
border-color: #fc0;
}
#toast.err {
- background: #b00;
- border-color: #f00;
+ background: #900;
+ border-color: #d06;
}
#tt.b {
padding: 0 2em;
diff --git a/copyparty/web/md2.js b/copyparty/web/md2.js
index 68f63375..29303414 100644
--- a/copyparty/web/md2.js
+++ b/copyparty/web/md2.js
@@ -323,11 +323,11 @@ function save(e) {
save_cls = save_btn.getAttribute('class') + '';
if (save_cls.indexOf('disabled') >= 0)
- return toast.inf(2000, "no changes");
+ return toast.inf(2, "no changes");
var force = (save_cls.indexOf('force-save') >= 0);
if (force && !confirm('confirm that you wish to lose the changes made on the server since you opened this document'))
- return alert('ok, aborted');
+ return toast.inf(3, 'aborted');
var txt = dom_src.value;
@@ -352,18 +352,15 @@ function save_cb() {
if (this.readyState != XMLHttpRequest.DONE)
return;
- if (this.status !== 200) {
- alert('Error! The file was NOT saved.\n\n' + this.status + ": " + (this.responseText + '').replace(/^
/, ""));
- return;
- }
+ if (this.status !== 200)
+ return alert('Error! The file was NOT saved.\n\n' + this.status + ": " + (this.responseText + '').replace(/^/, ""));
var r;
try {
r = JSON.parse(this.responseText);
}
catch (ex) {
- alert('Failed to parse reply from server:\n\n' + this.responseText);
- return;
+ return alert('Failed to parse reply from server:\n\n' + this.responseText);
}
if (!r.ok) {
@@ -438,7 +435,7 @@ function savechk_cb() {
last_modified = this.lastmod;
server_md = this.txt;
draw_md();
- toast.ok(2000, 'save OK' + (this.ntry ? '
attempt ' + this.ntry : ''));
+ toast.ok(2, 'save OK' + (this.ntry ? '\nattempt ' + this.ntry : ''));
modpoll.disabled = false;
}
@@ -720,7 +717,7 @@ function fmt_table(e) {
var ind2 = tab[a].match(re_ind)[0];
if (ind != ind2 && a != 1) // the table can be a list entry or something, ignore [0]
- return alert(err + 'indentation mismatch on row#2 and ' + row_name + ',\n' + tab[a]);
+ return toast.err(7, err + 'indentation mismatch on row#2 and ' + row_name + ',\n' + tab[a]);
var t = tab[a].slice(ind.length);
t = t.replace(re_lpipe, "");
@@ -730,7 +727,7 @@ function fmt_table(e) {
if (a == 0)
ncols = tab[a].length;
else if (ncols < tab[a].length)
- return alert(err + 'num.columns(' + row_name + ') exceeding row#2; ' + ncols + ' < ' + tab[a].length);
+ return toast.err(7, err + 'num.columns(' + row_name + ') exceeding row#2; ' + ncols + ' < ' + tab[a].length);
// if row has less columns than row2, fill them in
while (tab[a].length < ncols)
@@ -747,7 +744,7 @@ function fmt_table(e) {
for (var col = 0; col < tab[1].length; col++) {
var m = tab[1][col].match(re_align);
if (!m)
- return alert(err + 'invalid column specification, row#2, col ' + (col + 1) + ', [' + tab[1][col] + ']');
+ return toast.err(7, err + 'invalid column specification, row#2, col ' + (col + 1) + ', [' + tab[1][col] + ']');
if (m[2]) {
if (m[1])
@@ -835,10 +832,9 @@ function mark_uni(e) {
ptn = new RegExp('([^' + js_uni_whitelist + ']+)', 'g'),
mod = txt.replace(/\r/g, "").replace(ptn, "\u2588\u2770$1\u2771");
- if (txt == mod) {
- alert('no results; no modifications were made');
- return;
- }
+ if (txt == mod)
+ return toast.inf(5, 'no results; no modifications were made');
+
dom_src.value = mod;
}
@@ -852,10 +848,9 @@ function iter_uni(e) {
re = new RegExp('([^' + js_uni_whitelist + ']+)'),
m = re.exec(txt.slice(ofs));
- if (!m) {
- alert('no more hits from cursor onwards');
- return;
- }
+ if (!m)
+ return toast.inf(5, 'no more hits from cursor onwards');
+
ofs += m.index;
dom_src.setSelectionRange(ofs, ofs + m[0].length, "forward");
diff --git a/copyparty/web/mde.js b/copyparty/web/mde.js
index 1c83d457..3030c21c 100644
--- a/copyparty/web/mde.js
+++ b/copyparty/web/mde.js
@@ -106,15 +106,12 @@ function md_changed(mde, on_srv) {
function save(mde) {
var save_btn = QS('.editor-toolbar button.save');
- if (save_btn.classList.contains('disabled')) {
- alert('there is nothing to save');
- return;
- }
+ if (save_btn.classList.contains('disabled'))
+ return toast.inf(2, 'no changes');
+
var force = save_btn.classList.contains('force-save');
- if (force && !confirm('confirm that you wish to lose the changes made on the server since you opened this document')) {
- alert('ok, aborted');
- return;
- }
+ if (force && !confirm('confirm that you wish to lose the changes made on the server since you opened this document'))
+ return toast.inf(3, 'aborted');
var txt = mde.value();
@@ -138,18 +135,15 @@ function save_cb() {
if (this.readyState != XMLHttpRequest.DONE)
return;
- if (this.status !== 200) {
- alert('Error! The file was NOT saved.\n\n' + this.status + ": " + (this.responseText + '').replace(/^/, ""));
- return;
- }
+ if (this.status !== 200)
+ return alert('Error! The file was NOT saved.\n\n' + this.status + ": " + (this.responseText + '').replace(/^/, ""));
var r;
try {
r = JSON.parse(this.responseText);
}
catch (ex) {
- alert('Failed to parse reply from server:\n\n' + this.responseText);
- return;
+ return alert('Failed to parse reply from server:\n\n' + this.responseText);
}
if (!r.ok) {
diff --git a/copyparty/web/up2k.js b/copyparty/web/up2k.js
index c610303c..5a2e4d9d 100644
--- a/copyparty/web/up2k.js
+++ b/copyparty/web/up2k.js
@@ -1176,10 +1176,6 @@ function up2k_init(subtle) {
}
t.t_hashed = Date.now();
- if (t.n == 0 && window.location.hash == '#dbg') {
- var spd = (t.size / ((t.t_hashed - t.t_hashing) / 1000.)) / (1024 * 1024.);
- alert('{0} ms, {1} MB/s\n'.format(t.t_hashed - t.t_hashing, spd.toFixed(3)) + t.hash.join('\n'));
- }
pvis.seth(t.n, 2, 'hashing done');
pvis.seth(t.n, 1, '📦 wait');
diff --git a/copyparty/web/util.js b/copyparty/web/util.js
index 872b361a..6fe18d1a 100644
--- a/copyparty/web/util.js
+++ b/copyparty/web/util.js
@@ -654,7 +654,6 @@ var toast = (function () {
obj = mknod('div');
obj.setAttribute('id', 'toast');
- obj.onclick = r.hide;
document.body.appendChild(obj);;
r.hide = function () {
@@ -666,9 +665,9 @@ var toast = (function () {
r.show = function (cl, ms, txt) {
clearTimeout(te);
if (ms)
- te = setTimeout(r.hide, ms);
+ te = setTimeout(r.hide, ms * 1000);
- obj.innerHTML = txt;
+ obj.innerHTML = txt.replace(/\n/g, '
\n');
obj.className = cl + ' vis';
r.visible = true;
};
@@ -686,5 +685,6 @@ var toast = (function () {
r.show('err', ms, txt);
};
+ obj.onclick = r.hide;
return r;
})();