ichie-benjamin / laravel-code-generator
An intelligent code generator for Laravel framework that will save you time! This awesome tool will help you generate resources like views, controllers, routes, migrations, languages and/or form-requests! It is extremely flexible and customizable to cover many on the use cases. It is shipped with cr
Requires
- laravel/framework: >=9
Requires (Dev)
- mockery/mockery: ^1.4
- orchestra/testbench: ~3.0
- phpunit/phpunit: ^10
This package is auto-updated.
Last update: 2024-12-29 03:13:59 UTC
README
Introduction
An intelligent code generator for Laravel framework that will save you time!! This awesome tool will help you generate resources like views, controllers, routes, migrations, languages and/or form-requests! It is extremely flexible and customizable to cover many on the use cases. It is shipped with cross-browsers compatible template, along with a client-side validation to modernize your application.
For full documentation and live demo please visit crestapps.com
**Note: ** The this is fork of CrestApps/laravel-code-generator, all credit should go the creator
Features
- One step installation when using Laravel 10+
- Create very clean, reusable and highly readable code to build on.
- Create full resources using a single command with migration or from existing database.
- Creates full resources for all of the existing tables in the database using one command.
- Create full API-based resources using a single command with migration or from existing database.
- Create beautiful documentation for your API.
- Create api-resource and api-resource-collection with Laravel 5.5+.
- Allows you to save the fields in a JSON file and recreate resources when the business needs changes.
- Utilizes JSON based resource-file to allow you to define your resources. Resource-file allows you to easily regenerate the resource at any time even when the business rules change.
- Create standard CRUD controllers with simple or form-request validation.
- Customizable view’s templates to enable you to change the standard look and feel of your application.
- Create model with relations.
- Create named routes with and without group.
- Create standard CRUD views.
- Smart migration engine! Keeps track of all generated migrations to only create the needed migration.
- Intelligent enough to automatically handles the relations between the models.
- Very flexible and rich with configurable options.
- Easy commands to create resource-file; additionally, add or reduce existing resource-file.
- Full capability to generate multi-languages applications.
- Client-side validation.
- File uploading handling.
- Auto store multiple-response in the database.
- Create form-request to clean up your controller and increase your code reusability.
- Create view's layouts with and without client-side validation.
- Change the template at run time to generate different views.
- Ability to generate views with and without Laravel-Collective.
- Nicely handles any date, time or datetime field.
- Auto handles any boolean field.
- Very easy to use with lots of documentation.
Installation
-
To download this package into your laravel project, use the command-line to execute the following command
composer require ichie-benjamin/laravel-code-generator
A layout is required for the default views! The code generator allows you to create a layout using the command-line. Of cource you can use your own layout. You'll only need to include CSS bootstrap framework in your layout for the default templates to work properly. Additionally, you can chose to you design your own templetes using a different or no css framework.
Lessons
Checkout our channel on YouTube.com
Available Commands
The command in between the square brackets [] must be replaced with a variable of your choice.
-
Main commands
- php artisan create:scaffold [model-name]
- php artisan create:controller [model-name]
- php artisan create:model [model-name]
- php artisan create:form-request [model-name]
- php artisan create:routes [model-name]
- php artisan create:migration [model-name]
- php artisan create:language [model-name]
- php artisan create:mapped-resources
-
API commands
- php artisan create:api-scaffold [model-name]
- php artisan create:api-controller [model-name]
- php artisan create:api-resources [model-name]
- php artisan api-doc:create-controller [model-name]
- php artisan api-doc:create-view [model-name]
-
Views commands
- php artisan create:layout [application-name]
- php artisan create:views [model-name]
- php artisan create:index-view [model-name]
- php artisan create:create-view [model-name]
- php artisan create:edit-view [model-name]
- php artisan create:show-view [model-name]
- php artisan create:form-view [model-name]
-
Resource's files commands
- php artisan resource-file:from-database [model-name]
- php artisan resource-file:create [model-name]
- php artisan resource-file:append [model-name]
- php artisan resource-file:reduce [model-name]
- php artisan resource-file:delete [model-name]
-
Migration commands
- php artisan migrate-all
- php artisan migrate:rollback-all
- php artisan migrate:reset-all
- php artisan migrate:refresh-all
- php artisan migrate:status-all
Full documentation available at crestapps.com.
Live demo is available at crestapps.com.
Basic example - CRUD with migration
php artisan resource-file:create AssetCategory --fields=id,name,description,is_active
The above command will create resource-file names
php artisan create:scaffold AssetCategory --with-migration
The above command will create a model , a controller
Basic example - CRUD with migration - Shortcut
php artisan create:scaffold AssetCategory --with-migration --fields=id,name,description,is_active
The above command will create resource-file names first. Then, it will create a model , a controller . This is a short way to issuing both `resource-file:create` and `create:scaffold` in one line
Basic API example - CRUD with migration
php artisan resource-file:create AssetCategory --fields=id,name,description,is_active
The above command will create resource-file names
php artisan create:scaffold AssetCategory --with-migration
The above command will create a model , a controller
Basic example using translations for English and Arabic - with migration
php artisan resource-file:create AssetCategory --fields=id,name,description,is_active --translation-for=en,ar
The above command will create resource-file names
php artisan create:scaffold AssetCategory --with-migration
The above command will create a model , a controller
Basic example with form-request
php artisan resource-file:create AssetCategory --fields=id,name,description,is_active
The above command will create resource-file names
php artisan create:scaffold AssetCategory --with-form-request
The above command will create a model , a controller
Basic example with soft-delete and migration
php artisan resource-file:create AssetCategory --fields=id,name,description,is_active
The above command will create resource-file names
php artisan create:scaffold AssetCategory --with-soft-delete --with-migration
The above command will create a model , a controller
Creating resources from existing database
php artisan create:scaffold AssetCategory --table-exists
The above command will create resource-file names . It is going to assume that the table name is called "asset_categories" in your database. If that is not the case, you can use
Then it will create a model , a controller
You may also create a resource-file from existing database separately using
php artisan resource-file:from-database AssetCategory
Creating resources from existing database with translation for English and Arabic
php artisan create:scaffold AssetCategory --translation-for=en,ar --table-exists
The above command will create resource-file names
Then it will create a model , a controller
You may also create a resource-file from existing database separately using
php artisan resource-file:from-database AssetCategory --translation-for=en,ar
Creating resources from existing database with translation for English and Arabic in two step for better control over the fields!
php artisan resource-file:from-database AssetCategory --translation-for=en,ar
php artisan create:scaffold AssetCategory
The above command will create resource-file names
Then it will create a model , a controller
License
"Laravel Code Generator" is an open-sourced software licensed under the MIT license