TIF_NGANJUK_E41220778/resources/views/admin/buku/create.blade.php

136 lines
9.5 KiB
PHP

<x-app-layout>
@section('page-title', $pageTitle)
<div class="d-flex align-items-center mb-4">
<a href="{{ route('admin.buku.index') }}" class="btn btn-outline-secondary me-3">
<i class="bi bi-arrow-left"></i>
</a>
<h3 class="my-0 fw-bold">Formulir Tambah Buku</h3>
</div>
<div class="row justify-content-center">
<div class="col-md-11">
<div class="card border-0 shadow-sm">
<div class="card-body p-4">
<div class="card-body">
<form action="{{ route('admin.buku.store') }}" method="POST" enctype="multipart/form-data">
@csrf
<div class="row">
<div class="col-md-8">
<div class="mb-3">
<label for="judul" class="form-label">Judul Buku <span class="text-danger">*</span></label>
<input type="text" name="judul" class="form-control @error('judul') is-invalid @enderror" id="judul"
placeholder="Masukkan judul buku" value="{{ old('judul') }}" maxlength="50">
@error('judul')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="mb-3">
<label for="penulis" class="form-label">Penulis <span class="text-danger">*</span></label>
<input type="text" name="penulis" class="form-control @error('penulis') is-invalid @enderror" id="penulis"
placeholder="Masukkan nama penulis" value="{{ old('penulis') }}" maxlength="50" pattern="[a-zA-Z\s.,'\']+">
@error('penulis')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="row">
<div class="col-md-3 mb-3">
<label for="category_id" class="form-label">Kategori <span class="text-danger">*</span></label>
<select name="category_id" class="form-select @error('category_id') is-invalid @enderror" id="category_id">
<option value="" disabled selected>Pilih Kategori</option>
@foreach($categories as $category)
<option value="{{ $category->id }}" {{ old('category_id') == $category->id ? 'selected' : '' }}>{{ $category->name }}</option>
@endforeach
</select>
@error('category_id')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="col-md-3 mb-3">
<label for="tahun" class="form-label">Tahun Terbit <span class="text-danger">*</span></label>
<select name="tahun" class="form-select @error('tahun') is-invalid @enderror" id="tahun">
<option value="" disabled selected>Pilih Tahun</option>
@for ($year = date('Y') + 1; $year >= 1500; $year--)
<option value="{{ $year }}" {{ old('tahun') == $year ? 'selected' : '' }}>{{ $year }}</option>
@endfor
</select>
@error('tahun')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="col-md-3 mb-3">
<label for="kode_buku" class="form-label">Kode Buku</label>
<input type="text" name="kode_buku" class="form-control @error('kode_buku') is-invalid @enderror" id="kode_buku"
value="{{ old('kode_buku') }}" placeholder="Contoh: 330" maxlength="10"
inputmode="numeric" oninput="this.value = this.value.replace(/[^0-9]/g, '')">
@error('kode_buku')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="col-md-3 mb-3">
<label for="stok" class="form-label">Stok <span class="text-danger">*</span></label>
<input type="number" name="stok" class="form-control @error('stok') is-invalid @enderror" id="stok"
value="{{ old('stok', 1) }}" min="0" max="99" oninput="if(this.value.length > 2) this.value = this.value.slice(0, 2); this.value = this.value.replace(/[^0-9]/g, '')">
@error('stok')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
</div>
</div>
{{-- TIPE AKSES --}}
<div class="mb-3">
<label class="form-label">Tipe Akses</label>
<div class="d-flex gap-3">
<div class="form-check">
<input class="form-check-input @error('tipe_akses') is-invalid @enderror" type="checkbox" name="tipe_akses[]" value="offline" id="tipe_offline" {{ is_array(old('tipe_akses')) && in_array('offline', old('tipe_akses')) ? 'checked' : '' }}>
<label class="form-check-label" for="tipe_offline">Peminjaman
Offline</label>
</div>
<div class="form-check">
<input class="form-check-input @error('tipe_akses') is-invalid @enderror" type="checkbox" name="tipe_akses[]" value="online" id="tipe_online" {{ is_array(old('tipe_akses')) && in_array('online', old('tipe_akses')) ? 'checked' : '' }}>
<label class="form-check-label" for="tipe_online">Baca Online</label>
</div>
</div>
@error('tipe_akses')
<div class="text-danger small mt-1">{{ $message }}</div>
@enderror
</div>
<div class="col-md-4">
<div class="mb-3">
<label for="cover" class="form-label">Cover Buku</label>
<input type="file" name="cover" class="form-control @error('cover') is-invalid @enderror" id="cover" accept="image/*">
@error('cover')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
<div class="mb-3">
<label for="file_pdf" class="form-label">File PDF (untuk buku online)</label>
<input type="file" name="file_pdf" class="form-control @error('file_pdf') is-invalid @enderror" id="file_pdf" accept=".pdf">
@error('file_pdf')
<div class="invalid-feedback">{{ $message }}</div>
@enderror
</div>
</div>
</div>
</div>
<hr class="my-4">
<div class="d-flex justify-content-end">
<button type="submit" class="btn btn-primary px-4 fw-bold">
<i class="bi bi-save me-2"></i>Simpan Buku
</button>
</div>
</form>
</div>
</div>
</div>
</div>
@push('scripts')
<script>
document.addEventListener('DOMContentLoaded', function() {
// Script removed to allow standard server-side validation
});
</script>
@endpush
</x-app-layout>