|
|
@ -464,19 +464,20 @@ def index(page):
|
|
|
|
title=_(u"Recently Added Books"), page="root")
|
|
|
|
title=_(u"Recently Added Books"), page="root")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@web.route('/<data>/<sort>', defaults={'page': 1})
|
|
|
|
@web.route('/<data>/<sort>', defaults={'page': 1, 'book_id': 1})
|
|
|
|
@web.route('/<data>/<sort>/<int:page>')
|
|
|
|
@web.route('/<data>/<sort>/<int:book_id>', defaults={'page': 1})
|
|
|
|
|
|
|
|
@web.route('/<data>/<sort>/<int:book_id>/<int:page>')
|
|
|
|
@login_required_if_no_ano
|
|
|
|
@login_required_if_no_ano
|
|
|
|
def books_list(data,sort, page):
|
|
|
|
def books_list(data, sort, book_id, page):
|
|
|
|
order = [db.Books.timestamp.desc()]
|
|
|
|
order = [db.Books.timestamp.desc()]
|
|
|
|
if sort == 'pubnew':
|
|
|
|
if sort == 'pubnew':
|
|
|
|
order = [db.Books.pubdate.desc()]
|
|
|
|
order = [db.Books.pubdate.desc()]
|
|
|
|
if sort == 'pubold':
|
|
|
|
if sort == 'pubold':
|
|
|
|
order = [db.Books.pubdate]
|
|
|
|
order = [db.Books.pubdate]
|
|
|
|
if sort == 'abc':
|
|
|
|
if sort == 'abc':
|
|
|
|
[db.Books.sort]
|
|
|
|
order = [db.Books.sort]
|
|
|
|
if sort == 'zyx':
|
|
|
|
if sort == 'zyx':
|
|
|
|
[db.Books.sort.desc()]
|
|
|
|
order = [db.Books.sort.desc()]
|
|
|
|
if sort == 'new':
|
|
|
|
if sort == 'new':
|
|
|
|
order = [db.Books.timestamp.desc()]
|
|
|
|
order = [db.Books.timestamp.desc()]
|
|
|
|
if sort == 'old':
|
|
|
|
if sort == 'old':
|
|
|
@ -503,38 +504,44 @@ def books_list(data,sort, page):
|
|
|
|
elif data == "read":
|
|
|
|
elif data == "read":
|
|
|
|
return render_read_books(page, True, order=order)
|
|
|
|
return render_read_books(page, True, order=order)
|
|
|
|
elif data == "hot":
|
|
|
|
elif data == "hot":
|
|
|
|
if current_user.check_visibility(ub.SIDEBAR_HOT):
|
|
|
|
return render_hot_books(page)
|
|
|
|
if current_user.show_detail_random():
|
|
|
|
elif data == "author":
|
|
|
|
random = db.session.query(db.Books).filter(common_filters()) \
|
|
|
|
return render_author_books(page, book_id, order)
|
|
|
|
.order_by(func.random()).limit(config.config_random_books)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
random = false()
|
|
|
|
|
|
|
|
off = int(int(config.config_books_per_page) * (page - 1))
|
|
|
|
|
|
|
|
all_books = ub.session.query(ub.Downloads, ub.func.count(ub.Downloads.book_id)).order_by(
|
|
|
|
|
|
|
|
ub.func.count(ub.Downloads.book_id).desc()).group_by(ub.Downloads.book_id)
|
|
|
|
|
|
|
|
hot_books = all_books.offset(off).limit(config.config_books_per_page)
|
|
|
|
|
|
|
|
entries = list()
|
|
|
|
|
|
|
|
for book in hot_books:
|
|
|
|
|
|
|
|
downloadBook = db.session.query(db.Books).filter(common_filters()).filter(
|
|
|
|
|
|
|
|
db.Books.id == book.Downloads.book_id).first()
|
|
|
|
|
|
|
|
if downloadBook:
|
|
|
|
|
|
|
|
entries.append(downloadBook)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
ub.delete_download(book.Downloads.book_id)
|
|
|
|
|
|
|
|
# ub.session.query(ub.Downloads).filter(book.Downloads.book_id == ub.Downloads.book_id).delete()
|
|
|
|
|
|
|
|
# ub.session.commit()
|
|
|
|
|
|
|
|
numBooks = entries.__len__()
|
|
|
|
|
|
|
|
pagination = Pagination(page, config.config_books_per_page, numBooks)
|
|
|
|
|
|
|
|
return render_title_template('index.html', random=random, entries=entries, pagination=pagination,
|
|
|
|
|
|
|
|
title=_(u"Hot Books (most downloaded)"), page="hot")
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
entries, random, pagination = fill_indexpage(page, db.Books, True, order)
|
|
|
|
entries, random, pagination = fill_indexpage(page, db.Books, True, order)
|
|
|
|
return render_title_template('index.html', random=random, entries=entries, pagination=pagination,
|
|
|
|
return render_title_template('index.html', random=random, entries=entries, pagination=pagination,
|
|
|
|
title=_(u"Books"), page="newest")
|
|
|
|
title=_(u"Books"), page="newest")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def render_hot_books(page):
|
|
|
|
|
|
|
|
if current_user.check_visibility(ub.SIDEBAR_HOT):
|
|
|
|
|
|
|
|
if current_user.show_detail_random():
|
|
|
|
|
|
|
|
random = db.session.query(db.Books).filter(common_filters()) \
|
|
|
|
|
|
|
|
.order_by(func.random()).limit(config.config_random_books)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
random = false()
|
|
|
|
|
|
|
|
off = int(int(config.config_books_per_page) * (page - 1))
|
|
|
|
|
|
|
|
all_books = ub.session.query(ub.Downloads, ub.func.count(ub.Downloads.book_id)).order_by(
|
|
|
|
|
|
|
|
ub.func.count(ub.Downloads.book_id).desc()).group_by(ub.Downloads.book_id)
|
|
|
|
|
|
|
|
hot_books = all_books.offset(off).limit(config.config_books_per_page)
|
|
|
|
|
|
|
|
entries = list()
|
|
|
|
|
|
|
|
for book in hot_books:
|
|
|
|
|
|
|
|
downloadBook = db.session.query(db.Books).filter(common_filters()).filter(
|
|
|
|
|
|
|
|
db.Books.id == book.Downloads.book_id).first()
|
|
|
|
|
|
|
|
if downloadBook:
|
|
|
|
|
|
|
|
entries.append(downloadBook)
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
ub.delete_download(book.Downloads.book_id)
|
|
|
|
|
|
|
|
# ub.session.query(ub.Downloads).filter(book.Downloads.book_id == ub.Downloads.book_id).delete()
|
|
|
|
|
|
|
|
# ub.session.commit()
|
|
|
|
|
|
|
|
numBooks = entries.__len__()
|
|
|
|
|
|
|
|
pagination = Pagination(page, config.config_books_per_page, numBooks)
|
|
|
|
|
|
|
|
return render_title_template('index.html', random=random, entries=entries, pagination=pagination,
|
|
|
|
|
|
|
|
title=_(u"Hot Books (most downloaded)"), page="hot")
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@web.route("/author")
|
|
|
|
@web.route("/author")
|
|
|
|
@login_required_if_no_ano
|
|
|
|
@login_required_if_no_ano
|
|
|
|
def author_list():
|
|
|
|
def author_list():
|
|
|
@ -547,18 +554,16 @@ def author_list():
|
|
|
|
.group_by(func.upper(func.substr(db.Authors.sort,1,1))).all()
|
|
|
|
.group_by(func.upper(func.substr(db.Authors.sort,1,1))).all()
|
|
|
|
for entry in entries:
|
|
|
|
for entry in entries:
|
|
|
|
entry.Authors.name = entry.Authors.name.replace('|', ',')
|
|
|
|
entry.Authors.name = entry.Authors.name.replace('|', ',')
|
|
|
|
return render_title_template('list.html', entries=entries, folder='web.author', charlist=charlist,
|
|
|
|
return render_title_template('list.html', entries=entries, folder='web.books_list', charlist=charlist,
|
|
|
|
title=u"Author list", page="authorlist")
|
|
|
|
title=u"Author list", page="authorlist", data='author')
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
abort(404)
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@web.route("/author/<int:book_id>", defaults={'page': 1})
|
|
|
|
# ToDo wrong order function
|
|
|
|
@web.route("/author/<int:book_id>/<int:page>")
|
|
|
|
def render_author_books(page, book_id, order):
|
|
|
|
@login_required_if_no_ano
|
|
|
|
|
|
|
|
def author(book_id, page):
|
|
|
|
|
|
|
|
entries, __, pagination = fill_indexpage(page, db.Books, db.Books.authors.any(db.Authors.id == book_id),
|
|
|
|
entries, __, pagination = fill_indexpage(page, db.Books, db.Books.authors.any(db.Authors.id == book_id),
|
|
|
|
[db.Series.name, db.Books.series_index], db.books_series_link, db.Series)
|
|
|
|
[order[0], db.Series.name, db.Books.series_index], db.books_series_link, db.Series)
|
|
|
|
if entries is None:
|
|
|
|
if entries is None:
|
|
|
|
flash(_(u"Error opening eBook. File does not exist or file is not accessible:"), category="error")
|
|
|
|
flash(_(u"Error opening eBook. File does not exist or file is not accessible:"), category="error")
|
|
|
|
return redirect(url_for("web.index"))
|
|
|
|
return redirect(url_for("web.index"))
|
|
|
|