aboutsummaryrefslogtreecommitdiff
path: root/http.go
diff options
context:
space:
mode:
authorFelix Hanley <felix@userspace.com.au>2017-06-18 10:23:25 +0000
committerFelix Hanley <felix@userspace.com.au>2017-06-18 10:23:25 +0000
commitd6f623afb8993af3a8dc41417eee3b14550a0d5d (patch)
tree7b84174ad600714178fb3f57d95d191698cc51fa /http.go
parentde6c420e7706c5705b3b48e545c9c5fd81ab851c (diff)
downloaddhtsearch-d6f623afb8993af3a8dc41417eee3b14550a0d5d.tar.gz
dhtsearch-d6f623afb8993af3a8dc41417eee3b14550a0d5d.tar.bz2
Update to interface
Diffstat (limited to 'http.go')
-rw-r--r--http.go105
1 files changed, 59 insertions, 46 deletions
diff --git a/http.go b/http.go
index 4c0c8be..5cdaf5a 100644
--- a/http.go
+++ b/http.go
@@ -70,34 +70,61 @@ var html = []byte(`
<head>
<title>DHT search</title>
<meta charset="UTF-8">
+ <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">
<style>
- body { padding:0;margin:0;color:#666;line-height:1.5;font-size:16px; }
- .header { padding:1em;border-bottom:1px solid #555; }
- input { padding:2px; }
- .page { padding:1em 2em; }
+ * { box-sizing:border-box; }
+ body { padding:0;margin:0;color:#666;line-height:1.5;font-size:16px;font-family:sans-serif; }
ul { list-style:none;padding:0;margin:0; }
+ a { color:#000;text-decoration:none; }
+ .header { padding:1em;border-bottom:1px solid #555;background-color:#eee; }
+ .search { display:flex;float:left;margin:0;padding:0; }
+ .search__input { font-size:1.25em;padding:2px; }
+ .page { padding:1em; }
.torrent { margin-bottom:1em; }
- .torrent__name { display:block; }
- .torrent__magnet { display:block; }
- .torrent__size, .torrent__file-count, .torrent__seen, .torrent__tags { padding-right:1em; }
- .tag { display:inline;text-decoration:none; }
+ .torrent__name { display:block;overflow:hidden; }
+ .search__button, .torrent__magnet { height:32px;width:32px;background: url() no-repeat top left; }
+ .search__button { display:inline-block;border:none;margin-left:5px;margin-right:5px; }
+ .search__button:focus { outline:none; }
+ .search__button--active { animation-name:spin;animation-duration:3s;animation-iteration-count:infinite;-webkit-animation-name:spin;-webkit-animation-duration:3s;-webkit-animation-iteration-count:infinite; }
+ .torrent__magnet { display:block;float:left;margin-top:4px;margin-right:.5em; }
+ .torrent__size, .torrent__file-count, .torrent__seen, .torrent__tags { display:inline-block;padding-right:1em;white-space:nowrap; }
+ .tag { display:inline; }
.files { padding-left:2em;font-family:monospace;font-size:.75em; }
.files { display:none; }
.files--active { display:block; }
.file__size { margin-left:.5em;font-size:.875em; }
.stats { display:block;margin:0;margin-top:1em; }
- .stats__key, .stats__value { display:inline-block;font-size:.75em;padding:0;margin:0; }
- .stats__key { margin-right:.25em;color:#222; }
+ .stats__key, .stats__value { float:left;padding:0;margin:0; }
+ .stats__key { clear:left;margin-right:.25em;color:#222;white-space:nowrap; }
.stats__key:after { content:':'; }
.stats__value { margin-right:.5em;color:#888; }
+
+ .site-nav:after { content:'';display:table;clear:both; }
+ .site-nav__open, .site-nav__close { position:absolute;top:1.25em;right:1em;color:#666; }
+ .site-nav__close { left:1em; }
+ .site-nav__open:before { content:'☰ ' }
+ .site-nav__target { position:fixed;top:0;left:0; }
+ .site-nav__target:target + .site-nav__drawer { transform:none; }
+ .site-nav__drawer { position:fixed;top:0;right:0;bottom:0;margin:0;padding:1em;padding-top:2em;width:300px;float:right;background-color:#e8e8e8;overflow:visible;z-index:1;transition:0.2s;will-change:tranform;transform:translateX(100%); }
+ @keyframes spin { from {transform:rotate(0deg);} to {transform:rotate(360deg);} }
+ @-webkit-keyframes spin { from {transform:rotate(0deg);} to {transform:rotate(360deg);} }
</style>
</head>
<body id="body">
<div class="header">
- <input id="search" type="text" name="search" placeholder="Search" />
- <button id="go">Go</button>
+ <nav class="site-nav">
+ <div class="search">
+ <input id="search" class="search__input" type="text" name="search" placeholder="Search" />
+ <button id="go" class="search__button"></button>
+ </div>
+ <a href="#trigger:nav" class="site-nav__open">Stats</a>
+ <a class="site-nav__target" id="trigger:nav"></a>
+ <div class="site-nav__drawer">
+ <a href="#0" class="site-nav__close">Close</a>
<dl id="stats" class="stats"></dl>
</div>
+ </nav>
+ </div>
<div id="page" class="page">
</div>
<script>
@@ -120,8 +147,7 @@ var processResponse = function (resp) {
}
}
var search = function (term) {
- var oldButton = bEl.innerHTML
- bEl.innerHTML = 'Searching'
+ bEl.classList.add('search__button--active')
var query = ''
var tIdx = term.indexOf('tag:')
if (tIdx >= 0) {
@@ -138,45 +164,32 @@ var search = function (term) {
].join('')
var torrents = data.map(function (t) {
var magnet = 'magnet:?xt=urn:btih:' + t.infohash
- var pre = [
+ return [
'<li class="torrent">',
+ '<a class="torrent__magnet" href="', magnet, '"></a>',
'<a class="torrent__name" href="', magnet, '">', t.name, '</a>',
- '<span class="torrent__magnet">', magnet, '</span>',
- '<span class="torrent__size">Size:&nbsp;', humanSize(t.size), '</span>',
- '<span class="torrent__seen">Last&nbsp;seen:&nbsp;<time datetime="', t.seen, '">', new Date(t.seen).toLocaleString(), '</time></span>'
- ].join('')
- var tags = ''
- if (t.tags.length) {
- tags = [
- '<span class="torrent__tags">Tags: ',
- t.tags.map(function (g) { return '<a class="tag" href="/tags/' + g + '">' + g + '</a>' }).join(',&nbsp;'),
- '</span>'
+ '<span class="torrent__size">Size: ', humanSize(t.size), '</span>',
+ '<span class="torrent__seen">Last seen: <time datetime="', t.seen, '">', new Date(t.seen).toLocaleString(), '</time></span>',
+ '<span class="torrent__tags">Tags: ',
+ t.tags.map(function (g) { return '<a class="tag" href="/tags/' + g + '">' + g + '</a>' }).join(', '),
+ '</span>',
+ t.files.length === 0 ? '' : ['<a class="torrent__file-count toggler" href="#">Files: ', t.files.length, '</a>'].join(''),
+ '<ul class="files">',
+ t.files.map(function (f) {
+ return [
+ '<li class="files__file file">',
+ '<span class="file__path">', f.path, '</span>',
+ '<span class="file__size">[', humanSize(f.size), ']</span>',
+ '</li>'
].join('')
- }
- var files = ''
- if (t.files.length) {
- var fHtml = t.files.map(function (f) {
- return [
- '<li class="files__file file">',
- '<span class="file__path">', f.path, '</span>',
- '<span class="file__size">[', humanSize(f.size), ']</span>',
- '</li>'
- ].join('')
- })
- files = [
- '<span class="torrent__file-count">Files:&nbsp;', t.files.length, '</span>',
- '<a class="toggler" href="#">toggle files</a><ul class="files">',
- fHtml.join(''),
- '</ul>'].join('')
- }
- var post = [
+ }).join(''),
+ '</ul>',
'</li>'
].join('')
- return pre + tags + files + post
}).join('')
var post = '</ul>'
- bEl.innerHTML = oldButton
pEl.innerHTML = pre + torrents + post
+ bEl.classList.remove('search__button--active')
var togglers = document.getElementsByClassName('toggler')
for (var i = 0; i < togglers.length; i += 1) {
var el = togglers[i]
@@ -210,7 +223,7 @@ var getStats = function () {
statsEl.innerHTML = Object.keys(data).map(function (k) {
return [
'<dt class="stats__key">',
- k.replace(/_/g,'&nbsp;'),
+ k.replace(/_/g,' '),
'</dt><dd class="stats__value">',
k.indexOf('bytes') === -1 ? data[k] : humanSize(data[k]),
'</dd>'