warpgate/templates/web/tabs/shares.html
grabbit 2432f83914 Re-trigger warmup on config reload and add per-share warmup status tracking
Warmup config changes via the web UI now actually run warmup without requiring
a daemon restart. Adds generation-based warmup tracking with progress reporting
across CLI status, JSON API, SSE live updates, and web UI badges/detail panels.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-18 19:13:04 +08:00

108 lines
4.7 KiB
HTML

<div x-data="{ expanded: new URLSearchParams(location.search).get('expand') || '{{ expand }}' }">
<table class="share-table">
<thead>
<tr>
<th>Name</th>
<th>Health</th>
<th>Mount</th>
<th>Cache</th>
<th>Dirty</th>
<th>Speed</th>
<th>Transfers</th>
</tr>
</thead>
<tbody>
{% for share in shares %}
<tr class="share-row" @click="expanded = expanded === '{{ share.name }}' ? '' : '{{ share.name }}'">
<td><strong>{{ share.name }}</strong></td>
<td>
{% if share.health == "OK" %}
<span class="badge badge-ok">OK</span>
{% elif share.health == "FAILED" %}
<span class="badge badge-error">FAILED</span>
{% elif share.health == "PROBING" %}
<span class="badge badge-warn">PROBING</span>
{% else %}
<span class="badge badge-warn">PENDING</span>
{% endif %}
{% if share.read_only %}
<span class="badge badge-ro">RO</span>
{% endif %}
{% if share.warmup_state == "running" %}
<span class="badge badge-warmup">WARMUP {{ share.warmup_done }}/{{ share.warmup_total }}</span>
{% elif share.warmup_state == "pending" %}
<span class="badge badge-warmup">WARMUP...</span>
{% elif share.warmup_state == "complete" %}
<span class="badge badge-ok">WARMED</span>
{% endif %}
</td>
<td class="mono">{{ share.mount_point }}</td>
<td>{{ share.cache_display }}</td>
<td>{{ share.dirty_count }}</td>
<td>{{ share.speed_display }}</td>
<td>{{ share.transfers }}</td>
</tr>
<tr x-show="expanded === '{{ share.name }}'" x-transition x-cloak class="detail-row">
<td colspan="7">
<div class="detail-panel">
<div class="detail-grid">
<div class="detail-card">
<div class="label">Cache Used</div>
<div class="value">{{ share.cache_display }}</div>
</div>
<div class="detail-card">
<div class="label">Dirty Files</div>
<div class="value">{{ share.dirty_count }}</div>
</div>
<div class="detail-card">
<div class="label">Transfer Speed</div>
<div class="value">{{ share.speed_display }}</div>
</div>
<div class="detail-card">
<div class="label">Active Transfers</div>
<div class="value">{{ share.transfers }}</div>
</div>
</div>
<table class="info-table">
<tr><td>Health</td><td>{{ share.health }}</td></tr>
{% if share.health == "FAILED" %}
<tr><td>Probe Error</td><td class="error-text">{{ share.health_message }}</td></tr>
{% endif %}
<tr><td>Connection</td><td class="mono">{{ share.connection }}</td></tr>
<tr><td>Mount Point</td><td class="mono">{{ share.mount_point }}</td></tr>
<tr><td>Remote Path</td><td class="mono">{{ share.remote_path }}</td></tr>
<tr><td>RC Port</td><td>{{ share.rc_port }}</td></tr>
<tr><td>Errored Files</td><td>{{ share.errored_files }}</td></tr>
<tr><td>Total Errors</td><td>{{ share.errors }}</td></tr>
<tr><td>Mounted</td><td>{% if share.mounted %}Yes{% else %}No{% endif %}</td></tr>
<tr><td>Read-Only</td><td>{% if share.read_only %}Yes{% else %}No{% endif %}</td></tr>
</table>
{% if !share.warmup_rules.is_empty() %}
<h4 style="margin-top:1rem;margin-bottom:0.5rem;font-size:0.95em">Warmup Rules</h4>
<table class="info-table">
<thead><tr>
<td style="font-weight:600;color:var(--text-muted)">Path</td>
<td style="font-weight:600;color:var(--text-muted)">Filter</td>
<td style="font-weight:600;color:var(--text-muted)">State</td>
<td style="font-weight:600;color:var(--text-muted)">Progress</td>
</tr></thead>
<tbody>
{% for rule in share.warmup_rules %}
<tr>
<td class="mono">{{ rule.path }}</td>
<td>{% if rule.newer_than.is_empty() %}-{% else %}{{ rule.newer_than }}{% endif %}</td>
<td><span class="badge badge-{{ rule.badge_class }}">{{ rule.state }}</span></td>
<td>{{ rule.cached + rule.skipped }}/{{ rule.total_files }}</td>
</tr>
{% endfor %}
</tbody>
</table>
{% endif %}
</div>
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>