Align commerce module with the monorepo module structure by updating all namespaces to use the Core\Mod\Commerce convention. This change supports the recent monorepo separation and ensures consistency with other modules. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
55 lines
1.3 KiB
PHP
55 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace Core\Mod\Commerce\View\Modal\Web;
|
|
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Livewire\Attributes\Layout;
|
|
use Livewire\Component;
|
|
use Core\Mod\Commerce\Models\Order;
|
|
use Core\Mod\Tenant\Models\User;
|
|
|
|
#[Layout('shared::layouts.checkout')]
|
|
class CheckoutCancel extends Component
|
|
{
|
|
public ?Order $order = null;
|
|
|
|
public string $orderNumber = '';
|
|
|
|
public function mount(?string $order = null): void
|
|
{
|
|
if ($order) {
|
|
$this->orderNumber = $order;
|
|
$foundOrder = Order::where('order_number', $order)->first();
|
|
|
|
// Verify ownership before exposing order details
|
|
if ($foundOrder && $this->authorizeOrder($foundOrder)) {
|
|
$this->order = $foundOrder;
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Verify the current user is authorised to view this order.
|
|
*/
|
|
protected function authorizeOrder(Order $order): bool
|
|
{
|
|
$user = Auth::user();
|
|
|
|
if (! $user instanceof User) {
|
|
return false;
|
|
}
|
|
|
|
$workspace = $user->defaultHostWorkspace();
|
|
|
|
if (! $workspace) {
|
|
return false;
|
|
}
|
|
|
|
return $order->workspace_id === $workspace->id;
|
|
}
|
|
|
|
public function render()
|
|
{
|
|
return view('commerce::web.checkout.checkout-cancel');
|
|
}
|
|
}
|