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
|
|
|
|
2023-05-08 12:28:49 +03:00
|
|
|
// Connect Sphinx search server
|
|
|
|
$sphinx = new SphinxQL(SPHINX_HOST, SPHINX_PORT);
|
2023-04-01 19:29:39 +03:00
|
|
|
|
2023-05-08 12:28:49 +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;
|
|
|
|
margin: 280px auto;
|
|
|
|
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>
|