mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-23 19: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);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user