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 @@