You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
3.8 KiB
113 lines
3.8 KiB
<?php
|
|
|
|
namespace App\Http\Controllers\Admin;
|
|
|
|
use App\Http\Requests\DomainsRequest;
|
|
use App\Models\Domain;
|
|
use Backpack\CRUD\app\Http\Controllers\CrudController;
|
|
use Backpack\CRUD\app\Library\CrudPanel\CrudPanelFacade as CRUD;
|
|
|
|
/**
|
|
* Class DomainsCrudController
|
|
* @package App\Http\Controllers\Admin
|
|
* @property-read \Backpack\CRUD\app\Library\CrudPanel\CrudPanel $crud
|
|
*/
|
|
class DomainsCrudController extends CrudController
|
|
{
|
|
use \Backpack\CRUD\app\Http\Controllers\Operations\ListOperation;
|
|
use \Backpack\CRUD\app\Http\Controllers\Operations\CreateOperation;
|
|
use \Backpack\CRUD\app\Http\Controllers\Operations\UpdateOperation;
|
|
use \Backpack\CRUD\app\Http\Controllers\Operations\DeleteOperation;
|
|
use \Backpack\CRUD\app\Http\Controllers\Operations\ShowOperation;
|
|
|
|
/**
|
|
* Configure the CrudPanel object. Apply settings to all operations.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function setup()
|
|
{
|
|
CRUD::setModel(\App\Models\Domain::class);
|
|
CRUD::setRoute(config('backpack.base.route_prefix') . '/domains');
|
|
CRUD::setEntityNameStrings(
|
|
__('entities.domain.singular'),
|
|
__('entities.domain.plural'),
|
|
);
|
|
if (!backpack_user()->hasRole('admin')){
|
|
$this->crud->denyAllAccess();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Define what happens when the List operation is loaded.
|
|
*
|
|
* @see https://backpackforlaravel.com/docs/crud-operation-list-entries
|
|
* @return void
|
|
*/
|
|
protected function setupListOperation()
|
|
{
|
|
CRUD::column([
|
|
'label' => "user",
|
|
'type' => 'select',
|
|
'name' => 'user_id', // the db column for the foreign key
|
|
'entity' => 'user',
|
|
'model' => "App\Models\User", // related model
|
|
'attribute' => 'email', // foreign key attribute that is shown to user
|
|
]);
|
|
CRUD::setFromDb(); // set columns from db columns.
|
|
|
|
/**
|
|
* Columns can be defined using the fluent syntax:
|
|
* - CRUD::column('price')->type('number');
|
|
*/
|
|
}
|
|
|
|
/**
|
|
* Define what happens when the Create operation is loaded.
|
|
*
|
|
* @see https://backpackforlaravel.com/docs/crud-operation-create
|
|
* @return void
|
|
*/
|
|
protected function setupCreateOperation()
|
|
{
|
|
CRUD::setFromDb(); // set fields from db columns.
|
|
CRUD::field([ // Select
|
|
'label' => "user",
|
|
'type' => 'select',
|
|
'name' => 'user_id', // the db column for the foreign key
|
|
'entity' => 'user',
|
|
'model' => "App\Models\User", // related model
|
|
'attribute' => 'email', // foreign key attribute that is shown to user
|
|
'options' => (function ($query) {
|
|
return $query->orderBy('id', 'ASC')->get();
|
|
}), // you can use this to filter the results show in the select
|
|
]);
|
|
|
|
/**
|
|
* Fields can be defined using the fluent syntax:
|
|
* - CRUD::field('price')->type('number');
|
|
*/
|
|
}
|
|
|
|
/**
|
|
* Define what happens when the Update operation is loaded.
|
|
*
|
|
* @see https://backpackforlaravel.com/docs/crud-operation-update
|
|
* @return void
|
|
*/
|
|
protected function setupUpdateOperation()
|
|
{
|
|
$this->setupCreateOperation();
|
|
CRUD::field([ // Select
|
|
'label' => "user",
|
|
'type' => 'select',
|
|
'name' => 'user_id', // the db column for the foreign key
|
|
'entity' => 'user',
|
|
'model' => "App\Models\User", // related model
|
|
'attribute' => 'email', // foreign key attribute that is shown to user
|
|
'options' => (function ($query) {
|
|
return $query->orderBy('id', 'ASC')->get();
|
|
}), // you can use this to filter the results show in the select
|
|
]);
|
|
}
|
|
}
|
|
|