aboutsummaryrefslogtreecommitdiffhomepage
path: root/ui
diff options
context:
space:
mode:
authorGravatar Diego Agulló <diego.agullo@mo2o.com>2018-12-14 09:54:25 +0100
committerGravatar Frédéric Guillot <fred@miniflux.net>2018-12-16 16:58:48 -0800
commitcf25efb4d9202573b5b8eeb8ff56df9568b4c331 (patch)
treeb4e1293046ab047219e9dedd8fa095b0f7c5e682 /ui
parent012138179c4210313f63ec8a4982d366ccee299c (diff)
Allow to switch between unread only and all entries on category/feed views
Diffstat (limited to 'ui')
-rw-r--r--ui/category_entries.go3
-rw-r--r--ui/category_entries_all.go72
-rw-r--r--ui/feed_entries.go3
-rw-r--r--ui/feed_entries_all.go72
-rw-r--r--ui/ui.go2
5 files changed, 150 insertions, 2 deletions
diff --git a/ui/category_entries.go b/ui/category_entries.go
index 19b17b9..998f207 100644
--- a/ui/category_entries.go
+++ b/ui/category_entries.go
@@ -39,7 +39,7 @@ func (h *handler) showCategoryEntriesPage(w http.ResponseWriter, r *http.Request
builder.WithCategoryID(category.ID)
builder.WithOrder(model.DefaultSortingOrder)
builder.WithDirection(user.EntryDirection)
- builder.WithoutStatus(model.EntryStatusRemoved)
+ builder.WithStatus(model.EntryStatusUnread)
builder.WithOffset(offset)
builder.WithLimit(nbItemsPerPage)
@@ -66,6 +66,7 @@ func (h *handler) showCategoryEntriesPage(w http.ResponseWriter, r *http.Request
view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
view.Set("countErrorFeeds", h.store.CountErrorFeeds(user.ID))
view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID))
+ view.Set("showOnlyUnreadEntries", true)
html.OK(w, r, view.Render("category_entries"))
}
diff --git a/ui/category_entries_all.go b/ui/category_entries_all.go
new file mode 100644
index 0000000..3ae98e9
--- /dev/null
+++ b/ui/category_entries_all.go
@@ -0,0 +1,72 @@
+// Copyright 2018 Frédéric Guillot. All rights reserved.
+// Use of this source code is governed by the Apache 2.0
+// license that can be found in the LICENSE file.
+
+package ui // import "miniflux.app/ui"
+
+import (
+ "net/http"
+
+ "miniflux.app/http/request"
+ "miniflux.app/http/response/html"
+ "miniflux.app/http/route"
+ "miniflux.app/model"
+ "miniflux.app/ui/session"
+ "miniflux.app/ui/view"
+)
+
+func (h *handler) showCategoryEntriesAllPage(w http.ResponseWriter, r *http.Request) {
+ user, err := h.store.UserByID(request.UserID(r))
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ categoryID := request.RouteInt64Param(r, "categoryID")
+ category, err := h.store.Category(request.UserID(r), categoryID)
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ if category == nil {
+ html.NotFound(w, r)
+ return
+ }
+
+ offset := request.QueryIntParam(r, "offset", 0)
+ builder := h.store.NewEntryQueryBuilder(user.ID)
+ builder.WithCategoryID(category.ID)
+ builder.WithOrder(model.DefaultSortingOrder)
+ builder.WithDirection(user.EntryDirection)
+ builder.WithoutStatus(model.EntryStatusRemoved)
+ builder.WithOffset(offset)
+ builder.WithLimit(nbItemsPerPage)
+
+ entries, err := builder.GetEntries()
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ count, 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)
+ view.Set("category", category)
+ view.Set("total", count)
+ view.Set("entries", entries)
+ view.Set("pagination", getPagination(route.Path(h.router, "categoryEntriesAll", "categoryID", category.ID), count, offset))
+ view.Set("menu", "categories")
+ view.Set("user", user)
+ view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
+ view.Set("countErrorFeeds", h.store.CountErrorFeeds(user.ID))
+ view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID))
+ view.Set("showOnlyUnreadEntries", false)
+
+ html.OK(w, r, view.Render("category_entries"))
+}
diff --git a/ui/feed_entries.go b/ui/feed_entries.go
index 46fec9a..4191ed7 100644
--- a/ui/feed_entries.go
+++ b/ui/feed_entries.go
@@ -37,7 +37,7 @@ func (h *handler) showFeedEntriesPage(w http.ResponseWriter, r *http.Request) {
offset := request.QueryIntParam(r, "offset", 0)
builder := h.store.NewEntryQueryBuilder(user.ID)
builder.WithFeedID(feed.ID)
- builder.WithoutStatus(model.EntryStatusRemoved)
+ builder.WithStatus(model.EntryStatusUnread)
builder.WithOrder(model.DefaultSortingOrder)
builder.WithDirection(user.EntryDirection)
builder.WithOffset(offset)
@@ -66,6 +66,7 @@ func (h *handler) showFeedEntriesPage(w http.ResponseWriter, r *http.Request) {
view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
view.Set("countErrorFeeds", h.store.CountErrorFeeds(user.ID))
view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID))
+ view.Set("showOnlyUnreadEntries", true)
html.OK(w, r, view.Render("feed_entries"))
}
diff --git a/ui/feed_entries_all.go b/ui/feed_entries_all.go
new file mode 100644
index 0000000..f5bbab2
--- /dev/null
+++ b/ui/feed_entries_all.go
@@ -0,0 +1,72 @@
+// Copyright 2018 Frédéric Guillot. All rights reserved.
+// Use of this source code is governed by the Apache 2.0
+// license that can be found in the LICENSE file.
+
+package ui // import "miniflux.app/ui"
+
+import (
+ "net/http"
+
+ "miniflux.app/http/request"
+ "miniflux.app/http/response/html"
+ "miniflux.app/http/route"
+ "miniflux.app/model"
+ "miniflux.app/ui/session"
+ "miniflux.app/ui/view"
+)
+
+func (h *handler) showFeedEntriesAllPage(w http.ResponseWriter, r *http.Request) {
+ user, err := h.store.UserByID(request.UserID(r))
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ feedID := request.RouteInt64Param(r, "feedID")
+ feed, err := h.store.FeedByID(user.ID, feedID)
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ if feed == nil {
+ html.NotFound(w, r)
+ return
+ }
+
+ offset := request.QueryIntParam(r, "offset", 0)
+ builder := h.store.NewEntryQueryBuilder(user.ID)
+ builder.WithFeedID(feed.ID)
+ builder.WithoutStatus(model.EntryStatusRemoved)
+ builder.WithOrder(model.DefaultSortingOrder)
+ builder.WithDirection(user.EntryDirection)
+ builder.WithOffset(offset)
+ builder.WithLimit(nbItemsPerPage)
+
+ entries, err := builder.GetEntries()
+ if err != nil {
+ html.ServerError(w, r, err)
+ return
+ }
+
+ count, 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)
+ view.Set("feed", feed)
+ view.Set("entries", entries)
+ view.Set("total", count)
+ view.Set("pagination", getPagination(route.Path(h.router, "feedEntriesAll", "feedID", feed.ID), count, offset))
+ view.Set("menu", "feeds")
+ view.Set("user", user)
+ view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
+ view.Set("countErrorFeeds", h.store.CountErrorFeeds(user.ID))
+ view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID))
+ view.Set("showOnlyUnreadEntries", false)
+
+ html.OK(w, r, view.Render("feed_entries"))
+}
diff --git a/ui/ui.go b/ui/ui.go
index 0a41042..23440e7 100644
--- a/ui/ui.go
+++ b/ui/ui.go
@@ -66,6 +66,7 @@ func Serve(router *mux.Router, cfg *config.Config, store *storage.Storage, pool
uiRouter.HandleFunc("/feed/{feedID}/remove", handler.removeFeed).Name("removeFeed").Methods("POST")
uiRouter.HandleFunc("/feed/{feedID}/update", handler.updateFeed).Name("updateFeed").Methods("POST")
uiRouter.HandleFunc("/feed/{feedID}/entries", handler.showFeedEntriesPage).Name("feedEntries").Methods("GET")
+ uiRouter.HandleFunc("/feed/{feedID}/entries/all", handler.showFeedEntriesAllPage).Name("feedEntriesAll").Methods("GET")
uiRouter.HandleFunc("/feed/{feedID}/entry/{entryID}", handler.showFeedEntryPage).Name("feedEntry").Methods("GET")
uiRouter.HandleFunc("/feed/icon/{iconID}", handler.showIcon).Name("icon").Methods("GET")
@@ -75,6 +76,7 @@ func Serve(router *mux.Router, cfg *config.Config, store *storage.Storage, pool
uiRouter.HandleFunc("/category/create", handler.showCreateCategoryPage).Name("createCategory").Methods("GET")
uiRouter.HandleFunc("/category/save", handler.saveCategory).Name("saveCategory").Methods("POST")
uiRouter.HandleFunc("/category/{categoryID}/entries", handler.showCategoryEntriesPage).Name("categoryEntries").Methods("GET")
+ uiRouter.HandleFunc("/category/{categoryID}/entries/all", handler.showCategoryEntriesAllPage).Name("categoryEntriesAll").Methods("GET")
uiRouter.HandleFunc("/category/{categoryID}/edit", handler.showEditCategoryPage).Name("editCategory").Methods("GET")
uiRouter.HandleFunc("/category/{categoryID}/update", handler.updateCategory).Name("updateCategory").Methods("POST")
uiRouter.HandleFunc("/category/{categoryID}/remove", handler.removeCategory).Name("removeCategory").Methods("POST")