- Added logic to determine if the user can create resources for each project and generate the corresponding route for adding resources based on the project's first environment. - Updated the project index view to display the new resource creation option alongside existing project settings. - Adjusted various views to include a margin-top adjustment for better layout consistency.
128 lines
6.3 KiB
PHP
128 lines
6.3 KiB
PHP
<div>
|
|
<x-slot:title>
|
|
Dashboard | Coolify
|
|
</x-slot>
|
|
@if (session('error'))
|
|
<span x-data x-init="$wire.emit('error', '{{ session('error') }}')" />
|
|
@endif
|
|
<h1>Dashboard</h1>
|
|
<div class="subtitle">Your self-hosted infrastructure.</div>
|
|
@if (request()->query->get('success'))
|
|
<div class=" mb-10 font-bold alert alert-success">
|
|
Your subscription has been activated! Welcome onboard! It could take a few seconds before your
|
|
subscription is activated.<br> Please be patient.
|
|
</div>
|
|
@endif
|
|
|
|
<section class="-mt-2">
|
|
<h3 class="pb-2">Projects</h3>
|
|
@if ($projects->count() > 0)
|
|
<div class="grid grid-cols-1 gap-4 xl:grid-cols-2">
|
|
@foreach ($projects as $project)
|
|
<div class="relative gap-2 cursor-pointer box group">
|
|
<a href="{{ $project->navigateTo() }}" class="absolute inset-0"></a>
|
|
<div class="flex flex-1 mx-6">
|
|
<div class="flex flex-col justify-center flex-1">
|
|
<div class="box-title">{{ $project->name }}</div>
|
|
<div class="box-description">
|
|
{{ $project->description }}
|
|
</div>
|
|
</div>
|
|
<div class="relative z-10 flex items-center justify-center gap-4 text-xs font-bold">
|
|
@if ($project->environments->first())
|
|
@can('createAnyResource')
|
|
<a class="hover:underline"
|
|
href="{{ route('project.resource.create', [
|
|
'project_uuid' => $project->uuid,
|
|
'environment_uuid' => $project->environments->first()->uuid,
|
|
]) }}">
|
|
+ Add Resource
|
|
</a>
|
|
@endcan
|
|
@endif
|
|
@can('update', $project)
|
|
<a class="hover:underline"
|
|
href="{{ route('project.edit', ['project_uuid' => $project->uuid]) }}">
|
|
Settings
|
|
</a>
|
|
@endcan
|
|
</div>
|
|
</div>
|
|
</div>
|
|
@endforeach
|
|
</div>
|
|
@else
|
|
<div class="flex flex-col gap-1">
|
|
<div class='font-bold dark:text-warning'>No projects found.</div>
|
|
<div class="flex items-center gap-1">
|
|
<x-modal-input buttonTitle="Add" title="New Project">
|
|
<livewire:project.add-empty />
|
|
</x-modal-input> your first project or
|
|
go to the <a class="underline dark:text-white" href="{{ route('onboarding') }}">onboarding</a> page.
|
|
</div>
|
|
</div>
|
|
@endif
|
|
</section>
|
|
|
|
<section>
|
|
<h3 class="pb-2">Servers</h3>
|
|
@if ($servers->count() > 0)
|
|
<div class="grid grid-cols-1 gap-4 xl:grid-cols-2">
|
|
@foreach ($servers as $server)
|
|
<a href="{{ route('server.show', ['server_uuid' => data_get($server, 'uuid')]) }}"
|
|
@class([
|
|
'gap-2 border cursor-pointer box group',
|
|
'border-red-500' =>
|
|
!$server->settings->is_reachable || $server->settings->force_disabled,
|
|
])>
|
|
<div class="flex flex-col justify-center mx-6">
|
|
<div class="box-title">
|
|
{{ $server->name }}
|
|
</div>
|
|
<div class="box-description">
|
|
{{ $server->description }}</div>
|
|
<div class="flex gap-1 text-xs text-error">
|
|
@if (!$server->settings->is_reachable)
|
|
Not reachable
|
|
@endif
|
|
@if (!$server->settings->is_reachable && !$server->settings->is_usable)
|
|
&
|
|
@endif
|
|
@if (!$server->settings->is_usable)
|
|
Not usable by Coolify
|
|
@endif
|
|
</div>
|
|
</div>
|
|
<div class="flex-1"></div>
|
|
</a>
|
|
@endforeach
|
|
</div>
|
|
@else
|
|
@if ($privateKeys->count() === 0)
|
|
<div class="flex flex-col gap-1">
|
|
<div class='font-bold dark:text-warning'>No private keys found.</div>
|
|
<div class="flex items-center gap-1">Before you can add your server, first <x-modal-input
|
|
buttonTitle="add" title="New Private Key">
|
|
<livewire:security.private-key.create from="server" />
|
|
</x-modal-input> a private key
|
|
or
|
|
go to the <a class="underline dark:text-white" href="{{ route('onboarding') }}">onboarding</a>
|
|
page.
|
|
</div>
|
|
</div>
|
|
@else
|
|
<div class="flex flex-col gap-1">
|
|
<div class='font-bold dark:text-warning'>No servers found.</div>
|
|
<div class="flex items-center gap-1">
|
|
<x-modal-input buttonTitle="Add" title="New Server" :closeOutside="false">
|
|
<livewire:server.create />
|
|
</x-modal-input> your first server
|
|
or
|
|
go to the <a class="underline dark:text-white" href="{{ route('onboarding') }}">onboarding</a>
|
|
page.
|
|
</div>
|
|
</div>
|
|
@endif
|
|
@endif
|
|
</section>
|
|
</div>
|