- $user = $this->user->findOrFail($id);
- setting()->putUser($user, 'books_view_type', $viewType);
-
- $previousUrl = url()->previous();
- if (empty($previousUrl)) {
- // if no previous URL, redirect to settings
- return redirect("/settings/users/$id");
- } else {
- // redirect to the previous page.
- return redirect($previousUrl);
+ $user = $this->user->findOrFail($userId);
+ $key = $listName . '_view_type';
+ setting()->putUser($user, $key, $viewType);
+
+ return redirect()->back(302, [], "/settings/users/$userId");
+ }
+
+ /**
+ * Change the stored sort type for the books view.
+ * @param $id
+ * @param Request $request
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ public function changeBooksSort($id, Request $request)
+ {
+ // TODO - Test this endpoint
+ return $this->changeListSort($id, $request, 'books');
+ }
+
+ /**
+ * Changed the stored preference for a list sort order.
+ * @param int $userId
+ * @param Request $request
+ * @param string $listName
+ * @return \Illuminate\Http\RedirectResponse
+ */
+ protected function changeListSort(int $userId, Request $request, string $listName)
+ {
+ $this->checkPermissionOrCurrentUser('users-manage', $userId);
+
+ $sort = $request->get('sort');
+ if (!in_array($sort, ['name', 'created_at', 'updated_at'])) {
+ $sort = 'name';