arwp / main-master
Automated framework for building CRUD web application
Installs: 116
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 1
Open Issues: 0
Language:JavaScript
Type:project
Requires
- php: ^8.0.2
- guzzlehttp/guzzle: ^7.2
- laravel/framework: ^12.0
- laravel/sanctum: ^4.0
- laravel/tinker: ^2.7
- spatie/laravel-html: ^3.2
- yajra/laravel-datatables-oracle: ^12.0
Requires (Dev)
- fakerphp/faker: ^1.9.1
- laravel/pint: ^1.0
- laravel/sail: ^1.0.1
- mockery/mockery: ^1.4.4
- nunomaduro/collision: ^8.1
- phpunit/phpunit: ^11.0.9
- spatie/laravel-ignition: ^2.0
README
Framework PHP untuk Para Pengrajin Web
Main Master
( Generator CRUD )
Main Master adalah generator CRUD untuk proyek Laravel. Proyek ini dibuat untuk mempermudah para pengembang dalam membangun proyek Laravel. Dibuat menggunakan Laravel 12 dan Bootstrap 5.
Dibuat dengan ❤️ oleh arwp
Persyaratan
- Laravel 12 atau lebih baru
- PHP 8.2 atau lebih baru
- MySQL 5.7 atau database lainnya
- Composer 2.2.* atau lebih baru
Fitur Utama
- Login with authentication (email and password)
- Login API with Sanctum
- CRUD with ajax request
- role and permission management
- Sidebar notification
- Header notification
- Dark Mode
- Create a menu seeder and access the menu using the php artisan
app:convert-menu command
. - Morph File
- Default Menu
- Dashboard
- Menu with sub menu (multi level)
- Role Management
- Access Group
- Level Access
- Access Menu
- Faq
- user management
- Announcement
Cara Instalasi
# Dari Packagist $ composer create-project arwp/main-master {nama-proyek-anda} # ---- ATAU ----- # Clone repositori $ git clone https://github.com/arwahyu01/main-master.git {nama-proyek-anda} $ cd main-master $ composer install $ cp .env.example .env $ php artisan key:generate $ php artisan migrate --seed $ php artisan serve # atau gunakan valet
Fitur untuk Pengembang (MVC Builder):
Install paket ini ke proyek Laravel Anda
composer require arwp/mvc
Jangan lupa untuk mengatur konfigurasi, baca selengkapnya di sini
Skrip Khusus
Untuk Datatables
- Gunakan skrip ini untuk mengirim banyak data ke 'datatable.blade.js'
- Hapus skrip lama dan ganti dengan skrip berikut:
- script lama :
<script src="{{ asset('js/'.$backend.'/'.$page->code.'/datatable.js') }}"></script>
- script baru:
<script type="application/javascript"> fetch("{{ url('/js/'.$backend.'/'.$page->code.'/datatable.js') }}", { method: 'POST', headers: { "X-CSRF-TOKEN": "{{ csrf_token() }}", "Content-Type": "application/json" }, body: JSON.stringify({id: "{{ $id }}"}) }) .then(e => e.text()) .then(r => { Function('"use strict";\n' + r)(); }).catch(e => console.log(e)); </script>
- Gunakan
JSON.stringify({'id': "{{ $id }}",'id2': "{{ $id2 }}"})
untuk mengirim beberapa arguemen kedatatable.blade.js
- Gunakan
JSON.stringify({id: "{{ $id }}"})
untuk satu permintaan - Tambahkan
$id
di filedatatable.blade.js
seperti ini:
$('#datatable').DataTable({ ajax: `{{ url(config('master.app.url.backend').'/'.$url.'/data?id='${id}') }}`, });
Berikut contoh penjelasan yang bisa kamu gunakan dalam file README.md
untuk menjelaskan mekanisme sub-sub menu dinamis dengan ID induk di Laravel:
📚 Sub-Sub Menu Dinamis (Dengan ID Induk)
Dalam implementasi sub-menu atau sub-sub menu yang membutuhkan hubungan dengan data induk (misalnya kategori, parent item, dsb), mekanisme berikut digunakan agar proses penambahan data (create
) tetap mengetahui ID dari entitas induknya.
🔗 Alur Umum:
- Controller induk meneruskan
id
data induk ke halaman sub-menu. - View sub-menu (
index.blade.php
) menampilkan tombol "Tambah" yang menyisipkanid
ke URL. - Controller sub-menu mengambil
id
dariRequest
dan menggunakannya untuk menyiapkan halamancreate
.
🧩 Implementasi
1. Kirimkan ID dari controller induk:
return view('sub_menu.index', compact('id', 'page', 'user'));
2. Sesuaikan tombol Tambah di index.blade.php
pada sub-menu:
@if($user->create) <button type="button" class="btn-action pull-right btn btn-success btn-sm" data-title="Tambah" data-id="{{ $id }}" data-url="{{ $page->url.'/create?id='.$id }}"> <span class="fa fa-plus-circle"></span> Tambah </button> @endif
⚠️ Catatan: Atribut
data-action="create"
tidak lagi digunakan, jadi hapus jika masih ada.
3. Tangani ID di controller sub-menu:
public function create(Request $request) { $id = $request->input('id'); $page = Page::where('id', $id)->first(); $user = Auth::user(); return view($page->url.'.create', compact('page', 'user')); }
4. Sertakan id
di form create.blade.php
:
<input type="hidden" name="parent_id" value="{{ request('id') }}">
Dengan pendekatan ini, halaman sub-menu tetap mengetahui data induknya dan hubungan antar data dapat terjaga secara dinamis.
Lisensi
- Paket MVC Builder: Paket ini tidak memiliki lisensi, dan bebas digunakan untuk proyek pribadi.
- Template Eduadmin: Template Eduadmin yang digunakan untuk tampilan dalam paket ini tidak gratis. Anda perlu membeli lisensinya untuk penggunaan komersial dari sini.
- Hak Cipta dan Atribusi: Mohon hormati hak cipta dari paket dan kontributornya. Jangan menghapus kredit yang ada di dalam file.
Semoga Main Master ini mempercepat dan mempermudah proses pengembangan proyek Anda. Jika Anda memiliki pertanyaan atau saran, jangan ragu untuk menghubungi saya di Insta atau LinkedIn.