with(['practitioner.person', 'speciality', 'practitioner.metas', 'metas', 'organization']) ->when($request->search ?? null, function($query, $search) { $query->whereHas('practitioner.person', function($person) use ($search) { $person->where('name', 'LIKE', '%'.$search.'%'); }); }) ->whereHas('speciality'); if ($request->has('hospital_id_in')) { $hospital_ids = explode(',', $request->hospital_id_in); $doctors->whereIn('organization_id', $hospital_ids); } else if ($request->has('hospital_id')) { $doctors->where('organization_id', $request->hospital_id); } $doctors = $doctors->paginate(6); return response()->json([ 'message' => 'Sukses mengambil data Dokter', 'doctors' => Helper::paginateResources(PractitionerRoleToDoctorResource::collection($doctors)) ]); } /** * Show the form for creating a new resource. * @return Renderable */ public function create() { return view('linksehat::create'); } /** * Store a newly created resource in storage. * @param Request $request * @return Renderable */ public function store(Request $request) { // } /** * Show the specified resource. * @param int $id * @return Renderable */ public function show($id) { $doctor = PractitionerRole::query() ->with(['practitioner', 'practitioner.person', 'speciality', 'practitioner.metas', 'metas', 'organization']) ->where('id', $id) ->firstOrFail(); return response()->json(PractitionerRoleToDoctorDetailResource::make($doctor)); } /** * Show the form for editing the specified resource. * @param int $id * @return Renderable */ public function edit($id) { return view('linksehat::edit'); } /** * Update the specified resource in storage. * @param Request $request * @param int $id * @return Renderable */ public function update(Request $request, $id) { // } /** * Remove the specified resource from storage. * @param int $id * @return Renderable */ public function destroy($id) { // } }