feat: add function to pause screen generation for up to 480min

chore: code quality
This commit is contained in:
Benjamin Nussbaum 2025-07-10 17:47:42 +02:00
parent 4fb5f54e18
commit 7e355c2d92
10 changed files with 207 additions and 25 deletions

View file

@ -314,6 +314,13 @@ new class extends Component {
<flux:separator vertical/>
<x-responsive-icons.battery :percent="$device->batteryPercent"/>
@endif
@if($device->isPauseActive())
<flux:separator vertical/>
<flux:tooltip content="Pause active until {{$device->pause_until?->format('H:i')}}"
position="bottom">
<flux:icon name="pause-circle" variant="solid"/>
</flux:tooltip>
@endif
</div>
<div>
<flux:modal.trigger name="edit-device">

View file

@ -23,6 +23,8 @@ new class extends Component {
public $mirror_device_id = null;
public ?int $pause_duration;
protected $rules = [
'mac_address' => 'required',
'api_key' => 'required',
@ -75,6 +77,20 @@ new class extends Component {
// \App\Jobs\FetchProxyCloudResponses::dispatch();
// }
}
public function pauseDevice($deviceId): void
{
$this->validate([
'pause_duration' => 'required|integer',
]);
$device = auth()->user()->devices()->findOrFail($deviceId);
$pauseUntil = now()->addMinutes($this->pause_duration);
$device->update(['pause_until' => $pauseUntil]);
$this->reset('pause_duration');
\Flux::modal('pause-device-' . $deviceId)->close();
$this->devices = auth()->user()->devices;
session()->flash('message', 'Device paused until ' . $pauseUntil->format('H:i'));
}
}
?>
@ -93,7 +109,8 @@ new class extends Component {
<div class="mb-4">
<flux:callout variant="success" icon="check-circle" heading=" {{ session('message') }}">
<x-slot name="controls">
<flux:button icon="x-mark" variant="ghost" x-on:click="$el.closest('[data-flux-callout]').remove()" />
<flux:button icon="x-mark" variant="ghost"
x-on:click="$el.closest('[data-flux-callout]').remove()"/>
</x-slot>
</flux:callout>
</div>
@ -138,7 +155,7 @@ new class extends Component {
</div>
<div class="mb-4">
<flux:checkbox wire:model.live="is_mirror" label="Mirrors Device" />
<flux:checkbox wire:model.live="is_mirror" label="Mirrors Device"/>
</div>
@if($is_mirror)
@ -216,14 +233,27 @@ new class extends Component {
<td class="py-3 px-3 first:pl-0 last:pr-0 text-sm whitespace-nowrap font-medium text-zinc-800 dark:text-white"
>
<div class="flex items-center gap-4">
<flux:button href="{{ route('devices.configure', $device) }}" wire:navigate icon="eye">
<flux:button.group>
<flux:button href="{{ route('devices.configure', $device) }}" wire:navigate icon="eye" iconVariant="outline">
</flux:button>
@if($device->isPauseActive())
<flux:tooltip content="Device paused until: {{ $device->pause_until?->format('H:i') }}">
<flux:button icon="pause-circle"/>
</flux:tooltip>
@else
<flux:modal.trigger name="pause-device-{{ $device->id }}">
<flux:button icon="pause-circle" iconVariant="outline">
</flux:button>
</flux:modal.trigger>
@endif
</flux:button.group>
<flux:tooltip
content="Proxies images from the TRMNL Cloud service when no image is set (available in TRMNL DEV Edition only)."
position="bottom">
<flux:switch wire:click="toggleProxyCloud({{ $device->id }})"
:checked="$device->proxy_cloud"
:checked="$device->proxy_cloud"
:disabled="$device->mirror_device_id !== null"
label="☁️ Proxy"/>
</flux:tooltip>
@ -238,4 +268,34 @@ new class extends Component {
</div>
</div>
@foreach ($devices as $device)
<flux:modal name="pause-device-{{ $device->id }}">
<div class="space-y-6">
<div>
<flux:heading size="lg">Pause</flux:heading>
<div class="text-sm text-zinc-500 mt-2">Select how long to pause screen generation for <span
class="font-semibold">{{ $device->name }}</span>.
</div>
</div>
<form wire:submit="pauseDevice({{ $device->id }})">
<div class="mb-4">
<flux:radio.group wire:model.live="pause_duration" label="Pause Duration" variant="segmented">
<flux:radio value="30" label="30 min"/>
<flux:radio value="60" label="60 min"/>
<flux:radio value="120" label="120 min"/>
<flux:radio value="240" label="240 min"/>
<flux:radio value="480" label="480 min"/>
</flux:radio.group>
</div>
<div class="flex">
<flux:spacer/>
<flux:modal.close>
<flux:button variant="ghost">Cancel</flux:button>
</flux:modal.close>
<flux:button type="submit" variant="primary">Save</flux:button>
</div>
</form>
</div>
</flux:modal>
@endforeach
</div>

View file

@ -77,7 +77,7 @@ new class extends Component {
<div class="mt-6">
<p>
<flux:badge>GET</flux:badge>
<flux:badge>GET</flux:badge><flux:badge>POST</flux:badge>
<span class="ml-2 font-mono">{{ route('display.status') }}?device_id={{ $selected_device }}</span>
</p>
<div class="mt-4">
@ -88,6 +88,14 @@ new class extends Component {
</flux:button>
</div>
</div>
<div class="mt-4">
<h3 class="text-lg">Body <flux:badge size="sm">POST</flux:badge></h3>
<div class="font-mono">
<pre>
{&#x22;default_refresh_interval&#x22;: 900, &#x22;sleep_mode_enabled&#x22;: true, &#x22;pause_until&#x22;: &#x22;2025-07-10T22:00:00+02:00&#x22;}
</pre>
</div>
</div>
</div>
</div>
</div>