Ich habe 2 Datentabellen, die ich auf derselben Seite anzeigen muss. Sie werden bereits auf ihrer eigenen Seite verwendet, aber die Dashboard-Seite muss beide enthalten.
Die Probleme, auf die ich stoße:
Meine Fragen :
In meinem ServiceProvider:
public function boot()
{
View::composer(['dashboard', 'user.index'], function(\Illuminate\View\View $view){
$userTable = Datatables::getHtmlBuilder()
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.username')])
->addColumn(['data' => 'name_en', 'name' => 'name_en', 'title' => trans('messages.name (english)')])
->addColumn(['data' => 'name_jp', 'name' => 'name_jp', 'title' => trans('messages.name (japanese)')])
->addColumn(['data' => 'phone_number', 'name' => 'phone_number', 'title' => trans('messages.phone number')])
->addColumn(['data' => 'extension', 'name' => 'extension', 'title' => trans('messages.extension')])
->addAction([])
->ajax(route('user_index_data'))
;
$view->with('userTable', $userTable);
});
View::composer(['dashboard', 'group.index'], function(\Illuminate\View\View $view) {
$groupTable = DataTables::getHtmlBuilder()
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.group username')])
->addColumn(['data' => 'name', 'name' => 'name', 'title' => trans('messages.group name')])
->addColumn(['data' => 'users', 'name' => 'users', 'title' => trans('messages.active users')])
->addAction([])
->ajax(route('group_index_data'));
$view->with('groupTable', $groupTable);
});
}
In der dashboard.blade.php
@section('content')
<div class="row">
<div class="col-sm-6 col-xs-12">
{!! $userTable->table() !!}
{!! $userTable->scripts() !!}
</div>
</div>
<div class="row">
<div class="col-sm-6 col-xs-12">
{!! $groupTable->table() !!}
{!! $groupTable->scripts() !!}
</div>
</div>
<strong i="20">@endsection</strong>
Ich habe ein bisschen herumgegraben und einen Weg gefunden, es zum Laufen zu bringen.
Ich registriere meine eigenen Erbauer:
public function register()
{
$this->app->bind('datatables.html.userTable', function () {
return $this->app->make(Builder::class);
});
$this->app->bind('datatables.html.groupTable', function () {
return $this->app->make(Builder::class);
});
}
Dann verwende ich in der Boot-Methode () die Builder und setze das Tabellenattribut 'id':
public function boot()
{
View::composer(['dashboard', 'user.index'], function(\Illuminate\View\View $view){
$userTableBuilder = app('datatables.html.userTable');
$userTable = $userTableBuilder
->setTableAttribute('id', 'userTable')
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.username')])
->addColumn(['data' => 'name_en', 'name' => 'name_en', 'title' => trans('messages.name (english)')])
->addColumn(['data' => 'name_jp', 'name' => 'name_jp', 'title' => trans('messages.name (japanese)')])
->addColumn(['data' => 'phone_number', 'name' => 'phone_number', 'title' => trans('messages.phone number')])
->addColumn(['data' => 'extension', 'name' => 'extension', 'title' => trans('messages.extension')])
->addAction([])
->ajax(route('user_index_data'))
;
$view->with('userTable', $userTable);
});
View::composer(['dashboard', 'group.index'], function(\Illuminate\View\View $view) {
$groupTableBuilder = app('datatables.html.groupTable');
$groupTable = $groupTableBuilder
->setTableAttribute('id', 'groupTable')
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.group username')])
->addColumn(['data' => 'name', 'name' => 'name', 'title' => trans('messages.group name')])
->addColumn(['data' => 'users', 'name' => 'users', 'title' => trans('messages.active users')])
->addAction([])
->ajax(route('group_index_data'));
$view->with('groupTable', $groupTable);
});
}
Bildschirmfoto :
Suchen und Sortieren funktionieren.
@Mopster Ich denke, Sie können auch unter app('datatables.html')
:
public function boot()
{
View::composer(['dashboard', 'user.index'], function(\Illuminate\View\View $view){
$userTable = app('datatables.html')
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.username')])
->addColumn(['data' => 'name_en', 'name' => 'name_en', 'title' => trans('messages.name (english)')])
->addColumn(['data' => 'name_jp', 'name' => 'name_jp', 'title' => trans('messages.name (japanese)')])
->addColumn(['data' => 'phone_number', 'name' => 'phone_number', 'title' => trans('messages.phone number')])
->addColumn(['data' => 'extension', 'name' => 'extension', 'title' => trans('messages.extension')])
->addAction([])
->ajax(route('user_index_data'))
;
$view->with('userTable', $userTable);
});
View::composer(['dashboard', 'group.index'], function(\Illuminate\View\View $view) {
$groupTable = app('datatables.html')
->addColumn(['data' => 'username', 'name' => 'username', 'title' => trans('messages.group username')])
->addColumn(['data' => 'name', 'name' => 'name', 'title' => trans('messages.group name')])
->addColumn(['data' => 'users', 'name' => 'users', 'title' => trans('messages.active users')])
->addAction([])
->ajax(route('group_index_data'));
$view->with('groupTable', $groupTable);
});
}
Wenn Sie Datatables::getHtmlBuilder()
wird immer eine einzelne Instanz zurückgegeben, während beim Aufrufen im IoC eine neue Instanz erstellt wird.
@yajra In der Tat! Vielen Dank!