forked from Archives/Athou_commafeed
display feeds without category when the root category is selected
This commit is contained in:
@@ -44,6 +44,7 @@ public class StartupBean {
|
|||||||
|
|
||||||
if (userService.getCount() == 0) {
|
if (userService.getCount() == 0) {
|
||||||
log.info("Populating database with default values");
|
log.info("Populating database with default values");
|
||||||
|
|
||||||
User user = new User();
|
User user = new User();
|
||||||
byte[] salt = encryptionService.generateSalt();
|
byte[] salt = encryptionService.generateSalt();
|
||||||
user.setName("admin");
|
user.setName("admin");
|
||||||
@@ -52,13 +53,21 @@ public class StartupBean {
|
|||||||
salt));
|
salt));
|
||||||
userService.save(user);
|
userService.save(user);
|
||||||
|
|
||||||
|
User testUser = new User();
|
||||||
|
byte[] saltTest = encryptionService.generateSalt();
|
||||||
|
testUser.setName("test");
|
||||||
|
testUser.setSalt(saltTest);
|
||||||
|
testUser.setPassword(encryptionService.getEncryptedPassword("test",
|
||||||
|
saltTest));
|
||||||
|
userService.save(testUser);
|
||||||
|
|
||||||
Feed dilbert = new Feed(
|
Feed dilbert = new Feed(
|
||||||
"http://feed.dilbert.com/dilbert/daily_strip");
|
"http://feed.dilbert.com/dilbert/daily_strip");
|
||||||
feedService.save(dilbert);
|
feedService.save(dilbert);
|
||||||
|
|
||||||
Feed engadget = new Feed("http://www.engadget.com/rss.xml");
|
Feed engadget = new Feed("http://www.engadget.com/rss.xml");
|
||||||
feedService.save(engadget);
|
feedService.save(engadget);
|
||||||
|
|
||||||
Feed frandroid = new Feed("http://feeds.feedburner.com/frandroid");
|
Feed frandroid = new Feed("http://feeds.feedburner.com/frandroid");
|
||||||
feedService.save(frandroid);
|
feedService.save(frandroid);
|
||||||
|
|
||||||
@@ -92,7 +101,7 @@ public class StartupBean {
|
|||||||
sub2.setTitle("Engadget");
|
sub2.setTitle("Engadget");
|
||||||
sub2.setUser(user);
|
sub2.setUser(user);
|
||||||
feedSubscriptionService.save(sub2);
|
feedSubscriptionService.save(sub2);
|
||||||
|
|
||||||
FeedSubscription sub3 = new FeedSubscription();
|
FeedSubscription sub3 = new FeedSubscription();
|
||||||
sub3.setFeed(frandroid);
|
sub3.setFeed(frandroid);
|
||||||
sub3.setTitle("Frandroid");
|
sub3.setTitle("Frandroid");
|
||||||
|
|||||||
@@ -65,6 +65,30 @@ public class FeedEntryService extends GenericDAO<FeedEntry, Long> {
|
|||||||
return query.getResultList();
|
return query.getResultList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<FeedEntryWithStatus> getEntries(User user, boolean unreadOnly) {
|
||||||
|
return getEntries(user, unreadOnly, -1, -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<FeedEntryWithStatus> getEntries(User user, boolean unreadOnly,
|
||||||
|
int offset, int limit) {
|
||||||
|
String queryName = null;
|
||||||
|
if (unreadOnly) {
|
||||||
|
queryName = "Entry.unread";
|
||||||
|
} else {
|
||||||
|
queryName = "Entry.all";
|
||||||
|
}
|
||||||
|
Query query = em.createNamedQuery(queryName);
|
||||||
|
query.setParameter("userId", user.getId());
|
||||||
|
query.setParameter("user", user);
|
||||||
|
if (offset > -1) {
|
||||||
|
query.setFirstResult(offset);
|
||||||
|
}
|
||||||
|
if (limit > -1) {
|
||||||
|
query.setMaxResults(limit);
|
||||||
|
}
|
||||||
|
return buildList(query.getResultList());
|
||||||
|
}
|
||||||
|
|
||||||
public List<FeedEntryWithStatus> getEntries(Feed feed, User user,
|
public List<FeedEntryWithStatus> getEntries(Feed feed, User user,
|
||||||
boolean unreadOnly) {
|
boolean unreadOnly) {
|
||||||
return getEntries(feed, user, unreadOnly, -1, -1);
|
return getEntries(feed, user, unreadOnly, -1, -1);
|
||||||
@@ -91,13 +115,13 @@ public class FeedEntryService extends GenericDAO<FeedEntry, Long> {
|
|||||||
return buildList(query.getResultList());
|
return buildList(query.getResultList());
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<FeedEntryWithStatus> getEntries(List<FeedCategory> categories, User user,
|
public List<FeedEntryWithStatus> getEntries(List<FeedCategory> categories,
|
||||||
boolean unreadOnly) {
|
User user, boolean unreadOnly) {
|
||||||
return getEntries(categories, user, unreadOnly, -1, -1);
|
return getEntries(categories, user, unreadOnly, -1, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<FeedEntryWithStatus> getEntries(List<FeedCategory> categories, User user,
|
public List<FeedEntryWithStatus> getEntries(List<FeedCategory> categories,
|
||||||
boolean unreadOnly, int offset, int limit) {
|
User user, boolean unreadOnly, int offset, int limit) {
|
||||||
String queryName = null;
|
String queryName = null;
|
||||||
if (unreadOnly) {
|
if (unreadOnly) {
|
||||||
queryName = "Entry.unreadByCategories";
|
queryName = "Entry.unreadByCategories";
|
||||||
@@ -116,11 +140,11 @@ public class FeedEntryService extends GenericDAO<FeedEntry, Long> {
|
|||||||
}
|
}
|
||||||
return buildList(query.getResultList());
|
return buildList(query.getResultList());
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("rawtypes")
|
@SuppressWarnings("rawtypes")
|
||||||
private List<FeedEntryWithStatus> buildList(List list){
|
private List<FeedEntryWithStatus> buildList(List list) {
|
||||||
List<FeedEntryWithStatus> result = Lists.newArrayList();
|
List<FeedEntryWithStatus> result = Lists.newArrayList();
|
||||||
for (Object object :list) {
|
for (Object object : list) {
|
||||||
Object[] array = (Object[]) object;
|
Object[] array = (Object[]) object;
|
||||||
FeedEntry entry = (FeedEntry) array[0];
|
FeedEntry entry = (FeedEntry) array[0];
|
||||||
FeedEntryStatus status = (FeedEntryStatus) array[1];
|
FeedEntryStatus status = (FeedEntryStatus) array[1];
|
||||||
|
|||||||
@@ -1,11 +1,9 @@
|
|||||||
package com.commafeed.frontend.pages;
|
package com.commafeed.frontend.pages;
|
||||||
|
|
||||||
import org.apache.wicket.markup.html.WebPage;
|
|
||||||
|
|
||||||
import com.commafeed.frontend.pages.auth.LoginPanel;
|
import com.commafeed.frontend.pages.auth.LoginPanel;
|
||||||
|
|
||||||
@SuppressWarnings("serial")
|
@SuppressWarnings("serial")
|
||||||
public class LoginPage extends WebPage {
|
public class LoginPage extends BasePage {
|
||||||
|
|
||||||
public LoginPage() {
|
public LoginPage() {
|
||||||
add(new LoginPanel("login"));
|
add(new LoginPanel("login"));
|
||||||
|
|||||||
@@ -59,13 +59,6 @@ public class EntriesREST extends AbstractREST {
|
|||||||
buildEntries(subscription, offset, limit, unreadOnly));
|
buildEntries(subscription, offset, limit, unreadOnly));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
FeedCategory feedCategory = null;
|
|
||||||
if (!ALL.equals(id)) {
|
|
||||||
feedCategory = feedCategoryService.findById(getUser(),
|
|
||||||
Long.valueOf(id));
|
|
||||||
}
|
|
||||||
List<FeedCategory> childrenCategories = feedCategoryService
|
|
||||||
.findAllChildrenCategories(getUser(), feedCategory);
|
|
||||||
|
|
||||||
List<FeedSubscription> subs = feedSubscriptionService
|
List<FeedSubscription> subs = feedSubscriptionService
|
||||||
.findAll(getUser());
|
.findAll(getUser());
|
||||||
@@ -76,10 +69,36 @@ public class EntriesREST extends AbstractREST {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
entries.setName(ALL.equals(id) ? "All" : feedCategory.getName());
|
if (ALL.equals(id)) {
|
||||||
entries.getEntries().addAll(
|
entries.setName("All");
|
||||||
buildEntries(childrenCategories, subMapping, offset, limit,
|
entries.getEntries().addAll(
|
||||||
unreadOnly));
|
buildEntries(subMapping, offset, limit, unreadOnly));
|
||||||
|
} else {
|
||||||
|
FeedCategory feedCategory = feedCategoryService.findById(
|
||||||
|
getUser(), Long.valueOf(id));
|
||||||
|
List<FeedCategory> childrenCategories = feedCategoryService
|
||||||
|
.findAllChildrenCategories(getUser(), feedCategory);
|
||||||
|
entries.getEntries().addAll(
|
||||||
|
buildEntries(childrenCategories, subMapping, offset,
|
||||||
|
limit, unreadOnly));
|
||||||
|
entries.setName(feedCategory.getName());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return entries;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<Entry> buildEntries(Map<Long, FeedSubscription> subMapping,
|
||||||
|
int offset, int limit, boolean unreadOnly) {
|
||||||
|
List<Entry> entries = Lists.newArrayList();
|
||||||
|
|
||||||
|
List<FeedEntryWithStatus> unreadEntries = feedEntryService.getEntries(
|
||||||
|
getUser(), unreadOnly, offset, limit);
|
||||||
|
for (FeedEntryWithStatus feedEntry : unreadEntries) {
|
||||||
|
Long id = feedEntry.getEntry().getFeed().getId();
|
||||||
|
entries.add(populateEntry(buildEntry(feedEntry), subMapping.get(id)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return entries;
|
return entries;
|
||||||
@@ -155,16 +174,20 @@ public class EntriesREST extends AbstractREST {
|
|||||||
markEntry(entry, read);
|
markEntry(entry, read);
|
||||||
}
|
}
|
||||||
} else if (type == Type.category) {
|
} else if (type == Type.category) {
|
||||||
FeedCategory feedCategory = null;
|
List<FeedEntryWithStatus> entries = null;
|
||||||
if (!ALL.equals(id)) {
|
|
||||||
feedCategory = feedCategoryService.findById(getUser(),
|
if (ALL.equals(id)) {
|
||||||
Long.valueOf(id));
|
entries = feedEntryService.getEntries(getUser(), false);
|
||||||
}
|
} else {
|
||||||
List<FeedCategory> childrenCategories = feedCategoryService
|
FeedCategory feedCategory = feedCategoryService.findById(
|
||||||
.findAllChildrenCategories(getUser(), feedCategory);
|
getUser(), Long.valueOf(id));
|
||||||
|
List<FeedCategory> childrenCategories = feedCategoryService
|
||||||
|
.findAllChildrenCategories(getUser(), feedCategory);
|
||||||
|
|
||||||
|
entries = feedEntryService.getEntries(childrenCategories,
|
||||||
|
getUser(), false);
|
||||||
|
}
|
||||||
|
|
||||||
List<FeedEntryWithStatus> entries = feedEntryService.getEntries(
|
|
||||||
childrenCategories, getUser(), false);
|
|
||||||
for (FeedEntryWithStatus entry : entries) {
|
for (FeedEntryWithStatus entry : entries) {
|
||||||
markEntry(entry, true);
|
markEntry(entry, true);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,14 @@
|
|||||||
<named-query name="Entry.byGuids">
|
<named-query name="Entry.byGuids">
|
||||||
<query>select e from FeedEntry e where e.guid in (:guids) order by e.updated desc</query>
|
<query>select e from FeedEntry e where e.guid in (:guids) order by e.updated desc</query>
|
||||||
</named-query>
|
</named-query>
|
||||||
|
|
||||||
|
<named-query name="Entry.unread">
|
||||||
|
<query>select e, s from FeedEntry e LEFT JOIN e.statuses s WITH (s.user.id=:userId) where exists (select s2 from FeedSubscription s2 where s2.user=:user and s2.feed = e.feed) and not exists (select s3 from FeedEntryStatus s3 where s3.entry = e and s3.user =:user and s3.read=true) order by e.updated desc</query>
|
||||||
|
</named-query>
|
||||||
|
<named-query name="Entry.all">
|
||||||
|
<query>select e, s from FeedEntry e LEFT JOIN e.statuses s WITH (s.user.id=:userId) where exists (select s2 from FeedSubscription s2 where s2.user=:user and s2.feed = e.feed) order by e.updated desc</query>
|
||||||
|
</named-query>
|
||||||
|
|
||||||
<named-query name="Entry.unreadByFeed">
|
<named-query name="Entry.unreadByFeed">
|
||||||
<query>select e, s from FeedEntry e LEFT JOIN e.statuses s WITH (s.user.id=:userId) where e.feed=:feed and not exists (select s2 from FeedEntryStatus s2 where s2.entry=e and s2.user.id=:userId and s2.read=true) order by e.updated desc</query>
|
<query>select e, s from FeedEntry e LEFT JOIN e.statuses s WITH (s.user.id=:userId) where e.feed=:feed and not exists (select s2 from FeedEntryStatus s2 where s2.entry=e and s2.user.id=:userId and s2.read=true) order by e.updated desc</query>
|
||||||
</named-query>
|
</named-query>
|
||||||
|
|||||||
Reference in New Issue
Block a user