model::query() // ->where('restaurant_id', auth()->user()->restaurant_id) ->with(['permissions']) ->when($request->search, function ($query) use ($request) { $query->where('name', 'like', $request->search.'%'); }) ->orderBy($orderColumn, $orderDirection) ->paginate($perPage); } public function getById(int $id) { return $this->model::where('id', $id)->first(); } public function create(array $data) { $role = $this->model::create([ 'name' => $data['name'], 'restaurant_id' => $this->getCurrentRestaurantId(), 'guard_name' => 'web', 'description' => $data['description'] ?? null, ]); $role->permissions()->sync($data['permissions']); return $role; } public function update(int $id, array $data) { $model = $this->getById($id); $model->update($data); if (! empty($data['permissions'])) { $permissions = Permission::whereIn('id', $data['permissions'])->pluck('name')->toArray(); $model->syncPermissions($permissions); } return $model; } public function delete(int $id) { return DB::table('roles')->where('id', $id)->delete(); } }