mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-25 12:37:23 +08:00
exam-table
This commit is contained in:
@@ -40,10 +40,10 @@ class ExamController extends Controller
|
||||
{
|
||||
$rules = [
|
||||
'name' => 'required|string',
|
||||
'begin' => 'required|date_format:Y-m-d H:i:s',
|
||||
'end' => 'required|date_format:Y-m-d H:i:s',
|
||||
'requires' => 'required|array|min:1',
|
||||
'filters' => 'required|array|min:1',
|
||||
'indexes' => 'required|array|min:1',
|
||||
'status' => 'required|in:0,1',
|
||||
// 'begin' => 'nullable|date',
|
||||
// 'end' => 'nullable|date',
|
||||
];
|
||||
$request->validate($rules);
|
||||
$result = $this->repository->store($request->all());
|
||||
@@ -55,11 +55,13 @@ class ExamController extends Controller
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
* @return array
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
$result = $this->repository->getDetail($id);
|
||||
$resource = new ExamResource($result);
|
||||
return $this->success($resource);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -73,10 +75,8 @@ class ExamController extends Controller
|
||||
{
|
||||
$rules = [
|
||||
'name' => 'required|string',
|
||||
'begin' => 'required|date_format:Y-m-d H:i:s',
|
||||
'end' => 'required|date_format:Y-m-d H:i:s',
|
||||
'requires' => 'required|array|min:1',
|
||||
'filters' => 'required|array|min:1',
|
||||
'indexes' => 'required|array|min:1',
|
||||
'status' => 'required|in:0,1',
|
||||
];
|
||||
$request->validate($rules);
|
||||
$result = $this->repository->update($request->all(), $id);
|
||||
|
||||
@@ -2,6 +2,9 @@
|
||||
|
||||
namespace App\Http\Resources;
|
||||
|
||||
use App\Models\Exam;
|
||||
use App\Models\User;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Http\Resources\Json\JsonResource;
|
||||
|
||||
class ExamResource extends JsonResource
|
||||
@@ -21,8 +24,52 @@ class ExamResource extends JsonResource
|
||||
'begin' => $this->begin,
|
||||
'end' => $this->end,
|
||||
'filters' => $this->filters,
|
||||
'requires' => $this->requires,
|
||||
'filters_formatted' => $this->formatFilters($this->resource),
|
||||
'indexes' => $this->indexes,
|
||||
'indexes_formatted' => $this->formatIndexes($this->resource),
|
||||
'status' => $this->status,
|
||||
'status_text' => $this->statusText,
|
||||
];
|
||||
}
|
||||
|
||||
private function formatFilters(Exam $exam)
|
||||
{
|
||||
$currentFilters = $exam->filters;
|
||||
$arr = [];
|
||||
$filter = Exam::FILTER_USER_CLASS;
|
||||
if (!empty($currentFilters->{$filter})) {
|
||||
$classes = collect(User::$classes)->only($currentFilters->{$filter});
|
||||
$arr[] = sprintf('%s: %s', Exam::$filters[$filter]['name'], $classes->pluck('text')->implode(', '));
|
||||
}
|
||||
|
||||
$filter = Exam::FILTER_USER_REGISTER_TIME_RANGE;
|
||||
if (!empty($currentFilters->{$filter})) {
|
||||
$range = $currentFilters->{$filter};
|
||||
$arr[] = sprintf(
|
||||
"%s: \n%s ~ %s",
|
||||
Exam::$filters[$filter]['name'],
|
||||
$range[0] ? Carbon::parse($range[0])->toDateTimeString() : '-',
|
||||
$range[1] ? Carbon::parse($range[1])->toDateTimeString() : '-'
|
||||
);
|
||||
}
|
||||
|
||||
return implode("\n", $arr);
|
||||
}
|
||||
|
||||
private function formatIndexes(Exam $exam)
|
||||
{
|
||||
$indexes = $exam->indexes;
|
||||
$arr = [];
|
||||
foreach ($indexes as $index) {
|
||||
if (isset($index['checked']) && $index['checked']) {
|
||||
$arr[] = sprintf(
|
||||
'%s: %s %s',
|
||||
Exam::$indexes[$index['index']]['name'] ?? '',
|
||||
$index['require_value'],
|
||||
Exam::$indexes[$index['index']]['unit'] ?? ''
|
||||
);
|
||||
}
|
||||
}
|
||||
return implode("\n", $arr);
|
||||
}
|
||||
}
|
||||
|
||||
+22
-11
@@ -4,28 +4,39 @@ namespace App\Models;
|
||||
|
||||
class Exam extends NexusModel
|
||||
{
|
||||
protected $fillable = ['name', 'description', 'begin', 'end', 'status'];
|
||||
protected $fillable = ['name', 'description', 'begin', 'end', 'status', 'filters', 'indexes'];
|
||||
|
||||
protected $casts = [
|
||||
'filters' => 'object',
|
||||
'indexes' => 'array',
|
||||
];
|
||||
|
||||
const STATUS_ENABLED = 0;
|
||||
const STATUS_DISABLED = 1;
|
||||
|
||||
public static $status = [
|
||||
self::STATUS_ENABLED => ['text' => '启用中'],
|
||||
self::STATUS_DISABLED => ['text' => '已禁用'],
|
||||
self::STATUS_ENABLED => ['text' => 'Enabled'],
|
||||
self::STATUS_DISABLED => ['text' => 'Disabled'],
|
||||
];
|
||||
|
||||
const INDEX_UPLOADED = 1;
|
||||
const INDEX_SEED_TIME = 2;
|
||||
const INDEX_SEED_TIME_AVERGAGE = 2;
|
||||
const INDEX_DOWNLOADED = 3;
|
||||
const INDEX_LEECH_TIME = 4;
|
||||
const INDEX_BONUS = 5;
|
||||
const INDEX_BONUS = 4;
|
||||
|
||||
public static $indexes = [
|
||||
self::INDEX_UPLOADED => ['text' => 'Uploaded'],
|
||||
self::INDEX_SEED_TIME => ['text' => 'Seed time'],
|
||||
self::INDEX_DOWNLOADED => ['text' => 'Download'],
|
||||
self::INDEX_LEECH_TIME => ['text' => 'Leech time'],
|
||||
self::INDEX_BONUS => ['text' => 'Bonus'],
|
||||
self::INDEX_UPLOADED => ['name' => 'Uploaded', 'unit' => 'GB'],
|
||||
self::INDEX_SEED_TIME_AVERGAGE => ['name' => 'Seed Time Average', 'unit' => 'Hour'],
|
||||
self::INDEX_DOWNLOADED => ['name' => 'Downloaded', 'unit' => 'GB'],
|
||||
self::INDEX_BONUS => ['name' => 'Bonus', 'unit' => ''],
|
||||
];
|
||||
|
||||
const FILTER_USER_CLASS = 'classes';
|
||||
const FILTER_USER_REGISTER_TIME_RANGE = 'register_time_range';
|
||||
|
||||
public static $filters = [
|
||||
self::FILTER_USER_CLASS => ['name' => 'User Class'],
|
||||
self::FILTER_USER_REGISTER_TIME_RANGE => ['name' => 'User Register Time Range'],
|
||||
];
|
||||
|
||||
public function getStatusTextAttribute()
|
||||
|
||||
@@ -5,6 +5,7 @@ use App\Models\Exam;
|
||||
use App\Models\Setting;
|
||||
use App\Models\User;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Support\Arr;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
class ExamRepository extends BaseRepository
|
||||
@@ -19,6 +20,10 @@ class ExamRepository extends BaseRepository
|
||||
|
||||
public function store(array $params)
|
||||
{
|
||||
$data = Arr::only($params, ['name', 'description', 'status', 'filters']);
|
||||
if (!empty($params['begin'])) {
|
||||
|
||||
}
|
||||
$exam = Exam::query()->create($params);
|
||||
return $exam;
|
||||
}
|
||||
@@ -30,11 +35,28 @@ class ExamRepository extends BaseRepository
|
||||
return $exam;
|
||||
}
|
||||
|
||||
public function getDetail($id)
|
||||
{
|
||||
$exam = Exam::query()->findOrFail($id);
|
||||
return $exam;
|
||||
}
|
||||
|
||||
public function listIndexes()
|
||||
{
|
||||
$out = [];
|
||||
foreach(Exam::$indexes as $key => $value) {
|
||||
$out[$key] = $value['text'];
|
||||
$value['index'] = $key;
|
||||
$out[] = $value;
|
||||
}
|
||||
return $out;
|
||||
}
|
||||
|
||||
public function listFilters()
|
||||
{
|
||||
$out = [];
|
||||
foreach(Exam::$filters as $key => $value) {
|
||||
$value['filter'] = $key;
|
||||
$out[] = $value;
|
||||
}
|
||||
return $out;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user