2023-08-29 12:36:17 +00:00
|
|
|
<div>
|
2024-06-07 09:01:10 +00:00
|
|
|
<x-slot:title>
|
2024-07-25 20:50:18 +00:00
|
|
|
Dashboard | Last Hour Cloud
|
|
|
|
</x-slot>
|
|
|
|
@if (session('error'))
|
2023-08-30 16:23:55 +00:00
|
|
|
<span x-data x-init="$wire.emit('error', '{{ session('error') }}')" />
|
2024-07-25 20:50:18 +00:00
|
|
|
@endif
|
|
|
|
<h1>Dashboard</h1>
|
|
|
|
<div class="subtitle">Your self-hosted infrastructure.</div>
|
|
|
|
@if (request()->query->get('success'))
|
2024-05-02 10:27:04 +00:00
|
|
|
<div class="items-center justify-center mb-10 font-bold rounded alert alert-success">
|
2024-07-25 20:50:18 +00:00
|
|
|
<svg xmlns="http://www.w3.org/2000/svg" class="w-6 h-6 stroke-current shrink-0" fill="none" viewBox="0 0 24 24">
|
|
|
|
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z" />
|
2023-08-30 16:23:55 +00:00
|
|
|
</svg>
|
2024-05-02 10:27:04 +00:00
|
|
|
Your subscription has been activated! Welcome onboard! <br>It could take a few seconds before your
|
2024-05-10 07:56:39 +00:00
|
|
|
subscription is activated.<br> Please be patient.
|
2023-08-30 16:23:55 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
@endif
|
|
|
|
<h3 class="pb-4">Projects</h3>
|
|
|
|
@if ($projects->count() > 0)
|
2024-03-22 10:34:15 +00:00
|
|
|
<div class="grid grid-cols-1 gap-2 xl:grid-cols-2">
|
|
|
|
@foreach ($projects as $project)
|
2024-07-25 20:50:18 +00:00
|
|
|
<div class="gap-2 border border-transparent cursor-pointer box group" onclick="gotoProject('{{ $project->uuid }}','{{ $project->default_environment() }}')">
|
|
|
|
<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 }}
|
2024-05-10 07:56:39 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
<div class="flex items-center justify-center gap-2 text-xs font-bold ">
|
|
|
|
<a class="hover:underline" href="{{ route('project.resource.create', ['project_uuid' => data_get($project, 'uuid'), 'environment_name' => data_get($project, 'environments.0.name', 'production')]) }}">
|
|
|
|
<span class="p-2 font-bold">+
|
|
|
|
Add Resource</span>
|
|
|
|
</a>
|
|
|
|
<a class="hover:underline" href="{{ route('project.edit', ['project_uuid' => data_get($project, 'uuid')]) }}">
|
|
|
|
Settings
|
|
|
|
</a>
|
|
|
|
</div>
|
2024-02-23 11:59:14 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
</div>
|
2024-03-22 10:34:15 +00:00
|
|
|
@endforeach
|
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
@else
|
2024-03-22 10:34:15 +00:00
|
|
|
<div class="flex flex-col gap-1">
|
2024-03-22 16:02:09 +00:00
|
|
|
<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
|
2024-03-21 13:30:35 +00:00
|
|
|
go to the <a class="underline dark:text-white" href="{{ route('onboarding') }}">onboarding</a> page.
|
2024-03-18 13:35:46 +00:00
|
|
|
</div>
|
2024-03-22 10:34:15 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
@endif
|
2024-03-22 10:34:15 +00:00
|
|
|
|
2024-07-25 20:50:18 +00:00
|
|
|
<h3 class="py-4">Servers</h3>
|
|
|
|
@if ($servers->count() > 0)
|
2024-03-22 10:34:15 +00:00
|
|
|
<div class="grid grid-cols-1 gap-2 xl:grid-cols-2">
|
|
|
|
@foreach ($servers as $server)
|
2024-07-25 20:50:18 +00:00
|
|
|
<a href="{{ route('server.show', ['server_uuid' => data_get($server, 'uuid')]) }}" @class([ 'gap-2 border cursor-pointer box group' , 'border-transparent'=> $server->settings->is_reachable,
|
|
|
|
'border-red-500' => !$server->settings->is_reachable,
|
|
|
|
])>
|
|
|
|
<div class="flex flex-col justify-center mx-6">
|
|
|
|
<div class="box-title">
|
|
|
|
{{ $server->name }}
|
2024-03-18 13:35:46 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
<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 Last Hour Cloud
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="flex-1"></div>
|
|
|
|
</a>
|
2024-03-22 10:34:15 +00:00
|
|
|
@endforeach
|
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
@else
|
2024-03-22 10:34:15 +00:00
|
|
|
@if ($private_keys->count() === 0)
|
2024-07-25 20:50:18 +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') }}">onboarding</a>
|
|
|
|
page.
|
2024-03-22 10:34:15 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
</div>
|
2024-03-22 10:34:15 +00:00
|
|
|
@else
|
2024-07-25 20:50:18 +00:00
|
|
|
<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.
|
2024-03-24 15:00:25 +00:00
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
</div>
|
2024-03-22 10:34:15 +00:00
|
|
|
@endif
|
2024-07-25 20:50:18 +00:00
|
|
|
@endif
|
|
|
|
@if ($servers->count() > 0 && $projects->count() > 0)
|
2024-03-22 16:02:09 +00:00
|
|
|
<div class="flex items-center gap-2">
|
|
|
|
<h3 class="py-4">Deployments</h3>
|
|
|
|
@if (count($deployments_per_server) > 0)
|
2024-07-25 20:50:18 +00:00
|
|
|
<x-loading />
|
2024-03-22 16:02:09 +00:00
|
|
|
@endif
|
2024-05-29 07:09:22 +00:00
|
|
|
<x-modal-confirmation isErrorButton action="cleanup_queue" buttonTitle="Cleanup Queues">
|
|
|
|
This will clean up the deployment queue. <br>Please think again.
|
|
|
|
</x-modal-confirmation>
|
2024-03-22 16:02:09 +00:00
|
|
|
</div>
|
2024-03-24 15:00:25 +00:00
|
|
|
<div wire:poll.3000ms="get_deployments" class="grid grid-cols-1">
|
2024-03-22 16:02:09 +00:00
|
|
|
@forelse ($deployments_per_server as $server_name => $deployments)
|
2024-07-25 20:50:18 +00:00
|
|
|
<h4 class="py-4">{{ $server_name }}</h4>
|
|
|
|
<div class="grid grid-cols-1 gap-2 lg:grid-cols-3">
|
|
|
|
@foreach ($deployments as $deployment)
|
|
|
|
<a href="{{ data_get($deployment, 'deployment_url') }}" @class([ 'gap-2 cursor-pointer box group border-l-2 border-dotted' , 'dark:border-coolgray-300'=> data_get($deployment, 'status') === 'queued',
|
|
|
|
'border-yellow-500' => data_get($deployment, 'status') === 'in_progress',
|
|
|
|
])>
|
|
|
|
<div class="flex flex-col justify-center mx-6">
|
|
|
|
<div class="box-title">
|
|
|
|
{{ data_get($deployment, 'application_name') }}
|
|
|
|
</div>
|
|
|
|
@if (data_get($deployment, 'pull_request_id') !== 0)
|
|
|
|
<div class="box-description">
|
|
|
|
PR #{{ data_get($deployment, 'pull_request_id') }}
|
|
|
|
</div>
|
|
|
|
@endif
|
|
|
|
<div class="box-description">
|
|
|
|
{{ str(data_get($deployment, 'status'))->headline() }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="flex-1"></div>
|
|
|
|
</a>
|
|
|
|
@endforeach
|
|
|
|
</div>
|
2024-03-22 16:02:09 +00:00
|
|
|
@empty
|
2024-07-25 20:50:18 +00:00
|
|
|
<div>No deployments running.</div>
|
2024-03-22 16:02:09 +00:00
|
|
|
@endforelse
|
|
|
|
</div>
|
2024-07-25 20:50:18 +00:00
|
|
|
@endif
|
2024-03-18 13:32:49 +00:00
|
|
|
|
2024-07-25 20:50:18 +00:00
|
|
|
<script>
|
|
|
|
function gotoProject(uuid, environment) {
|
|
|
|
if (!environment) {
|
|
|
|
window.location.href = '/project/' + uuid;
|
|
|
|
}
|
|
|
|
window.location.href = '/project/' + uuid + '/' + environment;
|
2024-06-24 16:33:01 +00:00
|
|
|
}
|
2024-07-25 20:50:18 +00:00
|
|
|
</script>
|
|
|
|
{{-- <x-forms.button wire:click='getIptables'>Get IPTABLES</x-forms.button> --}}
|
|
|
|
</div>
|