Произвольные столбцы
Вы можете регистрировать свои собственные типы столбцов в файле bootstrap.php
в директории bootstrapDirectory
(по умолчанию app/admin/bootstrap.php
).
Column::register('{type}', \Foo\Bar\MyColumn::class)
Ваш класс должен реализовывать интерфейс SleepingOwl\Admin\Columns\Interfaces\ColumnInterface
или расширять класс SleepingOwl\Admin\Columns\Column\BaseColumn
.
Пример
bootstrap.php
Column::register('yesNo', \Acme\YesNoColumn::class)
1. Acme/YesNoColumn.php используя интерфейс
use SleepingOwl\Admin\Columns\Interfaces\ColumnInterface;
class YesNoColumn implements ColumnInterface
{
public function renderHeader()
{
return '<th>Yes/no</th>';
}
public function render($instance, $totalCount)
{
$content = ($instance->bool) ? 'yes' : 'no';
return '<td>' . $content . '</td>';
}
public function getName()
{
return 'columng-name';
}
public function isHidden()
{
// return false to display this column
// return true to hide this column (used for column appendants)
return false;
}
public function myCustomMethod()
{
}
}
Использование в конфигурации модели
->columns(function ()
{
Column::yesNo()->myCustomMethod();
})
2. Acme/YesNoColumn.php используя класс BaseColumn
use SleepingOwl\Admin\Columns\Column\BaseColumn;
class YesNoColumn extends BaseColumn
{
public function render($instance, $totalCount)
{
$content = ($instance->{$this->name}) ? 'yes' : 'no';
return parent::render($instance, $totalCount, $content);
}
}
Использование в конфигурации модели
->columns(function ()
{
Column::yesNo('bool', 'Label')->sortable(false);
})