Admin panel updated with shadcn-vue components

This commit is contained in:
Simon Pocrnjič
2026-01-05 18:27:35 +01:00
parent 70a5d015e0
commit c4d9ecb39e
37 changed files with 5407 additions and 3740 deletions
@@ -1,5 +1,12 @@
<script setup>
import AdminLayout from '@/Layouts/AdminLayout.vue'
import { Link } from '@inertiajs/vue3'
import { Settings2Icon, FileTextIcon, CalendarIcon, AlertTriangleIcon, ListIcon, PencilIcon } from 'lucide-vue-next'
import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@/Components/ui/card'
import { Badge } from '@/Components/ui/badge'
import { Button } from '@/Components/ui/button'
import { Separator } from '@/Components/ui/separator'
const props = defineProps({
config: Object,
})
@@ -7,26 +14,95 @@ const props = defineProps({
<template>
<AdminLayout title="Nastavitve dokumentov">
<h1 class="text-2xl font-semibold mb-4">Nastavitve dokumentov</h1>
<div class="space-y-4">
<div class="p-4 bg-white rounded border">
<h2 class="font-medium mb-2">Privzeti vzorci</h2>
<p class="text-sm text-gray-600">Ime datoteke: <code class="px-1 bg-gray-100 rounded">{{ config.file_name_pattern }}</code></p>
<p class="text-sm text-gray-600">Format datuma: <code class="px-1 bg-gray-100 rounded">{{ config.date_format }}</code></p>
<p class="text-sm text-gray-600">Politika nerešenih: <code class="px-1 bg-gray-100 rounded">{{ config.unresolved_policy }}</code></p>
</div>
<div class="p-4 bg-white rounded border">
<h2 class="font-medium mb-2">Dovoljeni tokeni (whitelist)</h2>
<div v-for="(cols, entity) in config.whitelist" :key="entity" class="mb-3">
<div class="text-sm font-semibold">{{ entity }}</div>
<div class="text-xs text-gray-600" v-if="cols.length">{{ cols.join(', ') }}</div>
<div class="text-xs text-gray-400" v-else>(brez specifičnih stolpcev)</div>
</div>
</div>
<div class="p-4 bg-white rounded border">
<h2 class="font-medium mb-2">Uredi (prihaja)</h2>
<p class="text-xs text-gray-500">Za urejanje bo dodan obrazec. Trenutno spremembe izvedite v <code>config/documents.php</code>.</p>
</div>
<div class="max-w-4xl mx-auto space-y-6">
<Card>
<CardHeader>
<div class="flex items-start justify-between">
<div class="flex items-start gap-3">
<div class="inline-flex items-center justify-center h-10 w-10 rounded-lg bg-primary/10 text-primary">
<Settings2Icon class="h-5 w-5" />
</div>
<div>
<CardTitle>Nastavitve dokumentov</CardTitle>
<CardDescription>
Sistemska konfiguracija za generiranje in upravljanje dokumentov
</CardDescription>
</div>
</div>
<Button size="sm" as-child>
<Link :href="route('admin.document-settings.edit')">
<PencilIcon class="h-4 w-4 mr-2" />
Uredi
</Link>
</Button>
</div>
</CardHeader>
<CardContent class="space-y-6">
<!-- Basic Configuration -->
<div class="space-y-4">
<h3 class="text-sm font-semibold flex items-center gap-2">
<FileTextIcon class="h-4 w-4" />
Privzeti vzorci
</h3>
<div class="grid gap-3">
<div class="flex items-start justify-between p-3 rounded-lg border bg-muted/50">
<div>
<p class="text-sm font-medium">Ime datoteke</p>
<p class="text-xs text-muted-foreground mt-0.5">Vzorec za generiranje imen</p>
</div>
<Badge variant="secondary" class="font-mono text-xs">
{{ config.file_name_pattern }}
</Badge>
</div>
<div class="flex items-start justify-between p-3 rounded-lg border bg-muted/50">
<div>
<p class="text-sm font-medium">Format datuma</p>
<p class="text-xs text-muted-foreground mt-0.5">Privzeto formatiranje datumov</p>
</div>
<Badge variant="secondary" class="font-mono text-xs">
{{ config.date_format }}
</Badge>
</div>
<div class="flex items-start justify-between p-3 rounded-lg border bg-muted/50">
<div>
<p class="text-sm font-medium">Politika nerešenih</p>
<p class="text-xs text-muted-foreground mt-0.5">Vedenje pri nerešenih spremenljivkah</p>
</div>
<Badge variant="secondary" class="font-mono text-xs">
{{ config.unresolved_policy }}
</Badge>
</div>
</div>
</div>
<Separator />
<!-- Whitelist Configuration -->
<div class="space-y-4">
<h3 class="text-sm font-semibold flex items-center gap-2">
<ListIcon class="h-4 w-4" />
Dovoljeni tokeni (whitelist)
</h3>
<div class="grid gap-3">
<Card v-for="(cols, entity) in config.whitelist" :key="entity" class="border-muted">
<CardHeader class="pb-3">
<CardTitle class="text-sm font-mono">{{ entity }}</CardTitle>
</CardHeader>
<CardContent>
<div v-if="cols.length" class="flex flex-wrap gap-1.5">
<Badge v-for="col in cols" :key="col" variant="outline" class="text-xs font-mono">
{{ col }}
</Badge>
</div>
<p v-else class="text-xs text-muted-foreground italic">
(brez specifičnih stolpcev)
</p>
</CardContent>
</Card>
</div>
</div>
</CardContent>
</Card>
</div>
</AdminLayout>
</template>