 1072a0c17c
			
		
	
	1072a0c17c
	
	
	
		
			
			- fix: show time details even if a deployment has failed - feat: added back "finished x min ago" to make it easier to see how long ago a deployment was finished
		
			
				
	
	
		
			93 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <div class="flex flex-col gap-2" wire:poll.5000ms="refreshExecutions" x-data="{
 | |
|     init() {
 | |
|         let interval;
 | |
|         $wire.$watch('isPollingActive', value => {
 | |
|             if (value) {
 | |
|                 interval = setInterval(() => {
 | |
|                     $wire.polling();
 | |
|                 }, 1000);
 | |
|             } else {
 | |
|                 if (interval) clearInterval(interval);
 | |
|             }
 | |
|         });
 | |
|     }
 | |
| }">
 | |
|     @forelse($executions as $execution)
 | |
|         <a wire:click="selectTask({{ data_get($execution, 'id') }})" @class([
 | |
|             'flex flex-col border-l-2 transition-colors p-4 cursor-pointer bg-white hover:bg-gray-100 dark:bg-coolgray-100 dark:hover:bg-coolgray-200 text-black dark:text-white',
 | |
|             'bg-gray-200 dark:bg-coolgray-200' => data_get($execution, 'id') == $selectedKey,
 | |
|             'border-blue-500/50 border-dashed' => data_get($execution, 'status') === 'running',
 | |
|             'border-error' => data_get($execution, 'status') === 'failed',
 | |
|             'border-success' => data_get($execution, 'status') === 'success',
 | |
|         ])>
 | |
|             @if (data_get($execution, 'status') === 'running')
 | |
|                 <div class="absolute top-2 right-2">
 | |
|                     <x-loading />
 | |
|                 </div>
 | |
|             @endif
 | |
|             <div class="flex items-center gap-2 mb-2">
 | |
|                 <span @class([
 | |
|                     'px-3 py-1 rounded-md text-xs font-medium tracking-wide shadow-sm',
 | |
|                     'bg-blue-100/80 text-blue-700 dark:bg-blue-500/20 dark:text-blue-300 dark:shadow-blue-900/5' => data_get($execution, 'status') === 'running',
 | |
|                     'bg-red-100 text-red-800 dark:bg-red-900/30 dark:text-red-200 dark:shadow-red-900/5' => data_get($execution, 'status') === 'failed',
 | |
|                     'bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-200 dark:shadow-green-900/5' => data_get($execution, 'status') === 'success',
 | |
|                 ])>
 | |
|                     @php
 | |
|                         $statusText = match(data_get($execution, 'status')) {
 | |
|                             'success' => 'Success',
 | |
|                             'running' => 'In Progress',
 | |
|                             'failed' => 'Failed',
 | |
|                             default => ucfirst(data_get($execution, 'status'))
 | |
|                         };
 | |
|                     @endphp
 | |
|                     {{ $statusText }}
 | |
|                 </span>
 | |
|             </div>
 | |
|             <div class="text-gray-600 dark:text-gray-400 text-sm">
 | |
|                 Started: {{ formatDateInServerTimezone(data_get($execution, 'created_at', now()), data_get($task, 'application.destination.server') ?? data_get($task, 'service.destination.server')) }}
 | |
|                 @if(data_get($execution, 'status') !== 'running')
 | |
|                     <br>Ended: {{ formatDateInServerTimezone(data_get($execution, 'finished_at'), data_get($task, 'application.destination.server') ?? data_get($task, 'service.destination.server')) }}
 | |
|                     <br>Duration: {{ calculateDuration(data_get($execution, 'created_at'), data_get($execution, 'finished_at')) }}
 | |
|                     <br>Finished {{ \Carbon\Carbon::parse(data_get($execution, 'finished_at'))->diffForHumans() }}
 | |
|                 @endif
 | |
|             </div>
 | |
|         </a>
 | |
|         @if (strlen($execution->message) > 0)
 | |
|             <x-forms.button wire:click.prevent="downloadLogs({{ data_get($execution, 'id') }})">
 | |
|                 Download Logs
 | |
|             </x-forms.button>
 | |
|         @endif
 | |
|         @if (data_get($execution, 'id') == $selectedKey)
 | |
|             <div class="p-4 mb-2 bg-gray-100 dark:bg-coolgray-200 rounded">
 | |
|                 @if (data_get($execution, 'status') === 'running')
 | |
|                     <div class="flex items-center gap-2 mb-2">
 | |
|                         <span>Task is running...</span>
 | |
|                         <x-loading class="w-4 h-4" />
 | |
|                     </div>
 | |
|                 @endif
 | |
|                 @if ($this->logLines->isNotEmpty())
 | |
|                     <div>
 | |
|                         <pre class="whitespace-pre-wrap">
 | |
| @foreach ($this->logLines as $line)
 | |
| {{ $line }}
 | |
| @endforeach
 | |
| </pre>
 | |
|                         <div class="flex gap-2">
 | |
|                             @if ($this->hasMoreLogs())
 | |
|                                 <x-forms.button wire:click.prevent="loadMoreLogs" isHighlighted>
 | |
|                                     Load More
 | |
|                                 </x-forms.button>
 | |
|                             @endif
 | |
| 
 | |
|                         </div>
 | |
|                     </div>
 | |
|                 @else
 | |
|                     <div>No output was recorded for this execution.</div>
 | |
|                 @endif
 | |
|             </div>
 | |
|         @endif
 | |
|     @empty
 | |
|         <div class="p-4 bg-gray-100 dark:bg-coolgray-100 rounded">No executions found.</div>
 | |
|     @endforelse
 | |
| </div>
 |