update ui

This commit is contained in:
Zack Scholl 2019-07-11 06:00:00 -07:00
parent 63b4e74d8f
commit d43418e290
6 changed files with 356 additions and 244 deletions

BIN
static/banner.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

185
static/main.js Normal file
View file

@ -0,0 +1,185 @@
var files = [];
var isConnected = false;
var relativeDirectory = "";
function consoleLog(s) {
console.log(s);
if (typeof s === 'object') {
s = JSON.stringify(s);
}
if (!(s.startsWith("[debug]"))) {
document.getElementById("consoleText").value = document.getElementById("consoleText").value + s + "\n";
document.getElementById("consoleText").scrollTop = document.getElementById("consoleText").scrollHeight;
}
}
function humanFileSize(bytes, si) {
var thresh = si ? 1000 : 1024;
if (Math.abs(bytes) < thresh) {
return bytes + ' B';
}
var units = si ? ['kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'] : ['KiB', 'MiB', 'GiB', 'TiB', 'PiB',
'EiB', 'ZiB', 'YiB'
];
var u = -1;
do {
bytes /= thresh;
++u;
} while (Math.abs(bytes) >= thresh && u < units.length - 1);
return bytes.toFixed(1) + ' ' + units[u];
}
var Name = "";
var filesize = 0;
(function(Dropzone) {
Dropzone.autoDiscover = false;
let drop = new Dropzone('div#filesBox', {
maxFiles: 1000,
url: '/',
method: 'post',
createImageThumbnails: false,
previewTemplate: "<div id='preview' class='.dropzone-previews'></div>",
autoProcessQueue: false,
});
drop.on('addedfile', function(file) {
// console.log(file);
var domain = document.getElementById("inputDomain").value
files.push(file);
if (files.length == 1) {
relativeDirectory = file.webkitRelativePath.split("/")[0];
} else if (file.webkitRelativePath.split("/")[0] != relativeDirectory) {
relativeDirectory = "";
}
if (!(isConnected)) {
isConnected = true;
socketSend({
type: "domain",
message: domain,
key: document.getElementById("inputKey").value,
})
}
var filesString = "files are";
var domainName = `${window.publicURL}/${domain}/`;
if (files.length == 1) {
filesString = "file is"
domainName += `${file.name}`
}
document.getElementById("consoleHeader").innerHTML =
`<p>Your ${filesString} available at:<br> <center><strong><a href="${domainName}" target="_blank">${domainName}</a></strong></center></p>`;
html = `<ul>`
for (i = 0; i < files.length; i++) {
var urlToFile = files[i].name;
if ('fullPath' in files[i]) {
urlToFile = files[i].fullPath;
}
html = html +
`<li><a href="/${domain}/${urlToFile}" target="_blank">/${urlToFile}</a></li>`
}
html = html + `</ul>`;
document.getElementById("fileList").innerHTML = html;
document.getElementById("filesBox").classList.add("hide");
document.getElementById("console").classList.remove("hide");
document.getElementById("inputKey").readOnly = "true";
document.getElementById("inputDomain").readOnly = "true";
})
})(Dropzone);
var socket; // websocket
/* websockets */
function socketSend(data) {
if (socket == null) {
return
}
if (socket.readyState != 1) {
return
}
jsonData = JSON.stringify(data);
socket.send(jsonData);
if (jsonData.length > 100) {
consoleLog("[debug] ws-> " + jsonData.substring(0, 99))
} else {
consoleLog("[debug] ws-> " + jsonData)
}
}
const socketMessageListener = (event) => {
var data = JSON.parse(event.data);
if (!('type' in data && 'message' in data)) {
consoleLog(`[warn] got bad data ${event.data}`);
return
}
console.log(data)
consoleLog(`[debug] ${data.message}`)
if (data.type == "get") {
var foundFile = false
var iToSend = 0
for (i = 0; i < files.length; i++) {
if (files[i].webkitRelativePath == data.message || files[i].name == data.message || files[i]
.webkitRelativePath == relativeDirectory + "/" + data.message) {
iToSend = i;
var reader = new FileReader();
reader.onload = function(theFile) {
socketSend({
type: "get",
message: reader.result,
success: true,
key: document.getElementById("inputKey").value,
})
consoleLog(
`${data.ip} [${(new Date()).toUTCString()}] /${data.message} 200 ${files[i].size}`
);
};
reader.readAsDataURL(files[i]);
foundFile = true
break
}
}
if (foundFile == false) {
socketSend({
type: "get",
message: "not found",
success: false,
key: document.getElementById("inputKey").value,
})
consoleLog(`${data.ip} [${(new Date()).toUTCString()}] /${data.message} 404`);
}
} else if (data.type == "domain") {
console.log(`[info] ${data.message}`);
} else if (data.type == "message") {
console.log(`[info] ${data.message}`);
} else {
consoleLog(`[debug] unknown`);
}
};
const socketOpenListener = (event) => {
consoleLog('[info] connected');
};
const socketCloseListener = (event) => {
if (socket) {
consoleLog('[info] disconnected');
}
var url = window.origin.replace("http", "ws") + '/ws';
try {
socket = new WebSocket(url);
socket.addEventListener('open', socketOpenListener);
socket.addEventListener('message', socketMessageListener);
socket.addEventListener('close', socketCloseListener);
} catch (err) {
consoleLog("[info] no connection available")
}
};
socketCloseListener();

View file

@ -329,3 +329,67 @@ However, delay the fade out process for 2.5 seconds */
opacity: 0;
}
}
.main {
padding-top: 20px;
}
.list {
display: flex;
flex-wrap: wrap;
}
.list>div {
padding: 0.4em;
}
body {
text-decoration-skip: ink;
}
.hide {
display: none;
}
textarea {
width: 100%;
border: none;
resize: none;
height: 20em;
border: 1px solid #ccc;
background-color: #f5f5f5;
padding: 1em;
font-size: 0.9em;
}
details>p>code {
background-color: inherit;
}
.editer {
margin: 0.2em;
padding: 0.5em;
background-color: #f5f5f5;
display: inline;
border: none;
font-weight: bold;
font-family: var(--sans-font);
font-size: 1em;
}
.banner {
padding-top: 3em;
}
.p05 {
padding-top: 0.5em;
padding-bottom: 0.5em;
}
.flexcol {
display: flex;
flex-direction: row;
align-content: center;
}