Governance UI: block batch activate subscriptions in renewal missing subscription scope

This commit is contained in:
萝卜
2026-03-17 01:19:51 +08:00
parent 44f3e97a84
commit 8e93437748
2 changed files with 42 additions and 0 deletions

View File

@@ -50,6 +50,11 @@ class PlatformOrderToolsGuard
*/ */
public static function batchActivateSubscriptionsReason(array $filters): string public static function batchActivateSubscriptionsReason(array $filters): string
{ {
// 治理集合优先:续费单未绑定订阅属于“先治理再推进”的高风险集合,不允许执行批量同步。
if ((string) ($filters['renewal_missing_subscription'] ?? '') === '1') {
return '当前集合为「续费单未绑定订阅」治理集合:请先完成订阅绑定/修复关联后再批量同步订阅。';
}
if ((string) ($filters['syncable_only'] ?? '') !== '1') { if ((string) ($filters['syncable_only'] ?? '') !== '1') {
return '请先勾选「只看可同步」再执行批量同步。'; return '请先勾选「只看可同步」再执行批量同步。';
} }

View File

@@ -0,0 +1,37 @@
<?php
namespace Tests\Feature;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Tests\TestCase;
class AdminPlatformOrderIndexBatchActivateButtonShouldDisableWhenRenewalMissingSubscriptionTest extends TestCase
{
use RefreshDatabase;
protected function loginAsPlatformAdmin(): void
{
$this->seed();
$this->post('/admin/login', [
'email' => 'platform.admin@demo.local',
'password' => 'Platform@123456',
])->assertRedirect('/admin');
}
public function test_batch_activate_button_should_disable_when_renewal_missing_subscription_present(): void
{
$this->loginAsPlatformAdmin();
$res = $this->get('/admin/platform-orders?renewal_missing_subscription=1');
$res->assertOk();
$html = (string) $res->getContent();
$this->assertStringContainsString('批量同步订阅(当前筛选范围)', $html);
$this->assertStringContainsString('data-role="batch-activate-subscriptions-blocked-hint"', $html);
$this->assertStringContainsString('续费单未绑定订阅', $html);
$this->assertTrue(str_contains($html, 'type="submit" disabled') || str_contains($html, 'disabled="disabled"'));
}
}