| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 | <?phpnamespace App\Http\Controllers\Admin;use App\Http\Requests\Admin\KnowledgeSave;use App\Http\Requests\Admin\KnowledgeSort;use App\Models\Knowledge;use Illuminate\Http\Request;use App\Http\Controllers\Controller;use Illuminate\Support\Facades\DB;class KnowledgeController extends Controller{    public function fetch(Request $request)    {        if ($request->input('id')) {            $knowledge = Knowledge::find($request->input('id'))->toArray();            if (!$knowledge) abort(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)) {                abort(500, '创建失败');            }        } else {            try {                Knowledge::find($request->input('id'))->update($params);            } catch (\Exception $e) {                abort(500, '保存失败');            }        }        return response([            'data' => true        ]);    }    public function show(Request $request)    {        if (empty($request->input('id'))) {            abort(500, '参数有误');        }        $knowledge = Knowledge::find($request->input('id'));        if (!$knowledge) {            abort(500, '知识不存在');        }        $knowledge->show = $knowledge->show ? 0 : 1;        if (!$knowledge->save()) {            abort(500, '保存失败');        }        return response([            'data' => true        ]);    }    public function sort(KnowledgeSort $request)    {        DB::beginTransaction();        foreach ($request->input('knowledge_ids') as $k => $v) {            if (!Knowledge::find($v)->update(['sort' => $k + 1])) {                DB::rollBack();                abort(500, '保存失败');            }        }        DB::commit();        return response([            'data' => true        ]);    }    public function drop(Request $request)    {        if (empty($request->input('id'))) {            abort(500, '参数有误');        }        $knowledge = Knowledge::find($request->input('id'));        if (!$knowledge) {            abort(500, '知识不存在');        }        if (!$knowledge->delete()) {            abort(500, '删除失败');        }        return response([            'data' => true        ]);    }}
 |