Baronsindo / crudstarter

Laravel Package for crud generation

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

crudstarter_small

Crud and API Generator Package

Stars Issues License Packagist Downloads

Package which lets you automate tedious CRUD Operations.

Requirements

Laravel Version: >= 8.0
PHP Version: >= 7.3
Composer: >= 2.0

Installation

composer require niraj/crudstarter --dev

Optional (If you want to edit stub files)

php artisan vendor:publish --tag=crud-stub

Generate Dashboard (One time command)

php artisan gen:dashboard

Package Usage

Basic Usage

  • To generate CRUD

php artisan gen:crud {ModelName} --fields="fieldName:dataType fieldName:dataType"

  • To generate API

php artisan gen:api {ModelName} --fields="fieldName:dataType fieldName:dataType

  • To delete CRUD Files

php artisan del:crud {ModelName}

  • To delete API Files

php artisan del:api {ModelName}

Example: To generate Post CRUD php artisan gen:crud Post --fields="name:str slug:str description:text image:str status:bool"

Adding Fields

You can add fields in gen commands which auto fills model, migration, request and api resources

To add fields we use --fields="field_name1:data_type1{space}field_name2:data_type2"

Example: To generate Post CRUD with fields

php artisan gen:crud Post --fields="name:str description:text count:int by_admin:bool is_published:select:options=published,pending"

Note: Please run auto-alignment (code-formatting) command in your ide/text-editor in generated blade files [eg: Ctrl+Alt+Shift+L in phpstorm].

Adding Relationships

to add this functionality simply add --relations="your code here" in gen command

Example: To generate Profile CRUD with relations (hasOne: Account, hasMany: Blogs and belongTo: User)

php artisan gen:crud Profile --fields="name:str user_id:fid" --relations="haso:account hasm:blogs belt:user"

Relation Name Short Hand For
haso hasOne
hasm hasMany
belt belongsTo
belm belongsToMany

Note: you can use hasMany, belongsTo etc directly in --relations command if you feel comfortable and it currently only supports these 4 common relations type.

Adding Soft-Deleting fuctionality

to add this functionality simply add --softDelete in gen command

Example: To generate Post CRUD with soft deletes

php artisan gen:crud Post --fields="name:str description:text" --softDelete

Field Data Type

some short hands for convenience are provided i.e instead of unsignedInteger we can use uint instead while defining fields

Data type Name Short Hand For
inc increments
int integer
uint unsignedInteger
tinyint tinyInteger
utinyint unsignedTinyInteger
smallint smallInteger
usmallint unsignedSmallInteger
mediumint mediumInteger
umediumint unsignedMediumInteger
bigint bigInteger
ubigint unsignedBigInteger
txt text
tinytext tinyText
mediumtext mediumText
longtext longText
bool boolean
fid foreignId

Note: For other data types like date, enum, decimal, uuid etc can typed as it is.

What will be generated !

  • CRUD

    -[ Model, Controller, Blade Files, Request, Migration ] with Feature Test Skeleton!

  • API

    -[ ApiController, ApiRequest, ApiResource ] with Feature Test Skeleton!

Note: Model, Factory, Migration can be also generated for API if needed.

Customization

  • You can easily customize everything to your need by simply changing stubs files present in crud-stub folder present in resources/crud-stub

Notes

  • You may have to easily customize blade files according to your dashboard template. Which Can be done easily.

  • HAPPY CODING 🤘

About

Laravel Package for crud generation

License:MIT License


Languages

Language:PHP 49.1%Language:Blade 28.3%Language:JavaScript 20.9%Language:CSS 1.8%