Upload for all files fix 119 (#120)
* allow uploading files not only to http + replace symbol images by unicode symbols allow uploading files to root dir and http. + replace symbol images by unicode symbols * backend for uploading arbitrary files * fix uploading to http
This commit is contained in:
parent
5cf303de79
commit
7c8fe9c164
@ -33,6 +33,29 @@
|
||||
|
||||
.dropBox {width:100vw; height:100vh; margin-top: -200px; padding-top: 200px;}
|
||||
|
||||
#uploaddir{
|
||||
background-color: #2E3134;
|
||||
font-size:16px;
|
||||
font-weight:bold;
|
||||
color:#7f858a;
|
||||
padding: 40px 50px;
|
||||
margin-bottom: 30px;
|
||||
}
|
||||
|
||||
#uploaddir a{
|
||||
background-color:#007a96;
|
||||
padding:12px 26px;
|
||||
color:#fff;
|
||||
font-size:14px;
|
||||
border-radius:2px;
|
||||
cursor:pointer;
|
||||
margin-top:12px;
|
||||
line-height:1;
|
||||
margin-left: 10px;
|
||||
}
|
||||
#selectedDir {
|
||||
margin-top:20px;
|
||||
}
|
||||
#upload{
|
||||
font-family:'PT Sans Narrow', sans-serif;
|
||||
background-color:#373a3d;
|
||||
@ -140,14 +163,24 @@
|
||||
position: absolute;
|
||||
}
|
||||
|
||||
.delete:after{
|
||||
color: #ff0000;
|
||||
content: "\2718";
|
||||
}
|
||||
|
||||
.uploaded:after{
|
||||
color: #00ff00;
|
||||
content: "\2714";
|
||||
}
|
||||
|
||||
#upload ul li span{
|
||||
width: 15px;
|
||||
height: 12px;
|
||||
background: url('') no-repeat;
|
||||
cursor:pointer;
|
||||
position: absolute;
|
||||
top: 34px;
|
||||
right: 33px;
|
||||
cursor:pointer;
|
||||
font-size:18px;
|
||||
}
|
||||
|
||||
#upload ul li.working span{
|
||||
@ -189,7 +222,7 @@
|
||||
var chunkSize = 128;
|
||||
var totalUploaded = 0;
|
||||
|
||||
var tpl = '<li class="working" id="file%filenum%"><div class="chart" id="graph%filenum%" data-percent="0"></div><p>%filename%<i>%filesize%</i></p><span id="fileStatus%filenum%" onclick="DeleteFiles(%filenum%);"></span></li>';
|
||||
var tpl = '<li class="working" id="file%filenum%"><div class="chart" id="graph%filenum%" data-percent="0"></div><p>%filename%<i>%filesize%</i></p><span class="delete" id="fileStatus%filenum%" onclick="DeleteFiles(%filenum%);"></span></li>';
|
||||
|
||||
document.addEventListener("DOMContentLoaded", function() {
|
||||
var dropbox;
|
||||
@ -200,6 +233,8 @@
|
||||
dropbox.addEventListener("drop", drop, false);
|
||||
|
||||
UpdateFileList();
|
||||
|
||||
UploadDir("http");
|
||||
});
|
||||
|
||||
function dragenter(e) {
|
||||
@ -235,13 +270,13 @@
|
||||
var fileNames = {};
|
||||
|
||||
for (var i = 0; i < filesCount; i++) {
|
||||
fileNames[tfiles[i].name] = i;
|
||||
fileNames[uploadDir + tfiles[i].name] = i;
|
||||
}
|
||||
|
||||
Keys(fileNames).sort(function(a,b){var c=a.toLowerCase(),d=b.toLowerCase();return c<d?-1:c>d?1:0}).forEach(function(item) {
|
||||
var i = fileNames[item];
|
||||
|
||||
var append = tpl.replace(/%filename%/g, tfiles[i].name);
|
||||
var append = tpl.replace(/%filename%/g, uploadDir + tfiles[i].name);
|
||||
append = append.replace(/%filesize%/g, formatFileSize(tfiles[i].size));
|
||||
append = append.replace(/%filenum%/g, i);
|
||||
|
||||
@ -380,7 +415,7 @@
|
||||
totalUploaded = 0;
|
||||
|
||||
if (statusElement) {
|
||||
statusElement.style["background-position"] = "0 3px";
|
||||
statusElement.classList.add("uploaded");
|
||||
}
|
||||
|
||||
if (currentUploadingFile < files.length) {
|
||||
@ -396,7 +431,7 @@
|
||||
fileUploadRequest = 0;
|
||||
}
|
||||
|
||||
lastRequest = 'upload.lua?cmd=upload&filename=' + file.name + '&filesize=' + file.size + '&len=' + chunkLen + '&offset=' + sendingOffset + '&data=' + filedata;
|
||||
lastRequest = 'upload.lua?cmd=upload&filename=' + uploadDir + file.name + '&filesize=' + file.size + '&len=' + chunkLen + '&offset=' + sendingOffset + '&data=' + filedata;
|
||||
|
||||
fileUploadRequest.timeout = 5000;
|
||||
fileUploadRequest.open('GET', lastRequest, true);
|
||||
@ -406,6 +441,16 @@
|
||||
fr.readAsArrayBuffer(file);
|
||||
}
|
||||
|
||||
function UploadDir(dir) {
|
||||
if (uploadingInProgress == 0) {
|
||||
document.getElementById('dir').innerHTML = "/" + dir;
|
||||
uploadDir = dir;
|
||||
if (!(uploadDir == "")) {
|
||||
uploadDir += "/";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function formatFileSize(bytes) {
|
||||
if (typeof bytes !== 'number') {
|
||||
return '';
|
||||
@ -494,14 +539,14 @@
|
||||
|
||||
document.getElementById('fileInfo').innerHTML = '';
|
||||
|
||||
var tpl = '<li class="working"><p style="left: 30px;">%filenamelink%<i>%filesize%</i></p><span id="fileStatus" onclick="RemoveFile(\'%filename%\');"></span></li>';
|
||||
var tpl = '<li class="working"><p style="left: 30px;">%filenamelink%<i>%filesize%</i></p><span class="delete" id="fileStatus" onclick="RemoveFile(\'%filename%\');"></span></li>';
|
||||
var tplTotal = '<li class="working"><p style="left: 30px;">Used:<i>%used%</i></p></li><li class="working"><p style="left: 30px;">Free:<i>%free%</i></p></li><li class="working"><p style="left: 30px;">Total:<i>%total%</i></p></li>';
|
||||
|
||||
var append, link;
|
||||
|
||||
Keys(fileList).sort(function(a,b){var c=a.toLowerCase(),d=b.toLowerCase();return c<d?-1:c>d?1:0}).forEach(function(item) {
|
||||
if (!(item.match(/\.lc$/ig))) {
|
||||
link = item.replace(/\.gz$/g, '');
|
||||
if (!item.match(/\.lc$/ig) && item.match(/^http\//ig)) {
|
||||
link = item.replace(/\.gz$/g, '').replace(/^http\//g, '');
|
||||
append = tpl.replace(/%filenamelink%/g, '<a href="' + link + '" target="_blank">' + item + '</a>');
|
||||
}
|
||||
else {
|
||||
@ -549,6 +594,10 @@
|
||||
<body>
|
||||
<div id="dropbox" class="dropBox">
|
||||
<div id="upload">
|
||||
<div id="uploaddir" class="uploadDir">
|
||||
<a onclick='UploadDir("");'>/</a>
|
||||
<a onclick='UploadDir("http");'>/http</a>
|
||||
<div id="selectedDir">selected Directory: <div id = "dir">bla</div></div></div>
|
||||
<div id="drop">
|
||||
Drop Here
|
||||
|
||||
|
||||
@ -48,18 +48,16 @@ return function (connection, req, args)
|
||||
|
||||
if (mbCmd == 'upload') then
|
||||
if (fieldsCount > 5) then
|
||||
if (mbFilename ~= 'upload.lua') then
|
||||
if (mbFilename ~= 'http/upload.lua') then
|
||||
connection:send('"offset":"' .. mbOffset .. '",')
|
||||
connection:send('"len":"' .. mbLen .. '",')
|
||||
connection:send('"filename":"' .. mbFilename .. '"')
|
||||
|
||||
mbFilename = 'http/' .. mbFilename
|
||||
|
||||
|
||||
for i=1,string.len(mbData),2 do
|
||||
currentByte = tonumber(string.sub(mbData, i, i + 1), 16)
|
||||
binaryData = binaryData .. string.char(currentByte)
|
||||
end
|
||||
|
||||
|
||||
local mbTmpFilename = string.sub(mbFilename, 0, 27) .. '.dnl'
|
||||
if (mbOffset > 0) then
|
||||
file.open(mbTmpFilename,'a+')
|
||||
@ -77,7 +75,7 @@ return function (connection, req, args)
|
||||
file.remove(mbFilename)
|
||||
file.rename(mbTmpFilename, mbFilename)
|
||||
file.remove(mbTmpFilename)
|
||||
|
||||
|
||||
if (string.sub(mbFilename, -4) == '.lua') then
|
||||
file.remove(string.sub(mbFilename, 0, -3) .. "lc")
|
||||
node.compile(mbFilename)
|
||||
@ -90,39 +88,34 @@ return function (connection, req, args)
|
||||
local remaining, used, total=file.fsinfo()
|
||||
|
||||
local headerExist = 0
|
||||
|
||||
|
||||
connection:send('"files":{')
|
||||
|
||||
|
||||
for name, size in pairs(file.list()) do
|
||||
local isHttpFile = string.match(name, "(http/)") ~= nil
|
||||
|
||||
if isHttpFile then
|
||||
if (headerExist > 0) then
|
||||
connection:send(',')
|
||||
end
|
||||
|
||||
local url = string.match(name, ".*/(.*)")
|
||||
|
||||
connection:send('"' .. url .. '":"' .. size .. '"')
|
||||
|
||||
headerExist = 1
|
||||
end
|
||||
if (headerExist > 0) then
|
||||
connection:send(',')
|
||||
end
|
||||
|
||||
local url = string.match(name, ".*/(.*)")
|
||||
url = name
|
||||
connection:send('"' .. url .. '":"' .. size .. '"')
|
||||
|
||||
headerExist = 1
|
||||
end
|
||||
|
||||
|
||||
connection:send('},')
|
||||
|
||||
|
||||
connection:send('"total":"' .. total .. '",')
|
||||
connection:send('"used":"' .. used .. '",')
|
||||
connection:send('"free":"' .. remaining .. '"')
|
||||
elseif (mbCmd == 'remove') then
|
||||
if (fieldsCount > 1) then
|
||||
if (mbFilename ~= 'upload.lua') and (mbFilename ~= 'upload.lc') and (mbFilename ~= 'upload.html.gz') then
|
||||
file.remove('http/' .. mbFilename)
|
||||
if (mbFilename ~= 'http/upload.lua') and (mbFilename ~= 'http/upload.lc') and (mbFilename ~= 'http/upload.html.gz') then
|
||||
file.remove(mbFilename)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
connection:send('}')
|
||||
collectgarbage()
|
||||
end
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user