has('limit') ? $request->limit : 10; $users = User::where('role', 'admin', 'creator') ->applyFilters( $request->only([ 'phone', 'email', 'display_name', 'orderByField', 'orderBy', ]) ) ->latest() ->paginate($limit); return response()->json([ 'users' => $users, ]); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\UserRequest $request * @return \Illuminate\Http\JsonResponse */ public function store(UserRequest $request) { $data = $request->validated(); $data['role'] = 'admin'; $data['company_id'] = Auth::user()->company_id; $data['creator_id'] = Auth::id(); $user = User::create($data); $user->setSettings([ 'language' => CompanySetting::getSetting('language', $user->company_id), ]); return response()->json([ 'user' => $user, 'success' => true, ]); } /** * Display the specified resource. * * @param \Crater\Models\User $user * @return \Illuminate\Http\JsonResponse */ public function show(User $user) { return response()->json([ 'user' => $user, 'success' => true, ]); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\UserRequest $request * @param \Crater\Models\User $user * @return \Illuminate\Http\JsonResponse */ public function update(UserRequest $request, User $user) { $user->update($request->validated()); return response()->json([ 'user' => $user, 'success' => true, ]); } /** * Display a listing of the resource. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\JsonResponse */ public function delete(Request $request) { if ($request->users) { User::destroy($request->users); } return response()->json([ 'success' => true, ]); } }