272 lines
15 KiB
PHP
272 lines
15 KiB
PHP
@php
|
|
// Allow BlueprintExtensionLibrary to work in all admin views without
|
|
// modifying all admin page controllers. Doing this should preserve
|
|
// basic compatibility for other modifications.
|
|
use Pterodactyl\BlueprintFramework\Libraries\ExtensionLibrary\Admin\BlueprintAdminLibrary as BlueprintExtensionLibrary;
|
|
$settings = app()->make('Pterodactyl\Contracts\Repository\SettingsRepositoryInterface');
|
|
$blueprint = app()->make(BlueprintExtensionLibrary::class, ['settings' => $settings]);
|
|
@endphp
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
|
<title>{{ config('app.name', 'Pterodactyl') }} - @yield('title')</title>
|
|
<meta content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" name="viewport">
|
|
<meta name="_token" content="{{ csrf_token() }}">
|
|
|
|
<link rel="apple-touch-icon" sizes="180x180" href="/favicons/apple-touch-icon.png">
|
|
<link rel="icon" type="image/png" href="/favicons/favicon-32x32.png" sizes="32x32">
|
|
<link rel="icon" type="image/png" href="/favicons/favicon-16x16.png" sizes="16x16">
|
|
<link rel="manifest" href="/favicons/manifest.json">
|
|
<link rel="mask-icon" href="/favicons/safari-pinned-tab.svg" color="#bc6e3c">
|
|
<link rel="shortcut icon" href="/favicons/favicon.ico">
|
|
<meta name="msapplication-config" content="/favicons/browserconfig.xml">
|
|
<meta name="theme-color" content="#0e4688">
|
|
|
|
@include('layouts.scripts')
|
|
|
|
@section('scripts')
|
|
{!! Theme::css('vendor/select2/select2.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('vendor/bootstrap/bootstrap.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('vendor/adminlte/admin.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('vendor/adminlte/colors/skin-blue.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('vendor/sweetalert/sweetalert.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('vendor/animate/animate.min.css?t={cache-version}') !!}
|
|
{!! Theme::css('css/pterodactyl.css?t={cache-version}') !!}
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css">
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/ionicons/2.0.1/css/ionicons.min.css">
|
|
<link rel="stylesheet" href="https://unpkg.com/boxicons@latest/css/boxicons.min.css">
|
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.1/font/bootstrap-icons.css">
|
|
|
|
<!--[if lt IE 9]>
|
|
<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
|
|
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
|
|
<![endif]-->
|
|
@show
|
|
</head>
|
|
<body class="hold-transition skin-blue fixed sidebar-mini">
|
|
<!-- Begin Blueprint cache-refresh requirement -->
|
|
<div
|
|
id="cacheOverlay-1"
|
|
style="
|
|
position: fixed;
|
|
bottom: 0px;
|
|
left: 0px;
|
|
background: black;
|
|
color: white;
|
|
padding: 0px 10px;
|
|
width: 100vw;
|
|
z-index: 6000001;
|
|
"
|
|
>
|
|
<p style="font-size: 20px;">
|
|
<code style="background: none; border: none; color: white !important;">[<i style="margin-left:20px">#</i> <i style="margin-right:3px">#</i>]</code>
|
|
<code style="background: none; border: none;">Outdated stylesheets detected.</code>
|
|
<code style="background: none; border: none; float: right; margin-top: 5px;"><button style="background: none; border: none; color: blue;">Learn more</button></code>
|
|
</p>
|
|
</div>
|
|
<!-- End Blueprint cache-refresh requirement -->
|
|
<div class="wrapper">
|
|
<header class="main-header">
|
|
<a href="{{ route('index') }}" class="logo">
|
|
<span>{{ config('app.name', 'Pterodactyl') }}</span>
|
|
</a>
|
|
<nav class="navbar navbar-static-top">
|
|
<a href="#" class="sidebar-toggle" data-toggle="push-menu" role="button">
|
|
<span class="sr-only">Toggle navigation</span>
|
|
<span class="icon-bar"></span>
|
|
<span class="icon-bar"></span>
|
|
<span class="icon-bar"></span>
|
|
</a>
|
|
<div class="navbar-custom-menu">
|
|
<ul class="nav navbar-nav">
|
|
<li class="user-menu">
|
|
<a href="{{ route('account') }}">
|
|
<img src="https://www.gravatar.com/avatar/{{ md5(strtolower(Auth::user()->email)) }}?s=160" class="user-image" alt="User Image">
|
|
<span class="hidden-xs">{{ Auth::user()->name_first }} {{ Auth::user()->name_last }}</span>
|
|
</a>
|
|
</li>
|
|
<li>
|
|
<!-- The puzzle icon in the admin panel to manage and configure your installed extensions. -->
|
|
<li><a href="{{ route('admin.extensions') }}" data-toggle="tooltip" data-placement="bottom" title="Extensions"><i class='fa fa-puzzle-piece <?php if($blueprint->fileRead("&bp.folder&/.blueprint/extensions/blueprint/private/db/onboarding") == "true"){ echo "bx-flashing"; } ?>'></i></a></li>
|
|
</li>
|
|
<li>
|
|
<li><a href="{{ route('index') }}" data-toggle="tooltip" data-placement="bottom" title="Exit Admin Control"><i class="fa fa-server"></i></a></li>
|
|
</li>
|
|
<li>
|
|
<li><a href="{{ route('auth.logout') }}" id="logoutButton" data-toggle="tooltip" data-placement="bottom" title="Logout"><i class="fa fa-sign-out"></i></a></li>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</nav>
|
|
</header>
|
|
<aside class="main-sidebar">
|
|
<section class="sidebar">
|
|
<ul class="sidebar-menu">
|
|
<li class="header">BASIC ADMINISTRATION</li>
|
|
<li class="{{ Route::currentRouteName() !== 'admin.index' ?: 'active' }}">
|
|
<a href="{{ route('admin.index') }}">
|
|
<i class="fa fa-home"></i> <span>Overview</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.settings') ?: 'active' }}">
|
|
<a href="{{ route('admin.settings')}}">
|
|
<i class="fa fa-wrench"></i> <span>Settings</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.api') ?: 'active' }}">
|
|
<a href="{{ route('admin.api.index')}}">
|
|
<i class="fa fa-gamepad"></i> <span>Application API</span>
|
|
</a>
|
|
</li>
|
|
<li class="header">MANAGEMENT</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.databases') ?: 'active' }}">
|
|
<a href="{{ route('admin.databases') }}">
|
|
<i class="fa fa-database"></i> <span>Databases</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.locations') ?: 'active' }}">
|
|
<a href="{{ route('admin.locations') }}">
|
|
<i class="fa fa-globe"></i> <span>Locations</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.nodes') ?: 'active' }}">
|
|
<a href="{{ route('admin.nodes') }}">
|
|
<i class="fa fa-sitemap"></i> <span>Nodes</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.servers') ?: 'active' }}">
|
|
<a href="{{ route('admin.servers') }}">
|
|
<i class="fa fa-server"></i> <span>Servers</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.users') ?: 'active' }}">
|
|
<a href="{{ route('admin.users') }}">
|
|
<i class="fa fa-users"></i> <span>Users</span>
|
|
</a>
|
|
</li>
|
|
<li class="header">SERVICE MANAGEMENT</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.mounts') ?: 'active' }}">
|
|
<a href="{{ route('admin.mounts') }}">
|
|
<i class="fa fa-magic"></i> <span>Mounts</span>
|
|
</a>
|
|
</li>
|
|
<li class="{{ ! starts_with(Route::currentRouteName(), 'admin.nests') ?: 'active' }}">
|
|
<a href="{{ route('admin.nests') }}">
|
|
<i class="fa fa-th-large"></i> <span>Nests</span>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</section>
|
|
</aside>
|
|
<div class="content-wrapper">
|
|
<section class="content-header">
|
|
@yield('content-header')
|
|
</section>
|
|
<section class="content">
|
|
<div class="row">
|
|
<div class="col-xs-12">
|
|
@if (count($errors) > 0)
|
|
<div class="alert alert-danger">
|
|
There was an error validating the data provided.<br><br>
|
|
<ul>
|
|
@foreach ($errors->all() as $error)
|
|
<li>{{ $error }}</li>
|
|
@endforeach
|
|
</ul>
|
|
</div>
|
|
@endif
|
|
@foreach (Alert::getMessages() as $type => $messages)
|
|
@foreach ($messages as $message)
|
|
<div class="alert alert-{{ $type }} alert-dismissable" role="alert">
|
|
{!! $message !!}
|
|
</div>
|
|
@endforeach
|
|
@endforeach
|
|
</div>
|
|
</div>
|
|
@yield('content')
|
|
<?php
|
|
|
|
// This might be further improved later.
|
|
|
|
if($blueprint->fileRead("&bp.folder&/.blueprint/extensions/blueprint/private/db/onboarding") == "true") {
|
|
echo "
|
|
<div class=\"notification\">
|
|
<p>Blueprint has now been installed, click the extension icon to take a look.</p>
|
|
</div>";
|
|
$blueprint->fileWipe("&bp.folder&/.blueprint/extensions/blueprint/private/db/onboarding");
|
|
}
|
|
|
|
$notification = $blueprint->dbGet("blueprint", "notification:text");
|
|
if($notification != null) {
|
|
echo "<div class=\"notification\">
|
|
<p>".$notification."</p>
|
|
</div>
|
|
";
|
|
|
|
$blueprint->dbSet("blueprint", "notification:text", "");
|
|
}
|
|
?>
|
|
</section>
|
|
</div>
|
|
<footer class="main-footer">
|
|
<div class="pull-right small text-gray" style="margin-right:10px;margin-top:-7px;">
|
|
<strong><i class="fa fa-fw {{ $appIsGit ? 'fa-git-square' : 'fa-code-fork' }}"></i></strong> {{ $appVersion }}<br />
|
|
<strong><i class="fa fa-fw fa-clock-o"></i></strong> {{ round(microtime(true) - LARAVEL_START, 3) }}s
|
|
</div>
|
|
Copyright © 2015 - {{ date('Y') }} <a href="https://pterodactyl.io/">Pterodactyl Software</a>.
|
|
</footer>
|
|
</div>
|
|
@section('footer-scripts')
|
|
<script src="/js/keyboard.polyfill.js" type="application/javascript"></script>
|
|
<script>keyboardeventKeyPolyfill.polyfill();</script>
|
|
|
|
{!! Theme::js('vendor/jquery/jquery.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/sweetalert/sweetalert.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/bootstrap/bootstrap.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/slimscroll/jquery.slimscroll.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/adminlte/app.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/bootstrap-notify/bootstrap-notify.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('vendor/select2/select2.full.min.js?t={cache-version}') !!}
|
|
{!! Theme::js('js/admin/functions.js?t={cache-version}') !!}
|
|
<script src="/js/autocomplete.js" type="application/javascript"></script>
|
|
|
|
@if(Auth::user()->root_admin)
|
|
<script>
|
|
$('#logoutButton').on('click', function (event) {
|
|
event.preventDefault();
|
|
|
|
var that = this;
|
|
swal({
|
|
title: 'Do you want to log out?',
|
|
type: 'warning',
|
|
showCancelButton: true,
|
|
confirmButtonColor: '#d9534f',
|
|
cancelButtonColor: '#d33',
|
|
confirmButtonText: 'Log out'
|
|
}, function () {
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: '{{ route('auth.logout') }}',
|
|
data: {
|
|
_token: '{{ csrf_token() }}'
|
|
},complete: function () {
|
|
window.location.href = '{{route('auth.login')}}';
|
|
}
|
|
});
|
|
});
|
|
});
|
|
</script>
|
|
@endif
|
|
|
|
<script>
|
|
$(function () {
|
|
$('[data-toggle="tooltip"]').tooltip();
|
|
})
|
|
</script>
|
|
@show
|
|
<!-- wrapper:insert -->
|
|
</body>
|
|
</html>
|