ajax()) { $model = Career::query()->orderBy('order'); return DataTables::eloquent($model) ->addIndexColumn() ->setRowClass('tableRow') ->editColumn('status', function (Career $career) { $status = $career->status ? 'Published' : 'Draft'; $color = $career->status ? 'text-success' : 'text-danger'; return "
{$status}
"; }) ->addColumn('action', 'ccms::career.datatable.action') ->rawColumns(['status', 'action']) ->toJson(); } return view('ccms::career.index', [ 'title' => 'Career List', ]); } /** * Show the form for creating a new resource. */ public function create() { $careerOptions = Career::where('status', 1)->pluck('job_title', 'id'); return view('ccms::career.create', [ 'title' => 'Create Career', 'editable' => false, 'careerOptions' => $careerOptions ]); } /** * Store a newly created resource in storage. */ public function store(Request $request) { $maxOrder = Career::max('order'); $order = $maxOrder ? ++$maxOrder : 1; $request->mergeIfMissing([ 'slug' => Str::slug($request->title), // 'order' => $order, ]); Career::create($request->all()); flash()->success("Career has been created!"); return redirect()->route('career.index'); } /** * Show the specified resource. */ public function show($id) { return view('ccms::show'); } /** * Show the form for editing the specified resource. */ public function edit($id) { $careerOptions = Career::where('status', 1)->pluck('job_title', 'id'); $career = Career::findOrFail($id); return view('ccms::career.edit', [ 'title' => 'Edit Career', 'editable' => true, 'career' => $career, 'careerOptions' => $careerOptions ]); } /** * Update the specified resource in storage. */ public function update(Request $request, $id) { $request->merge([ 'slug' => Str::slug($request->title), ]); $validated = $request->validate([]); $career = Career::findOrFail($id); $career->update($request->all()); flash()->success("Career has been updated."); return redirect()->back(); } /** * Remove the specified resource from storage. */ public function destroy($id) { $career = Career::findOrFail($id); $career->delete(); return response()->json(['status' => 200, 'message' => "Career has been deleted."], 200); } public function reorder(Request $request) { $careers = Career::all(); foreach ($careers as $career) { foreach ($request->order as $order) { if ($order['id'] == $career->id) { $career->update(['order' => $order['position']]); } } } return response(['status' => true, 'message' => 'Reordered successfully'], 200); } public function toggle($id) { $career = Career::findOrFail($id); $career->update(['status' => !$career->status]); return response(['status' => 200, 'message' => 'Toggled successfully'], 200); } }