Menambahkan fitur manajemen referensi link lengkap dengan CRUD, import/export Excel, serta melakukan perbaikan pada modul Bank Data untuk menampilkan semua data. ## Perubahan Detail ### 🔗 Fitur Referensi Link (Baru) **Model & Database:** - Membuat model `ReferensiLink` dengan relasi ke user (created_by, updated_by) - Membuat migration `create_referensi_link_table` dengan struktur lengkap - Menambahkan scopes untuk filtering dan searching **Controller & Request:** - Membuat `ReferensiLinkController` dengan fitur lengkap (CRUD, datatable, export/import) - Membuat `ReferensiLinkRequest` dengan validasi comprehensive - Menambahkan fitur toggle status aktif/inaktif **Export/Import:** - Membuat `ReferensiLinkExport` untuk export ke Excel dengan styling - Membuat `ReferensiLinkImport` untuk import dari Excel dengan validasi - Menambahkan template download untuk import **View & Navigation:** - Menambahkan menu "Referensi Link" di navigasi sistem - Membuat struktur role access untuk administrator dan admin ### 📊 Perbaikan Bank Data **Controller:** - Menambahkan fitur "show_all" untuk menampilkan semua data tanpa pagination - Memperbaiki Log facade import dari `Log` menjadi `Illuminate\Support\Facades\Log` - Menambahkan loading overlay untuk UX yang lebih baik **View:** - Menambahkan checkbox "Tampilkan Semua Data" di filter - Memperbaiki styling dan layout tabel - Menambahkan loading spinner saat filter diterapkan ### 🛠️ Helper & Utilitas **PdfHelper (Baru):** - Membuat helper untuk format teks PDF dengan handling karakter spesial - Menambahkan fungsi untuk konversi simbol matematika ke teks - Memastikan encoding UTF-8 yang proper **ImageController (Baru):** - Membuat controller untuk resize gambar dengan parameter width dan quality - Menggunakan ImageResizeService untuk processing gambar ### 🔧 Perbaikan Lainnya **View Components:** - Memperbaiki syntax HTML dan Blade template - Menambahkan role checking yang lebih proper - Memperbaiki format tampilan nilai menggunakan formatRupiah() ### 📁 File Baru - `Helpers/PdfHelper.php` - Helper untuk format PDF - `Http/Controllers/ImageController.php` - Controller untuk image resize - `Http/Controllers/ReferensiLinkController.php` - Controller referensi link - `Http/Requests/ReferensiLinkRequest.php` - Validasi referensi link - `Exports/ReferensiLinkExport.php` - Export Excel - `Imports/ReferensiLinkImport.php` - Import Excel - `Models/ReferensiLink.php` - Model referensi link - Database migration untuk tabel referensi_link ### 🔄 File Diperbarui - `module.json` - Menambahkan menu navigasi - `BankDataController.php` - Fitur show_all dan perbaikan Log - `resources/views/bank-data/index.blade.php` - UI improvements - Beberapa view components untuk perbaikan syntax dan role checking ## Alasan Perubahan 1. **Fitur Referensi Link**: Menyediakan manajemen link referensi yang terstruktur untuk kebutuhan dokumentasi dan regulasi 2. **Import/Export**: Memudahkan pengelolaan data referensi dalam jumlah besar via Excel 3. **Show All Data**: Memenuhi kebutuhan menampilkan semua data bank data di peta tanpa pagination 4. **PDF Helper**: Menangani masalah karakter spesial dalam generate PDF 5. **Image Controller**: Menyediakan endpoint untuk resize gambar secara dinamis
114 lines
3.2 KiB
PHP
114 lines
3.2 KiB
PHP
<?php
|
|
|
|
namespace Modules\Lpj\Http\Requests;
|
|
|
|
use Illuminate\Foundation\Http\FormRequest;
|
|
|
|
class ReferensiLinkRequest extends FormRequest
|
|
{
|
|
/**
|
|
* Get the validation rules that apply to the request.
|
|
*
|
|
* @return array<string, mixed>
|
|
*/
|
|
public function rules(): array
|
|
{
|
|
$rules = [
|
|
'name' => 'required|string|max:255',
|
|
'link' => 'required|string|max:500',
|
|
'kategori' => 'nullable|string|max:100',
|
|
'deskripsi' => 'nullable|string|max:2000',
|
|
'is_active' => 'boolean',
|
|
'urutan' => 'nullable|integer|min:0',
|
|
];
|
|
|
|
// Validasi tambahan untuk link
|
|
$rules['link'] .= '|url';
|
|
|
|
return $rules;
|
|
}
|
|
|
|
/**
|
|
* Determine if the user is authorized to make this request.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function authorize(): bool
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Get custom messages for validator errors.
|
|
*
|
|
* @return array<string, string>
|
|
*/
|
|
public function messages(): array
|
|
{
|
|
return [
|
|
'name.required' => 'Nama referensi link wajib diisi',
|
|
'name.string' => 'Nama referensi link harus berupa teks',
|
|
'name.max' => 'Nama referensi link maksimal 255 karakter',
|
|
'link.required' => 'Link wajib diisi',
|
|
'link.string' => 'Link harus berupa teks',
|
|
'link.max' => 'Link maksimal 500 karakter',
|
|
'link.url' => 'Link harus berupa URL yang valid',
|
|
'kategori.string' => 'Kategori harus berupa teks',
|
|
'kategori.max' => 'Kategori maksimal 100 karakter',
|
|
'deskripsi.string' => 'Deskripsi harus berupa teks',
|
|
'deskripsi.max' => 'Deskripsi maksimal 2000 karakter',
|
|
'is_active.boolean' => 'Status aktif harus berupa ya/tidak',
|
|
'urutan.integer' => 'Urutan harus berupa angka',
|
|
'urutan.min' => 'Urutan minimal 0',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Get custom attributes for validator errors.
|
|
*
|
|
* @return array<string, string>
|
|
*/
|
|
public function attributes(): array
|
|
{
|
|
return [
|
|
'name' => 'Nama Referensi Link',
|
|
'link' => 'Link',
|
|
'kategori' => 'Kategori',
|
|
'deskripsi' => 'Deskripsi',
|
|
'is_active' => 'Status Aktif',
|
|
'urutan' => 'Urutan',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Prepare the data for validation.
|
|
*
|
|
* @return void
|
|
*/
|
|
protected function prepareForValidation(): void
|
|
{
|
|
// Format link jika belum memiliki protocol
|
|
if ($this->has('link')) {
|
|
$link = $this->input('link');
|
|
if ($link && !preg_match('/^(https?:\/\/)/i', $link)) {
|
|
$this->merge([
|
|
'link' => 'https://' . $link
|
|
]);
|
|
}
|
|
}
|
|
|
|
// Set default is_active jika tidak diset
|
|
if (!$this->has('is_active')) {
|
|
$this->merge([
|
|
'is_active' => true
|
|
]);
|
|
}
|
|
|
|
// Set default urutan jika tidak diset atau 0
|
|
if (!$this->has('urutan') || empty($this->input('urutan'))) {
|
|
$this->merge([
|
|
'urutan' => 0
|
|
]);
|
|
}
|
|
}
|
|
} |