input('id')) { $knowledge = Knowledge::find($request->input('id'))->toArray(); if (!$knowledge) throw new ApiException(500, '知识不存在'); return response([ 'data' => $knowledge ]); } return response([ 'data' => Knowledge::select(['title', 'id', 'updated_at', 'category', 'show']) ->orderBy('sort', 'ASC') ->get() ]); } public function getCategory(Request $request) { return response([ 'data' => array_keys(Knowledge::get()->groupBy('category')->toArray()) ]); } public function save(KnowledgeSave $request) { $params = $request->validated(); if (!$request->input('id')) { if (!Knowledge::create($params)) { throw new ApiException(500, '创建失败'); } } else { try { Knowledge::find($request->input('id'))->update($params); } catch (\Exception $e) { throw new ApiException(500, '保存失败'); } } return response([ 'data' => true ]); } public function show(Request $request) { if (empty($request->input('id'))) { throw new ApiException(422, '参数有误'); } $knowledge = Knowledge::find($request->input('id')); if (!$knowledge) { throw new ApiException(500, '知识不存在'); } $knowledge->show = $knowledge->show ? 0 : 1; if (!$knowledge->save()) { throw new ApiException(500, '保存失败'); } return response([ 'data' => true ]); } public function sort(KnowledgeSort $request) { try { DB::beginTransaction(); foreach ($request->input('knowledge_ids') as $k => $v) { $knowledge = Knowledge::find($v); $knowledge->timestamps = false; $knowledge->update(['sort' => $k + 1]); } DB::commit(); } catch (\Exception $e) { DB::rollBack(); throw new ApiException(500, '保存失败'); } return response([ 'data' => true ]); } public function drop(Request $request) { if (empty($request->input('id'))) { throw new ApiException(422, '参数有误'); } $knowledge = Knowledge::find($request->input('id')); if (!$knowledge) { throw new ApiException(500, '知识不存在'); } if (!$knowledge->delete()) { throw new ApiException(500, '删除失败'); } return response([ 'data' => true ]); } }