Вы можете регистрировать свои собственные типы столбцов в файле 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);
})