From a79600c81f384cf7f61b0300fd73e459720e748d Mon Sep 17 00:00:00 2001 From: Ozzie Isaacs Date: Fri, 28 May 2021 18:22:29 +0200 Subject: [PATCH] Mass change book title and author (fix #1996) --- cps/editbooks.py | 52 ++++++++++++++++++++++++++++++++--- cps/static/js/table.js | 19 +++++++++++++ cps/templates/book_table.html | 11 +++++--- 3 files changed, 74 insertions(+), 8 deletions(-) diff --git a/cps/editbooks.py b/cps/editbooks.py index b5791c54..dd8bf420 100644 --- a/cps/editbooks.py +++ b/cps/editbooks.py @@ -1148,11 +1148,15 @@ def edit_list_book(param): 'newValue': ' & '.join([author.replace('|',',') for author in input_authors])}), mimetype='application/json') book.last_modified = datetime.utcnow() - calibre_db.session.commit() - # revert change for sort if automatic fields link is deactivated - if param == 'title' and vals.get('checkT') == "false": - book.sort = sort + try: calibre_db.session.commit() + # revert change for sort if automatic fields link is deactivated + if param == 'title' and vals.get('checkT') == "false": + book.sort = sort + calibre_db.session.commit() + except (OperationalError, IntegrityError) as e: + calibre_db.session.rollback() + log.error("Database error: %s", e) return ret @@ -1224,3 +1228,43 @@ def merge_list_book(): delete_book(from_book.id,"", True) return json.dumps({'success': True}) return "" + +@editbook.route("/ajax/xchange", methods=['POST']) +@login_required +@edit_required +def table_xchange_author_title(): + vals = request.get_json().get('xchange') + if vals: + for val in vals: + modif_date = False + book = calibre_db.get_book(val) + authors = book.title + entries = calibre_db.order_authors(book) + author_names = [] + for authr in entries.authors: + author_names.append(authr.name.replace('|', ',')) + + title_change = handle_title_on_edit(book, " ".join(author_names)) + input_authors, authorchange = handle_author_on_edit(book, authors) + if authorchange or title_change: + edited_books_id = book.id + modif_date = True + + if config.config_use_google_drive: + gdriveutils.updateGdriveCalibreFromLocal() + + if edited_books_id: + helper.update_dir_stucture(edited_books_id, config.config_calibre_dir, input_authors[0]) + if modif_date: + book.last_modified = datetime.utcnow() + try: + calibre_db.session.commit() + except (OperationalError, IntegrityError) as e: + calibre_db.session.rollback() + log.error("Database error: %s", e) + return json.dumps({'success': False}) + + if config.config_use_google_drive: + gdriveutils.updateGdriveCalibreFromLocal() + return json.dumps({'success': True}) + return "" diff --git a/cps/static/js/table.js b/cps/static/js/table.js index 88694837..a38ca1c6 100644 --- a/cps/static/js/table.js +++ b/cps/static/js/table.js @@ -46,9 +46,14 @@ $(function() { if (selections.length < 1) { $("#delete_selection").addClass("disabled"); $("#delete_selection").attr("aria-disabled", true); + $("#table_xchange").addClass("disabled"); + $("#table_xchange").attr("aria-disabled", true); } else { $("#delete_selection").removeClass("disabled"); $("#delete_selection").attr("aria-disabled", false); + $("#table_xchange").removeClass("disabled"); + $("#table_xchange").attr("aria-disabled", false); + } }); $("#delete_selection").click(function() { @@ -86,6 +91,20 @@ $(function() { }); }); + $("#table_xchange").click(function() { + $.ajax({ + method:"post", + contentType: "application/json; charset=utf-8", + dataType: "json", + url: window.location.pathname + "/../../ajax/xchange", + data: JSON.stringify({"xchange":selections}), + success: function success() { + $("#books-table").bootstrapTable("refresh"); + $("#books-table").bootstrapTable("uncheckAll"); + } + }); + }); + var column = []; $("#books-table > thead > tr > th").each(function() { var element = {}; diff --git a/cps/templates/book_table.html b/cps/templates/book_table.html index d088e54b..e340dc0a 100644 --- a/cps/templates/book_table.html +++ b/cps/templates/book_table.html @@ -20,17 +20,20 @@ {% block body %}

{{_(title)}}

-
+
{{_('Merge selected books')}}
{{_('Remove Selections')}}
+
+
{{_('Exchange author and title')}}
+
-
-
+
+
-
+