] * @since [v4.0] * @return \Illuminate\Http\Response */ public function index(Request $request) { $this->authorize('view', Location::class); $allowed_columns = ['id','name','address','address2','city','state','country','zip']; $locations = Location::select([ 'locations.id', 'locations.name', 'locations.address', 'locations.address2', 'locations.city', 'locations.state', 'locations.zip', 'locations.country', 'locations.parent_id', 'locations.currency' ])->withCount('assets')->withCount('users'); if ($request->has('search')) { $locations = $locations->TextSearch($request->input('search')); } $offset = $request->input('offset', 0); $limit = $request->input('limit', 50); $order = $request->input('order') === 'asc' ? 'asc' : 'desc'; $sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at'; $locations->orderBy($sort, $order); $total = $locations->count(); $locations = $locations->skip($offset)->take($limit)->get(); return (new DatatablesTransformer)->transformDatatables($locations, $total); } /** * Store a newly created resource in storage. * * @author [A. Gianotto] [] * @since [v4.0] * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $this->authorize('create', Location::class); $location = new Location; $location->fill($request->all()); if ($location->save()) { return response()->json(Helper::formatStandardApiResponse('success', $location, trans('admin/locations/message.create.success'))); } return response()->json(Helper::formatStandardApiResponse('error', null, $location->getErrors())); } /** * Display the specified resource. * * @author [A. Gianotto] [] * @since [v4.0] * @param int $id * @return \Illuminate\Http\Response */ public function show($id) { $this->authorize('view', Location::class); $location = Location::findOrFail($id); return $location; } /** * Update the specified resource in storage. * * @author [A. Gianotto] [] * @since [v4.0] * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request, $id) { $this->authorize('edit', Location::class); $location = Location::findOrFail($id); $location->fill($request->all()); if ($location->save()) { return response()->json(Helper::formatStandardApiResponse('success', $location, trans('admin/locations/message.update.success'))); } return response()->json(Helper::formatStandardApiResponse('error', null, $location->getErrors())); } /** * Remove the specified resource from storage. * * @author [A. Gianotto] [] * @since [v4.0] * @param int $id * @return \Illuminate\Http\Response */ public function destroy($id) { $this->authorize('delete', Location::class); $location = Location::findOrFail($id); $this->authorize('delete', $location); $location->delete(); return response()->json(Helper::formatStandardApiResponse('success', null, trans('admin/locations/message.delete.success'))); } }