mirror of
https://github.com/OPSnet/Gazelle.git
synced 2026-01-16 18:04:34 -05:00
228 lines
8.9 KiB
PHP
228 lines
8.9 KiB
PHP
<?php
|
|
// phpcs:disable PSR1.Methods.CamelCapsMethodName.NotCamelCaps
|
|
|
|
class View {
|
|
use \Gazelle\Pg;
|
|
|
|
/**
|
|
* Display the page header
|
|
* @param array<string> $option
|
|
*/
|
|
public static function show_header(string $pageTitle, array $option = []): void {
|
|
echo self::header($pageTitle, $option);
|
|
}
|
|
|
|
/**
|
|
* Generate the page header
|
|
* @param array<string> $option
|
|
*/
|
|
public static function header(string $pageTitle, array $option = []): string {
|
|
$js = isset($option['js']) ? array_map(fn($s) => "$s.js", explode(',', $option['js'])) : [];
|
|
global $Viewer;
|
|
global $Twig;
|
|
if (!isset($Viewer)) {
|
|
return $Twig->render('index/public-header.twig', [
|
|
'page_title' => $pageTitle,
|
|
'script' => $js,
|
|
]);
|
|
}
|
|
|
|
$staffPmManager = new Gazelle\Manager\StaffPM();
|
|
$activity = new Gazelle\User\Activity($Viewer);
|
|
$activity->configure()
|
|
->setStaffPM($staffPmManager);
|
|
|
|
$notifier = new Gazelle\User\Notification($Viewer);
|
|
$module = $Viewer->requestContext()->module();
|
|
$alertList = $notifier->setDocument($module, $_REQUEST['action'] ?? '')->alertList();
|
|
foreach ($alertList as $alert) {
|
|
if (in_array($alert->display(), [Gazelle\User\Notification::DISPLAY_TRADITIONAL, Gazelle\User\Notification::DISPLAY_TRADITIONAL_PUSH])) {
|
|
$activity->setAlert(sprintf('<a href="%s">%s</a>', $alert->notificationUrl(), $alert->title()));
|
|
}
|
|
}
|
|
|
|
$payMan = new Gazelle\Manager\Payment();
|
|
if ($Viewer->permitted('users_mod')) {
|
|
$raTypeMan = new Gazelle\Manager\ReportAutoType();
|
|
$activity->setStaff(new Gazelle\Staff($Viewer))
|
|
->setReport(new Gazelle\Stats\Report())
|
|
->setPayment($payMan)
|
|
->setApplicant(new Gazelle\Manager\Applicant())
|
|
->setDb(new Gazelle\DB())
|
|
->setScheduler(new Gazelle\TaskScheduler())
|
|
->setSSLHost(new Gazelle\Manager\SSLHost())
|
|
->setAutoReport(
|
|
new Gazelle\Search\ReportAuto(
|
|
new Gazelle\Manager\ReportAuto($raTypeMan),
|
|
$raTypeMan
|
|
)
|
|
);
|
|
|
|
$threshold = (new \Gazelle\Manager\SiteOption())
|
|
->findValueByName('download-warning-threshold');
|
|
if ($threshold) {
|
|
$activity->setStats((int)$threshold, new Gazelle\Stats\Torrent());
|
|
}
|
|
|
|
if (OPEN_EXTERNAL_REFERRALS) {
|
|
$activity->setReferral(new Gazelle\Manager\Referral());
|
|
}
|
|
}
|
|
|
|
$PageID = [$module, $_REQUEST['action'] ?? false, $_REQUEST['type'] ?? false];
|
|
$navLinks = [];
|
|
foreach ((new Gazelle\Manager\UserNavigation())->userControlList($Viewer) as $n) {
|
|
[$ID, $Key, $Title, $Target, $Tests, $TestUser, $Mandatory] = array_values($n);
|
|
if (str_contains($Tests, ':')) {
|
|
$testList = [];
|
|
foreach (array_map('trim', explode(',', $Tests)) as $Part) {
|
|
$testList[] = array_map(fn ($t) => $t === 'false' ? false : $t, explode(':', $Part));
|
|
}
|
|
} elseif (str_contains($Tests, ',')) {
|
|
$testList = array_map(fn ($t) => $t === 'false' ? false : $t, explode(',', $Tests));
|
|
} else {
|
|
$testList = [$Tests];
|
|
}
|
|
if ($Key === 'notifications' && !$Viewer->permitted('site_torrents_notify')) {
|
|
continue;
|
|
}
|
|
|
|
$extraClass = [];
|
|
if ($Key === 'inbox') {
|
|
$Target = 'inbox.php';
|
|
if ((new \Gazelle\User\Inbox($Viewer))->unreadTotal()) {
|
|
$extraClass[] = 'new-subscriptions';
|
|
}
|
|
} elseif ($Key === 'subscriptions') {
|
|
if (
|
|
isset($alertList['Subscription'])
|
|
&& (new \Gazelle\User\Subscription($Viewer))->unread()
|
|
) {
|
|
$extraClass[] = 'new-subscriptions';
|
|
}
|
|
if (self::add_active($PageID, ['userhistory', 'subscriptions'])) {
|
|
$extraClass[] = 'active';
|
|
}
|
|
} elseif ($Key === 'staffinbox') {
|
|
if (
|
|
$activity->showStaffInbox()
|
|
&& $staffPmManager->countByStatus($Viewer, ['Unanswered'])
|
|
) {
|
|
$extraClass[] = 'new-subscriptions';
|
|
}
|
|
if (self::add_active($PageID, $testList)) {
|
|
$extraClass[] = 'active';
|
|
}
|
|
} elseif (
|
|
$TestUser
|
|
&& $Viewer->id() != ($_REQUEST['userid'] ?? 0)
|
|
&& self::add_active($PageID, $testList)
|
|
) {
|
|
$extraClass[] = 'active';
|
|
}
|
|
$navLinks[] = "<li id=\"nav_{$Key}\""
|
|
. ($extraClass ? ' class="' . implode(' ', $extraClass) . '"' : '')
|
|
. "><a href=\"{$Target}\">{$Title}</a></li>\n";
|
|
}
|
|
|
|
return $Twig->render('index/private-header.twig', [
|
|
'page_title' => $pageTitle,
|
|
'script' => $js,
|
|
'scss_style' => isset($option['css'])
|
|
? array_map(fn($s) => "$s/style.css", explode(',', $option['css'])) : [],
|
|
'stylesheet' => new \Gazelle\User\Stylesheet($Viewer),
|
|
'use_noty' => $notifier->useNoty(),
|
|
'viewer' => $Viewer,
|
|
])
|
|
. $Twig->render('index/page-header.twig', [
|
|
'action' => $_REQUEST['action'] ?? null,
|
|
'action_list' => $activity->actionList(),
|
|
'alert_list' => $activity->alertList(),
|
|
'bonus' => new Gazelle\User\Bonus($Viewer),
|
|
'document' => $module,
|
|
'dono_target' => $payMan->monthlyPercent(new Gazelle\Manager\Donation()),
|
|
'nav_links' => $navLinks,
|
|
'viewer' => $Viewer,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Determine if a link should be marked as 'active'
|
|
* @param array<mixed> $Target
|
|
* @param array<mixed> $Tests
|
|
*/
|
|
protected static function add_active(array $Target, array $Tests): bool {
|
|
if (!is_array($Tests[0])) {
|
|
// Test all values in vectors
|
|
foreach ($Tests as $Type => $Part) {
|
|
if (!isset($Target[$Type]) || $Target[$Type] !== $Part) {
|
|
return false;
|
|
}
|
|
}
|
|
} else {
|
|
// Loop to the end of the array or until we find a matching test
|
|
foreach ($Tests as $Test) {
|
|
// If $Pass remains true after this test, it's a match
|
|
foreach ($Test as $Type => $Part) {
|
|
if (!isset($Target[$Type]) || $Target[$Type] !== $Part) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Display the footer of the page
|
|
*/
|
|
public static function show_footer(): void {
|
|
echo self::footer();
|
|
}
|
|
|
|
public static function footer(bool $showDisclaimer = false): string {
|
|
global $Twig, $Viewer;
|
|
if (!isset($Viewer)) {
|
|
return $Twig->render('index/public-footer.twig');
|
|
}
|
|
|
|
$launch = date('Y');
|
|
if ($launch != SITE_LAUNCH_YEAR) {
|
|
$launch = SITE_LAUNCH_YEAR . "-$launch";
|
|
}
|
|
|
|
$alertList = (new Gazelle\User\Notification($Viewer))
|
|
->setDocument(
|
|
$Viewer->requestContext()->module(),
|
|
$_REQUEST['action'] ?? ''
|
|
)
|
|
->alertList();
|
|
$notification = [];
|
|
foreach ($alertList as $alert) {
|
|
if (in_array($alert->display(), [Gazelle\User\Notification::DISPLAY_POPUP, Gazelle\User\Notification::DISPLAY_POPUP_PUSH])) {
|
|
$notification[] = $alert;
|
|
}
|
|
}
|
|
|
|
global $Cache, $Debug, $SessionID;
|
|
return $Twig->render('index/private-footer.twig', [
|
|
'cache' => $Cache,
|
|
'db' => Gazelle\DB::DB(),
|
|
'debug' => $Debug,
|
|
'disclaimer' => $showDisclaimer,
|
|
'last_active' => (new Gazelle\User\Session($Viewer))->lastActive($SessionID),
|
|
'launch' => $launch,
|
|
'load' => sys_getloadavg(),
|
|
'notification' => $notification,
|
|
'memory' => memory_get_usage(true),
|
|
'pg' => self::pgStatic()->stats(),
|
|
'textarea_js' => Gazelle\Util\Textarea::activate(),
|
|
'time_ms' => $Debug->duration() * 1000,
|
|
'viewer' => $Viewer,
|
|
'sphinxql' => class_exists('Sphinxql') && !empty(\Sphinxql::$Queries)
|
|
? ['list' => \Sphinxql::$Queries, 'time' => \Sphinxql::$Time]
|
|
: [],
|
|
]);
|
|
}
|
|
}
|