mirror of
https://github.com/ShaYmez/FreeSTAR-Status-Engine.git
synced 2024-11-14 00:01:45 -05:00
245 lines
14 KiB
PHP
245 lines
14 KiB
PHP
<?php
|
|
$statuses = array(_("Major outage"), _("Minor outage"), _("Planned maintenance"), _("Operational"));
|
|
$classes = array("danger", "warning", "primary", "success");
|
|
$icons = array("fa fa-times", "fa fa-exclamation", "fa fa-info", "fa fa-check");
|
|
$some = array(_("Some systems are experiencing major outages"), _("Some systems are experiencing minor outages"), _("Some systems are under maintenance"));
|
|
$all = array(_("Our systems are experiencing major outages."), _("Our systems are experiencing minor outages"), _("Our systems are under maintenance"), _("All systems operational"));
|
|
$permissions = array(_("Super admin"), _("Admin"), _("Editor"));
|
|
$visibility = array(_("Collapsed"), _("Expanded"), _("Expand on events"));
|
|
|
|
/**
|
|
* Class that encapsulates methods to render header and footer
|
|
*/
|
|
class Template
|
|
{
|
|
/**
|
|
* Renders header
|
|
* @param String $page_name name of the page to be displayed as title
|
|
* @param Boolean $admin decides whether to show admin menu
|
|
*/
|
|
public static function render_header($page_name, $page_id, $admin = false)
|
|
{
|
|
if (!$admin) {
|
|
// Create subscriber menu sections for later inclusion
|
|
// Check if we are on admin menu, if so do not display
|
|
$arr_url = explode("/", $_SERVER['PHP_SELF']);
|
|
$str_url = strtolower($arr_url[count($arr_url) - 2]);
|
|
if ('admin' == $str_url) {
|
|
$strSubsMenu = '';
|
|
} else {
|
|
if ($SUBSCRIBE_EMAIL || $SUBSCRIBE_TELEGRAM) {
|
|
// Subscriber menu is to be shown...
|
|
$strSubsMenu = '<ul class="nav navbar-nav mr-auto">';
|
|
// If subscriber is not logged on, display subscriber menus
|
|
if ((!isset($_SESSION['subscriber_valid'])) || false == $_SESSION['subscriber_valid']) {
|
|
$strSubsMenu .= '<li class="dropdown">
|
|
<a class="dropdown-toggle" data-toggle="dropdown" role="button" href="#"><span class="glyphicon glyphicon-th"></span> ' . _('Subscribe') . '</a>
|
|
<ul class="dropdown-menu ">';
|
|
|
|
if ($SUBSCRIBE_EMAIL) {
|
|
$strSubsMenu .= '<li><a href="?do=email_subscription&new=1"><span class="glyphicon glyphicon-envelope"></span> ' . _('Subscribe via email') . '</a></li>';
|
|
}
|
|
if ($SUBSCRIBE_TELEGRAM) {
|
|
$strSubsMenu .= '<li><a href="#"><script async src="https://telegram.org/js/telegram-widget.js?4" data-telegram-login="' . $TG_BOT_USERNAME . '" data-size="small" data-userpic="false" data-auth-url="' . WEB_URL . '/telegram_check.php" data-request-access="write"></script></a></li>';
|
|
}
|
|
$strSubsMenu .= '</ul>';
|
|
}
|
|
}
|
|
// If subscriber is logged on, display unsub and logoff menu points
|
|
if ((isset($_SESSION['subscriber_valid'])) && $_SESSION['subscriber_valid']) {
|
|
$strSubsMenu .= '<li><a href="?do=subscriptions">' . _('Subscriptions') . '</a></li>';
|
|
$strSubsMenu .= '<li><a href="' . WEB_URL . '/index.php?subscriber_logout=1">' . _('Logout') . '</a></li>';
|
|
}
|
|
$strSubsMenu .= '</ul>';
|
|
}
|
|
}
|
|
?>
|
|
<!doctype html>
|
|
<html lang="en">
|
|
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title><?php echo $page_name . " - " . NAME ?></title>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<meta name="description" content="Current service status for <?php echo NAME; ?> can be found here as well as incident history.">
|
|
<link rel="shortcut icon" href="<?php echo WEB_URL; ?>/favicon.ico" type="image/png">
|
|
<link rel="stylesheet" href="<?php echo WEB_URL; ?>/vendor/bootstrap/css/bootstrap.min.css">
|
|
<link rel="stylesheet" href="<?php echo WEB_URL; ?>/css/main.css" media="screen">
|
|
<link rel="stylesheet" href="<?php echo WEB_URL; ?>/css/print.css" media="print">
|
|
<link rel="apple-touch-icon" sizes="57x57" href="<?php echo WEB_URL; ?>/favicon/apple-icon-57x57.png">
|
|
<link rel="apple-touch-icon" sizes="60x60" href="<?php echo WEB_URL; ?>/favicon/apple-icon-60x60.png">
|
|
<link rel="apple-touch-icon" sizes="72x72" href="<?php echo WEB_URL; ?>/favicon/apple-icon-72x72.png">
|
|
<link rel="apple-touch-icon" sizes="76x76" href="<?php echo WEB_URL; ?>/favicon/apple-icon-76x76.png">
|
|
<link rel="apple-touch-icon" sizes="114x114" href="<?php echo WEB_URL; ?>/favicon/apple-icon-114x114.png">
|
|
<link rel="apple-touch-icon" sizes="120x120" href="<?php echo WEB_URL; ?>/favicon/apple-icon-120x120.png">
|
|
<link rel="apple-touch-icon" sizes="144x144" href="<?php echo WEB_URL; ?>/favicon/apple-icon-144x144.png">
|
|
<link rel="apple-touch-icon" sizes="152x152" href="<?php echo WEB_URL; ?>/favicon/apple-icon-152x152.png">
|
|
<link rel="apple-touch-icon" sizes="180x180" href="<?php echo WEB_URL; ?>/favicon/apple-icon-180x180.png">
|
|
<link rel="icon" type="image/png" sizes="192x192" href="<?php echo WEB_URL; ?>/favicon/android-icon-192x192.png">
|
|
<link rel="icon" type="image/png" sizes="32x32" href="<?php echo WEB_URL; ?>/favicon/favicon-32x32.png">
|
|
<link rel="icon" type="image/png" sizes="96x96" href="<?php echo WEB_URL; ?>/favicon/favicon-96x96.png">
|
|
<link rel="icon" type="image/png" sizes="16x16" href="<?php echo WEB_URL; ?>/favicon/favicon-16x16.png">
|
|
<link rel="manifest" href="<?php echo WEB_URL; ?>/favicon/manifest.json">
|
|
<meta name="msapplication-TileColor" content="#ffffff">
|
|
<meta name="msapplication-TileImage" content="/ms-icon-144x144.png">
|
|
<meta name="theme-color" content="#ffffff">
|
|
<link href="https://use.fontawesome.com/releases/v5.15.2/css/all.css" rel="stylesheet">
|
|
<?php
|
|
if (!$admin) {
|
|
$headpath = $_SERVER['DOCUMENT_ROOT'] . "/head.txt";
|
|
$headfile = fopen("$headpath", "r") or die("Unable to open head.txt!");
|
|
$head_additionalcode = fread($headfile, filesize($headpath));
|
|
fclose($headfile);
|
|
echo $head_additionalcode;
|
|
} else {
|
|
global $user;
|
|
?>
|
|
<link rel="stylesheet" href="<?php echo WEB_URL; ?>/vendor/flatpickr/flatpickr.min.css">
|
|
<?php
|
|
}
|
|
?>
|
|
</head>
|
|
|
|
<body>
|
|
<header class="fixed-top">
|
|
<div class="container">
|
|
<nav class="navbar navbar-expand-lg navbar-dark">
|
|
<div class="container-fluid">
|
|
<a class="navbar-brand" href="<?php echo WEB_URL; ?>/"><img src="<?php if (strlen(CUSTOM_LOGO_URL) > 1) {
|
|
echo CUSTOM_LOGO_URL;
|
|
} else {
|
|
echo WEB_URL . "/img/logo_white.png";
|
|
} ?>" alt="logo" class="menu-logo" width="50" height="50"></a>
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarToggler" aria-controls="navbarToggler" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<div class="collapse navbar-collapse" id="navbarToggler">
|
|
<ul class="navbar-nav ms-auto mb-2 mb-lg-0">
|
|
<?php
|
|
if (!$admin) {
|
|
?>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/"><?php echo _("Admin"); ?></a>
|
|
</li>
|
|
<li class="d-flex">
|
|
<input type="checkbox" class="custom-control-input" id="darkSwitch" hidden>
|
|
<label class="nav-link" for="darkSwitch"><i class="fas fa-moon"></i></label>
|
|
</li>
|
|
<li class="nav-item">
|
|
<?php echo $strSubsMenu; ?>
|
|
</li>
|
|
<?php
|
|
} else {
|
|
global $user;
|
|
?>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/"><?php echo _("Dashboard"); ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/?do=user"><?php printf(_("User (%s)"), $user->get_username()); ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/?do=settings"><?php echo _("Services & Users"); ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/?do=options"><?php echo _("Options"); ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link link-light" href="<?php echo WEB_URL; ?>/admin/?do=logout"><?php echo _("Logout"); ?></a>
|
|
</li>
|
|
<li class="d-flex">
|
|
<input type="checkbox" class="custom-control-input" id="darkSwitch" hidden>
|
|
<label class="nav-link" for="darkSwitch"><i class="fas fa-moon"></i></label>
|
|
</li>
|
|
<?php
|
|
}
|
|
?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
</div>
|
|
</header>
|
|
<main id="<?php echo $page_id; ?>" class="container <?php if ($admin) { ?>admin<?php } ?>">
|
|
<?php if ($admin) {
|
|
global $user;
|
|
}
|
|
}
|
|
/**
|
|
* Renders a toggle switch
|
|
* Created by Yigit Kerem Oktay
|
|
* @param String $toggletext will decide what the description text next to the toggle will be
|
|
* @param String $input_name will decide what the HTML Name attribute of the toggle will be
|
|
* @param Boolean $checked will decide if the toggle will initially be on or off
|
|
*/
|
|
public static function render_toggle($toggletext, $input_name, $checked)
|
|
{
|
|
?>
|
|
<div id="switch">
|
|
<label class="switch">
|
|
<input type="checkbox" name="<?php echo $input_name; ?>" <?php if ($checked) {
|
|
echo "checked";
|
|
} ?>>
|
|
<span class="slider round"></span>
|
|
</label>
|
|
<?php echo $toggletext; ?>
|
|
</div>
|
|
<?php
|
|
}
|
|
/**
|
|
* Renders footer
|
|
* @param Boolean $admin decides whether to load admin scripts
|
|
*/
|
|
public static function render_footer($admin = false)
|
|
{
|
|
global $negotiator;
|
|
$lang_names = $negotiator->get_accepted_langs();
|
|
?>
|
|
</main>
|
|
<footer id="footerwrap" class="sticky-bottom">
|
|
<div class="container">
|
|
<div class="row centered">
|
|
<div class="col-md-4 text-left"><a class="link-light" href="https://github.com/server-status-project/server-status/graphs/contributors" target=”_blank” rel=”noopener noreferrer”>Copyright © <?php echo date("Y"); ?> Server Status Project Contributors </a><?php if (strlen(COPYRIGHT_TEXT) > 1) {
|
|
echo " and " . COPYRIGHT_TEXT;
|
|
} ?></div>
|
|
<div class="col-md-4 text-center">
|
|
<div class="input-group dropup mb-3">
|
|
<button type="button" class="btn btn-primary" disabled><?php echo '<img src="' . $WEB_URL . '/locale/' . $_SESSION['locale'] . '/flag.png" alt="' . $lang_names[$_SESSION['locale']] . '">' . $lang_names[$_SESSION['locale']]; ?></button>
|
|
<button type="button" class="btn btn-primary dropdown-toggle dropdown-toggle-split" data-bs-toggle="dropdown" aria-expanded="false">
|
|
<span class="visually-hidden"><?php echo _("Toggle Dropdown"); ?></span>
|
|
</button>
|
|
<ul class="dropdown-menu">
|
|
<?php
|
|
foreach ($lang_names as $key => $value) {
|
|
echo '<a href="?lang=' . $key . '"><img src="' . $WEB_URL . '/locale/' . $key . '/flag.png" alt="' . $value . '">' . $value . '</a>';
|
|
}
|
|
?>
|
|
<li>
|
|
<hr class="dropdown-divider">
|
|
</li>
|
|
<li><a href="https://poeditor.com/join/project/37SpmJtyOm" target=”_blank” rel=”noopener noreferrer”><?php echo _("Help with translation!"); ?></a></li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-4 text-right"><a class="link-light" href="<?php echo IMPRINT_URL; ?>"><?php echo _("Imprint"); ?></a><a class="link-light" href="<?php echo POLICY_URL; ?>"><?php echo _("Privacy Policy"); ?></a></div>
|
|
</div>
|
|
<!--/row -->
|
|
</div>
|
|
<!--/container -->
|
|
</footer>
|
|
<script src="<?php echo WEB_URL; ?>/vendor/jquerry/jquery-3.6.0.min.js"></script>
|
|
<script src="<?php echo WEB_URL; ?>/vendor/jquerry/jquery.timeago.js"></script>
|
|
<script src="<?php echo WEB_URL; ?>/vendor/bootstrap/js/bootstrap.bundle.min.js"></script>
|
|
<script src="<?php echo WEB_URL; ?>/js/main.js"></script>
|
|
<?php if ($admin) { ?>
|
|
<script src="<?php echo WEB_URL; ?>/vendor/flatpickr/flatpickr.min.js"></script>
|
|
<script src="<?php echo WEB_URL; ?>/js/admin.js"></script>
|
|
<?php } ?>
|
|
<?php if ($GOOGLE_RECAPTCHA) { ?><script src='https://www.google.com/recaptcha/api.js'></script><?php } ?>
|
|
</body>
|
|
|
|
</html>
|
|
<?php
|
|
}
|
|
}
|