2021-11-03 04:51:04 +00:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<meta charset=utf-8>
|
|
|
|
<title>Your HTML Library</title>
|
2021-12-25 08:19:04 +00:00
|
|
|
<link rel=stylesheet href=/style.css>
|
2021-12-25 15:14:46 +00:00
|
|
|
<header>
|
|
|
|
<h1><a href=/>22120</a> — Internet Offline Library</h1>
|
|
|
|
</header>
|
2021-11-03 04:51:04 +00:00
|
|
|
<p>
|
|
|
|
View <a href=/archive_index.html>the index</a>
|
|
|
|
</p>
|
|
|
|
<form method=GET action=/search>
|
2021-12-25 15:14:46 +00:00
|
|
|
<fieldset class=search>
|
2021-11-03 04:51:04 +00:00
|
|
|
<legend>Search your archive</legend>
|
2021-12-25 15:14:46 +00:00
|
|
|
<input class=search type=search name=query placeholder="search your library">
|
2021-11-03 04:51:04 +00:00
|
|
|
<button>Search</button>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
|
|
|
<form method=POST action=/mode>
|
|
|
|
<fieldset>
|
|
|
|
<legend>Save or Serve: Mode Control</legend>
|
2021-12-25 15:14:46 +00:00
|
|
|
<p>
|
|
|
|
Control whether pages you browse are <label class=cmd for=save>saved to</label>, or
|
|
|
|
<label class=cmd for=serve>served from</label> your archive
|
|
|
|
<br>
|
|
|
|
<small><em class=caps>Pro-Tip:</em> Serve pages when you're offline, and it will still feel like you're online</small>
|
2021-11-03 04:51:04 +00:00
|
|
|
<p>
|
|
|
|
<label>
|
2021-12-25 15:14:46 +00:00
|
|
|
<input type=radio name=mode value=save id=save>
|
2021-11-03 04:51:04 +00:00
|
|
|
Save
|
|
|
|
</label>
|
|
|
|
<label>
|
2021-12-25 15:14:46 +00:00
|
|
|
<input type=radio name=mode value=serve id=serve>
|
2021-11-03 04:51:04 +00:00
|
|
|
Serve
|
|
|
|
</label>
|
2022-01-01 12:53:58 +00:00
|
|
|
<label>
|
|
|
|
<input type=radio name=mode value=select id=select>
|
2021-12-27 12:28:59 +00:00
|
|
|
Select (<em>Bookmark mode</em>)
|
|
|
|
</label>
|
2021-11-03 04:51:04 +00:00
|
|
|
<output name=notification>
|
|
|
|
<p>
|
|
|
|
<button>Change mode</button>
|
|
|
|
<script>
|
|
|
|
{
|
|
|
|
const form = document.currentScript.closest('form');
|
|
|
|
form.notification.value = "Getting current mode...";
|
2022-01-01 17:02:03 +00:00
|
|
|
setTimeout(showCurrentMode, 300);
|
2021-11-03 04:51:04 +00:00
|
|
|
|
|
|
|
async function showCurrentMode() {
|
|
|
|
const mode = await fetch('/mode').then(r => r.text());
|
|
|
|
form.notification.value = "";
|
|
|
|
form.querySelector(`[name="mode"][value="${mode}"]`).checked = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
|
|
|
<form method=POST action=/base_path>
|
|
|
|
<fieldset>
|
2022-01-01 17:02:03 +00:00
|
|
|
<legend id=new_base_path>File system path of archive</legend>
|
2021-11-03 04:51:04 +00:00
|
|
|
<p>
|
|
|
|
Set the path to where your archive folder will go
|
|
|
|
<br>
|
|
|
|
<small>The default is your home directory</small>
|
|
|
|
<p>
|
|
|
|
<label>
|
|
|
|
Base path
|
|
|
|
<input class=long type=text name=base_path placeholder="A folder path...">
|
|
|
|
</label>
|
|
|
|
<p>
|
|
|
|
<button>Change base path</button>
|
|
|
|
<script>
|
|
|
|
{
|
|
|
|
const form = document.currentScript.closest('form');
|
|
|
|
showCurrentLibraryPath();
|
|
|
|
|
|
|
|
form.base_path.onchange = e => {
|
|
|
|
self.target = e.target;
|
|
|
|
}
|
|
|
|
async function showCurrentLibraryPath() {
|
|
|
|
const base_path = await fetch('/base_path').then(r => r.text());
|
|
|
|
form.querySelector(`[name="base_path"]`).value = base_path;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
2021-12-27 12:28:59 +00:00
|
|
|
<form disabled method=POST action=/publish>
|
|
|
|
<fieldset>
|
|
|
|
<legend>Publish your archive</legend>
|
|
|
|
<p>
|
|
|
|
Publish a search engine from your archive
|
|
|
|
<br>
|
|
|
|
<small>This will generate a server.zip file that you can unzip and run</small>
|
|
|
|
<p>
|
|
|
|
<button disabled>Publish</button>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
2021-12-18 04:16:05 +00:00
|
|
|
<footer>
|
|
|
|
<cite>
|
|
|
|
<a rel=author href=https://github.com/i5ik/22120>22120 GitHub</a>
|
|
|
|
</cite>
|
|
|
|
</footer>
|