2024-01-07 16:23:41 +01:00
|
|
|
<div>
|
2024-06-07 11:01:10 +02:00
|
|
|
<x-slot:title>
|
|
|
|
{{ data_get_str($application, 'name')->limit(10) }} > Deployments | Coolify
|
|
|
|
</x-slot>
|
2024-01-07 16:23:41 +01:00
|
|
|
<h1>Deployments</h1>
|
2024-04-12 12:44:49 +02:00
|
|
|
<livewire:project.shared.configuration-checker :resource="$application" />
|
2024-01-07 16:23:41 +01:00
|
|
|
<livewire:project.application.heading :application="$application" />
|
|
|
|
{{-- <livewire:project.application.deployment.show :application="$application" :deployments="$deployments" :deployments_count="$deployments_count" /> --}}
|
2024-01-29 11:23:04 +01:00
|
|
|
<div class="flex flex-col gap-2 pb-10"
|
|
|
|
@if ($skip == 0) wire:poll.5000ms='reload_deployments' @endif>
|
2024-01-07 16:23:41 +01:00
|
|
|
<div class="flex items-end gap-2 pt-4">
|
|
|
|
<h2>Deployments <span class="text-xs">({{ $deployments_count }})</span></h2>
|
2024-03-20 12:54:06 +01:00
|
|
|
@if ($deployments_count > 0)
|
|
|
|
<x-forms.button disabled="{{ !$show_prev }}" wire:click="previous_page('{{ $default_take }}')"><svg
|
|
|
|
class="w-6 h-6" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
2024-01-29 13:06:26 +01:00
|
|
|
<path fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"
|
|
|
|
stroke-width="2" d="m14 6l-6 6l6 6z" />
|
|
|
|
</svg></x-forms.button>
|
2024-03-20 12:54:06 +01:00
|
|
|
<x-forms.button disabled="{{ !$show_next }}" wire:click="next_page('{{ $default_take }}')"><svg
|
|
|
|
class="w-6 h-6" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
2024-01-29 13:06:26 +01:00
|
|
|
<path fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round"
|
|
|
|
stroke-width="2" d="m10 18l6-6l-6-6z" />
|
|
|
|
</svg></x-forms.button>
|
2024-01-07 16:23:41 +01:00
|
|
|
@endif
|
|
|
|
</div>
|
2024-03-20 12:54:06 +01:00
|
|
|
@if ($deployments_count > 0)
|
|
|
|
<form class="flex items-end gap-2">
|
|
|
|
<x-forms.input id="pull_request_id" label="Pull Request"></x-forms.input>
|
|
|
|
<x-forms.button type="submit">Filter</x-forms.button>
|
|
|
|
</form>
|
|
|
|
@endif
|
2024-01-07 16:23:41 +01:00
|
|
|
@forelse ($deployments as $deployment)
|
2024-05-15 10:45:08 +02:00
|
|
|
<div @class([
|
|
|
|
'dark:bg-coolgray-100 p-2 border-l border-dashed transition-colors hover:no-underline box-without-bg-without-border bg-white flex-col cursor-pointer dark:hover:text-neutral-400 dark:hover:bg-coolgray-200',
|
|
|
|
'border-warning' =>
|
2024-01-07 16:23:41 +01:00
|
|
|
data_get($deployment, 'status') === 'in_progress' ||
|
|
|
|
data_get($deployment, 'status') === 'cancelled-by-user',
|
2024-05-15 10:45:08 +02:00
|
|
|
'border-error' => data_get($deployment, 'status') === 'failed',
|
|
|
|
'border-success' => data_get($deployment, 'status') === 'finished',
|
|
|
|
])
|
|
|
|
x-on:click.stop="goto('{{ $current_url . '/' . data_get($deployment, 'deployment_uuid') }}')">
|
2024-01-07 16:23:41 +01:00
|
|
|
<div class="flex flex-col justify-start">
|
|
|
|
<div class="flex gap-1">
|
|
|
|
{{ $deployment->created_at }} UTC
|
2024-03-25 10:41:44 +01:00
|
|
|
<span class=" dark:text-warning">></span>
|
2024-01-07 16:23:41 +01:00
|
|
|
{{ $deployment->status }}
|
|
|
|
</div>
|
2024-01-29 11:23:04 +01:00
|
|
|
@if (data_get($deployment, 'is_webhook') || data_get($deployment, 'pull_request_id'))
|
2024-06-14 14:48:12 +02:00
|
|
|
<div class="flex items-center gap-1">
|
2024-01-07 16:23:41 +01:00
|
|
|
@if (data_get($deployment, 'is_webhook'))
|
2024-01-29 11:23:04 +01:00
|
|
|
Webhook
|
2024-01-07 16:23:41 +01:00
|
|
|
@endif
|
2024-01-29 11:23:04 +01:00
|
|
|
@if (data_get($deployment, 'pull_request_id'))
|
|
|
|
@if (data_get($deployment, 'is_webhook'))
|
|
|
|
|
|
|
|
|
@endif
|
|
|
|
Pull Request #{{ data_get($deployment, 'pull_request_id') }}
|
2024-06-14 14:48:12 +02:00
|
|
|
@endif
|
|
|
|
@if (data_get($deployment, 'commit'))
|
|
|
|
<div class="dark:hover:text-white"
|
|
|
|
x-on:click.stop="goto('{{ $application->gitCommitLink(data_get($deployment, 'commit')) }}')">
|
|
|
|
<div class="text-xs underline">
|
|
|
|
@if ($deployment->commitMessage())
|
|
|
|
({{ data_get_str($deployment, 'commit')->limit(7) }} -
|
|
|
|
{{ $deployment->commitMessage() }})
|
|
|
|
@else
|
|
|
|
{{ data_get_str($deployment, 'commit')->limit(7) }}
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-01-07 16:23:41 +01:00
|
|
|
@endif
|
|
|
|
</div>
|
2024-01-29 11:23:04 +01:00
|
|
|
@else
|
2024-05-15 10:45:08 +02:00
|
|
|
<div class="flex items-center gap-1">
|
2024-05-15 10:47:57 +02:00
|
|
|
@if (data_get($deployment, 'rollback') === true)
|
|
|
|
Rollback
|
|
|
|
@else
|
2024-06-21 16:46:13 +02:00
|
|
|
@if (data_get($deployment, 'is_api'))
|
|
|
|
API
|
|
|
|
@else
|
|
|
|
Manual
|
|
|
|
@endif
|
2024-05-15 10:45:08 +02:00
|
|
|
@endif
|
|
|
|
@if (data_get($deployment, 'commit'))
|
|
|
|
<div class="dark:hover:text-white"
|
2024-05-15 10:47:57 +02:00
|
|
|
x-on:click.stop="goto('{{ $application->gitCommitLink(data_get($deployment, 'commit')) }}')">
|
2024-05-15 10:45:08 +02:00
|
|
|
<div class="text-xs underline">
|
2024-05-15 11:31:03 +02:00
|
|
|
@if ($deployment->commitMessage())
|
2024-05-28 19:00:59 +02:00
|
|
|
({{ data_get_str($deployment, 'commit')->limit(7) }} -
|
|
|
|
{{ $deployment->commitMessage() }})
|
2024-05-15 11:31:03 +02:00
|
|
|
@else
|
|
|
|
{{ data_get_str($deployment, 'commit')->limit(7) }}
|
|
|
|
@endif
|
|
|
|
</div>
|
2024-05-15 10:45:08 +02:00
|
|
|
</div>
|
|
|
|
@endif
|
2024-01-29 11:23:04 +01:00
|
|
|
</div>
|
2024-01-07 16:23:41 +01:00
|
|
|
@endif
|
2024-05-15 10:47:57 +02:00
|
|
|
@if (data_get($deployment, 'server_name') && $application->additional_servers->count() > 0)
|
2024-02-06 15:05:11 +01:00
|
|
|
<div class="flex gap-1">
|
|
|
|
Server: {{ data_get($deployment, 'server_name') }}
|
|
|
|
</div>
|
|
|
|
@endif
|
2024-01-07 16:23:41 +01:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="flex flex-col" x-data="elapsedTime('{{ $deployment->deployment_uuid }}', '{{ $deployment->status }}', '{{ $deployment->created_at }}', '{{ $deployment->updated_at }}')">
|
|
|
|
<div>
|
|
|
|
@if ($deployment->status !== 'in_progress')
|
|
|
|
Finished <span x-text="measure_since_started()">0s</span> in
|
2024-05-29 12:35:32 +00:00
|
|
|
<span class="font-bold" x-text="measure_finished_time()">0s</span>
|
2024-01-07 16:23:41 +01:00
|
|
|
@else
|
2024-06-14 14:48:12 +02:00
|
|
|
Running for <span class="font-bold" x-text="measure_since_started()">0s</span>
|
2024-01-07 16:23:41 +01:00
|
|
|
@endif
|
2024-05-31 13:01:44 +02:00
|
|
|
|
2024-01-07 16:23:41 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2024-05-15 10:45:08 +02:00
|
|
|
</div>
|
2024-01-07 16:23:41 +01:00
|
|
|
@empty
|
|
|
|
<div class="">No deployments found</div>
|
|
|
|
@endforelse
|
2024-05-15 10:45:08 +02:00
|
|
|
|
2024-03-20 12:54:06 +01:00
|
|
|
@if ($deployments_count > 0)
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/dayjs@1/dayjs.min.js"></script>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/dayjs@1/plugin/utc.js"></script>
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/dayjs@1/plugin/relativeTime.js"></script>
|
|
|
|
<script>
|
2024-05-15 10:45:08 +02:00
|
|
|
function goto(url) {
|
|
|
|
window.location.href = url;
|
|
|
|
};
|
2024-05-29 11:13:22 +02:00
|
|
|
let timers = {};
|
2024-01-07 16:23:41 +01:00
|
|
|
|
2024-05-29 11:13:22 +02:00
|
|
|
dayjs.extend(window.dayjs_plugin_utc);
|
|
|
|
dayjs.extend(window.dayjs_plugin_relativeTime);
|
2024-01-07 16:23:41 +01:00
|
|
|
|
2024-05-29 11:13:22 +02:00
|
|
|
Alpine.data('elapsedTime', (uuid, status, created_at, updated_at) => ({
|
2024-05-31 13:01:44 +02:00
|
|
|
finished_time: 'calculating...',
|
|
|
|
started_time: 'calculating...',
|
|
|
|
init() {
|
|
|
|
if (timers[uuid]) {
|
|
|
|
clearInterval(timers[uuid]);
|
2024-01-07 16:23:41 +01:00
|
|
|
}
|
2024-05-29 11:13:22 +02:00
|
|
|
if (status === 'in_progress') {
|
|
|
|
timers[uuid] = setInterval(() => {
|
|
|
|
this.finished_time = dayjs().diff(dayjs.utc(created_at),
|
|
|
|
'second') + 's'
|
|
|
|
}, 1000);
|
|
|
|
} else {
|
|
|
|
let seconds = dayjs.utc(updated_at).diff(dayjs.utc(created_at), 'second')
|
|
|
|
this.finished_time = seconds + 's';
|
|
|
|
}
|
|
|
|
},
|
|
|
|
measure_finished_time() {
|
2024-05-31 13:01:44 +02:00
|
|
|
if (this.finished_time > 2000) {
|
|
|
|
return 0;
|
|
|
|
} else {
|
|
|
|
return this.finished_time;
|
|
|
|
}
|
2024-05-29 11:13:22 +02:00
|
|
|
},
|
|
|
|
measure_since_started() {
|
|
|
|
return dayjs.utc(created_at).fromNow();
|
2024-05-31 13:01:44 +02:00
|
|
|
},
|
2024-05-29 11:13:22 +02:00
|
|
|
}))
|
2024-03-20 12:54:06 +01:00
|
|
|
</script>
|
|
|
|
@endif
|
2024-01-07 16:23:41 +01:00
|
|
|
</div>
|
|
|
|
</div>
|