diff options
| author | Felix Hanley <felix@userspace.com.au> | 2017-06-18 10:23:25 +0000 |
|---|---|---|
| committer | Felix Hanley <felix@userspace.com.au> | 2017-06-18 10:23:25 +0000 |
| commit | d6f623afb8993af3a8dc41417eee3b14550a0d5d (patch) | |
| tree | 7b84174ad600714178fb3f57d95d191698cc51fa /http.go | |
| parent | de6c420e7706c5705b3b48e545c9c5fd81ab851c (diff) | |
| download | dhtsearch-d6f623afb8993af3a8dc41417eee3b14550a0d5d.tar.gz dhtsearch-d6f623afb8993af3a8dc41417eee3b14550a0d5d.tar.bz2 | |
Update to interface
Diffstat (limited to 'http.go')
| -rw-r--r-- | http.go | 105 |
1 files changed, 59 insertions, 46 deletions
@@ -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: ', humanSize(t.size), '</span>', - '<span class="torrent__seen">Last seen: <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(', '), - '</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: ', 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,' '), + k.replace(/_/g,' '), '</dt><dd class="stats__value">', k.indexOf('bytes') === -1 ? data[k] : humanSize(data[k]), '</dd>' |
