86 lines
3.2 KiB
HTML
86 lines
3.2 KiB
HTML
{% extends "admin/base.html" %}
|
|
|
|
{% block title %}Songs{% endblock title %}
|
|
|
|
{% block content %}
|
|
<div class="space-y-2">
|
|
<div class="flex flex-wrap items-center justify-between gap-3">
|
|
<div>
|
|
<h1 class="text-2xl font-bold">Songs</h1>
|
|
<p class="text-sm opacity-70">Publish songs directly; albums only group them together.</p>
|
|
</div>
|
|
<div class="flex flex-wrap gap-2">
|
|
<a href="/admin/audio/tracks/upload" class="btn btn-neutral btn-sm">Upload song</a>
|
|
<a href="/admin/audio/albums" class="btn btn-ghost btn-sm">Albums</a>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card border border-base-300 bg-base-100 shadow-sm">
|
|
<div class="card-body">
|
|
{% if tracks | length > 0 %}
|
|
<div class="overflow-x-auto">
|
|
<table class="table">
|
|
<thead>
|
|
<tr>
|
|
<th>Song</th>
|
|
<th>Group</th>
|
|
<th>File</th>
|
|
<th>Status</th>
|
|
<th class="text-right">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for track in tracks %}
|
|
<tr>
|
|
<td class="font-medium">{{ track.title }}</td>
|
|
<td>
|
|
{% if track.album_id %}
|
|
<span class="badge">Album</span>
|
|
{% else %}
|
|
<span class="badge opacity-70">Ungrouped</span>
|
|
{% endif %}
|
|
</td>
|
|
<td class="text-sm">{{ track.audio_file_id }}</td>
|
|
<td>
|
|
{% if track.published %}
|
|
<span class="badge">Published</span>
|
|
{% else %}
|
|
<span class="badge opacity-70">Draft</span>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
<div class="flex gap-2">
|
|
<a href="/audio/tracks/{{ track.id }}/stream" class="btn btn-ghost btn-sm">Play</a>
|
|
{% if track.published %}
|
|
<form method="post" action="/admin/audio/tracks/{{ track.id }}/unpublish">
|
|
<button type="submit" class="btn btn-ghost btn-sm">Unpublish</button>
|
|
</form>
|
|
{% else %}
|
|
<form method="post" action="/admin/audio/tracks/{{ track.id }}/publish">
|
|
<button type="submit" class="btn btn-ghost btn-sm">Publish</button>
|
|
</form>
|
|
{% endif %}
|
|
<form method="post" action="/admin/audio/tracks/{{ track.id }}/delete">
|
|
<button type="submit" class="btn btn-ghost btn-sm">Delete</button>
|
|
</form>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
{% else %}
|
|
<div class="text-center">
|
|
<p class="font-medium">No songs yet.</p>
|
|
<p class="text-sm opacity-70">Upload a song, then group it into an album when needed.</p>
|
|
<div class="pt-2">
|
|
<a href="/admin/audio/tracks/upload" class="btn btn-neutral btn-sm">Upload song</a>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock content %}
|