forked from EtherDream/http-server-online
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
73 lines (70 loc) · 1.57 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<!doctype html>
<html>
<head>
<title>HTTP Server</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<style>
#btnOpenDir {
width: 400px;
height: 100px;
font-size: 20px;
margin-bottom: 20px;
}
#txtErr {
color: red;
}
</style>
</head>
<body>
<button id="btnOpenDir" disabled>Select Web Directory</button>
<div id="txtErr"></div>
<div id="divCmd" hidden>
<div>Stop Server: <a id="linkStop" href="/?stop" target="_blank"></a></div>
</div>
<script>
const sw = navigator.serviceWorker
btnOpenDir.onclick = async() => {
try {
var dirHandle = await showDirectoryPicker()
} catch {
return
}
if (location.search === '?stop') {
history.pushState(null, '', '/')
}
sw.controller.postMessage(dirHandle)
}
function showError(msg) {
txtErr.textContent = msg
}
async function main() {
if (!self.showDirectoryPicker) {
showError('File System Access API is not supported')
return
}
if (!sw) {
showError('Service Worker API is not supported')
return
}
if (!sw.controller) {
try {
await sw.register('sw.js')
} catch (err) {
showError(err.message)
return
}
}
sw.onmessage = (e) => {
if (e.data === 'GOT') {
location.reload()
}
}
btnOpenDir.disabled = false
divCmd.hidden = false
linkStop.textContent = linkStop.href
}
main()
</script>
</body>
</html>