diff options
author | 2024-03-01 16:12:17 -0800 | |
---|---|---|
committer | 2024-03-01 16:56:15 -0800 | |
commit | abdd5876a14e1971b5caac93f6735773e7ee388b (patch) | |
tree | 0c7fca43f80ab3b1da921b9250e62727faea6546 /internal/ui/search.go | |
parent | 1b5edfc00aa1f862c50665e9561df868d554a221 (diff) | |
download | v2-abdd5876a14e1971b5caac93f6735773e7ee388b.tar.gz v2-abdd5876a14e1971b5caac93f6735773e7ee388b.tar.zst v2-abdd5876a14e1971b5caac93f6735773e7ee388b.zip |
Move search form to a dedicated page
Diffstat (limited to 'internal/ui/search.go')
-rw-r--r-- | internal/ui/search.go | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/internal/ui/search.go b/internal/ui/search.go new file mode 100644 index 00000000..d426411f --- /dev/null +++ b/internal/ui/search.go @@ -0,0 +1,66 @@ +// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved. +// SPDX-License-Identifier: Apache-2.0 + +package ui // import "miniflux.app/v2/internal/ui" + +import ( + "net/http" + + "miniflux.app/v2/internal/http/request" + "miniflux.app/v2/internal/http/response/html" + "miniflux.app/v2/internal/http/route" + "miniflux.app/v2/internal/model" + "miniflux.app/v2/internal/ui/session" + "miniflux.app/v2/internal/ui/view" +) + +func (h *handler) showSearchPage(w http.ResponseWriter, r *http.Request) { + user, err := h.store.UserByID(request.UserID(r)) + if err != nil { + html.ServerError(w, r, err) + return + } + + searchQuery := request.QueryStringParam(r, "q", "") + offset := request.QueryIntParam(r, "offset", 0) + + var entries model.Entries + var entriesCount int + + if searchQuery != "" { + builder := h.store.NewEntryQueryBuilder(user.ID) + builder.WithSearchQuery(searchQuery) + builder.WithoutStatus(model.EntryStatusRemoved) + builder.WithOffset(offset) + builder.WithLimit(user.EntriesPerPage) + + entries, err = builder.GetEntries() + if err != nil { + html.ServerError(w, r, err) + return + } + + entriesCount, err = builder.CountEntries() + if err != nil { + html.ServerError(w, r, err) + return + } + } + + sess := session.New(h.store, request.SessionID(r)) + view := view.New(h.tpl, r, sess) + pagination := getPagination(route.Path(h.router, "search"), entriesCount, offset, user.EntriesPerPage) + pagination.SearchQuery = searchQuery + + view.Set("searchQuery", searchQuery) + view.Set("entries", entries) + view.Set("total", entriesCount) + view.Set("pagination", pagination) + view.Set("menu", "search") + view.Set("user", user) + view.Set("countUnread", h.store.CountUnreadEntries(user.ID)) + view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID)) + view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID)) + + html.OK(w, r, view.Render("search")) +} |