terminal based website playing music now

This commit is contained in:
Priec
2026-05-19 17:13:23 +02:00
parent cbd642c62c
commit e9439382cc
8 changed files with 580 additions and 360 deletions

View File

@@ -1,77 +1,100 @@
{% extends "admin/base.html" %}
{% block title %}New Audio Album{% endblock title %}
{% block title %}New album{% endblock title %}
{% block crumb %}audio/new-album{% endblock crumb %}
{% 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">New Audio Album</h1>
<p class="text-sm opacity-70">Create a container for uploaded tracks.</p>
</div>
<a href="/admin/audio/albums" class="btn btn-ghost btn-sm">Back to albums</a>
<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</span><span class="t-dim">#</span>
mkdir albums/new
</p>
<h1 class="term-title">new album</h1>
<p class="term-sub">// fill in the details, then tick the songs to include.</p>
</div>
<div class="term-cmd-actions">
<a href="/admin/audio/albums" class="btn btn-outline btn-sm">[ cancel ]</a>
</div>
</header>
<div class="card border border-base-300 bg-base-100 shadow-sm">
<div class="card-body">
<form method="post" action="/admin/audio/albums/create" class="space-y-2">
<div class="form-control">
<label class="label"><span class="label-text">Title</span></label>
<input type="text" name="title" required class="input input-bordered w-full">
<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/albums/new</span>
</div>
<div class="card-body">
<form method="post" action="/admin/audio/albums/create" enctype="multipart/form-data" class="space-y-2">
<div class="form-control">
<label class="label"><span class="label-text t-green">album title *</span></label>
<input type="text" name="title" required class="input input-bordered w-full" placeholder="e.g. Live at Home">
</div>
<div class="form-control">
<label class="label"><span class="label-text t-green">artist</span></label>
<input type="text" name="artist" class="input input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text t-green">release date</span></label>
<input type="date" name="release_date" class="input input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text t-green">cover image</span></label>
<input type="file" name="cover" accept="image/png,image/jpeg,image/webp,image/gif" class="file-input file-input-bordered w-full">
<p class="term-help">optional &mdash; png, jpg, webp or gif; uploaded right here, shown on the album page.</p>
</div>
<div class="form-control">
<label class="label"><span class="label-text t-green">description</span></label>
<textarea name="description" rows="5" class="textarea textarea-bordered w-full"></textarea>
</div>
<div class="term-formdiv"></div>
<div class="form-control">
<label class="label"><span class="label-text t-green">songs in this album</span></label>
{% if available_tracks | length > 0 %}
<div class="term-picklist">
{% for song in available_tracks %}
<label class="term-pick">
<input type="checkbox" name="track_ids" value="{{ song.id }}" class="checkbox checkbox-sm">
<span class="min-w-0 flex-1 font-medium">{{ song.title }}</span>
{% if song.published %}
<span class="term-tag is-green">published</span>
{% else %}
<span class="term-tag">draft</span>
{% endif %}
</label>
{% endfor %}
</div>
<div class="form-control">
<label class="label"><span class="label-text">Artist</span></label>
<input type="text" name="artist" class="input input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text">Release date</span></label>
<input type="date" name="release_date" class="input input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text">Cover image id</span></label>
<input type="text" name="cover_image_id" class="input input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text">Description</span></label>
<textarea name="description" rows="6" class="textarea textarea-bordered w-full"></textarea>
</div>
<div class="form-control">
<label class="label"><span class="label-text">Songs</span></label>
{% if available_tracks | length > 0 %}
<div class="divide-y divide-base-300 rounded border border-base-300">
{% for song in available_tracks %}
<label class="flex cursor-pointer items-center gap-3 p-2 hover:bg-base-200">
<input type="checkbox" name="track_ids" value="{{ song.id }}" class="checkbox checkbox-sm">
<span class="min-w-0 flex-1">
<span class="block truncate font-medium">{{ song.title }}</span>
<span class="block truncate text-xs opacity-70">{{ song.audio_file_id }}</span>
</span>
</label>
{% endfor %}
<p class="term-help">only songs that aren&rsquo;t in an album yet are shown. you can add or remove songs after creating the album.</p>
{% else %}
<div class="term-picklist">
<div class="term-pick">
<span class="term-help" style="margin:0">
no free songs to add &mdash;
<a href="/admin/audio/tracks/upload" class="t-blue">upload a song</a> first,
or create the album empty and add songs later.
</span>
</div>
{% else %}
<div class="rounded border border-base-300 p-2 text-sm opacity-70">
No ungrouped songs available.
</div>
{% endif %}
</div>
{% endif %}
</div>
<label class="label cursor-pointer justify-start gap-2">
<input type="checkbox" name="published" class="checkbox checkbox-sm">
<span class="label-text">Published</span>
</label>
<label class="label cursor-pointer justify-start gap-2">
<input type="checkbox" name="published" class="checkbox checkbox-sm">
<span class="label-text">publish now &mdash; visitors can see this album (leave off for a draft)</span>
</label>
<div class="flex flex-wrap gap-2 pt-2">
<button type="submit" class="btn btn-neutral btn-sm">Create</button>
<a href="/admin/audio/albums" class="btn btn-ghost btn-sm">Cancel</a>
</div>
</form>
</div>
<div class="flex flex-wrap gap-2 pt-2">
<button type="submit" class="btn btn-primary btn-sm">[ create album ]</button>
<a href="/admin/audio/albums" class="btn btn-ghost btn-sm">cancel</a>
</div>
</form>
</div>
</div>
{% endblock content %}