jzpeepz / dynamo
Quickly build admins for your existing Laravel application using real database tables
Installs: 1 645
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 4
Forks: 0
Open Issues: 2
Requires
- doctrine/dbal: ^2.10
- illuminate/support: ^6.0|^7.0|^8.0
- laravelcollective/html: ^6.0
- dev-master
- 1.4.28
- 1.4.27
- 1.4.26
- 1.4.25
- 1.4.24
- 1.4.23
- 1.4.22
- 1.4.21
- 1.4.20
- 1.4.18
- 1.4.17
- 1.4.16
- 1.4.15
- 1.4.14
- 1.4.13
- 1.4.12
- 1.4.11
- 1.4.10
- 1.4.9
- 1.4.8
- 1.4.7
- 1.4.6
- 1.4.5
- 1.4.4
- 1.4.2
- 1.4.1
- 1.4.0
- v1.3.x-dev
- 1.3.50
- 1.3.49
- 1.3.48
- 1.3.47
- 1.3.46
- 1.3.45
- 1.3.44
- 1.3.43
- 1.3.42
- 1.3.41
- 1.3.40
- 1.3.39
- 1.3.35
- 1.3.34
- 1.3.33
- 1.3.32
- 1.3.31
- 1.3.30
- 1.3.29
- 1.3.28
- 1.3.27
- 1.3.26
- 1.3.25
- 1.3.24
- 1.3.23
- 1.3.22
- 1.3.21
- 1.3.20
- 1.3.19
- 1.3.18
- 1.3.17
- 1.3.16
- 1.3.15
- 1.3.14
- 1.3.13
- 1.3.12
- 1.3.11
- 1.3.10
- 1.3.9
- 1.3.8
- 1.3.7
- 1.3.6
- 1.3.5
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.25
- 1.2.24
- 1.2.23
- 1.2.22
- 1.2.21
- 1.2.20
- 1.2.19
- 1.2.18
- 1.2.17
- 1.2.16
- 1.2.15
- 1.2.14
- 1.2.13
- 1.2.12
- 1.2.11
- 1.2.10
- 1.2.9
- 1.2.8
- 1.2.7
- 1.2.6
- 1.2.5
- 1.2.4
- 1.2.3
- 1.2.2
- 1.2.1
- 1.2
- v1.1.x-dev
- 1.1.15
- 1.1.14
- 1.1.13
- 1.1.12
- 1.1.11
- 1.1.10
- 1.1.9
- 1.1.8
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1
- 1.0.28
- 1.0.27
- 1.0.26
- 1.0.25
- 1.0.24
- 1.0.23
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-dependabot/composer/symfony/mime-4.4.1
- dev-dependabot/composer/symfony/http-foundation-4.4.1
- dev-BOOTSTRAP4
- dev-soft-deletes-fix
- dev-categories-feature
- dev-character-counter-feature
- dev-adding_realtionships_between_models
This package is auto-updated.
Last update: 2025-01-11 02:55:54 UTC
README
Install via Composer:
composer require jzpeepz/dynamo
Include the service provider in your config/app.php
:
Jzpeepz\Dynamo\DynamoServiceProvider::class
Publish the Dynamo config file:
php artisan vendor:publish --tag=dynamo
NOTE: If using a local disk for uploading, be sure to symlink it to your public directory and provide the proper path in the config file.
Configuration
storage_disk
Storage disk to use to store uploaded files. Default: 'local'
upload_path
Path within the storage disk to store the uploaded files. This is also the directory within the public directory to which the storage directory is linked. Default: '/uploads/'
route_prefix
Prefix to add to all Dynamo routes. Default: '' (empty string)
layout
Layout to use with Dynamo views. Default: 'layouts.app'
controller_namespace
Namespace for generated controllers. Default: 'App\Http\Controllers'
controller_path
Path for storing generated controllers. Default: app_path('/Http/Controllers')
view_prefix
Prefix for overridden views. Default: 'dynamo'
view_theme
Theme used for views. Default: 'bootstrap4'
target_blade_section
The blade section in templates where views are rendered. Default: 'content'
default_has_many_class
CSS class used by default on hasMany field types. Default: ''
model_uses
This value contains an array of the classes that should be imported into the generated model class. Default: []
model_implements
This value contains an array of the interfaces that should be implemented by the generated model class. Default: []
model_traits
This value contains an array of the traits that should be used by the generated model class. Default: []
Usage
Generating your first admin
The following command will create a controller, model, migration, and route for your admin:
php artisan make:dynamo Employee
Need to opt out of some of the Dynamo magic?
php artisan make:dynamo Employee --migration=no --model=no --controller=no --route=no
Customizing the admin
Admin customization happens in your controller inside the getDynamo()
function. This function returns a Dynamo instance which has lots of chainable methods that customize your Dynamo admin. Below are methods you can chain.
Customizing the index
By default, Dynamo will add all fields from the database table to the index. Removing the call to auto()
in the getDynamo()
method in the generated controller, will stop all fields from getting added to the index AND the form.
Adding index columns
addIndex($key, $label = null, $formatCallable = null)
This method allows you to add or update an index column.
Parameters:
$key
This is the column name in your database table if you are hoping to populate it with table data. Otherwise, it could be any unique name.
$label
(optional) This is pretty name you want folks to see.
$formatCallable
(optional) This is a closure that allows you to completely customize how the index column renders. This closure will receive one parameter of the Eloquent instance for that row. The closure should return what you would like to render in the index column.
Removing index columns
removeIndex($key)
This method allow you to remove a column from the index.
Parameters:
$key
This is the key used to create the index. It is typical the column name in the database table.
Removing all index columns
clearIndexes()
This method removes all index columns. This can be used to clear indexes create by auto()
while leaving the form fields in place.
Sorting index rows
indexOrderBy($column, $sort = 'asc')
This method allows you to order the rows returned from the database.
Paginate the index rows
paginate($limit)
This method allows you to set the number of rows to display on each page of the index.
Create tabs on the index
Add search to the index
Add filters to the index
Hide the delete button on each row
Hide the add button
Add buttons to the index
Add action buttons to the index
Customizing the form
Add a form field
Remove a form field
Creating form groups
return Dynamo::make(\App\Employee::class)
->group(FieldGroup::make('groupName')
->text('fieldName')
->text('fieldName');
});
Creating form tabs
Add a custom handler for a field
Extending Dynamo
Creating custom fields
Creating handlers to custom fields
Advanced Dynamo
Creating many to many relationships between dynamo models
Step 1: Generate the two models you will be using.
php artisan make:dynamo Faq
php artisan make:dynamo Category
Step 2: Complete the needed migrations.
Example Faq migration:
Schema::create('faqs', function (Blueprint $table) {
$table->increments('id');
$table->string('question', 255);
$table->mediumText('answer');
$table->timestamps();
});
Example Category migration:
Schema::create('categories', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->timestamps();
});
Example pivot table migration:
Schema::create('category_faq', function(Blueprint $table)
{
$table->integer('faq_id')->unsigned()->nullable();
$table->foreign('faq_id')->references('id')->on('faqs');
$table->integer('category_id')->unsigned()->nullable();
$table->foreign('category_id')->references('id')->on('categories');
});
Run php artisan migrate
.
Step 3: Add the proper belongsToMany Eloquent function to each model.
For the Category model:
public function faqs()
{
return $this->belongsToMany('App\Faq');
}
For the Faq Model:
public function categories()
{
return $this->belongsToMany('App\Category');
}
Step 4: Chain the hasMany()
method onto your Dynamo instance in both controllers. Make sure your key is the name of the Eloquent function from you model.
return Dynamo::make(\App\Employee::class)
->hasMany('categories', ['options' => [$categories]]);
Check out our more detailed Documentation
https://dynamo-admin.readthedocs.io/en/latest/index.html
License
Dynamo is open-sourced software licensed under the MIT license.