diff --git a/resources/views/admin/site_subscriptions/index.blade.php b/resources/views/admin/site_subscriptions/index.blade.php
index ee0d78f..84ae714 100644
--- a/resources/views/admin/site_subscriptions/index.blade.php
+++ b/resources/views/admin/site_subscriptions/index.blade.php
@@ -90,6 +90,8 @@
已过期
|
7天内到期
+ |
+ 已付无回执
diff --git a/tests/Feature/AdminSiteSubscriptionIndexShouldIncludePaidNoReceiptQuickFilterTest.php b/tests/Feature/AdminSiteSubscriptionIndexShouldIncludePaidNoReceiptQuickFilterTest.php
new file mode 100644
index 0000000..1c5a38c
--- /dev/null
+++ b/tests/Feature/AdminSiteSubscriptionIndexShouldIncludePaidNoReceiptQuickFilterTest.php
@@ -0,0 +1,52 @@
+seed();
+
+ $this->post('/admin/login', [
+ 'email' => 'platform.admin@demo.local',
+ 'password' => 'Platform@123456',
+ ])->assertRedirect('/admin');
+ }
+
+ public function test_site_subscription_index_should_include_paid_no_receipt_quick_filter(): void
+ {
+ $this->loginAsPlatformAdmin();
+
+ $res = $this->get('/admin/site-subscriptions?' . Arr::query([
+ 'merchant_id' => 2,
+ 'plan_id' => 3,
+ 'keyword' => 'alpha',
+ 'back' => '/admin/plans',
+ ]));
+ $res->assertOk();
+
+ $html = (string) $res->getContent();
+ $this->assertStringContainsString('已付无回执', $html);
+
+ $matched = preg_match('/]+href="([^"]+)"[^>]*>\s*已付无回执\s*<\/a>/u', $html, $m);
+ $this->assertSame(1, $matched, '未找到订阅列表页“已付无回执”快捷筛选');
+
+ $href = html_entity_decode($m[1] ?? '');
+ $parts = parse_url($href);
+ parse_str($parts['query'] ?? '', $q);
+
+ $this->assertSame('2', (string) ($q['merchant_id'] ?? ''));
+ $this->assertSame('3', (string) ($q['plan_id'] ?? ''));
+ $this->assertSame('alpha', (string) ($q['keyword'] ?? ''));
+ $this->assertSame('paid', (string) ($q['payment_status'] ?? ''));
+ $this->assertSame('none', (string) ($q['receipt_status'] ?? ''));
+ $this->assertSame('/admin/plans', (string) ($q['back'] ?? ''));
+ }
+}