Fix reseller package selection when older batches are exhausted
This commit is contained in:
@@ -247,11 +247,13 @@ class EventController extends Controller
|
||||
$tenant->refresh();
|
||||
$event->load(['eventType', 'tenant', 'eventPackages.package', 'eventPackages.addons']);
|
||||
|
||||
$activeResellerPackage = $tenant->getActiveResellerPackage();
|
||||
|
||||
return response()->json([
|
||||
'message' => 'Event created successfully',
|
||||
'data' => new EventResource($event),
|
||||
'package' => $event->eventPackage ? $event->eventPackage->package->name : 'None',
|
||||
'remaining_events' => $tenant->activeResellerPackage ? $tenant->activeResellerPackage->remaining_events : 0,
|
||||
'remaining_events' => $activeResellerPackage?->remaining_events ?? 0,
|
||||
], 201);
|
||||
}
|
||||
|
||||
|
||||
@@ -119,8 +119,6 @@ class TenantAdminTokenController extends Controller
|
||||
], 404);
|
||||
}
|
||||
|
||||
$tenant->loadMissing('activeResellerPackage');
|
||||
|
||||
$user = $request->user();
|
||||
$abilities = $user?->currentAccessToken()?->abilities ?? [];
|
||||
|
||||
@@ -131,7 +129,7 @@ class TenantAdminTokenController extends Controller
|
||||
$fullName = trim($first.' '.$last) ?: null;
|
||||
}
|
||||
|
||||
$activePackage = $tenant->activeResellerPackage;
|
||||
$activePackage = $tenant->getActiveResellerPackage();
|
||||
|
||||
return response()->json([
|
||||
'id' => $tenant->id,
|
||||
|
||||
@@ -37,7 +37,7 @@ class TenantPackageController extends Controller
|
||||
$this->hydratePackageSnapshot($package, $eventPackage);
|
||||
});
|
||||
|
||||
$activePackage = $tenant->activeResellerPackage?->load('package');
|
||||
$activePackage = $tenant->getActiveResellerPackage();
|
||||
|
||||
if (! ($activePackage instanceof TenantPackage)) {
|
||||
$activePackage = $packages->firstWhere('active', true);
|
||||
|
||||
@@ -233,10 +233,18 @@ class Tenant extends Model
|
||||
|
||||
public function getActiveResellerPackage(): ?TenantPackage
|
||||
{
|
||||
return $this->activeResellerPackage()->with('package')->first();
|
||||
return $this->getActiveResellerPackageFor(null);
|
||||
}
|
||||
|
||||
public function getActiveResellerPackageFor(?string $includedPackageSlug): ?TenantPackage
|
||||
{
|
||||
$candidates = $this->activeResellerPackagesQuery($includedPackageSlug)->get();
|
||||
|
||||
return $candidates->first(fn (TenantPackage $package) => $package->canCreateEvent())
|
||||
?? $candidates->first();
|
||||
}
|
||||
|
||||
private function activeResellerPackagesQuery(?string $includedPackageSlug): HasMany
|
||||
{
|
||||
$query = $this->tenantPackages()
|
||||
->with('package')
|
||||
@@ -258,7 +266,7 @@ class Tenant extends Model
|
||||
});
|
||||
}
|
||||
|
||||
return $query->first();
|
||||
return $query;
|
||||
}
|
||||
|
||||
public function activeSubscription(): Attribute
|
||||
|
||||
Reference in New Issue
Block a user