|
|
@@ -24,6 +24,7 @@ func (h *handler) showSearchEntryPage(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
|
entryID := request.RouteInt64Param(r, "entryID")
|
|
|
searchQuery := request.QueryStringParam(r, "q", "")
|
|
|
+ unreadOnly := request.QueryBoolParam(r, "unread", false)
|
|
|
builder := h.store.NewEntryQueryBuilder(user.ID)
|
|
|
builder.WithSearchQuery(searchQuery)
|
|
|
builder.WithEntryID(entryID)
|
|
|
@@ -57,6 +58,14 @@ func (h *handler) showSearchEntryPage(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
|
entryPaginationBuilder := storage.NewEntryPaginationBuilder(h.store, user.ID, entry.ID, user.EntryOrder, user.EntryDirection)
|
|
|
entryPaginationBuilder.WithSearchQuery(searchQuery)
|
|
|
+ if unreadOnly {
|
|
|
+ if entry.Status == model.EntryStatusRead {
|
|
|
+ entryPaginationBuilder.WithStatusOrEntryID(model.EntryStatusUnread, entry.ID)
|
|
|
+ } else {
|
|
|
+ entryPaginationBuilder.WithStatus(model.EntryStatusUnread)
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
prevEntry, nextEntry, err := entryPaginationBuilder.Entries()
|
|
|
if err != nil {
|
|
|
html.ServerError(w, r, err)
|
|
|
@@ -76,6 +85,7 @@ func (h *handler) showSearchEntryPage(w http.ResponseWriter, r *http.Request) {
|
|
|
sess := session.New(h.store, request.SessionID(r))
|
|
|
view := view.New(h.tpl, r, sess)
|
|
|
view.Set("searchQuery", searchQuery)
|
|
|
+ view.Set("searchUnreadOnly", unreadOnly)
|
|
|
view.Set("entry", entry)
|
|
|
view.Set("prevEntry", prevEntry)
|
|
|
view.Set("nextEntry", nextEntry)
|