File-based admin panel accessible at /admin.php with: - Session-based auth with bcrypt hashing and brute-force protection - Dashboard with site statistics and quick actions - Content manager: browse, create, edit, delete files - Config editor with JSON validation - Plugin overview with status indicators - User management: add, remove, change passwords - CSRF protection on all forms, path traversal prevention - Updated README (NL/EN) and guides with admin documentation
99 lines
5.0 KiB
PHP
99 lines
5.0 KiB
PHP
<div class="d-flex justify-content-between align-items-center mb-4">
|
|
<h2><i class="bi bi-file-earmark-text"></i> Content</h2>
|
|
<a href="admin.php?route=content-new&dir=<?= urlencode($subdir) ?>" class="btn btn-primary btn-sm">
|
|
<i class="bi bi-plus-lg"></i> Nieuw bestand
|
|
</a>
|
|
</div>
|
|
|
|
<?php if (!empty($subdir)): ?>
|
|
<?php
|
|
$parentDir = dirname($subdir);
|
|
$parentLink = $parentDir === '.' ? '' : $parentDir;
|
|
?>
|
|
<nav aria-label="breadcrumb" class="mb-3">
|
|
<ol class="breadcrumb">
|
|
<li class="breadcrumb-item"><a href="admin.php?route=content"><i class="bi bi-house"></i></a></li>
|
|
<?php
|
|
$crumbPath = '';
|
|
foreach (explode('/', $subdir) as $i => $crumb):
|
|
$crumbPath .= ($crumbPath ? '/' : '') . $crumb;
|
|
?>
|
|
<li class="breadcrumb-item <?= $crumbPath === $subdir ? 'active' : '' ?>">
|
|
<?php if ($crumbPath === $subdir): ?>
|
|
<?= htmlspecialchars($crumb) ?>
|
|
<?php else: ?>
|
|
<a href="admin.php?route=content&dir=<?= urlencode($crumbPath) ?>"><?= htmlspecialchars($crumb) ?></a>
|
|
<?php endif; ?>
|
|
</li>
|
|
<?php endforeach; ?>
|
|
</ol>
|
|
</nav>
|
|
<?php endif; ?>
|
|
|
|
<div class="card shadow-sm">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover mb-0">
|
|
<thead>
|
|
<tr>
|
|
<th>Naam</th>
|
|
<th>Type</th>
|
|
<th>Grootte</th>
|
|
<th>Gewijzigd</th>
|
|
<th style="width: 120px;">Acties</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<?php if (empty($items)): ?>
|
|
<tr><td colspan="5" class="text-muted text-center py-4">Geen bestanden gevonden.</td></tr>
|
|
<?php else: ?>
|
|
<?php foreach ($items as $item): ?>
|
|
<tr>
|
|
<td>
|
|
<?php if ($item['is_dir']): ?>
|
|
<a href="admin.php?route=content&dir=<?= urlencode($item['path']) ?>">
|
|
<i class="bi bi-folder-fill text-warning"></i> <?= htmlspecialchars($item['name']) ?>
|
|
</a>
|
|
<?php else: ?>
|
|
<a href="admin.php?route=content-edit&file=<?= urlencode($item['path']) ?>">
|
|
<?php
|
|
$icon = match($item['extension']) {
|
|
'md' => 'bi-file-text text-primary',
|
|
'php' => 'bi-file-code text-success',
|
|
'html' => 'bi-file-earmark text-info',
|
|
default => 'bi-file text-muted'
|
|
};
|
|
?>
|
|
<i class="bi <?= $icon ?>"></i> <?= htmlspecialchars($item['name']) ?>
|
|
</a>
|
|
<?php endif; ?>
|
|
</td>
|
|
<td>
|
|
<?php if ($item['is_dir']): ?>
|
|
<span class="badge bg-warning text-dark">Map</span>
|
|
<?php else: ?>
|
|
<span class="badge bg-secondary"><?= strtoupper($item['extension']) ?></span>
|
|
<?php endif; ?>
|
|
</td>
|
|
<td class="text-muted"><?= $item['size'] ?></td>
|
|
<td class="text-muted"><?= $item['modified'] ?></td>
|
|
<td>
|
|
<?php if (!$item['is_dir']): ?>
|
|
<a href="admin.php?route=content-edit&file=<?= urlencode($item['path']) ?>" class="btn btn-sm btn-outline-primary" title="Bewerken">
|
|
<i class="bi bi-pencil"></i>
|
|
</a>
|
|
<form method="POST" action="admin.php?route=content-delete&file=<?= urlencode($item['path']) ?>" class="d-inline" onsubmit="return confirm('Weet je zeker dat je dit bestand wilt verwijderen?')">
|
|
<input type="hidden" name="csrf_token" value="<?= $csrf ?>">
|
|
<button type="submit" class="btn btn-sm btn-outline-danger" title="Verwijderen">
|
|
<i class="bi bi-trash"></i>
|
|
</button>
|
|
</form>
|
|
<?php endif; ?>
|
|
</td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
<?php endif; ?>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|