70 lines
2.2 KiB
PHP
70 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace app\admin\controller\game;
|
|
|
|
use Throwable;
|
|
use app\common\controller\Backend;
|
|
use support\Response;
|
|
use Webman\Http\Request as WebmanRequest;
|
|
|
|
/**
|
|
* 渠道管理
|
|
*/
|
|
class Channel extends Backend
|
|
{
|
|
/**
|
|
* GameChannel模型对象
|
|
* @var object|null
|
|
* @phpstan-var \app\common\model\GameChannel|null
|
|
*/
|
|
protected ?object $model = null;
|
|
|
|
protected array|string $preExcludeFields = ['id', 'user_count', 'profit_amount', 'create_time', 'update_time'];
|
|
|
|
protected array $withJoinTable = ['adminGroup', 'admin'];
|
|
|
|
protected string|array $quickSearchField = ['id', 'code', 'name'];
|
|
|
|
protected function initController(WebmanRequest $request): ?Response
|
|
{
|
|
$this->model = new \app\common\model\GameChannel();
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* 查看
|
|
* @throws Throwable
|
|
*/
|
|
protected function _index(): Response
|
|
{
|
|
// 如果是 select 则转发到 select 方法,若未重写该方法,其实还是继续执行 index
|
|
if ($this->request && $this->request->get('select')) {
|
|
return $this->select($this->request);
|
|
}
|
|
|
|
/**
|
|
* 1. withJoin 不可使用 alias 方法设置表别名,别名将自动使用关联模型名称(小写下划线命名规则)
|
|
* 2. 以下的别名设置了主表别名,同时便于拼接查询参数等
|
|
* 3. paginate 数据集可使用链式操作 each(function($item, $key) {}) 遍历处理
|
|
*/
|
|
list($where, $alias, $limit, $order) = $this->queryBuilder();
|
|
$res = $this->model
|
|
->withJoin($this->withJoinTable, $this->withJoinType)
|
|
->with($this->withJoinTable)
|
|
->visible(['adminGroup' => ['name'], 'admin' => ['username']])
|
|
->alias($alias)
|
|
->where($where)
|
|
->order($order)
|
|
->paginate($limit);
|
|
|
|
return $this->success('', [
|
|
'list' => $res->items(),
|
|
'total' => $res->total(),
|
|
'remark' => get_route_remark(),
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 若需重写查看、编辑、删除等方法,请复制 @see \app\admin\library\traits\Backend 中对应的方法至此进行重写
|
|
*/
|
|
} |