nicoaudy / laravelmanthra
Laravel Manthra For Lazy Developer
Installs: 1 826
Dependents: 0
Suggesters: 0
Security: 0
Stars: 30
Watchers: 2
Forks: 9
Open Issues: 3
Requires
- php: ^7.0
- laravel/helpers: ^1.1
Requires (Dev)
- mockery/mockery: ^1.1
- orchestra/testbench: ~3.0
- phpunit/phpunit: ~7.0
- sempro/phpunit-pretty-print: ^1.0
- dev-master
- 2.2
- 2.1
- 2.0
- 1.2
- 1.1
- 1.0
- dev-dependabot/composer/symfony/http-kernel-4.4.50
- dev-remove-buy-me-coffee
- dev-enhance/readme-2
- dev-enhance/readme
- dev-add-screenshot-manthra-panel
- dev-select2
- dev-table-colspan
- dev-flash-message
- dev-draggable-fields
- dev-nullable-ability
- dev-separated-api-and-web
- dev-generator-panel
This package is auto-updated.
Last update: 2024-10-30 01:37:27 UTC
README
Installation
Via Composer
$ composer require nicoaudy/laravelmanthra dev-master
Install laravelcollective/html form helper packages for if you haven't installed yet.
$ composer require laravelcollective/html
$ composer dump-autoload
Publish vendor files of this package.
$ php artisan vendor:publish
Generator GUI
If you want to generate using gui, manthra will provide you with generator gui you can view in /manthra
.
You can modified your /manthra
to append middleware with forcing default route to your custom route.
// manthra controller $manthraNamespace = 'NicoAudy\LaravelManthra\Http\Controllers\ManthraController@index'; // your custom route Route::get('/manthra', $manthraNamespace)->middleware('auth');
Commands
Complete (web and api)
Generate crud scaffold web and api you may use this command, for example :
php artisan manthra:complete Cat --fields="name#string;age#integer; type#select#options=persian,maine coon,bengal; is_male#boolean" --view-path=pet --controller-namespace=Pet --route-group=pet --model-namespace=Models
Web
Generate crud scaffold web only you may use this command, for example :
php artisan manthra:web Cat --fields="name#string;age#integer; type#select#options=persian,maine coon,bengal; is_male#boolean" --view-path=pet --controller-namespace=Pet --route-group=pet --model-namespace=Models
Api
Generate crud scaffold api only you may use this command, the difference between web and api just (--view-path=)
flag, for example :
php artisan manthra:api Cat --fields="name#string;age#integer; type#select#options=persian,maine coon,bengal; is_male#boolean" --controller-namespace=Pet --route-group=pet --model-namespace=Models
Options:
Other commands (optional):
For controller:
- Standard Version
php artisan manthra:controller PostsController --crud-name=posts --model-name=Post --view-path="directory" --route-group=admin
- API Version
php artisan manthra:api-controller PostsController --crud-name=posts --model-name=Post --route-group=admin
Controller's Options:
For model:
php artisan manthra:model Post --fillable="['title', 'body']"
For migration:
php artisan manthra:migration posts --schema="title#string; body#text"
For view:
php artisan manthra:view posts --fields="title#string; body#text" --view-path="directory" --route-group=admin
By default, the generator will attempt to append the crud route to your Route
file. If you don't want the route added, you can use this option --route=no
.
After creating all resources, run migrate command. If necessary, include the route for your crud as well.
php artisan migrate
If you chose not to add the crud route in automatically (see above), you will need to include the route manually.
Route::resource('posts', 'PostsController');
Supported Field Types
These fields are supported for migration and view's form:
Form Field Types:
- text
- textarea
- password
- number
- date
- datetime
- time
- radio
- select
- file
Migration Field Types:
- string
- char
- varchar
- date
- datetime
- time
- timestamp
- text
- mediumtext
- longtext
- json
- jsonb
- binary
- integer
- bigint
- mediumint
- tinyint
- smallint
- boolean
- decimal
- double
- float
- enum
Custom Generator's Stub Template
You can customize the generator's stub files/templates to achieve your need.
-
Make sure you've published package's assets.
php artisan vendor:publish --provider="NicoAudy\LaravelManthra\LaravelManthraServiceProvider"
-
Turn on custom_template support on config/laravelmanthra.php
'custom_template' => true,
-
From the directory resources/manthra/stubs/ you can modify or customize the stub files.
-
On config/laravelmanthra.php you can add new stubs and choose which values are passed
Change log
Please see the changelog for more information on what has changed recently.
Contributing
Please see contributing.md for details and a todolist.
Credits
License
license. Please see the license file for more information.