统一后台列表页样式并调整站长菜单

This commit is contained in:
2026-04-26 18:10:37 +08:00
parent 61cfc2091c
commit 00270b3904
36 changed files with 2590 additions and 2345 deletions
+116 -105
View File
@@ -10,99 +10,110 @@
@section('title', '婚姻列表')
@section('content')
@php require resource_path('views/admin/partials/list-theme.php'); @endphp
<div class="flex items-center justify-between mb-5">
<h2 class="text-xl font-bold text-gray-800">📋 婚姻列表</h2>
<a href="{{ route('admin.marriages.index') }}" class="text-sm text-indigo-600 hover:underline"> 返回总览</a>
</div>
{{-- 筛选栏 --}}
<form method="GET" class="bg-white rounded-xl border shadow-sm p-4 mb-5 flex flex-wrap gap-3 items-end">
<div>
<label class="block text-xs font-bold text-gray-600 mb-1">状态</label>
<select name="status" class="border rounded-lg px-3 py-2 text-sm focus:outline-none">
<option value="">全部</option>
@foreach (['married' => '已婚', 'pending' => '求婚中', 'divorced' => '已离婚', 'rejected' => '被拒', 'expired' => '已过期'] as $val => $label)
<option value="{{ $val }}" @selected(request('status') === $val)>{{ $label }}</option>
@endforeach
</select>
<div class="{{ $adminListPageClass }}">
<div class="{{ $adminListHeaderCardClass }}">
<div class="flex flex-col gap-4 sm:flex-row sm:items-center sm:justify-between">
<div>
<h2 class="{{ $adminListHeaderTitleClass }}">📋 婚姻列表</h2>
<p class="{{ $adminListHeaderSubtitleClass }}">统一查看婚姻状态、亲密度与后台管理操作。</p>
</div>
<a href="{{ route('admin.marriages.index') }}" class="{{ $adminListSecondaryButtonClass }}">返回总览</a>
</div>
</div>
<div>
<label class="block text-xs font-bold text-gray-600 mb-1">搜索用户名</label>
<input type="text" name="search" value="{{ request('search') }}" placeholder="双方任一用户名..."
class="border rounded-lg px-3 py-2 text-sm w-48 focus:outline-none">
</div>
<button type="submit"
class="bg-indigo-600 text-white px-4 py-2 rounded-lg text-sm font-bold hover:bg-indigo-700 transition">
筛选
</button>
<a href="{{ route('admin.marriages.list') }}" class="text-sm text-gray-500 hover:underline py-2">重置</a>
</form>
{{-- 婚姻列表 --}}
<div class="bg-white rounded-xl shadow-sm border overflow-hidden">
<div class="overflow-x-auto">
<table class="w-full text-sm">
<thead class="bg-gray-50 text-gray-600 text-xs uppercase">
<tr>
<th class="px-4 py-3 text-left">ID</th>
<th class="px-4 py-3 text-left">双方</th>
<th class="px-4 py-3 text-left">戒指</th>
<th class="px-4 py-3 text-center">状态</th>
<th class="px-4 py-3 text-center">亲密度/等级</th>
<th class="px-4 py-3 text-center">结婚天数</th>
<th class="px-4 py-3 text-left">时间</th>
<th class="px-4 py-3 text-center">操作</th>
</tr>
</thead>
<tbody class="divide-y">
@forelse ($marriages as $m)
<tr class="hover:bg-gray-50 transition">
<td class="px-4 py-3 text-gray-400 font-mono text-xs">{{ $m->id }}</td>
<td class="px-4 py-3">
<div class="font-bold">{{ $m->user?->username }}</div>
<div class="text-gray-400 text-xs">× {{ $m->partner?->username }}</div>
</td>
<td class="px-4 py-3">
{{ $m->ringItem?->icon }} {{ $m->ringItem?->name ?? '—' }}
</td>
<td class="px-4 py-3 text-center">
<span
class="px-2 py-0.5 rounded-full text-xs font-bold
{{ match ($m->status) {
'married' => 'bg-green-100 text-green-700',
'pending' => 'bg-amber-100 text-amber-700',
'divorced' => 'bg-red-100 text-red-700',
'rejected' => 'bg-gray-100 text-gray-600',
'expired' => 'bg-slate-100 text-slate-500',
default => 'bg-gray-100 text-gray-600',
} }}">
{{ ['married' => '💑 已婚', 'pending' => '💍 求婚中', 'divorced' => '💔 已离婚', 'rejected' => '❌ 被拒', 'expired' => '⏰ 已过期'][$m->status] ?? $m->status }}
</span>
</td>
<td class="px-4 py-3 text-center">
<div class="font-bold text-indigo-600">{{ number_format($m->intimacy) }}</div>
<div class="text-xs text-gray-400">
{{ \App\Services\MarriageIntimacyService::levelIcon($m->level) }}
Lv{{ $m->level }}</div>
</td>
<td class="px-4 py-3 text-center text-gray-600">
{{ $m->married_at ? $m->married_at->diffInDays(now()) . ' 天' : '—' }}
</td>
<td class="px-4 py-3 text-xs text-gray-500">
@if ($m->married_at)
结婚:{{ $m->married_at->format('Y-m-d') }}
@elseif ($m->proposed_at)
求婚:{{ $m->proposed_at->format('Y-m-d') }}
@endif
@if ($m->divorced_at)
<div>离婚:{{ $m->divorced_at->format('Y-m-d') }}</div>
@endif
</td>
<td class="px-4 py-3 text-center" x-data="{ showDissolve: false }">
<div class="{{ $adminListFilterCardClass }}">
<div class="{{ $adminListFilterInnerClass }}">
<form method="GET" class="{{ $adminListFilterFormClass }}">
<div>
<label class="{{ $adminListFilterLabelClass }}">状态</label>
<select name="status" class="{{ $adminListFilterInputClass }}">
<option value="">全部</option>
@foreach (['married' => '已婚', 'pending' => '求婚中', 'divorced' => '已离婚', 'rejected' => '被拒', 'expired' => '已过期'] as $val => $label)
<option value="{{ $val }}" @selected(request('status') === $val)>{{ $label }}</option>
@endforeach
</select>
</div>
<div>
<label class="{{ $adminListFilterLabelClass }}">搜索用户名</label>
<input type="text" name="search" value="{{ request('search') }}" placeholder="双方任一用户名..."
class="w-48 {{ $adminListFilterInputClass }}">
</div>
<button type="submit" class="{{ $adminListPrimaryButtonClass }}">筛选</button>
<a href="{{ route('admin.marriages.list') }}" class="{{ $adminListSecondaryButtonClass }}">重置</a>
</form>
</div>
</div>
<div class="{{ $adminListCardClass }}">
<div class="{{ $adminListSectionHeadClass }}">
<div>
<h3 class="{{ $adminListSectionTitleClass }}">婚姻记录</h3>
<p class="{{ $adminListSectionDescClass }}">保留婚姻状态语义色,其他列表结构按统一后台样式展示。</p>
</div>
</div>
<div class="{{ $adminListTableWrapClass }}">
<table class="{{ $adminListTableClass }}">
<thead>
<tr class="{{ $adminListTableHeadRowClass }}">
<th class="{{ $adminListTableHeadCellClass }}">ID</th>
<th class="{{ $adminListTableHeadCellClass }}">双方</th>
<th class="{{ $adminListTableHeadCellClass }}">戒指</th>
<th class="{{ $adminListTableHeadCellClass }} text-center">状态</th>
<th class="{{ $adminListTableHeadCellClass }} text-center">亲密度/等级</th>
<th class="{{ $adminListTableHeadCellClass }} text-center">结婚天数</th>
<th class="{{ $adminListTableHeadCellClass }}">时间</th>
<th class="{{ $adminListTableHeadCellClass }} text-center">操作</th>
</tr>
</thead>
<tbody class="{{ $adminListTableBodyClass }}">
@forelse ($marriages as $m)
<tr class="{{ $adminListTableRowClass }}">
<td class="px-4 py-3 {{ $adminListSecondaryTextClass }} {{ $adminListNumericTextClass }}">{{ $m->id }}</td>
<td class="px-4 py-3">
<div class="{{ $adminListPrimaryTextClass }}">{{ $m->user?->username }}</div>
<div class="{{ $adminListSecondaryTextClass }}">× {{ $m->partner?->username }}</div>
</td>
<td class="px-4 py-3 {{ $adminListBodyTextClass }}">
{{ $m->ringItem?->icon }} {{ $m->ringItem?->name ?? '—' }}
</td>
<td class="px-4 py-3 text-center">
<span
class="{{ $adminListBadgeBaseClass }} {{ match ($m->status) {
'married' => 'border-green-200 bg-green-100 text-green-700',
'pending' => 'border-amber-200 bg-amber-100 text-amber-700',
'divorced' => 'border-red-200 bg-red-100 text-red-700',
'rejected' => 'border-gray-200 bg-gray-100 text-gray-600',
'expired' => 'border-slate-200 bg-slate-100 text-slate-500',
default => 'border-gray-200 bg-gray-100 text-gray-600',
} }}">
{{ ['married' => '💑 已婚', 'pending' => '💍 求婚中', 'divorced' => '💔 已离婚', 'rejected' => '❌ 被拒', 'expired' => '⏰ 已过期'][$m->status] ?? $m->status }}
</span>
</td>
<td class="px-4 py-3 text-center">
<div class="text-sm font-semibold text-indigo-600">{{ number_format($m->intimacy) }}</div>
<div class="{{ $adminListSecondaryTextClass }}">
{{ \App\Services\MarriageIntimacyService::levelIcon($m->level) }}
Lv{{ $m->level }}</div>
</td>
<td class="px-4 py-3 text-center {{ $adminListBodyTextClass }}">
{{ $m->married_at ? $m->married_at->diffInDays(now()) . ' 天' : '—' }}
</td>
<td class="px-4 py-3 {{ $adminListSecondaryTextClass }}">
@if ($m->married_at)
结婚:{{ $m->married_at->format('Y-m-d') }}
@elseif ($m->proposed_at)
求婚:{{ $m->proposed_at->format('Y-m-d') }}
@endif
@if ($m->divorced_at)
<div>离婚:{{ $m->divorced_at->format('Y-m-d') }}</div>
@endif
</td>
<td class="px-4 py-3 text-center" x-data="{ showDissolve: false }">
@if ($m->status === 'married')
<button @click="showDissolve = true"
class="text-xs bg-red-50 text-red-600 font-bold px-3 py-1.5 rounded hover:bg-red-600 hover:text-white transition">
class="{{ $adminListActionButtonClass }} bg-red-50 text-red-600 hover:bg-red-600 hover:text-white">
强制离婚
</button>
{{-- 强制离婚确认弹窗 --}}
@@ -123,9 +134,9 @@
class="w-full border rounded px-3 py-2 text-sm mb-3">
<div class="flex gap-2 justify-end">
<button type="button" @click="showDissolve = false"
class="px-3 py-1.5 border rounded text-sm text-gray-600">取消</button>
class="{{ $adminListSecondaryButtonClass }}">取消</button>
<button type="submit"
class="px-3 py-1.5 bg-red-600 text-white rounded text-sm font-bold">确认解除</button>
class="{{ $adminListActionButtonClass }} bg-red-600 text-white hover:bg-red-700">确认解除</button>
</div>
</form>
</div>
@@ -135,28 +146,28 @@
data-admin-confirm="确定取消该求婚吗?">
@csrf
<button type="submit"
class="text-xs bg-amber-50 text-amber-600 font-bold px-3 py-1.5 rounded hover:bg-amber-600 hover:text-white transition">
class="{{ $adminListActionButtonClass }} bg-amber-50 text-amber-600 hover:bg-amber-600 hover:text-white">
取消求婚
</button>
</form>
@else
<span class="text-xs text-gray-300"></span>
@endif
</td>
</tr>
@empty
<tr>
<td colspan="8" class="px-4 py-12 text-center text-gray-400">暂无记录</td>
</tr>
@endforelse
</tbody>
</table>
</div>
</td>
</tr>
@empty
<tr>
<td colspan="8" class="{{ $adminListEmptyClass }}">暂无记录</td>
</tr>
@endforelse
</tbody>
</table>
</div>
{{-- 分页 --}}
@if ($marriages->hasPages())
<div class="px-4 py-4 border-t">{{ $marriages->links() }}</div>
@endif
@if ($marriages->hasPages())
<div class="{{ $adminListPaginationClass }}">{{ $marriages->links() }}</div>
@endif
</div>
</div>
@endsection