Script erstellt

This commit is contained in:
Housemann
2025-08-10 18:09:07 +02:00
commit 2a15995cbb
196 changed files with 24790 additions and 0 deletions

View File

@@ -0,0 +1,124 @@
@extends('layouts.app')
@section('title', 'Verfügbare Lacke - NeoNail DB')
@section('content')
<div class="container">
<div class="row mb-4">
<div class="col-md-8">
<h2>
<i class="fas fa-search me-2"></i>Verfügbare NeoNail-Lacke
</h2>
<p class="text-muted">Lacke, die Sie noch nicht in Ihrer Sammlung haben</p>
</div>
<div class="col-md-4 text-end">
<div class="d-flex gap-2 justify-content-end">
<a href="{{ route('user-nail-polishes.create') }}" class="btn btn-success">
<i class="fas fa-plus me-2"></i>Neuen Lack hinzufügen
</a>
<a href="{{ route('user-nail-polishes.index') }}" class="btn btn-primary">
<i class="fas fa-palette me-2"></i>Meine Sammlung
</a>
</div>
</div>
</div>
<!-- Info-Box -->
<div class="alert alert-info mb-4">
<i class="fas fa-info-circle me-2"></i>
<strong>Hinweis:</strong> Diese Lacke sind Teil des gemeinsamen Hauptkatalogs und können nicht gelöscht werden.
Sie können sie nur zu Ihrer persönlichen Sammlung hinzufügen oder entfernen.
</div>
<!-- Suchleiste -->
<div class="row mb-4">
<div class="col-md-6">
<form method="GET" action="{{ route('user-nail-polishes.available') }}" class="d-flex">
<input type="text" name="search" class="form-control me-2"
placeholder="Nach Name oder Nummer suchen..."
value="{{ $search }}">
<button type="submit" class="btn btn-outline-primary">
<i class="fas fa-search"></i>
</button>
@if($search)
<a href="{{ route('user-nail-polishes.available') }}" class="btn btn-outline-secondary ms-2">
<i class="fas fa-times"></i>
</a>
@endif
</form>
</div>
<div class="col-md-6 text-end">
<span class="text-muted">
{{ $nailPolishes->total() }} verfügbare Lack{{ $nailPolishes->total() != 1 ? 'e' : '' }}
</span>
</div>
</div>
@if($nailPolishes->count() > 0)
<div class="row">
@foreach($nailPolishes as $nailPolish)
<div class="col-md-3 col-sm-6 mb-4">
<div class="card h-100 nail-polish-card">
@if($nailPolish->image_path)
<img src="{{ Storage::url($nailPolish->image_path) }}"
class="card-img-top nail-polish-image"
alt="{{ $nailPolish->name }}"
loading="lazy">
@else
<div class="card-img-top nail-polish-placeholder d-flex align-items-center justify-content-center">
<i class="fas fa-palette fa-3x text-muted"></i>
</div>
@endif
<div class="card-body d-flex flex-column">
<h6 class="card-title mb-1">{{ $nailPolish->name }}</h6>
<p class="card-text text-muted mb-2">Nr. {{ $nailPolish->number }}</p>
<div class="mt-auto">
<form method="POST" action="{{ route('user-nail-polishes.add', $nailPolish) }}"
class="d-inline">
@csrf
<button type="submit" class="btn btn-success btn-sm w-100">
<i class="fas fa-plus me-2"></i>Zur Sammlung hinzufügen
</button>
</form>
</div>
</div>
</div>
</div>
@endforeach
</div>
<!-- Pagination -->
@if($nailPolishes->hasPages())
<div class="row">
<div class="col-12">
<nav aria-label="Seitennavigation">
{{ $nailPolishes->appends(['search' => $search])->links() }}
</nav>
</div>
</div>
@endif
@else
<div class="text-center py-5">
<i class="fas fa-check-circle fa-4x text-success mb-3"></i>
<h4 class="text-success">Glückwunsch!</h4>
<p class="text-muted mb-4">
@if($search)
Keine verfügbaren Lacke gefunden, die "{{ $search }}" entsprechen.
@else
Sie haben bereits alle verfügbaren NeoNail-Lacke in Ihrer Sammlung!
@endif
</p>
<div class="d-flex gap-2 justify-content-center">
<a href="{{ route('user-nail-polishes.create') }}" class="btn btn-success">
<i class="fas fa-plus me-2"></i>Neuen Lack hinzufügen
</a>
<a href="{{ route('user-nail-polishes.index') }}" class="btn btn-primary">
<i class="fas fa-palette me-2"></i>Meine Sammlung anzeigen
</a>
</div>
</div>
@endif
</div>
@endsection

View File

@@ -0,0 +1,175 @@
@extends('layouts.app')
@section('title', 'Neuen Lack hinzufügen - NeoNail DB')
@section('content')
<div class="row justify-content-center">
<div class="col-md-8">
<div class="card">
<div class="card-header">
<h4 class="mb-0">
<i class="fas fa-plus me-2"></i>Neuen NeoNail-Lack hinzufügen
</h4>
</div>
<div class="card-body">
<div class="alert alert-info">
<i class="fas fa-info-circle me-2"></i>
<strong>Wichtig:</strong> Der neue Lack wird automatisch zum Hauptkatalog hinzugefügt und steht dann allen Benutzern zur Verfügung.
Er wird auch automatisch zu Ihrer Sammlung hinzugefügt.
</div>
@if ($errors->any())
<div class="alert alert-danger">
<ul class="mb-0">
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif
<form method="POST" action="https://neonail.vogt.de.com/create-nail-polish" enctype="multipart/form-data">
@csrf
<div class="row">
<div class="col-md-6">
<div class="mb-3">
<label for="name" class="form-label">Name des Lackes *</label>
<input type="text" class="form-control @error('name') is-invalid @enderror"
id="name" name="name" value="{{ old('name') }}"
placeholder="z.B. Classic Red" required>
@error('name')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
</div>
<div class="col-md-6">
<div class="mb-3">
<label for="number" class="form-label">Nummer des Lackes *</label>
<input type="text" class="form-control @error('number') is-invalid @enderror"
id="number" name="number" value="{{ old('number') }}"
placeholder="z.B. 001" required>
@error('number')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
<div class="mb-3">
<label for="manufacturer_id" class="form-label">Hersteller *</label>
<select class="form-control @error('manufacturer_id') is-invalid @enderror"
id="manufacturer_id" name="manufacturer_id" required>
<option value="">Hersteller auswählen...</option>
@foreach(\App\Models\Manufacturer::orderBy('name')->get() as $manufacturer)
<option value="{{ $manufacturer->id }}" {{ old('manufacturer_id') == $manufacturer->id ? 'selected' : '' }}>
{{ $manufacturer->name }}
</option>
@endforeach
</select>
@error('manufacturer_id')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
<div class="form-text">
<a href="https://neonail.vogt.de.com/manufacturers/create" target="_blank" class="text-decoration-none">
<i class="fas fa-plus"></i> Neuen Hersteller erstellen
</a>
</div>
</div>
</div>
<div class="col-md-6">
<div class="mb-3">
<label for="new_manufacturer" class="form-label">Oder neuen Hersteller erstellen</label>
<input type="text" class="form-control"
id="new_manufacturer" name="new_manufacturer"
placeholder="Name des neuen Herstellers">
<div class="form-text">
Falls der Hersteller noch nicht existiert, können Sie ihn hier erstellen.
</div>
</div>
</div>
</div>
<div class="mb-3">
<label for="image" class="form-label">Bild des Lackes (optional)</label>
<input type="file" class="form-control @error('image') is-invalid @enderror"
id="image" name="image" accept="image/*">
<div class="form-text">
<i class="fas fa-camera me-1"></i>
Sie können ein Bild mit der Handykamera aufnehmen oder eine Datei auswählen.
Maximale Größe: 10MB. Das Bild wird automatisch optimiert.
</div>
@error('image')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="d-flex gap-2">
<button type="submit" class="btn btn-primary flex-fill">
<i class="fas fa-save me-2"></i>Lack erstellen & zur Sammlung hinzufügen
</button>
<a href="{{ route('user-nail-polishes.index') }}" class="btn btn-outline-secondary">
<i class="fas fa-times me-2"></i>Abbrechen
</a>
</div>
</form>
</div>
</div>
<!-- Hinweise -->
<div class="card mt-4">
<div class="card-header">
<h5 class="mb-0">
<i class="fas fa-lightbulb me-2"></i>Hinweise
</h5>
</div>
<div class="card-body">
<ul class="mb-0">
<li>Der Lack wird automatisch zum Hauptkatalog hinzugefügt</li>
<li>Andere Benutzer können den Lack dann zu ihrer Sammlung hinzufügen</li>
<li>Das Bild wird automatisch auf 400x400 Pixel optimiert</li>
<li>Sie können den Lack später in Ihren Einstellungen bearbeiten</li>
<li>Neue Hersteller werden automatisch erstellt und stehen allen zur Verfügung</li>
</ul>
</div>
</div>
</div>
</div>
<script>
document.addEventListener('DOMContentLoaded', function() {
const manufacturerSelect = document.getElementById('manufacturer_id');
const newManufacturerInput = document.getElementById('new_manufacturer');
// Wenn ein Hersteller ausgewählt wird, leere das neue Hersteller Feld
manufacturerSelect.addEventListener('change', function() {
if (this.value) {
newManufacturerInput.value = '';
newManufacturerInput.disabled = true;
} else {
newManufacturerInput.disabled = false;
}
});
// Wenn ein neuer Hersteller eingegeben wird, leere die Auswahl
newManufacturerInput.addEventListener('input', function() {
if (this.value.trim()) {
manufacturerSelect.value = '';
manufacturerSelect.disabled = true;
} else {
manufacturerSelect.disabled = false;
}
});
// Initial state
if (newManufacturerInput.value.trim()) {
manufacturerSelect.disabled = true;
}
if (manufacturerSelect.value) {
newManufacturerInput.disabled = true;
}
});
</script>
@endsection

View File

@@ -0,0 +1,123 @@
@extends('layouts.app')
@section('title', 'Meine Sammlung - NeoNail DB')
@section('content')
<div class="container">
<div class="row mb-4">
<div class="col-md-8">
<h2>
<i class="fas fa-palette me-2"></i>Meine NeoNail-Sammlung
</h2>
<p class="text-muted">Verwalten Sie Ihre persönliche Nagellack-Sammlung</p>
</div>
<div class="col-md-4 text-end">
<div class="d-flex gap-2 justify-content-end">
<a href="{{ route('user-nail-polishes.create') }}" class="btn btn-success">
<i class="fas fa-plus me-2"></i>Neuen Lack hinzufügen
</a>
<a href="{{ route('user-nail-polishes.available') }}" class="btn btn-primary">
<i class="fas fa-search me-2"></i>Verfügbare Lacke
</a>
</div>
</div>
</div>
<!-- Suchleiste -->
<div class="row mb-4">
<div class="col-md-6">
<form method="GET" action="{{ route('user-nail-polishes.index') }}" class="d-flex">
<input type="text" name="search" class="form-control me-2"
placeholder="Nach Name oder Nummer suchen..."
value="{{ $search }}">
<button type="submit" class="btn btn-outline-primary">
<i class="fas fa-search"></i>
</button>
@if($search)
<a href="{{ route('user-nail-polishes.index') }}" class="btn btn-outline-secondary ms-2">
<i class="fas fa-times"></i>
</a>
@endif
</form>
</div>
<div class="col-md-6 text-end">
<span class="text-muted">
{{ $nailPolishes->total() }} Lack{{ $nailPolishes->total() != 1 ? 'e' : '' }} in Ihrer Sammlung
</span>
</div>
</div>
@if($nailPolishes->count() > 0)
<div class="row">
@foreach($nailPolishes as $nailPolish)
<div class="col-md-3 col-sm-6 mb-4">
<div class="card h-100 nail-polish-card">
@if($nailPolish->image_path)
<img src="{{ Storage::url($nailPolish->image_path) }}"
class="card-img-top nail-polish-image"
alt="{{ $nailPolish->name }}"
loading="lazy">
@else
<div class="card-img-top nail-polish-placeholder d-flex align-items-center justify-content-center">
<i class="fas fa-palette fa-3x text-muted"></i>
</div>
@endif
<div class="card-body d-flex flex-column">
<h6 class="card-title mb-1">{{ $nailPolish->name }}</h6>
<p class="card-text text-muted mb-2">Nr. {{ $nailPolish->number }}</p>
@if($nailPolish->manufacturer)
<p class="card-text text-muted mb-2">
<small><i class="fas fa-industry"></i> {{ $nailPolish->manufacturer->name }}</small>
</p>
@endif
<div class="mt-auto">
<form method="POST" action="https://neonail.vogt.de.com/remove-from-collection/{{ $nailPolish->id }}"
class="d-inline"
onsubmit="return confirm('Möchten Sie diesen Lack wirklich aus Ihrer Sammlung entfernen?')">
@csrf
<button type="submit" class="btn btn-outline-danger btn-sm w-100">
<i class="fas fa-trash me-2"></i>Entfernen
</button>
</form>
</div>
</div>
</div>
</div>
@endforeach
</div>
<!-- Pagination -->
@if($nailPolishes->hasPages())
<div class="row">
<div class="col-12">
<nav aria-label="Seitennavigation">
{{ $nailPolishes->appends(['search' => $search])->links() }}
</nav>
</div>
</div>
@endif
@else
<div class="text-center py-5">
<i class="fas fa-palette fa-4x text-muted mb-3"></i>
<h4 class="text-muted">Ihre Sammlung ist noch leer</h4>
<p class="text-muted mb-4">
@if($search)
Keine Lacke gefunden, die "{{ $search }}" entsprechen.
@else
Fügen Sie Ihren ersten NeoNail-Lack hinzu!
@endif
</p>
<div class="d-flex gap-2 justify-content-center">
<a href="{{ route('user-nail-polishes.create') }}" class="btn btn-success">
<i class="fas fa-plus me-2"></i>Ersten Lack hinzufügen
</a>
<a href="{{ route('user-nail-polishes.available') }}" class="btn btn-primary">
<i class="fas fa-search me-2"></i>Verfügbare Lacke durchsuchen
</a>
</div>
</div>
@endif
</div>
@endsection

View File

@@ -0,0 +1,70 @@
@extends('layouts.app')
@section('title', 'Sammlung von ' . $user->name . ' - NeoNail DB')
@section('content')
<div class="row">
<div class="col-12">
<div class="d-flex justify-content-between align-items-center mb-4">
<h1 class="h3 mb-0">
<i class="fas fa-palette me-2"></i>Sammlung von {{ $user->name }}
</h1>
<a href="{{ route('admin.users.index') }}" class="btn btn-outline-primary">
<i class="fas fa-arrow-left me-2"></i>Zurück zur Benutzerliste
</a>
</div>
<!-- Benutzer-Info -->
<div class="card mb-4">
<div class="card-body">
<div class="row align-items-center">
<div class="col-md-8">
<div class="d-flex align-items-center">
<i class="fas fa-user-circle fa-3x text-primary me-3"></i>
<div>
<h4 class="mb-1">{{ $user->name }}</h4>
<p class="text-muted mb-0">{{ $user->email }}</p>
<small class="text-muted">Registriert am {{ $user->created_at->format('d.m.Y') }}</small>
</div>
</div>
</div>
<div class="col-md-4 text-end">
<div class="h2 text-primary mb-0">{{ $nailPolishes->count() }}</div>
<p class="text-muted mb-0">Nagellacke in der Sammlung</p>
</div>
</div>
</div>
</div>
<!-- Sammlung -->
@if($nailPolishes->count() > 0)
<div class="row">
@foreach($nailPolishes as $nailPolish)
<div class="col-6 col-md-4 col-lg-3 mb-4">
<div class="card nail-polish-card h-100">
@if($nailPolish->image_path)
<img src="{{ Storage::url($nailPolish->image_path) }}"
class="nail-polish-image" alt="{{ $nailPolish->name }}">
@else
<div class="nail-polish-image d-flex align-items-center justify-content-center bg-light">
<i class="fas fa-image fa-3x text-muted"></i>
</div>
@endif
<div class="card-body">
<h6 class="card-title fw-bold">{{ $nailPolish->name }}</h6>
<p class="card-text text-muted small">Nr. {{ $nailPolish->number }}</p>
</div>
</div>
</div>
@endforeach
</div>
@else
<div class="text-center py-5">
<i class="fas fa-palette fa-4x text-muted mb-3"></i>
<h4 class="text-muted">Keine Nagellacke in der Sammlung</h4>
<p class="text-muted">{{ $user->name }} hat noch keine NeoNail-Lacke hinzugefügt.</p>
</div>
@endif
</div>
</div>
@endsection