У меня есть 2 таблицы данных, которые мне нужно показать на одной странице. Они уже используются на своей собственной странице, но страница панели управления должна содержать их обоих.
Проблемы, с которыми я сталкиваюсь:
Мои вопросы :
В моем 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);
});
}
В 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>
Я немного покопался и нашел способ заставить его работать.
Регистрирую собственных строителей:
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);
});
}
Затем в методе загрузки () я использую конструкторы и устанавливаю атрибут таблицы '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);
});
}
Скриншот :
Поиск и сортировка работают.
@Mopster Я думаю, вы также можете использовать ниже 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);
});
}
Использование Datatables::getHtmlBuilder()
всегда будет возвращать один экземпляр, а его вызов в IoC создаст новый экземпляр.
@yajra Действительно! Спасибо!