1
0
Fork 0
party-rank-server/app/Admin/Controllers/UserRankController.php

95 lines
3.4 KiB
PHP

<?php
namespace App\Admin\Controllers;
use App\Admin\Services\UserRankService;
use App\Models\UserRank;
use Slowlyo\OwlAdmin\Controllers\AdminController;
use Slowlyo\OwlAdmin\Renderers\Page;
use Maatwebsite\Excel\Facades\Excel;
/**
* 党员排名
*/
class UserRankController extends AdminController
{
protected string $serviceName = UserRankService::class;
protected $snOptions;
public function list(): Page
{
$crud = $this->baseCRUD()
->filterTogglable(false)
->columnsTogglable(false)
->footerToolbar([])
->headerToolbar([
$this->exportAction(),
])
->filter($this->baseFilter()->actions()->body([
amisMake()->SelectControl()->name('sn')->label(__('user_rank.sn'))->options($this->getSnOptions())->size('md'),
amisMake()->Component()->setType('submit')->label(__('admin.search'))->level('primary'),
]))
->columns([
amisMake()->TableColumn()->name('cate.name')->label(__('user_rank.cate_id')),
amisMake()->TableColumn()->name('user.name')->label(__('user_rank.user_id')),
amisMake()->TableColumn()->name('sort')->label(__('user_rank.sort'))->set('type', 'tpl')->tpl('${(start - 1) * size + index + 1}'),
amisMake()->TableColumn()->name('score')->label(__('user_rank.score')),
]);
return $this->baseList($crud);
}
public function getSnOptions()
{
if (!$this->snOptions) {
$this->snOptions = UserRank::select('sn')->groupBy('sn')->orderBy('sn', 'desc')->pluck('sn')->prepend('当前');
}
return $this->snOptions;
}
protected function exportAction($disableSelectedItem = false)
{
$event = fn($script) => ['click' => ['actions' => [['actionType' => 'custom', 'script' => $script]]]];
$downloadPath = '/' . admin_url('_download_export', true);
$exportPath = $this->getExportPath();
$doAction = <<<JS
doAction([
{ actionType: "ajax", args: { api: { url: url.toString(), method: "get" } } },
{
actionType: "custom",
expression: "\${event.data.responseResult.responseStatus === 0}",
script: "window.open('{$downloadPath}?path='+event.data.responseResult.responseData.path)"
}
])
JS;
return amisMake()->VanillaAction()
->label(__('admin.export.title'))
->set('icon', 'fa-solid fa-download')
->align('right')
->onEvent($event(
<<<JS
let url = new URL("{$exportPath}", window.location.origin)
let param = window.location.href.split('?')[1]
if (param) {
url = url + '&' + param
}
{$doAction}
JS
));
}
protected function export()
{
$sn = request('sn', data_get($this->getSnOptions(), 0));
// 默认在 storage/app/ 下
$path = __('user_rank.user_rank') . '-' . $sn . '.xlsx';
// 此处使用 laravel-excel 导出,可自行修改
(new \App\Exports\UserRank)->store($path, 'local');
return $this->response()->success(compact('path'));
}
}