Move refresh to compact icon button in header row

Refresh is now a ghost icon-only button next to the title instead of
a full-width outlined button. Create button text hidden on mobile
(icon-only). Saves vertical space on small screens.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Padreug 2026-04-20 08:00:01 +02:00
commit 63c20e39ae

View file

@ -60,24 +60,21 @@ function handleRefresh() {
<template> <template>
<div class="container mx-auto py-6 px-4"> <div class="container mx-auto py-6 px-4">
<!-- Page header --> <!-- Page header -->
<div class="flex flex-col sm:flex-row sm:justify-between sm:items-center gap-4 mb-6"> <div class="flex items-center justify-between mb-4">
<div class="space-y-1">
<h1 class="text-2xl sm:text-3xl font-bold text-foreground"> <h1 class="text-2xl sm:text-3xl font-bold text-foreground">
{{ t('activities.title') }} {{ t('activities.title') }}
</h1> </h1>
</div> <div class="flex items-center gap-2">
<div class="flex gap-2 sm:flex-shrink-0">
<Button <Button
v-if="isAuthenticated" v-if="isAuthenticated"
size="sm" size="sm"
@click="showCreateDialog = true" @click="showCreateDialog = true"
> >
<Plus class="w-4 h-4 mr-1.5" /> <Plus class="w-4 h-4 mr-1.5" />
{{ t('activities.createNew') }} <span class="hidden sm:inline">{{ t('activities.createNew') }}</span>
</Button> </Button>
<Button variant="outline" size="sm" @click="handleRefresh" :disabled="isLoading"> <Button variant="ghost" size="icon" class="h-8 w-8" @click="handleRefresh" :disabled="isLoading">
<RefreshCw class="w-4 h-4 mr-1.5" :class="{ 'animate-spin': isLoading }" /> <RefreshCw class="w-4 h-4" :class="{ 'animate-spin': isLoading }" />
Refresh
</Button> </Button>
</div> </div>
</div> </div>