YGGo/public/index.php

281 lines
6.2 KiB
PHP
Raw Normal View History

2023-04-01 19:29:39 +03:00
<?php
// Load system dependencies
2023-06-30 14:38:29 +03:00
require_once(__DIR__ . '/../config/app.php');
require_once(__DIR__ . '/../library/filter.php');
require_once(__DIR__ . '/../library/sphinxql.php');
2023-04-01 19:29:39 +03:00
// Connect Sphinx search server
$sphinx = new SphinxQL(SPHINX_HOST, SPHINX_PORT);
2023-04-01 19:29:39 +03:00
$totalPages = $sphinx->getHostPagesTotal();
2023-04-01 19:29:39 +03:00
$placeholder = Filter::plural($totalPages, [sprintf(_('Over %s page or enter the new one...'), $totalPages),
sprintf(_('Over %s pages or enter the new one...'), $totalPages),
sprintf(_('Over %s pages or enter the new one...'), $totalPages),
]);
?>
<!DOCTYPE html>
<html lang="<?php echo _('en-US') ?>">
<head>
<title><?php echo _('YGGo! Web Search Engine') ?></title>
<meta charset="utf-8" />
2023-04-25 19:35:52 +03:00
<?php if (API_MANIFEST_ENABLED) { ?>
2023-05-03 09:38:58 +03:00
<meta name="yggo:manifest" content="<?php echo sprintf('%s/api.php?action=manifest', WEBSITE_DOMAIN) ?>" />
2023-04-25 19:35:52 +03:00
<?php } ?>
2023-04-02 16:07:57 +03:00
<meta name="description" content="<?php echo _('Javascript-less Open Source Web Search Engine') ?>" />
2023-04-09 01:22:36 +03:00
<meta name="keywords" content="<?php echo _('web, search, engine, crawler, php, pdo, mysql, sphinx, yggdrasil, js-less, open source') ?>" />
2023-04-01 19:29:39 +03:00
<style>
* {
border: 0;
margin: 0;
padding: 0;
font-family: Sans-serif;
}
body {
background-color: #2e3436
}
h1 {
color: #fff;
font-weight: normal;
font-size: 48px;
margin: 16px 0
}
form {
display: block;
max-width: 640px;
2023-07-23 14:54:37 +03:00
margin: 16% auto;
2023-04-01 19:29:39 +03:00
text-align: center;
}
input {
width: 100%;
margin: 16px 0;
2023-04-02 22:05:47 +03:00
padding: 16px 0;
2023-04-01 19:29:39 +03:00
border-radius: 32px;
background-color: #000;
color: #fff;
font-size: 16px;
text-align: center;
}
input:hover {
background-color: #111
}
input:focus {
outline: none;
background-color: #111
}
input:focus::placeholder {
color: #090808;
}
button {
margin: 22px 0;
padding: 12px 16px;
border-radius: 4px;
cursor: pointer;
background-color: #3394fb;
color: #fff;
font-size: 14px;
}
button:hover {
background-color: #4b9df4;
}
footer {
position: fixed;
bottom: 0;
left:0;
right: 0;
text-align: center;
padding: 24px;
}
a, a:visited, a:active {
color: #ccc;
}
a:hover {
color: #fff;
}
2023-05-17 14:25:31 +03:00
footer > a,
footer > a:visited,
footer > a:active {
text-decoration: none;
}
2023-06-05 23:08:29 +03:00
footer > span:first-child {
color: #ff0;
}
footer > span:last-child {
color: #3394fb;
}
2023-04-02 22:04:41 +03:00
/*
* CSS animation
* by https://codepen.io/alvarotrigo/pen/GRvYNax
*/
main {
background: #2e3436;
background: -webkit-linear-gradient(to left, #8f94fb, #4e54c8);
width: 100%;
}
ul {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
overflow: hidden;
z-index:-1
}
li {
position: absolute;
display: block;
list-style: none;
width: 20px;
height: 20px;
background: rgba(255, 255, 255, 0.2);
animation: animate 25s linear infinite;
bottom: -150px;
}
li:nth-child(1) {
left: 25%;
width: 80px;
height: 80px;
animation-delay: 0s;
}
li:nth-child(2) {
left: 10%;
width: 20px;
height: 20px;
animation-delay: 2s;
animation-duration: 12s;
}
li:nth-child(3) {
left: 70%;
width: 20px;
height: 20px;
animation-delay: 4s;
}
li:nth-child(4) {
left: 40%;
width: 60px;
height: 60px;
animation-delay: 0s;
animation-duration: 18s;
}
li:nth-child(5) {
left: 65%;
width: 20px;
height: 20px;
animation-delay: 0s;
}
li:nth-child(6) {
left: 75%;
width: 110px;
height: 110px;
animation-delay: 3s;
}
li:nth-child(7) {
left: 35%;
width: 150px;
height: 150px;
animation-delay: 7s;
}
li:nth-child(8) {
left: 50%;
width: 25px;
height: 25px;
animation-delay: 15s;
animation-duration: 45s;
}
li:nth-child(9) {
left: 20%;
width: 15px;
height: 15px;
animation-delay: 2s;
animation-duration: 35s;
}
li:nth-child(10) {
left: 85%;
width: 150px;
height: 150px;
animation-delay: 0s;
animation-duration: 11s;
}
@keyframes animate {
0%{
transform: translateY(0) rotate(0deg);
opacity: 1;
border-radius: 0;
}
100%{
transform: translateY(-1000px) rotate(720deg);
opacity: 0;
border-radius: 50%;
}
}
2023-04-01 19:29:39 +03:00
</style>
</head>
<body>
<header>
<form name="search" method="GET" action="<?php echo WEBSITE_DOMAIN; ?>/search.php">
<h1><?php echo _('YGGo!') ?></h1>
<input type="text" name="q" placeholder="<?php echo $placeholder ?>" value="" />
<button type="submit"><?php echo _('Search') ?></button>
</form>
</header>
2023-04-02 22:04:41 +03:00
<!-- css animation : begin -->
<main>
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</main>
<!-- css animation : end -->
2023-04-01 19:29:39 +03:00
<footer>
2023-04-03 17:56:51 +03:00
<!-- This product released under the MIT License (https://github.com/YGGverse/YGGo/blob/main/LICENSE)
2023-04-02 23:06:02 +03:00
Before removing the copyright,
please, make a small donation to the project contributors:
2023-04-03 17:56:51 +03:00
https://github.com/YGGverse/YGGo#donate-to-contributors
2023-04-02 23:06:02 +03:00
-->
2023-07-07 12:43:56 +03:00
<span>^</span><a href="https://github.com/YGGverse/YGGo"><?php echo _('meow') ?></a><span>^</span>
2023-04-01 19:29:39 +03:00
</footer>
</body>
</html>