ahmed-aliraqi / crud-generator
This package is a useful tool to generate simple crud for laravel-modules/scaffolding
Installs: 4 589
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 0
Open Issues: 1
Requires
- php: >=8.0
- illuminate/console: >=9.0
- illuminate/support: >=9.0
README
Introduction
This package is a useful tool to generate simple crud for laravel-modules/scaffolding
the files that will be generated is:
- Lang Files (ar & en)
- Breadcrumb File
- View Files
- Api Resource Files
- Migration Files
- Factory File
- Policy Files
- Controller Files
- Model Files
- Request Files
- Filter Files
- Test Files
Installation
composer require ahmed-aliraqi/crud-generator --dev
Configuration
You should add config file using the following command to configure the supported resources.
php artisan vendor:publish --provider="AhmedAliraqi\CrudGenerator\CrudServiceProvider"
Then add the following comment line in the routes/dashboard.php
and routes/api.php
files:
/* The routes of generated crud will set here: Don't remove this line */
And the follwing comment line in the resources/views/layouts/sidebar.blade.php
file:
{{-- The sidebar of generated crud will set here: Don't remove this line --}}
Usage
For example if you want to generate a new CRUD named category
. make sure it's arabic words was defined in arabicWords
of config file and then use the following artisan
command:
php artisan make:crud category
Use translatable
option if the CRUD is translatable:
php artisan make:crud category --translatable
Use has-media
option if the CRUD has media:
php artisan make:crud category --has-media
Also you can use both options together to generate translatable and has media CRUD.
php artisan make:crud category --translatable --has-media
Account Type Cloner
php artisan account:clone customer merchant
This command will clone
customer
account type to another type namedmerchant
,
Some files should be modified manually like:
- add constant for the newly generated type in
app/Models/User.php
/** * The code of merchant type. * * @var string */ const MERCHANT_TYPE = 'merchant';
Then register the type in childTypes
array:
/** * @var array */ protected $childTypes = [ // other types ... self::MERCHANT_TYPE => Merchant::class, ];
- Add check for type helper in
app/Models/Helpers/UserHelper.php
:
/** * Determine whether the user type is merchant. * * @return bool */ public function isMerchant() { return $this->type == User::MERCHANT_TYPE; }
- Add seeders in
database/seeders/UserSeeder.php
:
Merchant::factory()->count(10)->create();
- Add translation lang file name to
config/lang-generator.php
'lang' => [ // ... 'merchants' => base_path('lang/{lang}/merchants.php'), /* The lang of generated crud will set here: Don't remove this line */ ],
- Update arabic translations in lang file for generated type
lang/ar/merchants.php
- Add type translated key into
lang/{lang}/users.php
:
'types' => [ // Other types ... 'merchant' => 'Merchant', ],
- Clone view files in dashboard from
customer
directory tomerchant
and replace allcustomer
word tomerchant
Customer
=>Merchant
customers
=>merchants
customer
=>merchant
- Add Sidebar link in
resources/views/dashboard/accounts/sidebar.blade.php
:
[ 'name' => trans('merchants.plural'), 'url' => route('dashboard.merchants.index'), 'can' => ['ability' => 'viewAny', 'model' => \App\Models\Merchant::class], 'active' => request()->routeIs('*merchants*'), ],
- Add the routes for the newly generated type in
routes/dashboard.php
file:
// Merchants Routes. Route::get('trashed/merchants', 'MerchantController@trashed')->name('merchants.trashed'); Route::get('trashed/merchants/{trashed_merchant}', 'MerchantController@showTrashed')->name('merchants.trashed.show'); Route::post('merchants/{trashed_merchant}/restore', 'MerchantController@restore')->name('merchants.restore'); Route::delete('merchants/{trashed_merchant}/forceDelete', 'MerchantController@forceDelete')->name('merchants.forceDelete'); Route::resource('merchants', 'MerchantController');
- Add route binding in
storage/soft_deletes_route_binding.json
:
{ "trashed_merchant": "App\\Models\\Merchant" }
- Add the permision in
storage/permissions.json
:
[
"manage.merchants"
]
- Add
actingAsMerchant
helper intotests/TestCase.php
/** * Set the currently logged in merchant for the application. * * @param null $driver * @return \App\Models\Merchant */ public function actingAsMerchant($driver = null) { $merchant = Merchant::factory()->create(); $this->be($merchant, $driver); return $merchant; }