Update html/discover.ejs
This commit is contained in:
parent
06def11d2b
commit
b2a3f74042
@ -18,532 +18,409 @@
|
||||
along with this program. If not, see https://www.gnu.org/licenses/.
|
||||
-->
|
||||
<% if (!isMobile) { %>
|
||||
<% if (!isMobile) { %>
|
||||
<!--
|
||||
This Source Code Form is subject to the terms of the GNU General Public License:
|
||||
|
||||
<!DOCTYPE html><html>
|
||||
Copyright (C) 2021-2025 Poke (https://codeberg.org/ashley/poke)
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License, version 3 of the License,
|
||||
or (at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see https://www.gnu.org/licenses/.
|
||||
-->
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<title>Poke | Discover</title>
|
||||
<link href="/css/yt-ukraine.svg?v=6" rel=icon>
|
||||
<meta content=website property=og:type>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<meta content="Poke - Discover" property=og:title>
|
||||
<meta content="Discover Popular videos on poke!" property=twitter:description>
|
||||
<meta content="https://cdn.glitch.global/d68d17bb-f2c0-4bc3-993f-50902734f652/aa70111e-5bcd-4379-8b23-332a33012b78.image.png?v=1701898829884" property=og:image>
|
||||
<meta content=summary_large_image name=twitter:card>
|
||||
<link rel="manifest" href="/manifest.json">
|
||||
<meta name="darkreader-lock"> <!-- tells dark reader that the site has a dark theme and to turn itself off -->
|
||||
<link href="/css/app-cdn.min.css" rel=stylesheet>
|
||||
<link href="/css/app-cdn.min.css" rel=stylesheet>
|
||||
<link href="/css/app.main.css?v=44600" rel=stylesheet>
|
||||
<link href="/css/search.main.css?v=57" rel=stylesheet>
|
||||
<link href=/css/watch.main.css rel=stylesheet>
|
||||
<meta content="#1a1a1a" name="theme-color">
|
||||
</head>
|
||||
<style>
|
||||
.mn {
|
||||
background: #181818;
|
||||
border-radius: 26px;
|
||||
padding: 6px;
|
||||
margin: auto;
|
||||
position: absolute;
|
||||
left: 50%;
|
||||
top: 50%;
|
||||
transform: translate(-50%, -50%);
|
||||
}
|
||||
@font-face {
|
||||
font-family: 'Ginto Nord';
|
||||
font-weight: 800;
|
||||
src:url('https://p.poketube.fun/https://cdn.statically.io/gh/brecert/discord-quote-generator/main/Ginto-Nord-800.woff') format("woff");
|
||||
}
|
||||
<meta charset="utf-8" />
|
||||
<title>Poke | Discover</title>
|
||||
<meta content="width=device-width, initial-scale=1, viewport-fit=cover" name="viewport" />
|
||||
<meta property="og:type" content="website" />
|
||||
<meta property="og:title" content="Poke - Discover" />
|
||||
<meta name="twitter:description" content="Discover Popular videos on poke!" />
|
||||
<meta property="og:image" content="https://cdn.glitch.global/d68d17bb-f2c0-4bc3-993f-50902734f652/aa70111e-5bcd-4379-8b23-332a33012b78.image.png?v=1701898829884" />
|
||||
<meta name="twitter:card" content="summary_large_image" />
|
||||
<meta name="theme-color" content="#1a1a1a" />
|
||||
<meta name="darkreader-lock" />
|
||||
<link rel="manifest" href="/manifest.json" />
|
||||
<link rel="icon" href="/css/yt-ukraine.svg?v=6" />
|
||||
<link href="/css/app-cdn.min.css" rel="stylesheet" />
|
||||
<link href="/css/app.main.css?v=44600" rel="stylesheet" />
|
||||
<link href="/css/search.main.css?v=57" rel="stylesheet" />
|
||||
<link href="/css/watch.main.css" rel="stylesheet" />
|
||||
<link href="https://p.poketube.fun/https://site-assets.fontawesome.com/releases/v6.1.1/css/all.css" rel="stylesheet" />
|
||||
|
||||
</style>
|
||||
<style nonce="IJD3y0awTwA2dd0pWOP+ZQ">
|
||||
#yt-masthead{line-height:0;margin:15px auto;width:440px;margin-top:25px}#logo-container{margin-right:5px;float:left;cursor:pointer;text-decoration:none}.logo{background:no-repeat url("//www.gstatic.com/youtube/img/branding/youtubelogo/1x/youtubelogo_30.png");width:125px;height:30px;cursor:pointer;display:inline-block}#masthead-search{display:flex;margin-top:3px;max-width:650px;overflow:hidden;padding:0;position:relative}.search-button{border-left:0;-moz-border-radius-topleft:0;border-top-left-radius:0;-moz-border-radius-bottomleft:0;border-bottom-left-radius:0;float:right;height:29px;padding:0;border:solid 1px transparent;border-color:#ffff;background:#999;;color:#333;cursor:pointer}.search-button:hover{border-color:#c6c6c6;background:#f0f0f0;box-shadow:0 1px 0 rgba(0,0,0,0.0)}.search-button-content{border:none;display:block;opacity:.6;padding:0;text-indent:-10000px;background:no-repeat url(//www.gstatic.com/youtube/src/web/htdocs/img/search.png);background-size:auto;width:15px;height:15px;box-shadow:none;margin:0 25px}#masthead-search-terms-border{flex:1 1 auto;border:1px solid #ccc;box-shadow:inset 0 1px 2px #eee;background-color:#fff;font-size:14px;height:29px;line-height:30px;margin:0 0 2px;overflow:hidden;position:relative;-moz-box-sizing:border-box;box-sizing:border-box;-webkit-transition:border-color .2s ease;transition:border-color .2s ease}#masthead-search-terms{background:#2c2f33;border:0;font-size:16px;height:100%;left:0;margin:0;outline:none;padding:2px 6px;position:absolute;width:100%;-moz-box-sizing:border-box;box-sizing:border-box}
|
||||
</style>
|
||||
<body>
|
||||
|
||||
|
||||
<section class=youtube-video>
|
||||
|
||||
|
||||
<style>
|
||||
@import url("https://p.poketube.fun/https://site-assets.fontawesome.com/releases/v6.1.1/css/all.css");
|
||||
|
||||
a.class:hover {
|
||||
text-decoration:underline;
|
||||
font-weight:bold
|
||||
}
|
||||
summary{
|
||||
color:gray;
|
||||
}
|
||||
summary:hover{
|
||||
color:white;
|
||||
}
|
||||
</style>
|
||||
|
||||
<style>
|
||||
body{
|
||||
overflow-x: hidden; /* Hide horizontal scrollbar */
|
||||
color:#111111
|
||||
}
|
||||
|
||||
<style>
|
||||
:root {
|
||||
--text-primary: #fff;
|
||||
--text-secondary: #fff;
|
||||
--text-link: #3ea6ff;
|
||||
--bg-1: #0b0d12;
|
||||
--bg-2: #111319;
|
||||
--bg-3: #161925;
|
||||
|
||||
--app-background: #111111;
|
||||
--context-menu-background: #333;
|
||||
--border-color: #444;
|
||||
--item-hover-background: #373737;
|
||||
--item-active-background: #383838;
|
||||
--brand: #df03a8;
|
||||
--brand-2: #3ea6ff;
|
||||
|
||||
--top-bar-background: #202020;
|
||||
--guide-background: #212121;
|
||||
--text-primary: #fff;
|
||||
--text-secondary: #c8c8c8;
|
||||
--text-dim: #a3a3a3;
|
||||
|
||||
--thumbnail-background: #252525;
|
||||
--glass-bg: rgba(255, 255, 255, 0.08);
|
||||
--glass-border: rgba(255, 255, 255, 0.16);
|
||||
--glass-hover: rgba(255, 255, 255, 0.12);
|
||||
|
||||
--channel-info-background: #181818;
|
||||
--channel-contents-background: #0f0f0f;
|
||||
}
|
||||
@font-face {
|
||||
font-family: 'Ginto Nord';
|
||||
font-weight: 800;
|
||||
src:url('https://p.poketube.fun/https://cdn.statically.io/gh/brecert/discord-quote-generator/main/Ginto-Nord-800.woff') format("woff");
|
||||
}
|
||||
--card-bg: rgba(0, 0, 0, 0.38);
|
||||
--thumbnail-bg: #0b0b0b;
|
||||
|
||||
.video > .info {
|
||||
grid-area: info;
|
||||
font-size: small;
|
||||
margin-left: 2px;
|
||||
height: auto;
|
||||
width: fit-content;
|
||||
text-align: left;
|
||||
margin-top: -7px;
|
||||
padding: 2px;
|
||||
--ring: rgba(223, 3, 168, 0.36);
|
||||
|
||||
--radius-xl: 20px;
|
||||
--radius-lg: 16px;
|
||||
--radius-md: 12px;
|
||||
|
||||
--shadow-1: 0 10px 30px rgba(0, 0, 0, 0.45);
|
||||
--shadow-2: 0 6px 18px rgba(0, 0, 0, 0.35);
|
||||
|
||||
--container: 1200px;
|
||||
--grid-gap: 14px;
|
||||
}
|
||||
|
||||
.progress-container {
|
||||
position: fixed;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
height: 3px;
|
||||
z-index: 9999;
|
||||
display:none;
|
||||
background-color: #f2f2f2;
|
||||
}
|
||||
|
||||
.progress-bar {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 0%;
|
||||
height: 100%;
|
||||
background-image: linear-gradient(to right,
|
||||
#ff0045,
|
||||
#ff0e55,
|
||||
#ff1d79
|
||||
);
|
||||
transition: width 0.5s ease-in-out;
|
||||
}
|
||||
@media (max-width: 1360px) { :root { --container: 1040px; } }
|
||||
@media (max-width: 1180px) { :root { --container: 920px; } }
|
||||
@media (max-width: 980px) { :root { --container: 92vw; } }
|
||||
|
||||
.video > .info > .title {
|
||||
color: var(--text-primary) !important;
|
||||
font-weight: bold;
|
||||
font-size: initial;
|
||||
margin-bottom: 0px;
|
||||
}
|
||||
.video-grid{
|
||||
justify-content: center;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
* { box-sizing: border-box; }
|
||||
html, body { height: 100%; }
|
||||
body {
|
||||
margin: 0;
|
||||
color: var(--text-primary);
|
||||
background:
|
||||
radial-gradient(1200px 800px at 15% 10%, #231638 0%, transparent 60%),
|
||||
radial-gradient(900px 700px at 85% 20%, #2b160e 0%, transparent 60%),
|
||||
radial-gradient(1000px 900px at 50% 90%, #09250e 0%, transparent 60%),
|
||||
linear-gradient(180deg, var(--bg-2), var(--bg-1) 40%, var(--bg-3) 100%);
|
||||
font-family: "poketube flex", Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
overflow-x: hidden;
|
||||
}
|
||||
.alert {
|
||||
padding: 20px;
|
||||
background-color: #f44336;
|
||||
color: white;
|
||||
opacity: 1;
|
||||
transition: opacity 0.6s;
|
||||
margin-bottom: 15px;
|
||||
}
|
||||
|
||||
.alert.success {background-color: #04AA6D;}
|
||||
.alert.info {background-color: #2196F3;}
|
||||
.alert.warning {background-color: #ff9800;}
|
||||
.container {
|
||||
width: min(var(--container), 100%);
|
||||
margin: 0 auto;
|
||||
padding: 24px;
|
||||
}
|
||||
|
||||
.closebtn {
|
||||
margin-left: 15px;
|
||||
color: white;
|
||||
font-weight: bold;
|
||||
float: right;
|
||||
font-size: 22px;
|
||||
line-height: 20px;
|
||||
cursor: pointer;
|
||||
transition: 0.3s;
|
||||
}
|
||||
.glass {
|
||||
background: var(--glass-bg);
|
||||
border: 1px solid var(--glass-border);
|
||||
border-radius: var(--radius-xl);
|
||||
backdrop-filter: blur(14px) saturate(1.25);
|
||||
-webkit-backdrop-filter: blur(14px) saturate(1.25);
|
||||
box-shadow: var(--shadow-1);
|
||||
}
|
||||
.glass:hover { background: var(--glass-hover); }
|
||||
@supports not (backdrop-filter: blur(10px)) {
|
||||
.glass { background: rgba(25, 25, 25, 0.65); }
|
||||
}
|
||||
|
||||
.closebtn:hover {
|
||||
color: black;
|
||||
}
|
||||
|
||||
section p {
|
||||
font-family:Whitney, Helvetica Neue, Helvetica, Arial, sans-serif;
|
||||
font-weight:400;
|
||||
color:#fff;
|
||||
font-size:16px;
|
||||
line-height:24px;
|
||||
margin-top:12px
|
||||
}
|
||||
.news {
|
||||
margin: 2em;
|
||||
background: #333;
|
||||
padding: 10px;
|
||||
border-radius: 1.5em;
|
||||
display:none;
|
||||
}
|
||||
|
||||
.sticky-top {
|
||||
position: sticky;
|
||||
top: 0px;
|
||||
z-index: 999;
|
||||
}
|
||||
.responsive {
|
||||
width: 100%;
|
||||
overflow-x: auto;
|
||||
}
|
||||
.tabs {
|
||||
display: table;
|
||||
font-family: poketube flex;
|
||||
border-collapse: separate;
|
||||
table-layout: auto;
|
||||
font-weight: 800;
|
||||
font-stretch: extra-expanded;
|
||||
border-spacing: 3px;
|
||||
}
|
||||
.tabs.tabs-center {
|
||||
margin-left: auto;
|
||||
background: #000;
|
||||
border-radius: 1em;
|
||||
margin-bottom: 45px;
|
||||
margin-right: auto;
|
||||
}
|
||||
|
||||
.tabs.tabs-justify {
|
||||
width: 100%;
|
||||
table-layout: fixed;
|
||||
}
|
||||
|
||||
|
||||
.tab.active {
|
||||
background: #1a1a1a !important;
|
||||
border-radius: 1em !important;
|
||||
}
|
||||
|
||||
.tabs a.tab {
|
||||
position: relative;
|
||||
display: table-cell;
|
||||
transition: all ease 0.3s;
|
||||
padding: 1em 1.6em;
|
||||
transform: translate3d(0, 0, 0);
|
||||
color: #fff;
|
||||
white-space: nowrap;
|
||||
cursor: pointer;
|
||||
}
|
||||
.tabs a.tab:hover {
|
||||
color: #3cb4fa;
|
||||
}
|
||||
.tabs a.tab:after {
|
||||
transition: all 0.3s cubic-bezier(1, 0, 0, 1);
|
||||
will-change: transform, box-shadow, opacity;
|
||||
position: absolute;
|
||||
content: '';
|
||||
height: 3px;
|
||||
bottom: 0px;
|
||||
left: 0px;
|
||||
right: 0px;
|
||||
border-radius: 3px 3px 0px 0px;
|
||||
opacity: 0;
|
||||
transform: scale(0, 1);
|
||||
}
|
||||
.tabs a.tab.active {
|
||||
color: #fff;
|
||||
}
|
||||
.tabs a.tab.active:after {
|
||||
opacity: 1;
|
||||
transform: scale(1, 1);
|
||||
}
|
||||
|
||||
|
||||
.tab:hover {
|
||||
background: var(--not-quite-black);
|
||||
text-decoration: none;
|
||||
border-radius: 1em;
|
||||
}
|
||||
|
||||
|
||||
@keyframes gradient {
|
||||
0% {
|
||||
background-position: 0 50%;
|
||||
}
|
||||
50% {
|
||||
background-position: 100% 50%;
|
||||
}
|
||||
100% {
|
||||
background-position: 0 50%;
|
||||
}
|
||||
}
|
||||
.progress-container {
|
||||
position: fixed; inset: 0 auto auto 0; width: 100%; height: 3px;
|
||||
background: transparent; z-index: 9999; display: none;
|
||||
}
|
||||
.progress-bar {
|
||||
width: 0%; height: 100%;
|
||||
background-image: linear-gradient(90deg, #ff0045, #ff0e55, #ff1d79);
|
||||
transition: width .5s ease-in-out;
|
||||
}
|
||||
|
||||
.app, .channel-page {
|
||||
background-image: radial-gradient(#231638, #2b160e, #09250e, #0f132b);
|
||||
|
||||
}
|
||||
.channel-info-container > img {
|
||||
width: 100%;
|
||||
}
|
||||
.video-grid > .video:hover{
|
||||
border:solid #ff0033;
|
||||
}
|
||||
nav.navbar {
|
||||
position: sticky; top: 12px; z-index: 50;
|
||||
width: min(var(--container), 100%);
|
||||
margin: 12px auto 0 auto;
|
||||
}
|
||||
.navbar-inner {
|
||||
display: grid;
|
||||
grid-template-columns: auto 1fr auto;
|
||||
align-items: center;
|
||||
gap: 12px;
|
||||
padding: 10px 14px;
|
||||
}
|
||||
.brand img { height: 36px; display: block; transform: translateZ(0); }
|
||||
|
||||
.video-grid > .video {
|
||||
border-radius: 16px;
|
||||
background: black;
|
||||
padding: 6px;
|
||||
border: #333 solid;
|
||||
}
|
||||
|
||||
/* nice classname am i rigth */
|
||||
.discover-some-bitches{
|
||||
text-align: center;
|
||||
width: 673px;
|
||||
margin: auto;
|
||||
}
|
||||
</style>
|
||||
<body>
|
||||
.search {
|
||||
display: flex; align-items: center; gap: 8px;
|
||||
padding: 8px 10px; border-radius: 999px;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.search input {
|
||||
flex: 1; background: transparent; color: var(--text-primary);
|
||||
border: 0; outline: 0; font-size: 14.5px; padding: 6px 8px; min-width: 120px;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.search button {
|
||||
border: 0; padding: 8px 12px; border-radius: 999px; color: #fff;
|
||||
background: linear-gradient(90deg, var(--brand), #ff5bcf);
|
||||
box-shadow: 0 0 0 0 rgba(0,0,0,0); cursor: pointer;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.search button:hover { box-shadow: 0 0 0 3px var(--ring); }
|
||||
|
||||
<div class="app" >
|
||||
<div class="progress-container">
|
||||
<div class="progress-bar"></div>
|
||||
</div>
|
||||
|
||||
|
||||
<nav>
|
||||
<div class=left>
|
||||
.actions a {
|
||||
display: inline-flex; align-items: center; justify-content: center;
|
||||
width: 40px; height: 40px; border-radius: 10px; color: #fff; text-decoration: none;
|
||||
}
|
||||
.actions a:hover { background: rgba(255,255,255,0.08); }
|
||||
|
||||
<a class="class" href="/143" style=font-family:Inter,sans-serif;color:#fff> <img style="transform: scale(1.3);width:8.5em;display: block;margin-left: auto;margin-right: auto;" src="/css/logo.svg?v=5"></a>
|
||||
</div>
|
||||
.page-head {
|
||||
margin-top: 18px; display: grid; gap: 8px; text-align: center;
|
||||
}
|
||||
.page-head h1 {
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
letter-spacing: 0.25px;
|
||||
font-size: clamp(1.6rem, 2.6vw, 2.25rem);
|
||||
margin: 0;
|
||||
}
|
||||
.page-head p {
|
||||
margin: 0; color: var(--text-secondary);
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
|
||||
<div class="middle">
|
||||
<div class="search">
|
||||
<form action=/search>
|
||||
<input class="search-bar" autocomplete="on" id="fname" name="query" style="color:#fff;background: linear-gradient(90deg, hsla(235, 21%, 21%, 1) 0%, hsla(194, 41%, 22%, 1) 50%, hsla(174, 48%, 20%, 1) 100%);">
|
||||
<button class="btn btn-success" type=submit><i class="fa-light fa-search"></i></button>
|
||||
</form>
|
||||
</div> </div>
|
||||
.tabs-wrap { margin-top: 18px; }
|
||||
.tabs {
|
||||
display: inline-flex; gap: 6px; padding: 6px; border-radius: 999px;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.tab {
|
||||
display: inline-flex; align-items: center; gap: 8px;
|
||||
padding: 10px 14px; border-radius: 999px; color: #fff; text-decoration: none;
|
||||
font-weight: 700; letter-spacing: .2px;
|
||||
transition: background .2s ease, color .2s ease;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.tab:hover { background: rgba(255,255,255,0.10); }
|
||||
.tab.active {
|
||||
background: linear-gradient(90deg, rgba(223,3,168,0.45), rgba(96,54,255,0.35));
|
||||
box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2), var(--shadow-2);
|
||||
}
|
||||
|
||||
|
||||
<div class=right>
|
||||
<a href="/weather"><i class="fa-light fa-sun"></i></a>
|
||||
<a href="/privacy"><i class="fa-light fa-shield"></i></a>
|
||||
<a href="/video/upload?from="><i class="fa-light fa-video"></i></a>
|
||||
<a href="https://codeberg.org/Ashley/poketube/issues"><i class="fa-light fa-bug"></i></a>
|
||||
.section-card { margin-top: 18px; padding: 16px; }
|
||||
|
||||
.video-grid {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
|
||||
gap: var(--grid-gap);
|
||||
}
|
||||
|
||||
.video {
|
||||
display: grid; grid-template-rows: auto 1fr;
|
||||
text-decoration: none; color: inherit;
|
||||
border-radius: var(--radius-lg); overflow: hidden; position: relative;
|
||||
background: rgba(0,0,0,0.22); border: 1px solid rgba(255,255,255,0.08);
|
||||
box-shadow: var(--shadow-2);
|
||||
transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.video:hover {
|
||||
transform: translateY(-4px);
|
||||
border-color: rgba(223,3,168,0.55);
|
||||
box-shadow: 0 8px 28px rgba(223,3,168,0.22);
|
||||
}
|
||||
|
||||
.thumbnail {
|
||||
position: relative;
|
||||
background: var(--thumbnail-bg) center/cover no-repeat;
|
||||
aspect-ratio: 16 / 9;
|
||||
}
|
||||
.thumbnail::after {
|
||||
content: ""; position: absolute; inset: 0;
|
||||
background: linear-gradient(to top, rgba(0,0,0,0.35), rgba(0,0,0,0));
|
||||
}
|
||||
.video-length {
|
||||
position: absolute; right: 8px; bottom: 8px; z-index: 2;
|
||||
font-size: 12px; font-weight: 800; padding: 4px 8px; border-radius: 8px;
|
||||
background: rgba(0,0,0,0.65); border: 1px solid rgba(255,255,255,0.18);
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
|
||||
.info {
|
||||
display: grid; gap: 6px; padding: 10px 12px 12px 12px; min-height: 84px;
|
||||
background: rgba(0,0,0,0.18); border-top: 1px solid rgba(255,255,255,0.08);
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.info .title {
|
||||
font-weight: 800; line-height: 1.25; color: var(--text-primary);
|
||||
display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
.info .byline {
|
||||
margin-top: -2px; font-size: 13px; color: var(--text-dim);
|
||||
font-family: "poketube flex", Inter, system-ui;
|
||||
}
|
||||
|
||||
@media (max-width: 780px) {
|
||||
.navbar-inner { grid-template-columns: 1fr auto; }
|
||||
.brand { display: none; }
|
||||
.tabs { overflow-x: auto; scrollbar-width: none; }
|
||||
.tabs::-webkit-scrollbar { display: none; }
|
||||
}
|
||||
|
||||
@media (prefers-reduced-motion: reduce) {
|
||||
.video, .progress-bar { transition: none !important; }
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div class="progress-container" aria-hidden="true">
|
||||
<div class="progress-bar"></div>
|
||||
</div>
|
||||
|
||||
<nav class="navbar">
|
||||
<div class="navbar-inner glass">
|
||||
<a class="brand" href="/143" aria-label="Poke Home">
|
||||
<img src="/css/logo.svg?v=5" alt="Poke logo" />
|
||||
</a>
|
||||
|
||||
<form class="search glass" action="/search" method="GET" role="search" aria-label="Search videos">
|
||||
<i class="fa-light fa-search" aria-hidden="true"></i>
|
||||
<input class="search-bar" autocomplete="on" id="fname" name="query" placeholder="Search on Poke…" />
|
||||
<button type="submit" class="btn btn-success" aria-label="Submit search">
|
||||
<i class="fa-light fa-arrow-right"></i>
|
||||
</button>
|
||||
</form>
|
||||
|
||||
<div class="actions">
|
||||
<a href="/weather" title="Weather"><i class="fa-light fa-sun"></i></a>
|
||||
<a href="/privacy" title="Privacy"><i class="fa-light fa-shield"></i></a>
|
||||
<a href="/video/upload?from=" title="Upload"><i class="fa-light fa-video"></i></a>
|
||||
<a href="https://codeberg.org/Ashley/poketube/issues" title="Report a bug"><i class="fa-light fa-bug"></i></a>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<header class="container page-head">
|
||||
<h1>Discover Popular Videos On Poke :3</h1>
|
||||
<p>uses the United States trending page(s) from YouTube</p>
|
||||
</header>
|
||||
|
||||
<div class="container tabs-wrap">
|
||||
<div class="tabs glass">
|
||||
<% if (!tab) { %>
|
||||
<a href="" class="tab active"><i class="fa-light fa-fire"></i><span>Now</span></a>
|
||||
<a href="?tab=music" class="tab"><i class="fa-light fa-music"></i><span>Music</span></a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern"></i><span>Gaming</span></a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film"></i><span>Movie Trailers</span></a>
|
||||
<% } %>
|
||||
<% } %>
|
||||
|
||||
<% if (tab === "music") { %>
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire"></i><span>Now</span></a>
|
||||
<a href="" class="tab active"><i class="fa-light fa-music"></i><span>Music</span></a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern"></i><span>Gaming</span></a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film"></i><span>Movie Trailers</span></a>
|
||||
<% } %>
|
||||
<% } %>
|
||||
|
||||
<% if (tab === "gaming") { %>
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire"></i><span>Now</span></a>
|
||||
<a href="?tab=music" class="tab"><i class="fa-light fa-music"></i><span>Music</span></a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="" class="tab active"><i class="fa-light fa-gamepad-modern"></i><span>Gaming</span></a>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film"></i><span>Movie Trailers</span></a>
|
||||
<% } %>
|
||||
<% } %>
|
||||
|
||||
<% if (tab === "movies") { %>
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire"></i><span>Now</span></a>
|
||||
<a href="?tab=music" class="tab"><i class="fa-light fa-music"></i><span>Music</span></a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern"></i><span>Gaming</span></a>
|
||||
<a href="" class="tab active"><i class="fa-light fa-film"></i><span>Movie Trailers</span></a>
|
||||
<% } %>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<main class="container">
|
||||
<section class="section-card glass">
|
||||
<div class="video-grid">
|
||||
<% inv.forEach(x => { %>
|
||||
<a href="/watch?v=<%- x.videoId %>" class="video canloadhd" data-author="<%- x.author %>">
|
||||
<div class="thumbnail" data-bg="/vi/<%= x.videoId %>/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLBy_x4UUHLNDZtJtJtH0PXeQGoRFTgw">
|
||||
<span class="video-length"><%- turntomins(x.lengthSeconds) %></span>
|
||||
</div>
|
||||
|
||||
</nav>
|
||||
|
||||
|
||||
|
||||
<div class="info">
|
||||
<span class="title" title="<%- x.title %>"><%- x.title %></span>
|
||||
<span class="byline" title="Video by <%- x.author %>">By <%- x.author %></span>
|
||||
</div>
|
||||
</a>
|
||||
<% }) %>
|
||||
</div>
|
||||
</section>
|
||||
</main>
|
||||
|
||||
<div class="channel-page" >
|
||||
<h1 style="font-size: 2em;margin-left: auto;margin-right: auto;text-align: center;font-family: poketube flex;font-weight: 1000;font-stretch: ultra-expanded;color: #fff;margin-bottom: 7px;margin-top: 31px;">Discover Popular Videos On Poke :3</h1>
|
||||
<p style="text-align: center;margin-top: -9px;color: gray;font-family: "poketube flex";font-weight: 400;font-stretch: extra-expanded;"> uses the united states trending page(s) from youtube!!</p>
|
||||
<% if (!tab) { %>
|
||||
<script>
|
||||
(function () {
|
||||
const bar = document.querySelector('.progress-bar');
|
||||
const wrap = document.querySelector('.progress-container');
|
||||
if (!bar || !wrap) return;
|
||||
bar.style.width = '0%';
|
||||
wrap.style.display = 'block';
|
||||
window.addEventListener('load', () => {
|
||||
bar.style.width = '100%';
|
||||
setTimeout(() => { wrap.style.display = 'none'; }, 500);
|
||||
}, { once: true });
|
||||
}());
|
||||
|
||||
<div class="tabs tabs-center">
|
||||
|
||||
<a href="" class="tab active"><i class="fa-light fa-fire" style="margin-right: 4px;"></i> Now</a>
|
||||
<a href="?tab=music"class="tab"><i class="fa-light fa-music" style="margin-right: 4px;"></i> Music</a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern" style="margin-right: 4px;"></i> Gaming</a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film" style="margin-right: 4px;"></i> Movie Trailers</a>
|
||||
(function () {
|
||||
const nodes = Array.from(document.querySelectorAll('.thumbnail[data-bg]'));
|
||||
if (!nodes.length) return;
|
||||
|
||||
<% } %>
|
||||
|
||||
</div>
|
||||
<% } %>
|
||||
<% if (tab === "music") { %>
|
||||
|
||||
<div class="tabs tabs-center">
|
||||
|
||||
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire" style="margin-right: 4px;"></i> Now</a>
|
||||
<a href="" class="tab active "><i class="fa-light fa-music" style="margin-right: 4px;"></i> Music</a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern" style="margin-right: 4px;"></i> Gaming</a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film" style="margin-right: 4px;"></i> Movie Trailers</a>
|
||||
<% } %>
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
<% } %>
|
||||
<% if (tab === "gaming") { %>
|
||||
|
||||
<div class="tabs tabs-center">
|
||||
|
||||
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire" style="margin-right: 4px;"></i> Now</a>
|
||||
<a href="?tab=music" class="tab"><i class="fa-light fa-music" style="margin-right: 4px;"></i> Music</a>
|
||||
<% if (!isMobile) { %>
|
||||
<a href="" class="tab active"><i class="fa-light fa-gamepad-modern" style="margin-right: 4px;"></i> Gaming</a>
|
||||
<a href="?tab=movies" class="tab"><i class="fa-light fa-film" style="margin-right: 4px;"></i> Movie Trailers</a>
|
||||
<% } %>
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
<% } %>
|
||||
|
||||
<% if (tab === "movies") { %>
|
||||
|
||||
<div class="tabs tabs-center">
|
||||
<a href="/app" class="tab"><i class="fa-light fa-fire" style="margin-right: 4px;"></i> Now</a>
|
||||
<a href="?tab=music" class="tab"><i class="fa-light fa-music" style="margin-right: 4px;"></i> Music</a>
|
||||
<a href="?tab=gaming" class="tab"><i class="fa-light fa-gamepad-modern" style="margin-right: 4px;"></i> Gaming</a>
|
||||
<a href="" class="tab active"><i class="fa-light fa-film" style="margin-right: 4px;"></i> Movie Trailers</a>
|
||||
</div>
|
||||
<% } %>
|
||||
|
||||
|
||||
|
||||
<div class="video-grid" style="border-top-left-radius:2em;width: 80em;border-top-right-radius: 2em;border: solid 1px #df03a8;">
|
||||
<% inv.forEach(x => { %>
|
||||
<a href="/watch?v=<%- x.videoId %>" class="video canloadhd" data-author="<%- x.author %>" >
|
||||
<div class="thumbnail" style="background-image: url('/vi/<%= x.videoId %>/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLBy_x4UUHLNDZtJtH0PXeQGoRFTgw');border-radius: 9.5px;"><span class="video-length"><%- turntomins(x.lengthSeconds) %></span></div>
|
||||
<div class="info">
|
||||
<span class="title max-lines-2" title="<%- x.title %>" style="font-family:Inter,sans-serif;"><%- x.title %></span>
|
||||
<span class="title max-lines-2" title="Video By <%- x.author %>" style="margin-top:1px">By <%- x.author %></span>
|
||||
|
||||
</div>
|
||||
|
||||
</a>
|
||||
|
||||
|
||||
<% }) %>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
|
||||
|
||||
<script src="/css/custom-css.js"> </script>
|
||||
<script>
|
||||
// @license magnet:?xt=urn:btih:1f739d935676111cfff4b4693e3816e664797050&dn=gpl-3.0.txt GPL-3.0-or-later
|
||||
|
||||
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
let bgs = document.querySelectorAll('[data-bg]');
|
||||
let bgCount = bgs.length;
|
||||
|
||||
function loadBg(index) {
|
||||
let bg = bgs[index];
|
||||
let bgUrl = bg.getAttribute('data-bg');
|
||||
bg.style.backgroundImage = `url(${bgUrl})`;
|
||||
bg.removeAttribute('data-bg');
|
||||
bg.classList.add('loaded');
|
||||
}
|
||||
|
||||
function lazyLoadBg() {
|
||||
for (let i = 0; i < bgCount; i++) {
|
||||
let bg = bgs[i];
|
||||
let bgRect = bg.getBoundingClientRect();
|
||||
if (bgRect.top < window.innerHeight && bgRect.bottom > 0) {
|
||||
loadBg(i);
|
||||
function load(el) {
|
||||
const url = el.getAttribute('data-bg');
|
||||
if (!url) return;
|
||||
el.style.backgroundImage = 'url(' + url + ')';
|
||||
el.removeAttribute('data-bg');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
lazyLoadBg();
|
||||
|
||||
window.addEventListener('scroll', lazyLoadBg);
|
||||
window.addEventListener('resize', lazyLoadBg);
|
||||
});
|
||||
|
||||
// Get the progress bar and container elements
|
||||
const progressBar1 = document.querySelector(".progress-bar");
|
||||
const progressContainer1 = document.querySelector(".progress-container");
|
||||
|
||||
// Set the initial width of the progress bar to 0%
|
||||
progressBar1.style.width = "0%";
|
||||
progressContainer1.style.display = 'block';
|
||||
|
||||
// Attach an event listener to the window object to listen for the 'load' event
|
||||
window.addEventListener("load", () => {
|
||||
progressBar1.style.width = "100%";
|
||||
setTimeout(() => {
|
||||
progressContainer1.style.display = 'none';
|
||||
}, 500);
|
||||
});
|
||||
|
||||
let isScrolling = false;
|
||||
let startY = 0;
|
||||
let currentY = 0;
|
||||
let velocityY = 0;
|
||||
let lastTimestamp = 0;
|
||||
|
||||
const element = document.documentElement || document.body; // Use the entire page for scrolling
|
||||
|
||||
element.addEventListener('mousedown', (e) => {
|
||||
isScrolling = true;
|
||||
startY = e.clientY;
|
||||
currentY = startY;
|
||||
velocityY = 0;
|
||||
lastTimestamp = performance.now();
|
||||
});
|
||||
|
||||
element.addEventListener('mousemove', (e) => {
|
||||
if (isScrolling) {
|
||||
const deltaY = e.clientY - currentY;
|
||||
currentY = e.clientY;
|
||||
const timestamp = performance.now();
|
||||
const elapsed = timestamp - lastTimestamp;
|
||||
lastTimestamp = timestamp;
|
||||
velocityY = deltaY / elapsed;
|
||||
|
||||
// Update the scroll position based on deltaY
|
||||
element.scrollTop += deltaY;
|
||||
}
|
||||
});
|
||||
|
||||
element.addEventListener('mouseup', () => {
|
||||
isScrolling = false;
|
||||
// Apply the kinetic scrolling effect based on the velocityY
|
||||
const animationFrame = () => {
|
||||
if (Math.abs(velocityY) > 0.1) {
|
||||
element.scrollTop += velocityY;
|
||||
velocityY *= 0.95; // Damping factor
|
||||
requestAnimationFrame(animationFrame);
|
||||
}
|
||||
};
|
||||
requestAnimationFrame(animationFrame);
|
||||
});
|
||||
|
||||
element.addEventListener('mouseleave', () => {
|
||||
isScrolling = false;
|
||||
});
|
||||
|
||||
element.addEventListener('wheel', (e) => {
|
||||
// Adjust the scrollTop based on e.deltaY
|
||||
element.scrollTop += e.deltaY;
|
||||
});
|
||||
// @license-end
|
||||
|
||||
</script>
|
||||
|
||||
</body >
|
||||
if ('IntersectionObserver' in window) {
|
||||
const io = new IntersectionObserver((entries, obs) => {
|
||||
entries.forEach(entry => {
|
||||
if (entry.isIntersecting) {
|
||||
load(entry.target);
|
||||
obs.unobserve(entry.target);
|
||||
}
|
||||
});
|
||||
}, { rootMargin: '200px 0px' });
|
||||
|
||||
nodes.forEach(n => io.observe(n));
|
||||
} else {
|
||||
const onScroll = () => {
|
||||
const vh = window.innerHeight || document.documentElement.clientHeight;
|
||||
nodes.forEach(n => {
|
||||
if (!n.hasAttribute('data-bg')) return;
|
||||
const r = n.getBoundingClientRect();
|
||||
if (r.top < vh + 200 && r.bottom > -200) load(n);
|
||||
});
|
||||
};
|
||||
onScroll();
|
||||
window.addEventListener('scroll', onScroll, { passive: true });
|
||||
window.addEventListener('resize', onScroll);
|
||||
}
|
||||
}());
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
<% } %>
|
||||
|
||||
<% } %>
|
||||
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user