mirror of
				https://github.com/janeczku/calibre-web
				synced 2025-10-25 12:27:39 +00:00 
			
		
		
		
	Fix for #2325 (author sort order differs from authors order with readonly database)
This commit is contained in:
		
							
								
								
									
										21
									
								
								cps/db.py
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								cps/db.py
									
									
									
									
									
								
							| @@ -17,7 +17,7 @@ | |||||||
| #  You should have received a copy of the GNU General Public License | #  You should have received a copy of the GNU General Public License | ||||||
| #  along with this program. If not, see <http://www.gnu.org/licenses/>. | #  along with this program. If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
| import sys | import copy | ||||||
| import os | import os | ||||||
| import re | import re | ||||||
| import ast | import ast | ||||||
| @@ -776,6 +776,8 @@ class CalibreDB(): | |||||||
|  |  | ||||||
|     # Orders all Authors in the list according to authors sort |     # Orders all Authors in the list according to authors sort | ||||||
|     def order_authors(self, entries, list_return=False, combined=False): |     def order_authors(self, entries, list_return=False, combined=False): | ||||||
|  |         # entries_copy = copy.deepcopy(entries) | ||||||
|  |         # entries_copy =[] | ||||||
|         for entry in entries: |         for entry in entries: | ||||||
|             if combined: |             if combined: | ||||||
|                 sort_authors = entry.Books.author_sort.split('&') |                 sort_authors = entry.Books.author_sort.split('&') | ||||||
| @@ -785,26 +787,31 @@ class CalibreDB(): | |||||||
|                 sort_authors = entry.author_sort.split('&') |                 sort_authors = entry.author_sort.split('&') | ||||||
|                 ids = [a.id for a in entry.authors] |                 ids = [a.id for a in entry.authors] | ||||||
|             authors_ordered = list() |             authors_ordered = list() | ||||||
|             error = False |             # error = False | ||||||
|             for auth in sort_authors: |             for auth in sort_authors: | ||||||
|                 results = self.session.query(Authors).filter(Authors.sort == auth.lstrip().strip()).all() |                 results = self.session.query(Authors).filter(Authors.sort == auth.lstrip().strip()).all() | ||||||
|                 # ToDo: How to handle not found author name |                 # ToDo: How to handle not found author name | ||||||
|                 if not len(results): |                 if not len(results): | ||||||
|                     log.error("Author {} not found to display name in right order".format(auth)) |                     log.error("Author {} not found to display name in right order".format(auth)) | ||||||
|                     error = True |                     # error = True | ||||||
|                     break |                     break | ||||||
|                 for r in results: |                 for r in results: | ||||||
|                     if r.id in ids: |                     if r.id in ids: | ||||||
|                         authors_ordered.append(r) |                         authors_ordered.append(r) | ||||||
|             if not error: |                         ids.remove(r.id) | ||||||
|  |             for author_id in ids: | ||||||
|  |                 result = self.session.query(Authors).filter(Authors.id == author_id).first() | ||||||
|  |                 authors_ordered.append(result) | ||||||
|  |  | ||||||
|  |             if list_return: | ||||||
|                 if combined: |                 if combined: | ||||||
|                     entry.Books.authors = authors_ordered |                     entry.Books.authors = authors_ordered | ||||||
|                 else: |                 else: | ||||||
|                     entry.authors = authors_ordered |                     entry.ordered_authors = authors_ordered | ||||||
|         if list_return: |  | ||||||
|             return entries |  | ||||||
|             else: |             else: | ||||||
|                 return authors_ordered |                 return authors_ordered | ||||||
|  |         return entries | ||||||
|  |  | ||||||
|  |  | ||||||
|     def get_typeahead(self, database, query, replace=('', ''), tag_filter=true()): |     def get_typeahead(self, database, query, replace=('', ''), tag_filter=true()): | ||||||
|         query = query or '' |         query = query or '' | ||||||
|   | |||||||
| @@ -47,7 +47,7 @@ | |||||||
|           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> |           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         </a> |         </a> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} |             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
|               {% if not loop.first %} |               {% if not loop.first %} | ||||||
|                 <span class="author-hidden-divider">&</span> |                 <span class="author-hidden-divider">&</span> | ||||||
| @@ -110,7 +110,7 @@ | |||||||
|       <div class="meta"> |       <div class="meta"> | ||||||
|         <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> |         <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
| 		  {% for author in entry.authors %} | 		  {% for author in entry.ordered_authors %} | ||||||
| 			{% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | 			{% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
| 				<a class="author-name author-hidden" href="https://www.goodreads.com/author/show/{{ author.gid }}" target="_blank" rel="noopener">{{author.name.replace('|',',')}}</a> | 				<a class="author-name author-hidden" href="https://www.goodreads.com/author/show/{{ author.gid }}" target="_blank" rel="noopener">{{author.name.replace('|',',')}}</a> | ||||||
| 				{% if loop.last %} | 				{% if loop.last %} | ||||||
|   | |||||||
| @@ -99,7 +99,7 @@ | |||||||
|       </div> |       </div> | ||||||
|       <h2 id="title">{{entry.title}}</h2> |       <h2 id="title">{{entry.title}}</h2> | ||||||
|       <p class="author"> |       <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             <a href="{{url_for('web.books_list',  data='author', sort_param='stored', book_id=author.id ) }}">{{author.name.replace('|',',')}}</a> |             <a href="{{url_for('web.books_list',  data='author', sort_param='stored', book_id=author.id ) }}">{{author.name.replace('|',',')}}</a> | ||||||
|             {% if not loop.last %} |             {% if not loop.last %} | ||||||
|               & |               & | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ | |||||||
|           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> |           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         </a> |         </a> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} |             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
|               {% if not loop.first %} |               {% if not loop.first %} | ||||||
|                 <span class="author-hidden-divider">&</span> |                 <span class="author-hidden-divider">&</span> | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ | |||||||
|           <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> |           <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         </a> |         </a> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} |             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
|               {% if not loop.first %} |               {% if not loop.first %} | ||||||
|                 <span class="author-hidden-divider">&</span> |                 <span class="author-hidden-divider">&</span> | ||||||
| @@ -101,7 +101,7 @@ | |||||||
|           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> |           <p title="{{ entry.title }}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         </a> |         </a> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} |             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
|               {% if not loop.first %} |               {% if not loop.first %} | ||||||
|                 <span class="author-hidden-divider">&</span> |                 <span class="author-hidden-divider">&</span> | ||||||
|   | |||||||
| @@ -105,7 +105,7 @@ | |||||||
|  |  | ||||||
|   <div class="sm2-playlist-wrapper"> |   <div class="sm2-playlist-wrapper"> | ||||||
|     <ul class="sm2-playlist-bd"> |     <ul class="sm2-playlist-bd"> | ||||||
|       <li><a href="{{ url_for('web.serve_book', book_id=mp3file,book_format=audioformat)}}"><b>{% for author in entry.authors %}{{author.name.replace('|',',')}} |       <li><a href="{{ url_for('web.serve_book', book_id=mp3file,book_format=audioformat)}}"><b>{% for author in entry.ordered_authors %}{{author.name.replace('|',',')}} | ||||||
|         {% if not loop.last %} & {% endif %} {% endfor %}</b> - {{entry.title}}</a></li> |         {% if not loop.last %} & {% endif %} {% endfor %}</b> - {{entry.title}}</a></li> | ||||||
|     </ul> |     </ul> | ||||||
|   </div> |   </div> | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ | |||||||
|           <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> |           <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         </a> |         </a> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} |             {% if loop.index > g.config_authors_max and g.config_authors_max != 0 %} | ||||||
|               {% if not loop.first %} |               {% if not loop.first %} | ||||||
|                 <span class="author-hidden-divider">&</span> |                 <span class="author-hidden-divider">&</span> | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ | |||||||
|       <div class="meta"> |       <div class="meta"> | ||||||
|         <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> |         <p title="{{entry.title}}" class="title">{{entry.title|shortentitle}}</p> | ||||||
|         <p class="author"> |         <p class="author"> | ||||||
|           {% for author in entry.authors %} |           {% for author in entry.ordered_authors %} | ||||||
|             <a href="{{url_for('web.books_list',  data='author', sort_param='new', book_id=author.id) }}">{{author.name.replace('|',',')}}</a> |             <a href="{{url_for('web.books_list',  data='author', sort_param='new', book_id=author.id) }}">{{author.name.replace('|',',')}}</a> | ||||||
|             {% if not loop.last %} |             {% if not loop.last %} | ||||||
|               & |               & | ||||||
|   | |||||||
							
								
								
									
										78
									
								
								cps/web.py
									
									
									
									
									
								
							
							
						
						
									
										78
									
								
								cps/web.py
									
									
									
									
									
								
							| @@ -300,43 +300,43 @@ def get_matching_tags(): | |||||||
|     return json_dumps |     return json_dumps | ||||||
|  |  | ||||||
|  |  | ||||||
| def get_sort_function(sort, data): | def get_sort_function(sort_param, data): | ||||||
|     order = [db.Books.timestamp.desc()] |     order = [db.Books.timestamp.desc()] | ||||||
|     if sort == 'stored': |     if sort_param == 'stored': | ||||||
|         sort = current_user.get_view_property(data, 'stored') |         sort_param = current_user.get_view_property(data, 'stored') | ||||||
|     else: |     else: | ||||||
|         current_user.set_view_property(data, 'stored', sort) |         current_user.set_view_property(data, 'stored', sort_param) | ||||||
|     if sort == 'pubnew': |     if sort_param == 'pubnew': | ||||||
|         order = [db.Books.pubdate.desc()] |         order = [db.Books.pubdate.desc()] | ||||||
|     if sort == 'pubold': |     if sort_param == 'pubold': | ||||||
|         order = [db.Books.pubdate] |         order = [db.Books.pubdate] | ||||||
|     if sort == 'abc': |     if sort_param == 'abc': | ||||||
|         order = [db.Books.sort] |         order = [db.Books.sort] | ||||||
|     if sort == 'zyx': |     if sort_param == 'zyx': | ||||||
|         order = [db.Books.sort.desc()] |         order = [db.Books.sort.desc()] | ||||||
|     if sort == 'new': |     if sort_param == 'new': | ||||||
|         order = [db.Books.timestamp.desc()] |         order = [db.Books.timestamp.desc()] | ||||||
|     if sort == 'old': |     if sort_param == 'old': | ||||||
|         order = [db.Books.timestamp] |         order = [db.Books.timestamp] | ||||||
|     if sort == 'authaz': |     if sort_param == 'authaz': | ||||||
|         order = [db.Books.author_sort.asc(), db.Series.name, db.Books.series_index] |         order = [db.Books.author_sort.asc(), db.Series.name, db.Books.series_index] | ||||||
|     if sort == 'authza': |     if sort_param == 'authza': | ||||||
|         order = [db.Books.author_sort.desc(), db.Series.name.desc(), db.Books.series_index.desc()] |         order = [db.Books.author_sort.desc(), db.Series.name.desc(), db.Books.series_index.desc()] | ||||||
|     if sort == 'seriesasc': |     if sort_param == 'seriesasc': | ||||||
|         order = [db.Books.series_index.asc()] |         order = [db.Books.series_index.asc()] | ||||||
|     if sort == 'seriesdesc': |     if sort_param == 'seriesdesc': | ||||||
|         order = [db.Books.series_index.desc()] |         order = [db.Books.series_index.desc()] | ||||||
|     if sort == 'hotdesc': |     if sort_param == 'hotdesc': | ||||||
|         order = [func.count(ub.Downloads.book_id).desc()] |         order = [func.count(ub.Downloads.book_id).desc()] | ||||||
|     if sort == 'hotasc': |     if sort_param == 'hotasc': | ||||||
|         order = [func.count(ub.Downloads.book_id).asc()] |         order = [func.count(ub.Downloads.book_id).asc()] | ||||||
|     if sort is None: |     if sort_param is None: | ||||||
|         sort = "new" |         sort_param = "new" | ||||||
|     return order, sort |     return order, sort_param | ||||||
|  |  | ||||||
|  |  | ||||||
| def render_books_list(data, sort, book_id, page): | def render_books_list(data, sort_param, book_id, page): | ||||||
|     order = get_sort_function(sort, data) |     order = get_sort_function(sort_param, data) | ||||||
|     if data == "rated": |     if data == "rated": | ||||||
|         return render_rated_books(page, book_id, order=order) |         return render_rated_books(page, book_id, order=order) | ||||||
|     elif data == "discover": |     elif data == "discover": | ||||||
| @@ -604,7 +604,7 @@ def render_language_books(page, name, order): | |||||||
|  |  | ||||||
|  |  | ||||||
| def render_read_books(page, are_read, as_xml=False, order=None): | def render_read_books(page, are_read, as_xml=False, order=None): | ||||||
|     sort = order[0] if order else [] |     sort_param = order[0] if order else [] | ||||||
|     if not config.config_read_column: |     if not config.config_read_column: | ||||||
|         if are_read: |         if are_read: | ||||||
|             db_filter = and_(ub.ReadBook.user_id == int(current_user.id), |             db_filter = and_(ub.ReadBook.user_id == int(current_user.id), | ||||||
| @@ -614,7 +614,7 @@ def render_read_books(page, are_read, as_xml=False, order=None): | |||||||
|         entries, random, pagination = calibre_db.fill_indexpage(page, 0, |         entries, random, pagination = calibre_db.fill_indexpage(page, 0, | ||||||
|                                                                 db.Books, |                                                                 db.Books, | ||||||
|                                                                 db_filter, |                                                                 db_filter, | ||||||
|                                                                 sort, |                                                                 sort_param, | ||||||
|                                                                 False, 0, |                                                                 False, 0, | ||||||
|                                                                 db.books_series_link, |                                                                 db.books_series_link, | ||||||
|                                                                 db.Books.id == db.books_series_link.c.book, |                                                                 db.Books.id == db.books_series_link.c.book, | ||||||
| @@ -629,7 +629,7 @@ def render_read_books(page, are_read, as_xml=False, order=None): | |||||||
|             entries, random, pagination = calibre_db.fill_indexpage(page, 0, |             entries, random, pagination = calibre_db.fill_indexpage(page, 0, | ||||||
|                                                                     db.Books, |                                                                     db.Books, | ||||||
|                                                                     db_filter, |                                                                     db_filter, | ||||||
|                                                                     sort, |                                                                     sort_param, | ||||||
|                                                                     False, 0, |                                                                     False, 0, | ||||||
|                                                                     db.books_series_link, |                                                                     db.books_series_link, | ||||||
|                                                                     db.Books.id == db.books_series_link.c.book, |                                                                     db.Books.id == db.books_series_link.c.book, | ||||||
| @@ -656,8 +656,8 @@ def render_read_books(page, are_read, as_xml=False, order=None): | |||||||
|                                      title=name, page=pagename, order=order[1]) |                                      title=name, page=pagename, order=order[1]) | ||||||
|  |  | ||||||
|  |  | ||||||
| def render_archived_books(page, sort): | def render_archived_books(page, sort_param): | ||||||
|     order = sort[0] or [] |     order = sort_param[0] or [] | ||||||
|     archived_books = ( |     archived_books = ( | ||||||
|         ub.session.query(ub.ArchivedBook) |         ub.session.query(ub.ArchivedBook) | ||||||
|         .filter(ub.ArchivedBook.user_id == int(current_user.id)) |         .filter(ub.ArchivedBook.user_id == int(current_user.id)) | ||||||
| @@ -678,7 +678,7 @@ def render_archived_books(page, sort): | |||||||
|     name = _(u'Archived Books') + ' (' + str(len(archived_book_ids)) + ')' |     name = _(u'Archived Books') + ' (' + str(len(archived_book_ids)) + ')' | ||||||
|     pagename = "archived" |     pagename = "archived" | ||||||
|     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=name, page=pagename, order=sort[1]) |                                  title=name, page=pagename, order=sort_param[1]) | ||||||
|  |  | ||||||
|  |  | ||||||
| def render_prepare_search_form(cc): | def render_prepare_search_form(cc): | ||||||
| @@ -767,32 +767,32 @@ def list_books(): | |||||||
|     off = int(request.args.get("offset") or 0) |     off = int(request.args.get("offset") or 0) | ||||||
|     limit = int(request.args.get("limit") or config.config_books_per_page) |     limit = int(request.args.get("limit") or config.config_books_per_page) | ||||||
|     search = request.args.get("search") |     search = request.args.get("search") | ||||||
|     sort = request.args.get("sort", "id") |     sort_param = request.args.get("sort", "id") | ||||||
|     order = request.args.get("order", "").lower() |     order = request.args.get("order", "").lower() | ||||||
|     state = None |     state = None | ||||||
|     join = tuple() |     join = tuple() | ||||||
|  |  | ||||||
|     if sort == "state": |     if sort_param == "state": | ||||||
|         state = json.loads(request.args.get("state", "[]")) |         state = json.loads(request.args.get("state", "[]")) | ||||||
|     elif sort == "tags": |     elif sort_param == "tags": | ||||||
|         order = [db.Tags.name.asc()] if order == "asc" else [db.Tags.name.desc()] |         order = [db.Tags.name.asc()] if order == "asc" else [db.Tags.name.desc()] | ||||||
|         join = db.books_tags_link, db.Books.id == db.books_tags_link.c.book, db.Tags |         join = db.books_tags_link, db.Books.id == db.books_tags_link.c.book, db.Tags | ||||||
|     elif sort == "series": |     elif sort_param == "series": | ||||||
|         order = [db.Series.name.asc()] if order == "asc" else [db.Series.name.desc()] |         order = [db.Series.name.asc()] if order == "asc" else [db.Series.name.desc()] | ||||||
|         join = db.books_series_link, db.Books.id == db.books_series_link.c.book, db.Series |         join = db.books_series_link, db.Books.id == db.books_series_link.c.book, db.Series | ||||||
|     elif sort == "publishers": |     elif sort_param == "publishers": | ||||||
|         order = [db.Publishers.name.asc()] if order == "asc" else [db.Publishers.name.desc()] |         order = [db.Publishers.name.asc()] if order == "asc" else [db.Publishers.name.desc()] | ||||||
|         join = db.books_publishers_link, db.Books.id == db.books_publishers_link.c.book, db.Publishers |         join = db.books_publishers_link, db.Books.id == db.books_publishers_link.c.book, db.Publishers | ||||||
|     elif sort == "authors": |     elif sort_param == "authors": | ||||||
|         order = [db.Authors.name.asc(), db.Series.name, db.Books.series_index] if order == "asc" \ |         order = [db.Authors.name.asc(), db.Series.name, db.Books.series_index] if order == "asc" \ | ||||||
|             else [db.Authors.name.desc(), db.Series.name.desc(), db.Books.series_index.desc()] |             else [db.Authors.name.desc(), db.Series.name.desc(), db.Books.series_index.desc()] | ||||||
|         join = db.books_authors_link, db.Books.id == db.books_authors_link.c.book, db.Authors, \ |         join = db.books_authors_link, db.Books.id == db.books_authors_link.c.book, db.Authors, \ | ||||||
|                db.books_series_link, db.Books.id == db.books_series_link.c.book, db.Series |                db.books_series_link, db.Books.id == db.books_series_link.c.book, db.Series | ||||||
|     elif sort == "languages": |     elif sort_param == "languages": | ||||||
|         order = [db.Languages.lang_code.asc()] if order == "asc" else [db.Languages.lang_code.desc()] |         order = [db.Languages.lang_code.asc()] if order == "asc" else [db.Languages.lang_code.desc()] | ||||||
|         join = db.books_languages_link, db.Books.id == db.books_languages_link.c.book, db.Languages |         join = db.books_languages_link, db.Books.id == db.books_languages_link.c.book, db.Languages | ||||||
|     elif order and sort in ["sort", "title", "authors_sort", "series_index"]: |     elif order and sort_param in ["sort", "title", "authors_sort", "series_index"]: | ||||||
|         order = [text(sort + " " + order)] |         order = [text(sort_param + " " + order)] | ||||||
|     elif not state: |     elif not state: | ||||||
|         order = [db.Books.timestamp.desc()] |         order = [db.Books.timestamp.desc()] | ||||||
|  |  | ||||||
| @@ -1263,7 +1263,7 @@ def extend_search_term(searchterm, | |||||||
|  |  | ||||||
|  |  | ||||||
| def render_adv_search_results(term, offset=None, order=None, limit=None): | def render_adv_search_results(term, offset=None, order=None, limit=None): | ||||||
|     sort = order[0] if order else [db.Books.sort] |     sort_param = order[0] if order else [db.Books.sort] | ||||||
|     pagination = None |     pagination = None | ||||||
|  |  | ||||||
|     cc = get_cc_columns(filter_config_custom_read=True) |     cc = get_cc_columns(filter_config_custom_read=True) | ||||||
| @@ -1378,7 +1378,7 @@ def render_adv_search_results(term, offset=None, order=None, limit=None): | |||||||
|             log.debug_or_exception(ex) |             log.debug_or_exception(ex) | ||||||
|             flash(_("Error on search for custom columns, please restart Calibre-Web"), category="error") |             flash(_("Error on search for custom columns, please restart Calibre-Web"), category="error") | ||||||
|  |  | ||||||
|     q = q.order_by(*sort).all() |     q = q.order_by(*sort_param).all() | ||||||
|     flask_session['query'] = json.dumps(term) |     flask_session['query'] = json.dumps(term) | ||||||
|     ub.store_combo_ids(q) |     ub.store_combo_ids(q) | ||||||
|     result_count = len(q) |     result_count = len(q) | ||||||
| @@ -1792,7 +1792,7 @@ def show_book(book_id): | |||||||
|  |  | ||||||
|         entry.tags = sort(entry.tags, key=lambda tag: tag.name) |         entry.tags = sort(entry.tags, key=lambda tag: tag.name) | ||||||
|  |  | ||||||
|         entry.authors = calibre_db.order_authors([entry]) |         entry.ordered_authors = calibre_db.order_authors([entry]) | ||||||
|  |  | ||||||
|         entry.kindle_list = check_send_to_kindle(entry) |         entry.kindle_list = check_send_to_kindle(entry) | ||||||
|         entry.reader_list = check_read_formats(entry) |         entry.reader_list = check_read_formats(entry) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Ozzie Isaacs
					Ozzie Isaacs