All Projects → nicoaudy → laravelmanthra

nicoaudy / laravelmanthra

Licence: MIT license
Laravel Crud Generator, I have working for years and I can tell you... It's all CRUD 💩💩💩

Programming Languages

PHP
23972 projects - #3 most used programming language
Blade
752 projects

Projects that are alternatives of or similar to laravelmanthra

laravel-crud-generator
Laravel CRUD Generator
Stars: ✭ 181 (+570.37%)
Mutual labels:  laravel-5-package, crud-generator
Lazyblorg
Blogging with Org-mode for very lazy people
Stars: ✭ 226 (+737.04%)
Mutual labels:  lazy
Lazy Vue
A small lazy image loader for Vue
Stars: ✭ 63 (+133.33%)
Mutual labels:  lazy
Lazy Rdp
Script for automatic scanning & brute-force RDP
Stars: ✭ 118 (+337.04%)
Mutual labels:  lazy
Reason Loadable
🔥 Suspense/Lazy for ReasonReact.
Stars: ✭ 88 (+225.93%)
Mutual labels:  lazy
Itiriri
A library built for ES6 iteration protocol.
Stars: ✭ 155 (+474.07%)
Mutual labels:  lazy
Jquery.lazy
A lightweight, fast, feature-rich, powerful and highly configurable delayed content, image and background lazy loading plugin for jQuery & Zepto.
Stars: ✭ 965 (+3474.07%)
Mutual labels:  lazy
two-factor-authentication
Two Factor Authentication for Laravel
Stars: ✭ 21 (-22.22%)
Mutual labels:  laravel-5-package
Vue Cheatsheet
Modified version of the official VueMastery cheatsheet
Stars: ✭ 188 (+596.3%)
Mutual labels:  lazy
Lazyhub
lazyhub - Terminal UI Client for GitHub using gocui.
Stars: ✭ 133 (+392.59%)
Mutual labels:  lazy
Lazy Compile Webpack Plugin
Boost webpack startup time by lazily compiling dynamic imports
Stars: ✭ 106 (+292.59%)
Mutual labels:  lazy
Imlazy
😴 Functional programming with lazy immutable iterables
Stars: ✭ 89 (+229.63%)
Mutual labels:  lazy
Hitchcock
The Master of Suspense 🍿
Stars: ✭ 167 (+518.52%)
Mutual labels:  lazy
Iter
Simple iterator abstract datatype, intended to iterate efficiently on collections while performing some transformations.
Stars: ✭ 71 (+162.96%)
Mutual labels:  lazy
lazy-kit
A new design system for developing with less effort. See how it looks:
Stars: ✭ 68 (+151.85%)
Mutual labels:  lazy
Responsively Lazy
Lazy load responsive images
Stars: ✭ 1,080 (+3900%)
Mutual labels:  lazy
Pimg
📷 Mini Image Lazy Loader for P(R)eact and Vue
Stars: ✭ 97 (+259.26%)
Mutual labels:  lazy
Lazy Collections
Collection of fast and lazy operations
Stars: ✭ 146 (+440.74%)
Mutual labels:  lazy
Friendships
a package for Friendships system
Stars: ✭ 45 (+66.67%)
Mutual labels:  laravel-5-package
jetstream-inertia-generator
Laravel 8 Admin CRUD generator built with Jetstream, Inertia js, Vue 3 and Tailwindcss 2
Stars: ✭ 105 (+288.89%)
Mutual labels:  crud-generator

LaravelManthra

Latest Version on Packagist Total Downloads

screenshot.png manthra.gif

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:

Option Description
--fields Fields name for the form & migration. e.g. --fields="title#string; content#text; category#select#options=technology,tips,health; user_id#integer#unsigned"
--route Include Crud route to routes.php? yes or no
--pk The name of the primary key
--view-path The name of the view path
--controller-namespace The namespace of the controller - sub directories will be created
--model-namespace The namespace that the model will be placed in - directories will be created
--route-group Prefix of the route group
--pagination The amount of models per page for index pages
--indexes The fields to add an index to. append "#unique" to a field name to add a unique index. Create composite fields by separating fieldnames with a pipe (``` --indexes="title,field1
--foreign-keys Any foreign keys for the table. e.g. --foreign-keys="user_id#id#users#cascade" where user_id is the column name, id is the name of the field on the foreign table, users is the name of the foreign table, and cascade is the operation 'ON DELETE' together with 'ON UPDATE'
--validations Validation rules for the form "col_name#rules_set" e.g. ``` "title#min:10
--relationships The relationships for the model. e.g. --relationships="comments#hasMany#App\Comment" in the format
--localize Allow to localize. e.g. localize=yes
--locales Locales language type. e.g. locals=en

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:

Option Description
--crud-name The name of the crud. e.g. --crud-name="post"
--model-name The name of the model. e.g. --model-name="Post"
--model-namespace The namespace of the model. e.g. --model-namespace="Custom\Namespace\Post"
--controller-namespace The namespace of the controller. e.g. --controller-namespace="Http\Controllers\Client"
--view-path The name of the view path
--fields Fields name for the form & migration. e.g. --fields="title#string; content#text; category#select#options=technology,tips,health; user_id#integer#unsigned"
--validations Validation rules for the form "col_name#rules_set" e.g. ``` "title#min:10
--route-group Prefix of the route group
--pagination The amount of models per page for index pages
--force Overwrite already existing controller.

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
  • email
  • 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.

  1. Make sure you've published package's assets.

    php artisan vendor:publish --provider="NicoAudy\LaravelManthra\LaravelManthraServiceProvider"
    
  2. Turn on custom_template support on config/laravelmanthra.php

    'custom_template' => true,
    
  3. From the directory resources/manthra/stubs/ you can modify or customize the stub files.

  4. 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.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].