Files
universal_web_loco_rewrite/assets/views/admin/audio/tracks.html
2026-05-19 17:13:23 +02:00

131 lines
5.4 KiB
HTML

{% extends "admin/base.html" %}
{% block title %}{{ album.title }} — tracks{% endblock title %}
{% block crumb %}audio/{{ album.slug }}{% endblock crumb %}
{% block content %}
<header class="term-cmd">
<div>
<p class="term-cmd-line">
<span class="t-red">root@universal-web</span><span class="t-dim">:</span><span class="t-yellow">/admin/audio/{{ album.slug }}</span><span class="t-dim">#</span>
ls
</p>
<h1 class="term-title">{{ album.title }}</h1>
<p class="term-sub">
// album &middot; {{ tracks | length }} song(s) &middot;
{% if album.published %}<span class="t-green">published</span>{% else %}<span class="t-yellow">draft</span>{% endif %}
</p>
</div>
<div class="term-cmd-actions">
<a href="/admin/audio/albums/{{ album.id }}/tracks/upload" class="btn btn-primary btn-sm">[ &uarr; upload song into album ]</a>
<a href="/audio/albums/{{ album.slug }}" class="btn btn-outline btn-sm">[ view ]</a>
<a href="/admin/audio/albums" class="btn btn-outline btn-sm">[ albums ]</a>
</div>
</header>
<div class="term-note">
<p class="term-note-title"># two ways to add a song to this album</p>
<div class="term-step">
<span class="term-step-n">[a]</span>
<span><b class="t-green">upload a new file</b> straight into the album &mdash; use the button above.</span>
</div>
<div class="term-step">
<span class="term-step-n">[b]</span>
<span><b class="t-green">pick an existing song</b> that isn&rsquo;t in any album yet &mdash; use the form below.</span>
</div>
</div>
<div class="card">
<div class="term-head">
<span class="term-dots" aria-hidden="true">
<span class="term-dot r"></span><span class="term-dot y"></span><span class="term-dot g"></span>
</span>
<span class="term-head-name">~/audio/{{ album.slug }}/tracklist</span>
<span class="term-head-meta term-tag is-purple">{{ tracks | length }} songs</span>
</div>
<div class="card-body">
{% if available_tracks | length > 0 %}
<form method="post" action="/admin/audio/albums/{{ album.id }}/tracks/add" class="space-y-2">
<div class="form-control">
<label class="label"><span class="label-text t-green">add an existing song</span></label>
<select name="track_id" required class="select select-bordered w-full">
{% for song in available_tracks %}
<option value="{{ song.id }}">{{ song.title }}</option>
{% endfor %}
</select>
<p class="term-help">these are songs you&rsquo;ve uploaded that aren&rsquo;t in an album yet.</p>
</div>
<button type="submit" class="btn btn-outline btn-sm">[ + add to album ]</button>
</form>
<div class="term-formdiv"></div>
{% endif %}
{% if tracks | length > 0 %}
<div class="overflow-x-auto">
<table class="table">
<thead>
<tr>
<th>#</th>
<th>song</th>
<th>status</th>
<th>featured</th>
<th class="text-right">actions</th>
</tr>
</thead>
<tbody>
{% for track in tracks %}
<tr>
<td class="t-dim">{% if track.track_number %}{{ track.track_number }}{% else %}&mdash;{% endif %}</td>
<td class="font-medium">{{ track.title }}</td>
<td>
{% if track.published %}
<span class="term-tag is-green">published</span>
{% else %}
<span class="term-tag">draft</span>
{% endif %}
</td>
<td>
{% if track.featured %}
<span class="term-tag is-aqua">featured</span>
{% else %}
<span class="t-dim"></span>
{% endif %}
</td>
<td>
<div class="flex flex-wrap 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 t-green">publish</button>
</form>
{% endif %}
<form method="post" action="/admin/audio/tracks/{{ track.id }}/remove-from-album">
<button type="submit" class="btn btn-ghost btn-sm">remove from album</button>
</form>
<form method="post" action="/admin/audio/tracks/{{ track.id }}/delete">
<button type="submit" class="btn btn-ghost btn-sm t-red">delete</button>
</form>
</div>
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
{% else %}
<div class="term-empty">
<p class="font-medium">this album has no songs yet</p>
<p class="term-empty-cmd">$ upload a file into the album, or add an existing song above</p>
<div class="pt-2">
<a href="/admin/audio/albums/{{ album.id }}/tracks/upload" class="btn btn-primary btn-sm">[ &uarr; upload song into album ]</a>
</div>
</div>
{% endif %}
</div>
</div>
{% endblock content %}