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.
86 lines
3.5 KiB
86 lines
3.5 KiB
<?php
|
|
|
|
namespace App\Admin\Controllers;
|
|
|
|
use App\Models\Agent;
|
|
use App\Models\AgentGrade;
|
|
use App\Admin\Repositories\BonusLog as BonusLogRepository;
|
|
use App\Models\User;
|
|
use App\Models\UserWallet;
|
|
use Dcat\Admin\Form;
|
|
use Dcat\Admin\Grid;
|
|
use Dcat\Admin\Show;
|
|
use Dcat\Admin\Controllers\AdminController;
|
|
use Dcat\Admin\Widgets\Alert;
|
|
|
|
class BonusLogStatisticsController extends AdminController
|
|
{
|
|
|
|
protected $title = '期权佣金统计';
|
|
|
|
/**
|
|
* Make a grid builder.
|
|
*
|
|
* @return Grid
|
|
*/
|
|
protected function grid()
|
|
{
|
|
return Grid::make(new BonusLogRepository(), function (Grid $grid) {
|
|
|
|
$grid->disableBatchDelete();
|
|
$grid->disableActions();
|
|
$grid->disableCreateButton();
|
|
$grid->disableRowSelector();
|
|
|
|
$grid->column('user_id', 'UID');
|
|
$grid->column('user.username', '用户名');
|
|
$grid->column('user.user_grade_name', '等级');
|
|
$grid->column('user.referrer', '代理')->display(function ($v) {
|
|
return User::query()->where("id", $v)->value("name") ?? '--';
|
|
});
|
|
// $grid->column('coin_name');
|
|
$grid->column('amount_sum', '佣金统计');
|
|
//
|
|
$grid->filter(function (Grid\Filter $filter) {
|
|
$grades = AgentGrade::getCachedGradeOption();
|
|
$lk = last(array_keys($grades));
|
|
foreach ($grades as $k => $v) {
|
|
$key = 'A' . ($k + 1);
|
|
$next_key = 'A' . ($k + 2);
|
|
if ($k == 0) {
|
|
$options1 = Agent::query()->where(['deep' => 0, 'is_agency' => 1])->pluck('username', 'id');
|
|
$filter->where($key, function ($q) {
|
|
$ids = Agent::getBaseAgentIds($this->input);
|
|
$q->whereHas('user', function ($q) use ($ids) {
|
|
$q->whereIn('referrer', $ids);
|
|
});
|
|
}, $v)->select($options1)->load($next_key, 'api/agents')->placeholder('请选择')->width(2);
|
|
} elseif ($k == $lk) {
|
|
$filter->where($key, function ($q) {
|
|
$id = $this->input;
|
|
$q->whereHas('user', function ($q) use ($id) {
|
|
$q->where('referrer', $id);
|
|
});
|
|
}, $v)->select()->placeholder('请选择')->width(2);
|
|
} else {
|
|
$filter->where($key, function ($q) {
|
|
$ids = Agent::getBaseAgentIds($this->input);
|
|
$q->whereHas('user', function ($q) use ($ids) {
|
|
$q->whereIn('referrer', $ids);
|
|
});
|
|
}, $v)->select()->load($next_key, 'api/agents')->placeholder('请选择')->width(2);
|
|
}
|
|
}
|
|
|
|
$filter->equal('user_id', '用户id')->width(2);
|
|
$filter->where('username', function ($q) {
|
|
$username = $this->input;
|
|
$q->whereHas('user', function ($q) use ($username) {
|
|
$q->where('username', $username)->orWhere('phone', $username)->orWhere('email', $username);
|
|
});
|
|
}, "用户名/手机/邮箱")->width(4);
|
|
$filter->between('created_at', "时间")->date()->width(4);
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|