mirror of
https://github.com/svemagie/indiekit-endpoint-microsub.git
synced 2026-04-02 15:35:00 +02:00
- Integrate updateFeedStatus into polling processor for health tracking - Add feed management UI showing status (active/error), errors, actions - Add edit feed URL feature to change non-RSS URLs to actual feeds - Add rediscover feature to run feed discovery and update URL - Add refresh button to force immediate poll - Update UI to use Indiekit's badge/button classes (badge--green/red, button--warning) - Add routes: /feeds/:feedId/edit, /feeds/:feedId/rediscover, /feeds/:feedId/refresh Fixes broken feeds by allowing users to: 1. Edit URL directly to the RSS/Atom feed 2. Click "Rediscover" to auto-find the feed from a blog URL 3. View error details and consecutive error counts Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
102 lines
3.8 KiB
Plaintext
102 lines
3.8 KiB
Plaintext
{% extends "layouts/reader.njk" %}
|
|
|
|
{% block reader %}
|
|
<div class="feeds">
|
|
<header class="feeds__header">
|
|
<a href="{{ baseUrl }}/channels/{{ channel.uid }}" class="back-link">
|
|
{{ icon("previous") }} {{ channel.name }}
|
|
</a>
|
|
</header>
|
|
|
|
<h2>{{ __("microsub.feeds.title") }}</h2>
|
|
|
|
{% if feeds.length > 0 %}
|
|
<div class="feeds__list">
|
|
{% for feed in feeds %}
|
|
<div class="feeds__item{% if feed.status == 'error' %} feeds__item--error{% endif %}">
|
|
<div class="feeds__info">
|
|
{% if feed.photo %}
|
|
<img src="{{ feed.photo }}"
|
|
alt=""
|
|
class="feeds__photo"
|
|
width="48"
|
|
height="48"
|
|
loading="lazy"
|
|
onerror="this.style.display='none'">
|
|
{% endif %}
|
|
<div class="feeds__details">
|
|
<span class="feeds__name">
|
|
{{ feed.title or feed.url }}
|
|
{% if feed.status == 'error' %}
|
|
<span class="badge badge--red">Error</span>
|
|
{% elif feed.status == 'active' %}
|
|
<span class="badge badge--green">Active</span>
|
|
{% endif %}
|
|
</span>
|
|
<a href="{{ feed.url }}" class="feeds__url" target="_blank" rel="noopener">
|
|
{{ feed.url | replace("https://", "") | replace("http://", "") }}
|
|
</a>
|
|
{% if feed.lastError %}
|
|
<span class="feeds__error">{{ feed.lastError }}</span>
|
|
{% endif %}
|
|
{% if feed.consecutiveErrors > 0 %}
|
|
<span class="feeds__error-count">{{ feed.consecutiveErrors }} consecutive errors</span>
|
|
{% endif %}
|
|
{% if feed.lastSuccessAt %}
|
|
<span class="feeds__meta">Last success: {{ feed.lastSuccessAt | date("relative") }}</span>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
<div class="feeds__actions">
|
|
<a href="{{ baseUrl }}/channels/{{ channel.uid }}/feeds/{{ feed._id }}/edit"
|
|
class="button button--secondary button--small"
|
|
title="Edit feed URL">
|
|
{{ icon("edit") }}
|
|
</a>
|
|
<form method="post" action="{{ baseUrl }}/channels/{{ channel.uid }}/feeds/{{ feed._id }}/rediscover" style="display:inline;">
|
|
<button type="submit" class="button button--secondary button--small" title="Rediscover feed">
|
|
{{ icon("discover") }}
|
|
</button>
|
|
</form>
|
|
<form method="post" action="{{ baseUrl }}/channels/{{ channel.uid }}/feeds/{{ feed._id }}/refresh" style="display:inline;">
|
|
<button type="submit" class="button button--secondary button--small" title="Refresh now">
|
|
{{ icon("refresh") }}
|
|
</button>
|
|
</form>
|
|
<form method="post" action="{{ baseUrl }}/channels/{{ channel.uid }}/feeds/remove" style="display:inline;">
|
|
<input type="hidden" name="url" value="{{ feed.url }}">
|
|
<button type="submit" class="button button--warning button--small" title="Unfollow">
|
|
{{ icon("delete") }}
|
|
</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
{% endfor %}
|
|
</div>
|
|
{% else %}
|
|
<div class="reader__empty">
|
|
{{ icon("syndicate") }}
|
|
<p>{{ __("microsub.feeds.empty") }}</p>
|
|
</div>
|
|
{% endif %}
|
|
|
|
<div class="feeds__add">
|
|
<h3>{{ __("microsub.feeds.follow") }}</h3>
|
|
<form method="post" action="{{ baseUrl }}/channels/{{ channel.uid }}/feeds" class="feeds__form">
|
|
{{ input({
|
|
id: "url",
|
|
name: "url",
|
|
label: __("microsub.feeds.url"),
|
|
type: "url",
|
|
required: true,
|
|
placeholder: __("microsub.feeds.urlPlaceholder"),
|
|
autocomplete: "off"
|
|
}) }}
|
|
<div class="button-group">
|
|
{{ button({ text: __("microsub.feeds.follow") }) }}
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|