Fix package limits in tenant overview
Some checks failed
linter / quality (push) Has been cancelled
tests / ci (push) Has been cancelled
tests / ui (push) Has been cancelled

This commit is contained in:
Codex Agent
2026-01-06 13:36:50 +01:00
parent e3deec9741
commit ef1773d966
3 changed files with 72 additions and 19 deletions

View File

@@ -29,23 +29,34 @@ class TenantPackageController extends Controller
->orderBy('created_at', 'desc')
->get();
$packages->each(function ($package) {
$pkg = $package->package;
$package->remaining_events = $pkg->max_events_per_year - $package->used_events;
$package->package_limits = array_merge(
$pkg->limits,
[
'branding_allowed' => $pkg->branding_allowed,
'watermark_allowed' => $pkg->watermark_allowed,
'features' => $pkg->features,
]
);
});
$packages->each(fn (TenantPackage $package) => $this->hydratePackageSnapshot($package));
$activePackage = $tenant->activeResellerPackage?->load('package');
if ($activePackage instanceof TenantPackage) {
$this->hydratePackageSnapshot($activePackage);
}
return response()->json([
'data' => $packages,
'active_package' => $tenant->activeResellerPackage ? $tenant->activeResellerPackage->load('package') : null,
'active_package' => $activePackage,
'message' => 'Tenant packages loaded successfully.',
]);
}
private function hydratePackageSnapshot(TenantPackage $package): void
{
$pkg = $package->package;
$maxEvents = $pkg?->max_events_per_year;
$package->remaining_events = $maxEvents === null ? null : max($maxEvents - $package->used_events, 0);
$package->package_limits = array_merge(
$pkg?->limits ?? [],
[
'branding_allowed' => $pkg?->branding_allowed,
'watermark_allowed' => $pkg?->watermark_allowed,
'features' => $pkg?->features ?? [],
]
);
}
}

View File

@@ -505,9 +505,6 @@ function PackageSummarySheet({
const { t } = useTranslation('management');
const { textStrong, muted, border, surface, accentSoft, primary } = useAdminTheme();
const text = textStrong;
const maxPhotos = (limits as Record<string, number | null> | null)?.max_photos ?? null;
const maxGuests = (limits as Record<string, number | null> | null)?.max_guests ?? null;
const galleryDays = (limits as Record<string, number | null> | null)?.gallery_days ?? null;
const resolvedFeatures = collectPackageFeatures({
features,
package_limits: limits,
@@ -532,9 +529,6 @@ function PackageSummarySheet({
</Text>
</YStack>
<YStack space="$2" marginTop="$2">
<SummaryRow label={t('mobileDashboard.packageSummary.limitPhotos', 'Photos')} value={formatPackageLimit(maxPhotos, t)} />
<SummaryRow label={t('mobileDashboard.packageSummary.limitGuests', 'Guests')} value={formatPackageLimit(maxGuests, t)} />
<SummaryRow label={t('mobileDashboard.packageSummary.limitDays', 'Gallery days')} value={formatPackageLimit(galleryDays, t)} />
<SummaryRow
label={t('mobileDashboard.packageSummary.remaining', 'Remaining events')}
value={formatPackageLimit(remainingEvents, t)}

View File

@@ -0,0 +1,48 @@
<?php
namespace Tests\Feature\Tenant;
use App\Http\Controllers\Api\TenantPackageController;
use App\Models\Package;
use App\Models\TenantPackage;
use Illuminate\Http\Request;
class TenantPackageOverviewTest extends TenantTestCase
{
public function test_active_package_contains_limits_and_features(): void
{
$package = Package::factory()->reseller()->create([
'max_photos' => 1500,
'max_guests' => 250,
'gallery_days' => 30,
'max_tasks' => 40,
'max_events_per_year' => 12,
'features' => ['custom_branding', 'reseller_dashboard'],
'branding_allowed' => true,
'watermark_allowed' => false,
]);
TenantPackage::factory()->create([
'tenant_id' => $this->tenant->id,
'package_id' => $package->id,
'active' => true,
'used_events' => 3,
]);
$request = Request::create('/api/v1/tenant/packages', 'GET');
$request->attributes->set('tenant', $this->tenant);
$response = app(TenantPackageController::class)->index($request);
$payload = $response->getData(true);
$this->assertSame(1500, $payload['active_package']['package_limits']['max_photos']);
$this->assertSame(250, $payload['active_package']['package_limits']['max_guests']);
$this->assertSame(30, $payload['active_package']['package_limits']['gallery_days']);
$this->assertSame(40, $payload['active_package']['package_limits']['max_tasks']);
$this->assertSame(12, $payload['active_package']['package_limits']['max_events_per_year']);
$this->assertTrue($payload['active_package']['package_limits']['branding_allowed']);
$this->assertFalse($payload['active_package']['package_limits']['watermark_allowed']);
$this->assertSame(['custom_branding', 'reseller_dashboard'], $payload['active_package']['package_limits']['features']);
$this->assertSame(9, $payload['active_package']['remaining_events']);
}
}