## Added - Feed Media Enhancement with Media RSS namespace support - RSS enclosure, media:content, media:thumbnail elements - JSON Feed image field for first image - ADR-059: Full feed media standardization roadmap ## Fixed - Media display on homepage (was only showing on note pages) - Responsive image sizing with CSS constraints - Caption display (now alt text only, not visible) - Logging correlation ID crash in non-request contexts ## Documentation - Feed media design documents and implementation reports - Media display fixes design and validation reports - Updated ROADMAP with v1.3.0/v1.4.0 media plans 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
60 lines
1.9 KiB
HTML
60 lines
1.9 KiB
HTML
{% extends "base.html" %}
|
|
{% from "partials/media.html" import display_media %}
|
|
|
|
{% block title %}StarPunk - Home{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="h-feed">
|
|
<h2 class="p-name">{{ config.SITE_NAME or 'Recent Notes' }}</h2>
|
|
|
|
{# Feed-level author h-card (per Q24) #}
|
|
{% if author %}
|
|
<div class="p-author h-card" style="display: none;">
|
|
<a class="p-name u-url" href="{{ author.url or author.me }}">{{ author.name or author.url }}</a>
|
|
</div>
|
|
{% endif %}
|
|
|
|
{% if notes %}
|
|
{% for note in notes %}
|
|
<article class="h-entry note-preview">
|
|
{# Detect if note has explicit title (starts with # heading) - per Q22 #}
|
|
{% set has_explicit_title = note.content.strip().startswith('#') %}
|
|
|
|
{# p-name only if note has explicit title (per Q22) #}
|
|
{% if has_explicit_title %}
|
|
<h3 class="p-name">{{ note.title }}</h3>
|
|
{% endif %}
|
|
|
|
{# Media preview (if available) #}
|
|
{{ display_media(note.media) }}
|
|
|
|
{# e-content: note content (preview) #}
|
|
<div class="e-content">
|
|
{{ note.html[:300]|safe }}{% if note.html|length > 300 %}...{% endif %}
|
|
</div>
|
|
|
|
<footer class="note-meta">
|
|
{# u-url for permalink #}
|
|
<a class="u-url" href="{{ url_for('public.note', slug=note.slug, _external=True) }}">
|
|
<time class="dt-published" datetime="{{ note.created_at.isoformat() }}">
|
|
{{ note.created_at.strftime('%B %d, %Y') }}
|
|
</time>
|
|
</a>
|
|
|
|
{# Author h-card nested in each h-entry (per Q20) #}
|
|
{% if author %}
|
|
<div class="p-author h-card">
|
|
<a class="p-name u-url" href="{{ author.url or author.me }}">
|
|
{{ author.name or author.url or author.me }}
|
|
</a>
|
|
</div>
|
|
{% endif %}
|
|
</footer>
|
|
</article>
|
|
{% endfor %}
|
|
{% else %}
|
|
<p class="empty-state">No notes published yet. Check back soon!</p>
|
|
{% endif %}
|
|
</div>
|
|
{% endblock %}
|