Files
character-browser/templates/scenes/create.html
Aodhan Collins 32a73b02f5 Add semantic tagging, search, favourite/NSFW filtering, and LLM job queue
Replaces old list-format tags (which duplicated prompt content) with structured
dict tags per category (origin_series, outfit_type, participants, style_type,
scene_type, etc.). Tags are now purely organizational metadata — removed from
the prompt pipeline entirely.

Adds is_favourite and is_nsfw columns to all 8 resource models. Favourite is
DB-only (user preference); NSFW is mirrored in JSON tags for rescan persistence.
All library pages get filter controls and favourites-first sorting.

Introduces a parallel LLM job queue (_enqueue_task + _llm_queue_worker) for
background tag regeneration, with the same status polling UI as ComfyUI jobs.
Fixes call_llm() to use has_request_context() fallback for background threads.

Adds global search (/search) across resources and gallery images, with navbar
search bar. Adds gallery image sidecar JSON for per-image favourite/NSFW metadata.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-21 03:22:09 +00:00

37 lines
1.9 KiB
HTML

{% extends "layout.html" %}
{% block content %}
<div class="container">
<div class="row justify-content-center">
<div class="col-md-8">
<div class="card shadow-sm border-0">
<div class="card-header bg-success text-white">Create New Scene</div>
<div class="card-body p-4">
<form action="{{ url_for('create_scene') }}" method="post">
<div class="mb-4">
<label for="name" class="form-label fw-bold">Scene Name</label>
<input type="text" class="form-control" id="name" name="name" placeholder="e.g. Luxury Bedroom" value="{{ form_data.get('name', '') }}" required>
<div class="form-text">The display name for the scene gallery.</div>
</div>
<div class="mb-4">
<label for="filename" class="form-label fw-bold">Scene ID / Filename <small class="text-muted">(Optional)</small></label>
<input type="text" class="form-control" id="filename" name="filename" placeholder="e.g. luxury_bedroom" value="{{ form_data.get('filename', '') }}">
<div class="form-text">Used for the JSON file and URL. Auto-generated from name if empty.</div>
</div>
<div class="alert alert-info border-0 shadow-none bg-light">
<i class="bi bi-info-circle me-2"></i> A blank scene profile will be created. You can then edit it to add specific background tags, furniture, and LoRA settings.
</div>
<div class="d-grid mt-4">
<button type="submit" class="btn btn-success btn-lg shadow-sm">Create Scene</button>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
{% endblock %}