314 lines
No EOL
16 KiB
PHP
314 lines
No EOL
16 KiB
PHP
<?php
|
|
|
|
// read toml config file
|
|
require_once 'vendor/autoload.php';
|
|
require_once 'functions/i18n.php';
|
|
require_once 'classes/Database.php';
|
|
require_once 'classes/Genre.php';
|
|
|
|
use Yosymfony\Toml\Toml;
|
|
|
|
$config = Toml::ParseFile('includes/config.toml');
|
|
$lang = $_SESSION['lang'] ?? $config['app']['locale'];
|
|
$locale = loadLocale($lang);
|
|
$genre= null;
|
|
$genreFound = false;
|
|
// if there's a query parameter named 'dj', load the DJ class
|
|
$db = new Database($config);
|
|
$genreRequested = false;
|
|
if (isset($_GET['genre']) && $_GET['genre'] != "") {
|
|
$genre = new Genre($_GET['genre'], $db);
|
|
if ($genre->get_name() != "") {
|
|
$genreRequested = true;
|
|
$genreFound = true;
|
|
}
|
|
}
|
|
|
|
|
|
?>
|
|
<!doctype html >
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
<title><?php echo $config['app']['name']; ?></title>
|
|
<link href="css/bootstrap.min.css" rel="stylesheet">
|
|
<link href="fontawesome/css/all.css" rel="stylesheet"/>
|
|
|
|
|
|
</head>
|
|
<body style="background-color: #eee;">
|
|
<?php require 'navbar.php'; ?>
|
|
<section style="background-color: #eee;">
|
|
<div class="container py-5">
|
|
<div class="row">
|
|
<div class="col">
|
|
<nav aria-label="breadcrumb" class="bg-body-tertiary rounded-3 p-3 mb-4">
|
|
<ol class="breadcrumb mb-0">
|
|
<li class="breadcrumb-item"><a href="#"><?php echo $locale['home']; ?></a></li>
|
|
<li class="breadcrumb-item"><a href="#"><?php echo $locale['genres']; ?></a></li>
|
|
<li class="breadcrumb-item active"
|
|
aria-current="page"><?php
|
|
if ($genre && $genre->get_name() != "") {
|
|
echo $genre->get_name();
|
|
} else {
|
|
echo $locale['notfound'];
|
|
}
|
|
?></li>
|
|
</ol>
|
|
</nav>
|
|
</div>
|
|
</div>
|
|
<?php if ($genreNotFound): ?>
|
|
<div class="row">
|
|
<div class="col-lg-4">
|
|
<div class="card mb-4">
|
|
<div class="card-body text-center">
|
|
<img src="<?php echo $dj->get_img(); ?>"
|
|
alt="avatar"
|
|
class="rounded-circle img-fluid" style="width: 150px;">
|
|
<h5 class="my-3"><?php echo $dj->get_name();
|
|
?></h5>
|
|
<?php
|
|
|
|
if ($dj->get_claimed()) {
|
|
echo '<p class="text-muted mb-1">';
|
|
echo "<i class='fa fa-user-shield' style='color: gold'>Claimed</i>";
|
|
echo "</p>";
|
|
}
|
|
|
|
?>
|
|
</p>
|
|
<p class="text-muted mb-4">$location1</p>
|
|
<div class="d-flex justify-content-center mb-2">
|
|
<button type="button" data-mdb-button-init data-mdb-ripple-init class="btn btn-primary">
|
|
<?php echo $locale['follow']; ?>
|
|
</button>
|
|
<button type="button" data-mdb-button-init data-mdb-ripple-init
|
|
class="btn btn-outline-primary ms-1"><?php echo $locale['message']; ?>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="card mb-4 mb-lg-0">
|
|
<div class="card-body p-0">
|
|
<ul class="list-group list-group-flush rounded-3">
|
|
<?php
|
|
function social_line($social, $value): string
|
|
{
|
|
$icon = "";
|
|
$url = "";
|
|
$color = "#000000";
|
|
|
|
switch ($social) {
|
|
case "facebook":
|
|
$icon = "fa-brands fa-facebook";
|
|
$url = "https://www.facebook.com/$value";
|
|
$color = "#3b5998";
|
|
$name = "Facebook";
|
|
break;
|
|
case "instagram":
|
|
$icon = "fa-brands fa-instagram";
|
|
$url = "https://www.instagram.com/$value";
|
|
$color = "#ac2bac";
|
|
$name = "Instagram";
|
|
break;
|
|
case "twitter":
|
|
$icon = "fa-brands fa-twitter";
|
|
$url = "https://www.twitter.com/$value";
|
|
$color = "#55acee";
|
|
$name = "Twitter";
|
|
break;
|
|
case "myspace":
|
|
$icon = "fa-brands fa-myspace";
|
|
$url = "https://www.myspace.com/$value";
|
|
$color = "#000000";
|
|
$name = "Myspace";
|
|
break;
|
|
case "soundcloud":
|
|
$icon = "fa-brands fa-soundcloud";
|
|
$url = "https://www.soundcloud.com/$value";
|
|
$color = "#ff8800";
|
|
$name = "Soundcloud";
|
|
break;
|
|
case "mixcloud":
|
|
$icon = "fa-brands fa-mixcloud";
|
|
$url = "https://www.mixcloud.com/$value";
|
|
$color = "#00c7f7";
|
|
$name = "Mixcloud";
|
|
break;
|
|
case "spotify":
|
|
$icon = "fa-brands fa-spotify";
|
|
$url = "https://www.spotify.com/$value";
|
|
$color = "#1DB954";
|
|
$name = "Spotify";
|
|
break;
|
|
}
|
|
|
|
return "
|
|
<li class='list-group-item d-flex justify-content-between align-items-center p-3'>
|
|
<i class='fa $icon fa-lg' style='color: $color;'></i>
|
|
<p class='mb-0'><a href='$url'>$value</a>
|
|
</p>
|
|
</li>";
|
|
}
|
|
$socials = $dj->get_socials();
|
|
|
|
foreach ($socials as $key => $value) {
|
|
echo social_line($key, $value);
|
|
}
|
|
|
|
?>
|
|
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-lg-8">
|
|
<div class="card mb-4">
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p class="mb-0">Full Name</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<p class="text-muted mb-0">Johnatan Smith</p>
|
|
</div>
|
|
</div>
|
|
<hr>
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p class="mb-0">Email</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<p class="text-muted mb-0">example@example.com</p>
|
|
</div>
|
|
</div>
|
|
<hr>
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p class="mb-0">Phone</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<p class="text-muted mb-0">(097) 234-5678</p>
|
|
</div>
|
|
</div>
|
|
<hr>
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p class="mb-0">Mobile</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<p class="text-muted mb-0">(098) 765-4321</p>
|
|
</div>
|
|
</div>
|
|
<hr>
|
|
<div class="row">
|
|
<div class="col-sm-3">
|
|
<p class="mb-0">Address</p>
|
|
</div>
|
|
<div class="col-sm-9">
|
|
<p class="text-muted mb-0">Bay Area, San Francisco, CA</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<div class="card mb-4 mb-md-0">
|
|
<div class="card-body">
|
|
<p class="mb-4"><span class="text-primary font-italic me-1">assigment</span> Project
|
|
Status
|
|
</p>
|
|
<p class="mb-1" style="font-size: .77rem;">Web Design</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 80%"
|
|
aria-valuenow="80"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Website Markup</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 72%"
|
|
aria-valuenow="72"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">One Page</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 89%"
|
|
aria-valuenow="89"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Mobile Template</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 55%"
|
|
aria-valuenow="55"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Backend API</p>
|
|
<div class="progress rounded mb-2" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 66%"
|
|
aria-valuenow="66"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-md-6">
|
|
<div class="card mb-4 mb-md-0">
|
|
<div class="card-body">
|
|
<p class="mb-4"><span class="text-primary font-italic me-1">assigment</span> Project
|
|
Status
|
|
</p>
|
|
<p class="mb-1" style="font-size: .77rem;">Web Design</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 80%"
|
|
aria-valuenow="80"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Website Markup</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 72%"
|
|
aria-valuenow="72"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">One Page</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 89%"
|
|
aria-valuenow="89"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Mobile Template</p>
|
|
<div class="progress rounded" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 55%"
|
|
aria-valuenow="55"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
<p class="mt-4 mb-1" style="font-size: .77rem;">Backend API</p>
|
|
<div class="progress rounded mb-2" style="height: 5px;">
|
|
<div class="progress-bar" role="progressbar" style="width: 66%"
|
|
aria-valuenow="66"
|
|
aria-valuemin="0" aria-valuemax="100"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php else: ?>
|
|
<div class="row">
|
|
<div class="col">
|
|
<div class="alert alert-danger" role="alert">
|
|
<?php echo $locale['genreNotFound']; ?>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php endif;
|
|
|
|
?>
|
|
|
|
</div>
|
|
</section>
|
|
|
|
</body>
|
|
</html>
|