Predefined backend functionality to quicker create custom user admin.
yaroslawww/laravel-user-adminboard is a Laravel package for predefined backend functionality to quicker create custom user admin..
It currently has 0 GitHub stars and 10 downloads on Packagist (latest version 1.0.1).
Install it with composer require yaroslawww/laravel-user-adminboard.
Discover more Laravel packages by yaroslawww
or browse all Laravel packages to compare alternatives.
Last updated
Predefined backend functionality to quicker create custom user admin on laravel.
Install the package via composer:
composer require yaroslawww/laravel-user-adminboard
Optionally you can publish the config file with:
php artisan vendor:publish --provider="UserAdmin\ServiceProvider" --tag="config"
Define routes
Route::middleware(['auth',])
->prefix('dashboard')
->group(function () {
\UserAdmin\Facades\UserAdmin::routes();
// ....
})
Create Index pages and resources
// app/UserAdmin/Index/PostsIndexPage.php
namespace App\UserAdmin\Index;
use App\UserAdmin\Index\Resources\PostResource;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\Request;
use UserAdmin\IndexPage\Actions\InlineActions\RedirectInlineAction;
use UserAdmin\IndexPage\Columns\TextColumn;
use UserAdmin\IndexPage\IndexPage;
class PostsIndexPage extends IndexPage
{
public static string $name = 'posts';
public ?string $identifier = null;
/**
* @inerhitDoc
*/
public string $responseResource = PostResource::class;
public function columns(): array
{
return [
( new TextColumn('Title', 'title') )
->sortable(),
// ...
];
}
/**
* @inheritDoc
*/
public function responsePerPage(Request $request, $query): ?int
{
return 20;
}
public function query(Request $request)
{
$request->validate([
'search' => ['nullable', 'string', 'max:200'],
]);
$query = Post::query();
if ($request->has('search')) {
$text = $request->input('search');
$query->where(function (Builder $query) use ($text) {
$query->orWhere('title', 'like', "%{$text}%");
});
}
return $query;
}
/**
* @inheritDoc
*/
public function inlineActions(): array
{
return [
( new RedirectInlineAction('edit') )
->setIcon('<icon-edit class="h-4"></icon-edit>')
->setTitle('Edit'),
( new RedirectInlineAction('preview') )
->setIcon('<icon-external-link class="h-4"></icon-external-link>')
->setTitle('Preview'),
];
}
}
// app/UserAdmin/Index/Resources/PostResource.php
namespace App\UserAdmin\Index\Resources;
use App\Models\Post;
use UserAdmin\Http\Resources\ListResource;
class PostResource extends ListResource
{
/**
* Transform the resource into an array.
*
* @param \Illuminate\Http\Request $request
*
* @return array
*/
public function toArray($request)
{
/** @var Post $post */
$post = $this->resource;
return [
'id' => $post->getKey(),
'title' => $post->title,
/* Actions data */
'actions_meta' => [
'edit' => [
'url' => $post->editUrl(),
],
'preview' => [
'url' => $post->frontendUrl(),
],
],
];
}
}
Register index page
class AppServiceProvider extends ServiceProvider
{
public function boot()
{
// ...
UserAdmin::indexPage()->usePages([
PostsIndexPage::class,
]);
}
}