reformat html (#124)
This commit is contained in:
parent
ca4fb20c00
commit
f13a10a01f
@ -1,21 +1,19 @@
|
|||||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
<!doctype html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
||||||
<title>Nice cars</title>
|
<title>Nice cars</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<h1>Nice cars!</h1>
|
<h1>Nice cars!</h1>
|
||||||
<p>
|
<p>
|
||||||
This page loads "large" images of fancy cars. It is meant to serve as a stress test for nodemcu-httpserver.<br>
|
This page loads "large" images of fancy cars. It is meant to serve as a stress test for nodemcu-httpserver.<br>
|
||||||
It works with three embedded images of cars, but the server crashes with four. Edit this file and try it yourself.<br>
|
It works with three embedded images of cars, but the server crashes with four. Edit this file and try it yourself.<br>
|
||||||
Whoever manages to modify nodemcu-httpserver to load all four images without crashing wins a prize!
|
Whoever manages to modify nodemcu-httpserver to load all four images without crashing wins a prize!
|
||||||
</p>
|
</p>
|
||||||
<figure><img src="cars-ferrari.jpg" /><figcaption>Ferrari</figcaption></figure>
|
<figure><img src="cars-ferrari.jpg" /><figcaption>Ferrari</figcaption></figure>
|
||||||
<figure><img src="cars-lambo.jpg" /><figcaption>Lamborghini</figcaption></figure>
|
<figure><img src="cars-lambo.jpg" /><figcaption>Lamborghini</figcaption></figure>
|
||||||
<figure><img src="cars-mas.jpg" /><figcaption>Maserati</figcaption></figure>
|
<figure><img src="cars-mas.jpg" /><figcaption>Maserati</figcaption></figure>
|
||||||
<figure><img src="cars-porsche.jpg" /><figcaption>Porsche</figcaption></figure>
|
<figure><img src="cars-porsche.jpg" /><figcaption>Porsche</figcaption></figure>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -18,7 +18,7 @@ return function (connection, req, args)
|
|||||||
|
|
||||||
dofile("httpserver-header.lc")(connection, 200, 'html')
|
dofile("httpserver-header.lc")(connection, 200, 'html')
|
||||||
connection:send([===[
|
connection:send([===[
|
||||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
<!doctype html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
||||||
|
|||||||
@ -1,24 +1,22 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<script>
|
<title>Counter</title>
|
||||||
document.addEventListener("DOMContentLoaded", function ()
|
<script>
|
||||||
{
|
document.addEventListener("DOMContentLoaded", function ()
|
||||||
var number = window.location.search;
|
{
|
||||||
if ( number == '') number = 0;
|
var number = window.location.search;
|
||||||
else number = number.substring(1,);
|
if ( number == '') number = 0;
|
||||||
|
else number = number.substring(1,);
|
||||||
number = parseInt(number) + 1;
|
number = parseInt(number) + 1;
|
||||||
document.getElementById('count').innerHTML = number;
|
document.getElementById('count').innerHTML = number;
|
||||||
window.location.search = '?' + number;
|
window.location.search = '?' + number;
|
||||||
}
|
})
|
||||||
)
|
</script>
|
||||||
</script>
|
</head>
|
||||||
</head>
|
<body>
|
||||||
<body>
|
<br>This page reloads itself as fast as it can to test the server.<br>
|
||||||
<br>This page reloads itself as fast as it can to test the server.</br>
|
<br>It is meant as a stress test to see when and if the server fails.<br>
|
||||||
<br>It is meant as a stress test to see when and if the server fails.</br>
|
<h1 id="count" class="countclass">-</h1>
|
||||||
<h1 id="count" class="countclass">
|
</body>
|
||||||
</h1>
|
|
||||||
</body>
|
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
@ -16,7 +16,7 @@ return function (connection, req, args)
|
|||||||
connection:send("<b>Flash Address: </b> " .. flashAddress .. " bytes<br/>\n" ..
|
connection:send("<b>Flash Address: </b> " .. flashAddress .. " bytes<br/>\n" ..
|
||||||
"<b>Flash Size: </b> " .. flashSize .. " bytes<br/>\n")
|
"<b>Flash Size: </b> " .. flashSize .. " bytes<br/>\n")
|
||||||
|
|
||||||
connection:send("<p>\n<b>Files:</b><br/>\n<ul>\n")
|
connection:send("<b>Files:</b><br/>\n<ul>\n")
|
||||||
for name, size in pairs(file.list()) do
|
for name, size in pairs(file.list()) do
|
||||||
local isHttpFile = string.match(name, "(http/)") ~= nil
|
local isHttpFile = string.match(name, "(http/)") ~= nil
|
||||||
if isHttpFile then
|
if isHttpFile then
|
||||||
@ -24,6 +24,6 @@ return function (connection, req, args)
|
|||||||
connection:send(' <li><a href="' .. url .. '">' .. url .. "</a> (" .. size .. " bytes)</li>\n")
|
connection:send(' <li><a href="' .. url .. '">' .. url .. "</a> (" .. size .. " bytes)</li>\n")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
connection:send("</ul>\n</p>\n</body></html>")
|
connection:send("</ul>\n</body></html>")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@ -1,32 +1,31 @@
|
|||||||
<html>
|
<!doctype html>
|
||||||
<head>
|
<html lang="en">
|
||||||
<title>Garage control</title>
|
<head>
|
||||||
</head>
|
<title>Garage control</title>
|
||||||
<body>
|
<style>
|
||||||
|
div{
|
||||||
<div align="center">
|
text-align: center;
|
||||||
|
}
|
||||||
<h2>Door 1</h2>
|
</style>
|
||||||
|
</head>
|
||||||
<form action="garage_door.lua" method="post"/>
|
<body>
|
||||||
<input type="hidden" name="door" value="1"/>
|
<div>
|
||||||
<input type="submit" name="action" value="status"/>
|
<h2>Door 1</h2>
|
||||||
<input type="submit" name="action" value="open"/>
|
<form action="garage_door.lua" method="post">
|
||||||
<input type="submit" name="action" value="close"/>
|
<input type="hidden" name="door" value="1">
|
||||||
<input type="submit" name="action" value="toggle"/>
|
<input type="submit" name="action" value="status">
|
||||||
</form>
|
<input type="submit" name="action" value="open">
|
||||||
|
<input type="submit" name="action" value="close">
|
||||||
<h2>Door 2</h2>
|
<input type="submit" name="action" value="toggle">
|
||||||
|
</form>
|
||||||
<form action="garage_door.lua" method="post"/>
|
<h2>Door 2</h2>
|
||||||
<input type="hidden" name="door" value="2"/>
|
<form action="garage_door.lua" method="post">
|
||||||
<input type="submit" name="action" value="status"/>
|
<input type="hidden" name="door" value="2">
|
||||||
<input type="submit" name="action" value="open"/>
|
<input type="submit" name="action" value="status">
|
||||||
<input type="submit" name="action" value="close"/>
|
<input type="submit" name="action" value="open">
|
||||||
<input type="submit" name="action" value="toggle"/>
|
<input type="submit" name="action" value="close">
|
||||||
</form>
|
<input type="submit" name="action" value="toggle">
|
||||||
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
</body>
|
||||||
</body>
|
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
@ -1,12 +1,11 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<link rel="stylesheet" type="text/css" href="garage_door_control.css">
|
<link rel="stylesheet" type="text/css" href="garage_door_control.css">
|
||||||
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
|
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>Garage Remote</title>
|
<title>Garage Remote</title>
|
||||||
</head>
|
<script>
|
||||||
<script>
|
|
||||||
var xmlHttp = null;
|
var xmlHttp = null;
|
||||||
|
|
||||||
function pushTheButton(door)
|
function pushTheButton(door)
|
||||||
@ -68,17 +67,22 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
<body bgcolor="#777777">
|
<style>
|
||||||
<div id="remote">
|
body {
|
||||||
<div id="label" class="start"></div>
|
background-color: #777;
|
||||||
<a href="#" onclick="pushTheButton(1);" class="button button-1">
|
}
|
||||||
<span>I</span>
|
</style>
|
||||||
</a>
|
</head>
|
||||||
<a href="#" onclick="pushTheButton(2); " class="button button-2">
|
<body>
|
||||||
<span>II</span>
|
<div id="remote">
|
||||||
</a>
|
<div id="label" class="start"></div>
|
||||||
<div id="spacer"></div>
|
<a href="#" onclick="pushTheButton(1);" class="button button-1">
|
||||||
</div>
|
<span>I</span>
|
||||||
|
</a>
|
||||||
|
<a href="#" onclick="pushTheButton(2); " class="button button-2">
|
||||||
|
<span>II</span>
|
||||||
|
</a>
|
||||||
|
<div id="spacer"></div>
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|||||||
@ -1,24 +1,29 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<title>Served by an ESP8266</title>
|
<title>Served by an ESP8266</title>
|
||||||
</head>
|
<style>
|
||||||
<body>
|
div{
|
||||||
<h1>Hello World!</h1>
|
text-align: center;
|
||||||
<div align="center">
|
}
|
||||||
<img src="underconstruction.gif">
|
</style>
|
||||||
</div>
|
</head>
|
||||||
<p>
|
<body>
|
||||||
|
<h1>Hello World!</h1>
|
||||||
|
<div>
|
||||||
|
<img alt="under construction" src="underconstruction.gif">
|
||||||
|
</div>
|
||||||
|
<p>
|
||||||
This page is served by <b>nodemcu-httpserver</b> running on an ESP8266 that uses the <a href="https://github.com/nodemcu/nodemcu-firmware">NodeMCU</a> firmware.
|
This page is served by <b>nodemcu-httpserver</b> running on an ESP8266 that uses the <a href="https://github.com/nodemcu/nodemcu-firmware">NodeMCU</a> firmware.
|
||||||
NodeMCU puts a <a href="http://www.lua.org">Lua</a> interpreter inside the ESP8266. This is surely one of the smallest web servers to date!
|
NodeMCU puts a <a href="http://www.lua.org">Lua</a> interpreter inside the ESP8266. This is surely one of the smallest web servers to date!
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<h3>Where's the source code?</h3>
|
<h3>Where's the source code?</h3>
|
||||||
<p>You can find the Lua code for nodemcu-httpserver in <a href="https://github.com/marcoskirsch/nodemcu-httpserver">GitHub</a></p>
|
<p>You can find the Lua code for nodemcu-httpserver in <a href="https://github.com/marcoskirsch/nodemcu-httpserver">GitHub</a></p>
|
||||||
|
|
||||||
<h3>Serve me some pages!</h3>
|
<h3>Serve me some pages!</h3>
|
||||||
<ul>
|
<ul>
|
||||||
<li><a href="index.html">Index</a>: This page (static)</li>
|
<li><a href="index.html">Index</a>: This page (static)</li>
|
||||||
<li><a href="hello_world.txt">A text file</a>: Simple text, to verify MIME type is ok. (static)</li>
|
<li><a href="hello_world.txt">A text file</a>: Simple text, to verify MIME type is ok. (static)</li>
|
||||||
<li><a href="cars.html">Nice cars</a>: Stress test, loads several "large" images. Makes the chip panic and restart :( (static)</li>
|
<li><a href="cars.html">Nice cars</a>: Stress test, loads several "large" images. Makes the chip panic and restart :( (static)</li>
|
||||||
@ -33,6 +38,6 @@
|
|||||||
<li><a href="file_list.lua">List all server files</a>: Displays a list of all the server files. (Lua)</li>
|
<li><a href="file_list.lua">List all server files</a>: Displays a list of all the server files. (Lua)</li>
|
||||||
<li><a href="upload.html">Upload</a>: Update, remove, list files on the server. Beware security implications. By <a href="https://github.com/ATAMAH">ATAMAH</a>.</li>
|
<li><a href="upload.html">Upload</a>: Update, remove, list files on the server. Beware security implications. By <a href="https://github.com/ATAMAH">ATAMAH</a>.</li>
|
||||||
<li><a href="foo.html">Foo</a>: A file that doesn't exist. Should error (404 error)</li>
|
<li><a href="foo.html">Foo</a>: A file that doesn't exist. Should error (404 error)</li>
|
||||||
</ul>
|
</ul>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
205
http/upload.css
Normal file
205
http/upload.css
Normal file
@ -0,0 +1,205 @@
|
|||||||
|
html{
|
||||||
|
background-color:#ebebec;
|
||||||
|
|
||||||
|
background-image:-webkit-radial-gradient(center, #ebebec, #b4b4b4);
|
||||||
|
background-image:-moz-radial-gradient(center, #ebebec, #b4b4b4);
|
||||||
|
background-image:radial-gradient(center, #ebebec, #b4b4b4);
|
||||||
|
}
|
||||||
|
|
||||||
|
body{
|
||||||
|
font:15px/1.3 Arial, sans-serif;
|
||||||
|
color: #4f4f4f;
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
overflow-x:hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
a, a:visited {
|
||||||
|
outline:none;
|
||||||
|
color:#389dc1;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover{
|
||||||
|
text-decoration:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
section, footer, header, aside{
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.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;
|
||||||
|
|
||||||
|
background-image:-webkit-linear-gradient(top, #373a3d, #313437);
|
||||||
|
background-image:-moz-linear-gradient(top, #373a3d, #313437);
|
||||||
|
background-image:linear-gradient(top, #373a3d, #313437);
|
||||||
|
|
||||||
|
width:450px;
|
||||||
|
padding:30px;
|
||||||
|
border-radius:3px;
|
||||||
|
|
||||||
|
margin:10px auto 10px;
|
||||||
|
box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
|
||||||
|
}
|
||||||
|
|
||||||
|
#drop{
|
||||||
|
background-color: #2E3134;
|
||||||
|
padding: 40px 50px;
|
||||||
|
margin-bottom: 30px;
|
||||||
|
border: 20px solid rgba(0, 0, 0, 0);
|
||||||
|
border-radius: 3px;
|
||||||
|
/* no external files */
|
||||||
|
border-image: url('') 25 repeat;
|
||||||
|
text-align: center;
|
||||||
|
text-transform: uppercase;
|
||||||
|
|
||||||
|
font-size:16px;
|
||||||
|
font-weight:bold;
|
||||||
|
color:#7f858a;
|
||||||
|
}
|
||||||
|
|
||||||
|
#drop a{
|
||||||
|
background-color:#007a96;
|
||||||
|
padding:12px 26px;
|
||||||
|
color:#fff;
|
||||||
|
font-size:14px;
|
||||||
|
border-radius:2px;
|
||||||
|
cursor:pointer;
|
||||||
|
display:block;
|
||||||
|
margin-top:12px;
|
||||||
|
line-height:1;
|
||||||
|
width:100px;
|
||||||
|
margin-left: 75px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#drop a:hover{
|
||||||
|
background-color:#0986a3;
|
||||||
|
}
|
||||||
|
|
||||||
|
#drop input{
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul{
|
||||||
|
list-style:none;
|
||||||
|
margin:0 -30px;
|
||||||
|
border-top:1px solid #2b2e31;
|
||||||
|
border-bottom:1px solid #3d4043;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li{
|
||||||
|
|
||||||
|
background-color:#333639;
|
||||||
|
|
||||||
|
background-image:-webkit-linear-gradient(top, #333639, #303335);
|
||||||
|
background-image:-moz-linear-gradient(top, #333639, #303335);
|
||||||
|
background-image:linear-gradient(top, #333639, #303335);
|
||||||
|
|
||||||
|
border-top:1px solid #3d4043;
|
||||||
|
border-bottom:1px solid #2b2e31;
|
||||||
|
padding:15px;
|
||||||
|
height: 52px;
|
||||||
|
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li input{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li p{
|
||||||
|
width: 300px;
|
||||||
|
overflow: hidden;
|
||||||
|
white-space: nowrap;
|
||||||
|
color: #EEE;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
position: absolute;
|
||||||
|
top: 8px;
|
||||||
|
left: 100px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li i{
|
||||||
|
font-weight: normal;
|
||||||
|
font-style:normal;
|
||||||
|
color:#7f7f7f;
|
||||||
|
display:block;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li canvas{
|
||||||
|
top: 5px;
|
||||||
|
left: 20px;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
.delete:after{
|
||||||
|
color: #ff0000;
|
||||||
|
content: "\2718";
|
||||||
|
}
|
||||||
|
|
||||||
|
.uploaded:after{
|
||||||
|
color: #00ff00;
|
||||||
|
content: "\2714";
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li span{
|
||||||
|
width: 15px;
|
||||||
|
height: 12px;
|
||||||
|
cursor:pointer;
|
||||||
|
position: absolute;
|
||||||
|
top: 34px;
|
||||||
|
right: 33px;
|
||||||
|
font-size:18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li.working span{
|
||||||
|
height: 16px;
|
||||||
|
background-position: 0 -12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#upload ul li.error p{
|
||||||
|
color:red;
|
||||||
|
}
|
||||||
|
|
||||||
|
.chart {
|
||||||
|
position:relative;
|
||||||
|
margin:0px;
|
||||||
|
width:48px; height:48px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.fileInfo {
|
||||||
|
text-align: center;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #7f858a;
|
||||||
|
margin-top: 24px;
|
||||||
|
margin-bottom: 24px;
|
||||||
|
text-transform: uppercase;
|
||||||
|
}
|
||||||
644
http/upload.html
644
http/upload.html
@ -1,617 +1,31 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<style type="text/css">
|
<title>Upload</title>
|
||||||
html{
|
<link rel="stylesheet" type="text/css" href="upload.css"/>
|
||||||
background-color:#ebebec;
|
<script src="upload.js"></script>
|
||||||
|
</head>
|
||||||
background-image:-webkit-radial-gradient(center, #ebebec, #b4b4b4);
|
<body>
|
||||||
background-image:-moz-radial-gradient(center, #ebebec, #b4b4b4);
|
<div id="dropbox" class="dropBox">
|
||||||
background-image:radial-gradient(center, #ebebec, #b4b4b4);
|
<div id="upload">
|
||||||
}
|
<div id="uploaddir" class="uploadDir">
|
||||||
|
<a onclick='UploadDir("");'>/</a>
|
||||||
body{
|
<a onclick='UploadDir("http");'>/http</a>
|
||||||
font:15px/1.3 Arial, sans-serif;
|
<div id="selectedDir">selected Directory: <div id = "dir">bla</div></div></div>
|
||||||
color: #4f4f4f;
|
<div id="drop">
|
||||||
margin:0;
|
Drop Here
|
||||||
padding:0;
|
|
||||||
overflow-x:hidden;
|
<a onclick='document.getElementById("browseInput").click();'>Browse</a>
|
||||||
}
|
<a onclick='UploadFiles();'>Upload</a>
|
||||||
|
<form><input id="browseInput" type="file" name="upl" onclick="this.form.reset();" onchange="handleFiles(this.files);" multiple /></form>
|
||||||
a, a:visited {
|
</div>
|
||||||
outline:none;
|
|
||||||
color:#389dc1;
|
<ul id="fileList">
|
||||||
}
|
</ul>
|
||||||
|
<div class="fileInfo">Files on device:</div>
|
||||||
a:hover{
|
<ul id="fileInfo">
|
||||||
text-decoration:none;
|
</ul>
|
||||||
}
|
</div>
|
||||||
|
</div>
|
||||||
section, footer, header, aside{
|
</body>
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
|
|
||||||
.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;
|
|
||||||
|
|
||||||
background-image:-webkit-linear-gradient(top, #373a3d, #313437);
|
|
||||||
background-image:-moz-linear-gradient(top, #373a3d, #313437);
|
|
||||||
background-image:linear-gradient(top, #373a3d, #313437);
|
|
||||||
|
|
||||||
width:450px;
|
|
||||||
padding:30px;
|
|
||||||
border-radius:3px;
|
|
||||||
|
|
||||||
margin:10px auto 10px;
|
|
||||||
box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
|
|
||||||
}
|
|
||||||
|
|
||||||
#drop{
|
|
||||||
background-color: #2E3134;
|
|
||||||
padding: 40px 50px;
|
|
||||||
margin-bottom: 30px;
|
|
||||||
border: 20px solid rgba(0, 0, 0, 0);
|
|
||||||
border-radius: 3px;
|
|
||||||
/* no external files */
|
|
||||||
border-image: url('') 25 repeat;
|
|
||||||
text-align: center;
|
|
||||||
text-transform: uppercase;
|
|
||||||
|
|
||||||
font-size:16px;
|
|
||||||
font-weight:bold;
|
|
||||||
color:#7f858a;
|
|
||||||
}
|
|
||||||
|
|
||||||
#drop a{
|
|
||||||
background-color:#007a96;
|
|
||||||
padding:12px 26px;
|
|
||||||
color:#fff;
|
|
||||||
font-size:14px;
|
|
||||||
border-radius:2px;
|
|
||||||
cursor:pointer;
|
|
||||||
display:block;
|
|
||||||
margin-top:12px;
|
|
||||||
line-height:1;
|
|
||||||
width:100px;
|
|
||||||
margin-left: 75px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#drop a:hover{
|
|
||||||
background-color:#0986a3;
|
|
||||||
}
|
|
||||||
|
|
||||||
#drop input{
|
|
||||||
display:none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul{
|
|
||||||
list-style:none;
|
|
||||||
margin:0 -30px;
|
|
||||||
border-top:1px solid #2b2e31;
|
|
||||||
border-bottom:1px solid #3d4043;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li{
|
|
||||||
|
|
||||||
background-color:#333639;
|
|
||||||
|
|
||||||
background-image:-webkit-linear-gradient(top, #333639, #303335);
|
|
||||||
background-image:-moz-linear-gradient(top, #333639, #303335);
|
|
||||||
background-image:linear-gradient(top, #333639, #303335);
|
|
||||||
|
|
||||||
border-top:1px solid #3d4043;
|
|
||||||
border-bottom:1px solid #2b2e31;
|
|
||||||
padding:15px;
|
|
||||||
height: 52px;
|
|
||||||
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li input{
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li p{
|
|
||||||
width: 300px;
|
|
||||||
overflow: hidden;
|
|
||||||
white-space: nowrap;
|
|
||||||
color: #EEE;
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
position: absolute;
|
|
||||||
top: 8px;
|
|
||||||
left: 100px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li i{
|
|
||||||
font-weight: normal;
|
|
||||||
font-style:normal;
|
|
||||||
color:#7f7f7f;
|
|
||||||
display:block;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li canvas{
|
|
||||||
top: 5px;
|
|
||||||
left: 20px;
|
|
||||||
position: absolute;
|
|
||||||
}
|
|
||||||
|
|
||||||
.delete:after{
|
|
||||||
color: #ff0000;
|
|
||||||
content: "\2718";
|
|
||||||
}
|
|
||||||
|
|
||||||
.uploaded:after{
|
|
||||||
color: #00ff00;
|
|
||||||
content: "\2714";
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li span{
|
|
||||||
width: 15px;
|
|
||||||
height: 12px;
|
|
||||||
cursor:pointer;
|
|
||||||
position: absolute;
|
|
||||||
top: 34px;
|
|
||||||
right: 33px;
|
|
||||||
font-size:18px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li.working span{
|
|
||||||
height: 16px;
|
|
||||||
background-position: 0 -12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#upload ul li.error p{
|
|
||||||
color:red;
|
|
||||||
}
|
|
||||||
|
|
||||||
.chart {
|
|
||||||
position:relative;
|
|
||||||
margin:0px;
|
|
||||||
width:48px; height:48px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fileInfo {
|
|
||||||
text-align: center;
|
|
||||||
font-size: 16px;
|
|
||||||
font-weight: bold;
|
|
||||||
color: #7f858a;
|
|
||||||
margin-top: 24px;
|
|
||||||
margin-bottom: 24px;
|
|
||||||
text-transform: uppercase;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
<script>
|
|
||||||
var files = [];
|
|
||||||
var sendingOffset = 0;
|
|
||||||
var lastRequest = '';
|
|
||||||
var dataView;
|
|
||||||
var filesCount = 0;
|
|
||||||
var currentUploadingFile = 0;
|
|
||||||
var uploadOrder = [];
|
|
||||||
var uploadingInProgress = 0;
|
|
||||||
var fileUploadRequest;
|
|
||||||
|
|
||||||
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 class="delete" id="fileStatus%filenum%" onclick="DeleteFiles(%filenum%);"></span></li>';
|
|
||||||
|
|
||||||
document.addEventListener("DOMContentLoaded", function() {
|
|
||||||
var dropbox;
|
|
||||||
|
|
||||||
dropbox = document.getElementById("dropbox");
|
|
||||||
dropbox.addEventListener("dragenter", dragenter, false);
|
|
||||||
dropbox.addEventListener("dragover", dragover, false);
|
|
||||||
dropbox.addEventListener("drop", drop, false);
|
|
||||||
|
|
||||||
UpdateFileList();
|
|
||||||
|
|
||||||
UploadDir("http");
|
|
||||||
});
|
|
||||||
|
|
||||||
function dragenter(e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
e.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
function dragover(e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
e.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
function drop(e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
var dt = e.dataTransfer;
|
|
||||||
|
|
||||||
handleFiles(dt.files);
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleFiles(tfiles) {
|
|
||||||
var filesCount = tfiles.length;
|
|
||||||
files = tfiles;
|
|
||||||
currentUploadingFile = 0;
|
|
||||||
uploadOrder = [];
|
|
||||||
|
|
||||||
sendingOffset = 0;
|
|
||||||
lastRequest = '';
|
|
||||||
|
|
||||||
document.getElementById('fileList').innerHTML = '';
|
|
||||||
|
|
||||||
var fileNames = {};
|
|
||||||
|
|
||||||
for (var i = 0; i < filesCount; 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, uploadDir + tfiles[i].name);
|
|
||||||
append = append.replace(/%filesize%/g, formatFileSize(tfiles[i].size));
|
|
||||||
append = append.replace(/%filenum%/g, i);
|
|
||||||
|
|
||||||
document.getElementById('fileList').insertAdjacentHTML('beforeend', append);
|
|
||||||
|
|
||||||
UpdateGraph(0, i);
|
|
||||||
|
|
||||||
uploadOrder.push(i);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function DeleteFiles(filenum) {
|
|
||||||
var elem = document.getElementById('file' + filenum.toString());
|
|
||||||
elem.parentNode.removeChild(elem);
|
|
||||||
|
|
||||||
if (uploadingInProgress) {
|
|
||||||
if (parseInt(filenum) != uploadOrder[currentUploadingFile]) {
|
|
||||||
for (var i = 0; i < uploadOrder.length; i++) {
|
|
||||||
if (uploadOrder[i] == filenum) {
|
|
||||||
delete uploadOrder[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
uploadingInProgress = 0;
|
|
||||||
|
|
||||||
RemoveFile(files[uploadOrder[currentUploadingFile]].name + '.dnl');
|
|
||||||
|
|
||||||
for (var i = 0; i < uploadOrder.length; i++) {
|
|
||||||
if (uploadOrder[i] == filenum) {
|
|
||||||
delete uploadOrder[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
currentUploadingFile++;
|
|
||||||
totalUploaded = 0;
|
|
||||||
sendingOffset = 0;
|
|
||||||
|
|
||||||
lastRequest = '';
|
|
||||||
fileUploadRequest.abort();
|
|
||||||
fileUploadRequest = 0;
|
|
||||||
|
|
||||||
UploadFiles();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
for (var i = 0; i < uploadOrder.length; i++) {
|
|
||||||
if (uploadOrder[i] == filenum) {
|
|
||||||
delete uploadOrder[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function UploadFiles() {
|
|
||||||
if (uploadOrder[currentUploadingFile] === undefined) {
|
|
||||||
uploadingInProgress = 0;
|
|
||||||
|
|
||||||
if (currentUploadingFile < files.length - 1) {
|
|
||||||
currentUploadingFile++;
|
|
||||||
|
|
||||||
UploadFiles();
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var fileNum = uploadOrder[currentUploadingFile];
|
|
||||||
var file = files[fileNum];
|
|
||||||
var chunkLen = 0;
|
|
||||||
var filedata = '';
|
|
||||||
|
|
||||||
uploadingInProgress = 1;
|
|
||||||
|
|
||||||
var fr = new FileReader();
|
|
||||||
|
|
||||||
fr.onload = function() {
|
|
||||||
dataView = null;
|
|
||||||
dataView = new Uint8Array(fr.result);
|
|
||||||
|
|
||||||
if (file.size <= chunkSize) {
|
|
||||||
sendingOffset = 0;
|
|
||||||
chunkLen = file.size;
|
|
||||||
|
|
||||||
for (var i = 0; i < dataView.length; i++) {
|
|
||||||
if (dataView[i] < 16) {
|
|
||||||
filedata += '0';
|
|
||||||
}
|
|
||||||
|
|
||||||
filedata += dataView[i].toString(16).toUpperCase();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (dataView.length - sendingOffset > chunkSize) {
|
|
||||||
chunkLen = chunkSize;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
chunkLen = dataView.length - sendingOffset;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
for (var i = sendingOffset; i < sendingOffset + chunkLen; i++) {
|
|
||||||
if (dataView[i] < 16) {
|
|
||||||
filedata += '0';
|
|
||||||
}
|
|
||||||
|
|
||||||
filedata += dataView[i].toString(16).toUpperCase();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fileUploadRequest = new XMLHttpRequest();
|
|
||||||
|
|
||||||
fileUploadRequest.onreadystatechange = function() {
|
|
||||||
if (fileUploadRequest.readyState != 4) return;
|
|
||||||
|
|
||||||
if (fileUploadRequest.status == 200) {
|
|
||||||
if (chunkLen + sendingOffset < dataView.length) {
|
|
||||||
totalUploaded += chunkSize;
|
|
||||||
|
|
||||||
UpdateGraph(Math.round((totalUploaded / file.size) * 100), uploadOrder[currentUploadingFile]);
|
|
||||||
|
|
||||||
sendingOffset += chunkSize;
|
|
||||||
UploadFiles();
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
var statusElement = document.getElementById('fileStatus' + uploadOrder[currentUploadingFile]);
|
|
||||||
|
|
||||||
sendingOffset = 0;
|
|
||||||
|
|
||||||
UpdateGraph(100, uploadOrder[currentUploadingFile]);
|
|
||||||
|
|
||||||
uploadingInProgress = 0;
|
|
||||||
|
|
||||||
UpdateFileList();
|
|
||||||
|
|
||||||
totalUploaded = 0;
|
|
||||||
|
|
||||||
if (statusElement) {
|
|
||||||
statusElement.classList.add("uploaded");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (currentUploadingFile < files.length) {
|
|
||||||
currentUploadingFile++;
|
|
||||||
UploadFiles();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
UploadFiles();
|
|
||||||
}
|
|
||||||
|
|
||||||
fileUploadRequest = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
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);
|
|
||||||
fileUploadRequest.send();
|
|
||||||
};
|
|
||||||
|
|
||||||
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 '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bytes >= 1073741824) {
|
|
||||||
return (bytes / 1073741824).toFixed(2) + ' GB';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bytes >= 1048576) {
|
|
||||||
return (bytes / 1048576).toFixed(2) + ' MB';
|
|
||||||
}
|
|
||||||
|
|
||||||
return (bytes / 1024).toFixed(2) + ' KB';
|
|
||||||
}
|
|
||||||
|
|
||||||
function UpdateGraph(percent, id) {
|
|
||||||
var el = document.getElementById('graph' + id); // get canvas
|
|
||||||
|
|
||||||
if (!el) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var options = {
|
|
||||||
percent: el.getAttribute('data-percent') || 0,
|
|
||||||
size: el.getAttribute('data-size') || 48,
|
|
||||||
lineWidth: el.getAttribute('data-line') || 8,
|
|
||||||
rotate: el.getAttribute('data-rotate') || 0
|
|
||||||
}
|
|
||||||
|
|
||||||
var canvas = document.createElement('canvas');
|
|
||||||
|
|
||||||
if (typeof(G_vmlCanvasManager) !== 'undefined') {
|
|
||||||
G_vmlCanvasManager.initElement(canvas);
|
|
||||||
}
|
|
||||||
|
|
||||||
var ctx = canvas.getContext('2d');
|
|
||||||
canvas.width = canvas.height = options.size;
|
|
||||||
|
|
||||||
el.appendChild(canvas);
|
|
||||||
|
|
||||||
ctx.translate(options.size / 2, options.size / 2); // change center
|
|
||||||
ctx.rotate((-1 / 2 + options.rotate / 180) * Math.PI); // rotate -90 deg
|
|
||||||
|
|
||||||
var radius = (options.size - options.lineWidth) / 2;
|
|
||||||
|
|
||||||
function drawCircle(color, lineWidth, percent) {
|
|
||||||
if (percent) {
|
|
||||||
percent = Math.min(Math.max(0, percent), 1);
|
|
||||||
ctx.beginPath();
|
|
||||||
ctx.arc(0, 0, radius, 0, Math.PI * 2 * percent, false);
|
|
||||||
ctx.strokeStyle = color;
|
|
||||||
ctx.lineCap = 'round'; // butt, round or square
|
|
||||||
ctx.lineWidth = lineWidth
|
|
||||||
ctx.stroke();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
options.percent = percent;
|
|
||||||
|
|
||||||
drawCircle('#2e3134', options.lineWidth + 1, 100 / 100);
|
|
||||||
drawCircle('#007a96', options.lineWidth, options.percent / 100);
|
|
||||||
}
|
|
||||||
|
|
||||||
function Keys(obj) {
|
|
||||||
var keys = [];
|
|
||||||
|
|
||||||
for(var key in obj){
|
|
||||||
if(obj.hasOwnProperty(key)){
|
|
||||||
keys.push(key);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return keys;
|
|
||||||
}
|
|
||||||
|
|
||||||
function UpdateFileList() {
|
|
||||||
var fileListRequest = new XMLHttpRequest();
|
|
||||||
|
|
||||||
fileListRequest.onreadystatechange = function() {
|
|
||||||
if (fileListRequest.readyState != 4) return;
|
|
||||||
|
|
||||||
if (fileListRequest.status == 200) {
|
|
||||||
var fileInfo = JSON.parse(fileListRequest.responseText);
|
|
||||||
var fileList = fileInfo['files'];
|
|
||||||
|
|
||||||
document.getElementById('fileInfo').innerHTML = '';
|
|
||||||
|
|
||||||
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) && 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 {
|
|
||||||
append = tpl.replace(/%filenamelink%/g, item);
|
|
||||||
}
|
|
||||||
|
|
||||||
append = append.replace(/%filename%/g, item);
|
|
||||||
append = append.replace(/%filesize%/g, formatFileSize(parseInt(fileList[item])));
|
|
||||||
document.getElementById('fileInfo').insertAdjacentHTML('beforeend', append);
|
|
||||||
});
|
|
||||||
|
|
||||||
append = tplTotal.replace(/%used%/g, formatFileSize(parseInt(fileInfo['used'])));
|
|
||||||
append = append.replace(/%free%/g, formatFileSize(parseInt(fileInfo['free'])));
|
|
||||||
append = append.replace(/%total%/g, formatFileSize(parseInt(fileInfo['total'])));
|
|
||||||
|
|
||||||
document.getElementById('fileInfo').insertAdjacentHTML('beforeend', append);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
fileListRequest = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
fileListRequest.open('GET', 'upload.lua?cmd=list', true);
|
|
||||||
fileListRequest.send();
|
|
||||||
}
|
|
||||||
|
|
||||||
function RemoveFile(name) {
|
|
||||||
var fileRemoveRequest = new XMLHttpRequest();
|
|
||||||
|
|
||||||
fileRemoveRequest.onreadystatechange = function() {
|
|
||||||
if (fileRemoveRequest.readyState != 4) return;
|
|
||||||
|
|
||||||
if (fileRemoveRequest.status == 200) {
|
|
||||||
UpdateFileList();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fileRemoveRequest.open('GET', 'upload.lua?cmd=remove&filename=' + name, true);
|
|
||||||
fileRemoveRequest.send();
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
</head>
|
|
||||||
<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
|
|
||||||
|
|
||||||
<a onclick='document.getElementById("browseInput").click();'>Browse</a>
|
|
||||||
<a onclick='UploadFiles();'>Upload</a>
|
|
||||||
<form><input id="browseInput" type="file" name="upl" onclick="this.form.reset();" onchange="handleFiles(this.files);" multiple /></form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<ul id="fileList">
|
|
||||||
</ul>
|
|
||||||
<div class="fileInfo">Files on device:</div>
|
|
||||||
<ul id="fileInfo">
|
|
||||||
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</body>
|
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
380
http/upload.js
Normal file
380
http/upload.js
Normal file
@ -0,0 +1,380 @@
|
|||||||
|
var files = [];
|
||||||
|
var sendingOffset = 0;
|
||||||
|
var lastRequest = '';
|
||||||
|
var dataView;
|
||||||
|
var filesCount = 0;
|
||||||
|
var currentUploadingFile = 0;
|
||||||
|
var uploadOrder = [];
|
||||||
|
var uploadingInProgress = 0;
|
||||||
|
var fileUploadRequest;
|
||||||
|
|
||||||
|
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 class="delete" id="fileStatus%filenum%" onclick="DeleteFiles(%filenum%);"></span></li>';
|
||||||
|
|
||||||
|
document.addEventListener("DOMContentLoaded", function() {
|
||||||
|
var dropbox;
|
||||||
|
|
||||||
|
dropbox = document.getElementById("dropbox");
|
||||||
|
dropbox.addEventListener("dragenter", dragenter, false);
|
||||||
|
dropbox.addEventListener("dragover", dragover, false);
|
||||||
|
dropbox.addEventListener("drop", drop, false);
|
||||||
|
|
||||||
|
UpdateFileList();
|
||||||
|
|
||||||
|
UploadDir("http");
|
||||||
|
});
|
||||||
|
|
||||||
|
function dragenter(e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
function dragover(e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
function drop(e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
var dt = e.dataTransfer;
|
||||||
|
|
||||||
|
handleFiles(dt.files);
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleFiles(tfiles) {
|
||||||
|
var filesCount = tfiles.length;
|
||||||
|
files = tfiles;
|
||||||
|
currentUploadingFile = 0;
|
||||||
|
uploadOrder = [];
|
||||||
|
|
||||||
|
sendingOffset = 0;
|
||||||
|
lastRequest = '';
|
||||||
|
|
||||||
|
document.getElementById('fileList').innerHTML = '';
|
||||||
|
|
||||||
|
var fileNames = {};
|
||||||
|
|
||||||
|
for (var i = 0; i < filesCount; 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, uploadDir + tfiles[i].name);
|
||||||
|
append = append.replace(/%filesize%/g, formatFileSize(tfiles[i].size));
|
||||||
|
append = append.replace(/%filenum%/g, i);
|
||||||
|
|
||||||
|
document.getElementById('fileList').insertAdjacentHTML('beforeend', append);
|
||||||
|
|
||||||
|
UpdateGraph(0, i);
|
||||||
|
|
||||||
|
uploadOrder.push(i);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function DeleteFiles(filenum) {
|
||||||
|
var elem = document.getElementById('file' + filenum.toString());
|
||||||
|
elem.parentNode.removeChild(elem);
|
||||||
|
|
||||||
|
if (uploadingInProgress) {
|
||||||
|
if (parseInt(filenum) != uploadOrder[currentUploadingFile]) {
|
||||||
|
for (var i = 0; i < uploadOrder.length; i++) {
|
||||||
|
if (uploadOrder[i] == filenum) {
|
||||||
|
delete uploadOrder[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
uploadingInProgress = 0;
|
||||||
|
|
||||||
|
RemoveFile(files[uploadOrder[currentUploadingFile]].name + '.dnl');
|
||||||
|
|
||||||
|
for (var i = 0; i < uploadOrder.length; i++) {
|
||||||
|
if (uploadOrder[i] == filenum) {
|
||||||
|
delete uploadOrder[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
currentUploadingFile++;
|
||||||
|
totalUploaded = 0;
|
||||||
|
sendingOffset = 0;
|
||||||
|
|
||||||
|
lastRequest = '';
|
||||||
|
fileUploadRequest.abort();
|
||||||
|
fileUploadRequest = 0;
|
||||||
|
|
||||||
|
UploadFiles();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
for (var i = 0; i < uploadOrder.length; i++) {
|
||||||
|
if (uploadOrder[i] == filenum) {
|
||||||
|
delete uploadOrder[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function UploadFiles() {
|
||||||
|
if (uploadOrder[currentUploadingFile] === undefined) {
|
||||||
|
uploadingInProgress = 0;
|
||||||
|
|
||||||
|
if (currentUploadingFile < files.length - 1) {
|
||||||
|
currentUploadingFile++;
|
||||||
|
|
||||||
|
UploadFiles();
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var fileNum = uploadOrder[currentUploadingFile];
|
||||||
|
var file = files[fileNum];
|
||||||
|
var chunkLen = 0;
|
||||||
|
var filedata = '';
|
||||||
|
|
||||||
|
uploadingInProgress = 1;
|
||||||
|
|
||||||
|
var fr = new FileReader();
|
||||||
|
|
||||||
|
fr.onload = function() {
|
||||||
|
dataView = null;
|
||||||
|
dataView = new Uint8Array(fr.result);
|
||||||
|
|
||||||
|
if (file.size <= chunkSize) {
|
||||||
|
sendingOffset = 0;
|
||||||
|
chunkLen = file.size;
|
||||||
|
|
||||||
|
for (var i = 0; i < dataView.length; i++) {
|
||||||
|
if (dataView[i] < 16) {
|
||||||
|
filedata += '0';
|
||||||
|
}
|
||||||
|
|
||||||
|
filedata += dataView[i].toString(16).toUpperCase();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (dataView.length - sendingOffset > chunkSize) {
|
||||||
|
chunkLen = chunkSize;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
chunkLen = dataView.length - sendingOffset;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
for (var i = sendingOffset; i < sendingOffset + chunkLen; i++) {
|
||||||
|
if (dataView[i] < 16) {
|
||||||
|
filedata += '0';
|
||||||
|
}
|
||||||
|
|
||||||
|
filedata += dataView[i].toString(16).toUpperCase();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fileUploadRequest = new XMLHttpRequest();
|
||||||
|
|
||||||
|
fileUploadRequest.onreadystatechange = function() {
|
||||||
|
if (fileUploadRequest.readyState != 4) return;
|
||||||
|
|
||||||
|
if (fileUploadRequest.status == 200) {
|
||||||
|
if (chunkLen + sendingOffset < dataView.length) {
|
||||||
|
totalUploaded += chunkSize;
|
||||||
|
|
||||||
|
UpdateGraph(Math.round((totalUploaded / file.size) * 100), uploadOrder[currentUploadingFile]);
|
||||||
|
|
||||||
|
sendingOffset += chunkSize;
|
||||||
|
UploadFiles();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var statusElement = document.getElementById('fileStatus' + uploadOrder[currentUploadingFile]);
|
||||||
|
|
||||||
|
sendingOffset = 0;
|
||||||
|
|
||||||
|
UpdateGraph(100, uploadOrder[currentUploadingFile]);
|
||||||
|
|
||||||
|
uploadingInProgress = 0;
|
||||||
|
|
||||||
|
UpdateFileList();
|
||||||
|
|
||||||
|
totalUploaded = 0;
|
||||||
|
|
||||||
|
if (statusElement) {
|
||||||
|
statusElement.classList.add("uploaded");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (currentUploadingFile < files.length) {
|
||||||
|
currentUploadingFile++;
|
||||||
|
UploadFiles();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
UploadFiles();
|
||||||
|
}
|
||||||
|
|
||||||
|
fileUploadRequest = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
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);
|
||||||
|
fileUploadRequest.send();
|
||||||
|
};
|
||||||
|
|
||||||
|
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 '';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (bytes >= 1073741824) {
|
||||||
|
return (bytes / 1073741824).toFixed(2) + ' GB';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (bytes >= 1048576) {
|
||||||
|
return (bytes / 1048576).toFixed(2) + ' MB';
|
||||||
|
}
|
||||||
|
|
||||||
|
return (bytes / 1024).toFixed(2) + ' KB';
|
||||||
|
}
|
||||||
|
|
||||||
|
function UpdateGraph(percent, id) {
|
||||||
|
var el = document.getElementById('graph' + id); // get canvas
|
||||||
|
|
||||||
|
if (!el) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var options = {
|
||||||
|
percent: el.getAttribute('data-percent') || 0,
|
||||||
|
size: el.getAttribute('data-size') || 48,
|
||||||
|
lineWidth: el.getAttribute('data-line') || 8,
|
||||||
|
rotate: el.getAttribute('data-rotate') || 0
|
||||||
|
}
|
||||||
|
|
||||||
|
var canvas = document.createElement('canvas');
|
||||||
|
|
||||||
|
if (typeof(G_vmlCanvasManager) !== 'undefined') {
|
||||||
|
G_vmlCanvasManager.initElement(canvas);
|
||||||
|
}
|
||||||
|
|
||||||
|
var ctx = canvas.getContext('2d');
|
||||||
|
canvas.width = canvas.height = options.size;
|
||||||
|
|
||||||
|
el.appendChild(canvas);
|
||||||
|
|
||||||
|
ctx.translate(options.size / 2, options.size / 2); // change center
|
||||||
|
ctx.rotate((-1 / 2 + options.rotate / 180) * Math.PI); // rotate -90 deg
|
||||||
|
|
||||||
|
var radius = (options.size - options.lineWidth) / 2;
|
||||||
|
|
||||||
|
function drawCircle(color, lineWidth, percent) {
|
||||||
|
if (percent) {
|
||||||
|
percent = Math.min(Math.max(0, percent), 1);
|
||||||
|
ctx.beginPath();
|
||||||
|
ctx.arc(0, 0, radius, 0, Math.PI * 2 * percent, false);
|
||||||
|
ctx.strokeStyle = color;
|
||||||
|
ctx.lineCap = 'round'; // butt, round or square
|
||||||
|
ctx.lineWidth = lineWidth
|
||||||
|
ctx.stroke();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
options.percent = percent;
|
||||||
|
|
||||||
|
drawCircle('#2e3134', options.lineWidth + 1, 100 / 100);
|
||||||
|
drawCircle('#007a96', options.lineWidth, options.percent / 100);
|
||||||
|
}
|
||||||
|
|
||||||
|
function Keys(obj) {
|
||||||
|
var keys = [];
|
||||||
|
|
||||||
|
for(var key in obj){
|
||||||
|
if(obj.hasOwnProperty(key)){
|
||||||
|
keys.push(key);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return keys;
|
||||||
|
}
|
||||||
|
|
||||||
|
function UpdateFileList() {
|
||||||
|
var fileListRequest = new XMLHttpRequest();
|
||||||
|
|
||||||
|
fileListRequest.onreadystatechange = function() {
|
||||||
|
if (fileListRequest.readyState != 4) return;
|
||||||
|
|
||||||
|
if (fileListRequest.status == 200) {
|
||||||
|
var fileInfo = JSON.parse(fileListRequest.responseText);
|
||||||
|
var fileList = fileInfo['files'];
|
||||||
|
|
||||||
|
document.getElementById('fileInfo').innerHTML = '';
|
||||||
|
|
||||||
|
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) && 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 {
|
||||||
|
append = tpl.replace(/%filenamelink%/g, item);
|
||||||
|
}
|
||||||
|
|
||||||
|
append = append.replace(/%filename%/g, item);
|
||||||
|
append = append.replace(/%filesize%/g, formatFileSize(parseInt(fileList[item])));
|
||||||
|
document.getElementById('fileInfo').insertAdjacentHTML('beforeend', append);
|
||||||
|
});
|
||||||
|
|
||||||
|
append = tplTotal.replace(/%used%/g, formatFileSize(parseInt(fileInfo['used'])));
|
||||||
|
append = append.replace(/%free%/g, formatFileSize(parseInt(fileInfo['free'])));
|
||||||
|
append = append.replace(/%total%/g, formatFileSize(parseInt(fileInfo['total'])));
|
||||||
|
|
||||||
|
document.getElementById('fileInfo').insertAdjacentHTML('beforeend', append);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
fileListRequest = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
fileListRequest.open('GET', 'upload.lua?cmd=list', true);
|
||||||
|
fileListRequest.send();
|
||||||
|
}
|
||||||
|
|
||||||
|
function RemoveFile(name) {
|
||||||
|
var fileRemoveRequest = new XMLHttpRequest();
|
||||||
|
|
||||||
|
fileRemoveRequest.onreadystatechange = function() {
|
||||||
|
if (fileRemoveRequest.readyState != 4) return;
|
||||||
|
|
||||||
|
if (fileRemoveRequest.status == 200) {
|
||||||
|
UpdateFileList();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fileRemoveRequest.open('GET', 'upload.lua?cmd=remove&filename=' + name, true);
|
||||||
|
fileRemoveRequest.send();
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user