87 lines
5.5 KiB
PHP
87 lines
5.5 KiB
PHP
<div class="p-6">
|
|
<div class="mb-8">
|
|
<h1 class="text-2xl font-bold text-gray-900">Feeds</h1>
|
|
<p class="mt-1 text-sm text-gray-500">
|
|
Manage your news feed sources
|
|
</p>
|
|
</div>
|
|
|
|
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
|
|
@forelse ($feeds as $feed)
|
|
<div class="bg-white rounded-lg shadow p-6" wire:key="feed-{{ $feed->id }}">
|
|
<div class="flex items-start justify-between">
|
|
<div class="flex items-center">
|
|
<div class="shrink-0">
|
|
@if ($feed->type === 'rss')
|
|
<svg class="h-8 w-8 text-orange-500" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor">
|
|
<path stroke-linecap="round" stroke-linejoin="round" d="M12.75 19.5v-.75a7.5 7.5 0 0 0-7.5-7.5H4.5m0-6.75h.75c7.87 0 14.25 6.38 14.25 14.25v.75M6 18.75a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0Z" />
|
|
</svg>
|
|
@else
|
|
<svg class="h-8 w-8 text-blue-500" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor">
|
|
<path stroke-linecap="round" stroke-linejoin="round" d="M12 21a9.004 9.004 0 0 0 8.716-6.747M12 21a9.004 9.004 0 0 1-8.716-6.747M12 21c2.485 0 4.5-4.03 4.5-9S14.485 3 12 3m0 18c-2.485 0-4.5-4.03-4.5-9S9.515 3 12 3m0 0a8.997 8.997 0 0 1 7.843 4.582M12 3a8.997 8.997 0 0 0-7.843 4.582m15.686 0A11.953 11.953 0 0 1 12 10.5c-2.998 0-5.74-1.1-7.843-2.918m15.686 0A8.959 8.959 0 0 1 21 12c0 .778-.099 1.533-.284 2.253m0 0A17.919 17.919 0 0 1 12 16.5c-3.162 0-6.133-.815-8.716-2.247m0 0A9.015 9.015 0 0 1 3 12c0-1.605.42-3.113 1.157-4.418" />
|
|
</svg>
|
|
@endif
|
|
</div>
|
|
<div class="ml-4 flex-1 min-w-0">
|
|
<h3 class="text-lg font-medium text-gray-900 truncate">
|
|
{{ $feed->name }}
|
|
</h3>
|
|
@if ($feed->description)
|
|
<p class="text-sm text-gray-500 line-clamp-2">
|
|
{{ $feed->description }}
|
|
</p>
|
|
@endif
|
|
</div>
|
|
</div>
|
|
<button
|
|
wire:click="toggle({{ $feed->id }})"
|
|
class="p-1 rounded-full {{ $feed->is_active ? 'bg-green-100 text-green-600' : 'bg-gray-100 text-gray-400' }}"
|
|
title="{{ $feed->is_active ? 'Active - Click to disable' : 'Inactive - Click to enable' }}"
|
|
>
|
|
<svg class="h-5 w-5" fill="currentColor" viewBox="0 0 20 20">
|
|
<path fill-rule="evenodd" d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.857-9.809a.75.75 0 00-1.214-.882l-3.483 4.79-1.88-1.88a.75.75 0 10-1.06 1.061l2.5 2.5a.75.75 0 001.137-.089l4-5.5z" clip-rule="evenodd" />
|
|
</svg>
|
|
</button>
|
|
</div>
|
|
|
|
<div class="mt-4 flex items-center justify-between">
|
|
<div class="flex items-center space-x-2">
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium {{ $feed->is_active ? 'bg-green-100 text-green-800' : 'bg-gray-100 text-gray-800' }}">
|
|
{{ $feed->is_active ? 'Active' : 'Inactive' }}
|
|
</span>
|
|
<span class="inline-flex items-center px-2.5 py-0.5 rounded-full text-xs font-medium bg-blue-100 text-blue-800">
|
|
{{ strtoupper($feed->type) }}
|
|
</span>
|
|
</div>
|
|
@if ($feed->url)
|
|
<a
|
|
href="{{ $feed->url }}"
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
class="text-gray-400 hover:text-gray-600"
|
|
title="Open feed URL"
|
|
>
|
|
<svg class="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor">
|
|
<path stroke-linecap="round" stroke-linejoin="round" d="M13.5 6H5.25A2.25 2.25 0 0 0 3 8.25v10.5A2.25 2.25 0 0 0 5.25 21h10.5A2.25 2.25 0 0 0 18 18.75V10.5m-10.5 6L21 3m0 0h-5.25M21 3v5.25" />
|
|
</svg>
|
|
</a>
|
|
@endif
|
|
</div>
|
|
|
|
<div class="mt-3 text-xs text-gray-500">
|
|
Created {{ $feed->created_at->format('M d, Y') }}
|
|
</div>
|
|
</div>
|
|
@empty
|
|
<div class="col-span-full text-center py-12">
|
|
<svg class="mx-auto h-12 w-12 text-gray-400" fill="none" viewBox="0 0 24 24" stroke-width="1.5" stroke="currentColor">
|
|
<path stroke-linecap="round" stroke-linejoin="round" d="M12.75 19.5v-.75a7.5 7.5 0 0 0-7.5-7.5H4.5m0-6.75h.75c7.87 0 14.25 6.38 14.25 14.25v.75M6 18.75a.75.75 0 1 1-1.5 0 .75.75 0 0 1 1.5 0Z" />
|
|
</svg>
|
|
<h3 class="mt-2 text-sm font-medium text-gray-900">No feeds</h3>
|
|
<p class="mt-1 text-sm text-gray-500">
|
|
No feeds have been configured yet.
|
|
</p>
|
|
</div>
|
|
@endforelse
|
|
</div>
|
|
</div>
|