|
|
|
@ -796,23 +796,24 @@ class CalibreDB():
|
|
|
|
|
def speaking_language(self, languages=None, return_all_languages=False, with_count=False, reverse_order=False):
|
|
|
|
|
from . import get_locale
|
|
|
|
|
|
|
|
|
|
if not languages:
|
|
|
|
|
if with_count:
|
|
|
|
|
if with_count:
|
|
|
|
|
if not languages:
|
|
|
|
|
languages = self.session.query(Languages, func.count('books_languages_link.book'))\
|
|
|
|
|
.join(books_languages_link).join(Books)\
|
|
|
|
|
.filter(self.common_filters(return_all_languages=return_all_languages)) \
|
|
|
|
|
.group_by(text('books_languages_link.lang_code')).all()
|
|
|
|
|
for lang in languages:
|
|
|
|
|
lang[0].name = isoLanguages.get_language_name(get_locale(), lang[0].lang_code)
|
|
|
|
|
return sorted(languages, key=lambda x: x[0].name, reverse=reverse_order)
|
|
|
|
|
else:
|
|
|
|
|
for lang in languages:
|
|
|
|
|
lang[0].name = isoLanguages.get_language_name(get_locale(), lang[0].lang_code)
|
|
|
|
|
return sorted(languages, key=lambda x: x[0].name, reverse=reverse_order)
|
|
|
|
|
else:
|
|
|
|
|
if not languages:
|
|
|
|
|
languages = self.session.query(Languages) \
|
|
|
|
|
.join(books_languages_link) \
|
|
|
|
|
.join(Books) \
|
|
|
|
|
.filter(self.common_filters(return_all_languages=return_all_languages)) \
|
|
|
|
|
.group_by(text('books_languages_link.lang_code')).all()
|
|
|
|
|
for lang in languages:
|
|
|
|
|
lang.name = isoLanguages.get_language_name(get_locale(), lang.lang_code)
|
|
|
|
|
for lang in languages:
|
|
|
|
|
lang.name = isoLanguages.get_language_name(get_locale(), lang.lang_code)
|
|
|
|
|
return sorted(languages, key=lambda x: x.name, reverse=reverse_order)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|