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,67 +1,83 @@
{% extends "admin/base.html" %}
{% block title %}Upload Track{% endblock title %}
{% block title %}Upload song{% endblock title %}
{% block crumb %}audio/upload{% 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">Upload Track</h1>
{% if album %}
<p class="text-sm opacity-70">{{ album.title }}</p>
{% else %}
<p class="text-sm opacity-70">Ungrouped song</p>
{% endif %}
</div>
<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>
{% if album %}cp song.mp3 {{ album.slug }}/{% else %}cp song.mp3 songs/{% endif %}
</p>
<h1 class="term-title">upload a song</h1>
{% if album %}
<a href="/admin/audio/albums/{{ album.id }}/tracks" class="btn btn-ghost btn-sm">Back to tracks</a>
<p class="term-sub">// goes straight into the album &ldquo;{{ album.title }}&rdquo;.</p>
{% else %}
<a href="/admin/audio/tracks" class="btn btn-ghost btn-sm">Back to songs</a>
<p class="term-sub">// uploads as a standalone song (a single) &mdash; you can add it to an album later.</p>
{% endif %}
</div>
<div class="term-cmd-actions">
{% if album %}
<a href="/admin/audio/albums/{{ album.id }}/tracks" class="btn btn-outline btn-sm">[ cancel ]</a>
{% else %}
<a href="/admin/audio/tracks" class="btn btn-outline btn-sm">[ cancel ]</a>
{% endif %}
</div>
</header>
<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">{% if album %}~/audio/{{ album.slug }}/upload{% else %}~/audio/songs/upload{% endif %}</span>
</div>
<div class="card-body">
{% if album %}
<form method="post" action="/admin/audio/albums/{{ album.id }}/tracks/upload-file" enctype="multipart/form-data" class="space-y-2">
{% else %}
<form method="post" action="/admin/audio/tracks/upload-file" enctype="multipart/form-data" class="space-y-2">
{% endif %}
<div class="form-control">
<label class="label"><span class="label-text t-green">1. audio file *</span></label>
<input type="file" name="file" accept="audio/mpeg,audio/wav,audio/ogg,audio/flac,audio/aac,audio/mp4,audio/webm" required class="file-input file-input-bordered w-full">
<p class="term-help">required &mdash; mp3, wav, ogg, flac, aac, m4a or webm.</p>
</div>
<div class="form-control">
<label class="label"><span class="label-text t-green">2. title</span></label>
<input type="text" name="title" class="input input-bordered w-full" placeholder="e.g. Sunburst Jam">
<p class="term-help">optional &mdash; leave blank to use the audio file&rsquo;s name.</p>
</div>
<div class="card border border-base-300 bg-base-100 shadow-sm">
<div class="card-body">
{% if album %}
<form method="post" action="/admin/audio/albums/{{ album.id }}/tracks/upload-file" enctype="multipart/form-data" class="space-y-2">
{% else %}
<form method="post" action="/admin/audio/tracks/upload-file" enctype="multipart/form-data" class="space-y-2">
<div class="form-control">
<label class="label"><span class="label-text t-green">3. track number</span></label>
<input type="number" name="track_number" min="1" class="input input-bordered w-full" placeholder="1">
<p class="term-help">optional &mdash; this song&rsquo;s position in the album&rsquo;s track list.</p>
</div>
{% endif %}
<div class="form-control">
<label class="label"><span class="label-text">Audio file</span></label>
<input type="file" name="file" accept="audio/mpeg,audio/wav,audio/ogg,audio/flac,audio/aac,audio/mp4,audio/webm" required class="file-input file-input-bordered w-full">
</div>
<div class="form-control">
<label class="label"><span class="label-text">Title</span></label>
<input type="text" name="title" class="input input-bordered w-full">
</div>
<label class="label cursor-pointer justify-start gap-2">
<input type="checkbox" name="featured" class="checkbox checkbox-sm">
<span class="label-text">featured &mdash; highlight this song on the site</span>
</label>
<div class="form-control">
<label class="label"><span class="label-text">Track number</span></label>
<input type="number" name="track_number" min="1" class="input input-bordered w-full">
</div>
<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 it (leave off to keep it a draft)</span>
</label>
<label class="label cursor-pointer justify-start gap-2">
<input type="checkbox" name="featured" class="checkbox checkbox-sm">
<span class="label-text">Featured</span>
</label>
<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>
<div class="flex flex-wrap gap-2 pt-2">
<button type="submit" class="btn btn-neutral btn-sm">Upload</button>
{% if album %}
<a href="/admin/audio/albums/{{ album.id }}/tracks" class="btn btn-ghost btn-sm">Cancel</a>
{% else %}
<a href="/admin/audio/tracks" class="btn btn-ghost btn-sm">Cancel</a>
{% endif %}
</div>
</form>
</div>
<div class="flex flex-wrap gap-2 pt-2">
<button type="submit" class="btn btn-primary btn-sm">[ &uarr; upload song ]</button>
{% if album %}
<a href="/admin/audio/albums/{{ album.id }}/tracks" class="btn btn-ghost btn-sm">cancel</a>
{% else %}
<a href="/admin/audio/tracks" class="btn btn-ghost btn-sm">cancel</a>
{% endif %}
</div>
</form>
</div>
</div>
{% endblock content %}