diff --git a/public/css/f0ck.css b/public/css/f0ck.css index 9771402..e02e83f 100644 --- a/public/css/f0ck.css +++ b/public/css/f0ck.css @@ -76,28 +76,6 @@ button { } /* Flummikram lol */ -div.pscroll { - opacity: 0.7; - position: fixed; - display: inline-block; - height: 64px; - width: 64px; - left: 50%; - cursor: pointer; - margin-left: -36px; - z-index: 999; -} -div.pscroll:hover { - opacity: 0.9; -} -div#up { - background-image: url(''); - top: 5.8em; -} -div#down { - background-image: url(''); - bottom: 5em; -} footer { position: fixed; bottom: 0; @@ -191,4 +169,25 @@ div#itemview { z-index: 999; background-color: rgba(0,0,0,0.8); display: none; -} \ No newline at end of file + + flex-direction: row; + width: 100%; +} + +div.items { + /*position: relative;*/ + flex: 1 1 0px; + + width: 100%; + height: 100%; +} +img.item { + position: absolute; + max-height: 100%; + max-width: 100%; + top: 0; + bottom: 0; + left: 0; + right: 0; + margin: auto; +} diff --git a/public/css/icons.css b/public/css/icons.css new file mode 100644 index 0000000..6000da6 --- /dev/null +++ b/public/css/icons.css @@ -0,0 +1,88 @@ +.close { + position: absolute; + right: 48px; + top: 48px; + width: 48px; + height: 48px; + opacity: 0.8; + background-color: rgba(0,0,0,0.5); +} +.close:hover { + opacity: 1; +} +.close:before, .close:after { + position: absolute; + left: 23px; + top: 3px; + content: ' '; + height: 40px; + width: 2px; + background-color: #333; +} +.close:before { + transform: rotate(45deg); +} +.close:after { + transform: rotate(-45deg); +} + + +div.arrow { + position: fixed; + cursor: pointer; + height: 70px; + width: 70px; + background-color: #000; + opacity: .5; + border-radius: 10px; + z-index: 90; +} +div.arrow:hover { + opacity: .9; + box-shadow: 0px 0px 0px 2px #dac8d2; + border-radius: 10px; + transition: .1s ease-in; +} +div.arrow:before { + content: ''; + position: absolute; + top: 7%; + left: 7%; + height: 60px; + width: 60px; + background-color: rgba(255, 255, 255, 0.5); +} + +div.top:before { + clip-path: polygon(0% 77%, 50% 23%, 100% 77%); +} +div.bottom:before { + clip-path: polygon(0% 23%, 100% 23%, 50% 77%); +} +div.left:before { + clip-path: polygon(23% 50%, 77% 0%, 77% 100%); +} +div.right:before { + clip-path: polygon(23% 0%, 77% 50%, 23% 100%); +} + +div.arrow.top { + top: 80px; + left: 50%; + transform: translateX(-50%); +} +div.arrow.bottom { + bottom: 80px; + left: 50%; + transform: translateX(-50%); +} +div.arrow.left { + left: 20px; + top: 50%; + transform: translateY(-50%); +} +div.arrow.right { + right: 20px; + top: 50%; + transform: translateY(-50%); +} diff --git a/public/js/f0ck.js b/public/js/f0ck.js index e397776..ff00ab0 100644 --- a/public/js/f0ck.js +++ b/public/js/f0ck.js @@ -120,7 +120,7 @@ const resize = e => { // events swiper.init(rt.container.wrapper, e => scroll({ target: { id: e.direction }})); -document.querySelectorAll("div.pscroll").forEach(p => p.addEventListener("click", scroll)); +[...document.querySelectorAll("div.arrow")].filter(e => ["up", "down"].includes(e.id)).forEach(p => p.addEventListener("click", scroll)); document.addEventListener("wheel", scroll); (() => { // init @@ -137,13 +137,32 @@ document.addEventListener("wheel", scroll); -window.addEventListener("hashchange", e => { +window.addEventListener("hashchange", async e => { const itemid = parseInt(e.newURL.split("#").slice(-1)); - if(itemid === "NaN") - return rt.container.itemview.style.display = "none"; + if(itemid <= 0) { // failover + rt.container.itemview.style.display = "none"; + return false; + } + rt.container.itemview.style.display = "flex"; // show itemview + rt.container.header.itempos.style.display = "block"; + rt.container.header.pagepos.style.display = "none"; + rt.container.header.iteminfo.style.display = "block"; + + rt.container.header.itempos.innerHTML = `item ${itemid}`; + + const item = await (await fetch(`/api/item/${itemid}`)).json(); + console.log(item); + + rt.container.header.infos.source.href = item.src; + rt.container.header.infos.source.innerHTML = item.srchost; + rt.container.header.infos.channel.innerHTML = `${item.usernetwork} ${item.userchannel}`; + rt.container.header.infos.title.innerHTML = `${item.mime} (${item.size})`; + rt.container.header.infos.nick.innerHTML = item.username; + + rt.container.items[1].innerHTML = ``; + rt.container.items[1].scrollIntoView({ block: rt.st.block }); // mitte - rt.container.itemview.style.display = "block"; // show itemview // remove page events document.removeEventListener("wheel", scroll); diff --git a/public/js/rt.js b/public/js/rt.js index c137196..7fa1458 100644 --- a/public/js/rt.js +++ b/public/js/rt.js @@ -17,6 +17,19 @@ export default { container: { wrapper: document.querySelector("div#wrapper"), itemview: document.querySelector("div#itemview"), + header: { + iteminfo: document.querySelector("div#itemInfo"), + pagepos: document.querySelector("div#pagePosition"), + itempos: document.querySelector("div#itemPosition"), + infos: { + title: document.querySelector("span#itemTitle"), + source: document.querySelector("a#itemSource"), + time: document.querySelector("span#itemTime"), + nick: document.querySelector("span#itemNick"), + channel: document.querySelector("span#itemChannel") + } + }, + items: document.querySelectorAll("div.items"), posts: document.querySelectorAll("div.posts") }, items: { diff --git a/views/index.hbs b/views/index.hbs index 495c87e..3d8145b 100644 --- a/views/index.hbs +++ b/views/index.hbs @@ -8,6 +8,7 @@