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.

93 lines
3.5 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Models\DictItem;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class DictItemController extends Controller
{
public function index(Request $request): JsonResponse
{
$query = DictItem::query();
if ($request->filled('dict_type')) {
$query->where('dict_type', $request->string('dict_type'));
}
if ($request->boolean('active_only')) {
$query->where('is_active', true);
}
$rows = $query->orderBy('dict_type')->orderBy('sort')->orderBy('id')->get();
return response()->json($rows);
}
public function store(Request $request): JsonResponse
{
$this->ensureSuperAdmin($request);
$data = $request->validate([
'dict_type' => ['required', 'string', 'max:80'],
'dict_name' => ['nullable', 'string', 'max:120'],
'remark' => ['nullable', 'string', 'max:255'],
'dict_sort' => ['nullable', 'integer', 'min:0'],
'item_label' => ['required', 'string', 'max:120'],
'item_value' => ['required', 'string', 'max:120'],
'item_remark' => ['nullable', 'string', 'max:255'],
'sort' => ['nullable', 'integer', 'min:0'],
'is_active' => ['boolean'],
]);
// array_merge 后者覆盖前者:显式传 null 时须写成空串,避免 NOT NULL 列报错(不能用 $a+$b左侧含 null 会保留 null
$row = DictItem::create(array_merge($data, [
'dict_name' => $data['dict_name'] ?? '',
'remark' => $data['remark'] ?? '',
'dict_sort' => $data['dict_sort'] ?? 0,
'item_remark' => $data['item_remark'] ?? '',
'sort' => $data['sort'] ?? 0,
'is_active' => $data['is_active'] ?? true,
]));
return response()->json($row, 201);
}
public function update(Request $request, DictItem $dictItem): JsonResponse
{
$this->ensureSuperAdmin($request);
$data = $request->validate([
'dict_type' => ['sometimes', 'string', 'max:80'],
'dict_name' => ['sometimes', 'nullable', 'string', 'max:120'],
'remark' => ['sometimes', 'nullable', 'string', 'max:255'],
'dict_sort' => ['sometimes', 'nullable', 'integer', 'min:0'],
'item_label' => ['sometimes', 'string', 'max:120'],
'item_value' => ['sometimes', 'string', 'max:120'],
'item_remark' => ['sometimes', 'nullable', 'string', 'max:255'],
'sort' => ['nullable', 'integer', 'min:0'],
'is_active' => ['boolean'],
]);
if (array_key_exists('dict_name', $data) && $data['dict_name'] === null) {
$data['dict_name'] = '';
}
if (array_key_exists('remark', $data) && $data['remark'] === null) {
$data['remark'] = '';
}
if (array_key_exists('item_remark', $data) && $data['item_remark'] === null) {
$data['item_remark'] = '';
}
$dictItem->fill($data)->save();
return response()->json($dictItem);
}
public function destroy(Request $request, DictItem $dictItem): JsonResponse
{
$this->ensureSuperAdmin($request);
$dictItem->delete();
return response()->json(['message' => '删除成功']);
}
private function ensureSuperAdmin(Request $request): void
{
abort_unless($request->user()?->isSuperAdmin(), 403, '仅超级管理员可操作');
}
}