coolify/resources/views/livewire/dashboard.blade.php

156 lines
8 KiB
PHP
Raw Permalink Normal View History

2023-08-29 12:36:17 +00:00
<div>
2024-06-07 09:01:10 +00:00
<x-slot:title>
Dashboard | MapleDeploy
2024-06-07 09:01:10 +00:00
</x-slot>
2023-08-29 13:51:30 +00:00
@if (session('error'))
2023-08-30 16:23:55 +00:00
<span x-data x-init="$wire.emit('error', '{{ session('error') }}')" />
2023-08-29 13:51:30 +00:00
@endif
2024-03-21 13:30:35 +00:00
<h1>Dashboard</h1>
{{-- MapleDeploy branding --}}
<div class="subtitle">Your deployment platform.</div>
2024-10-30 07:39:47 +00:00
<section class="-mt-2">
<div class="flex items-center gap-2 pb-2">
<h3>Projects</h3>
@if ($projects->count() > 0)
<x-modal-input buttonTitle="Add" title="New Project">
<x-slot:content>
<button
class="flex items-center justify-center size-4 text-white rounded hover:bg-coolgray-400 dark:hover:bg-coolgray-300 cursor-pointer">
<svg class="size-3" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"
stroke-width="2" stroke="currentColor">
<path stroke-linecap="round" stroke-linejoin="round" d="M12 4.5v15m7.5-7.5h-15" />
</svg>
</button>
</x-slot:content>
<livewire:project.add-empty />
</x-modal-input>
@endif
</div>
2024-10-30 07:39:47 +00:00
@if ($projects->count() > 0)
<div class="grid grid-cols-1 gap-4 xl:grid-cols-2">
2024-10-30 07:39:47 +00:00
@foreach ($projects as $project)
<div class="relative gap-2 cursor-pointer coolbox group">
<a href="{{ $project->navigateTo() }}" {{ wireNavigate() }} class="absolute inset-0"></a>
2024-10-30 07:39:47 +00:00
<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" {{ wireNavigate() }}
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" {{ wireNavigate() }}
href="{{ route('project.edit', ['project_uuid' => $project->uuid]) }}">
Settings
2024-11-22 14:28:06 +00:00
</a>
@endcan
2024-08-18 18:55:54 +00:00
</div>
2024-05-10 07:56:39 +00:00
</div>
</div>
2024-10-30 07:39:47 +00:00
@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') }}" {{ wireNavigate() }}>onboarding</a> page.
2024-02-23 11:59:14 +00:00
</div>
</div>
2024-10-30 07:39:47 +00:00
@endif
</section>
2024-03-22 10:34:15 +00:00
2024-10-30 07:39:47 +00:00
<section>
<div class="flex items-center gap-2 pb-2">
<h3>Servers</h3>
@if ($servers->count() > 0 && $privateKeys->count() > 0)
<x-modal-input buttonTitle="Add" title="New Server" :closeOutside="false">
<x-slot:content>
<button
class="flex items-center justify-center size-4 text-white rounded hover:bg-coolgray-400 dark:hover:bg-coolgray-300 cursor-pointer">
<svg class="size-3" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"
stroke-width="2" stroke="currentColor">
<path stroke-linecap="round" stroke-linejoin="round" d="M12 4.5v15m7.5-7.5h-15" />
</svg>
</button>
</x-slot:content>
<livewire:server.create />
</x-modal-input>
@endif
</div>
2024-10-30 07:39:47 +00:00
@if ($servers->count() > 0)
<div class="grid grid-cols-1 gap-4 xl:grid-cols-2">
2024-10-30 07:39:47 +00:00
@foreach ($servers as $server)
<a href="{{ route('server.show', ['server_uuid' => data_get($server, 'uuid')]) }}" {{ wireNavigate() }}
2024-10-30 07:39:47 +00:00
@class([
'gap-2 border cursor-pointer coolbox group',
'border-red-500' =>
!$server->settings->is_reachable || $server->settings->force_disabled,
2024-10-30 07:39:47 +00:00
])>
<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>
2024-03-22 10:34:15 +00:00
</div>
2024-10-30 07:39:47 +00:00
<div class="flex-1"></div>
</a>
@endforeach
2024-03-22 10:34:15 +00:00
</div>
@else
2024-11-03 20:11:35 +00:00
@if ($privateKeys->count() === 0)
2024-10-30 07:39:47 +00:00
<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') }}" {{ wireNavigate() }}>onboarding</a>
2024-10-30 07:39:47 +00:00
page.
</div>
2024-03-25 09:41:44 +00:00
</div>
2024-10-30 07:39:47 +00:00
@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') }}" {{ wireNavigate() }}>onboarding</a>
2024-10-30 07:39:47 +00:00
page.
</div>
</div>
@endif
2024-03-22 10:34:15 +00:00
@endif
2024-10-30 07:39:47 +00:00
</section>
2023-08-29 12:36:17 +00:00
</div>