diff --git a/cps/db.py b/cps/db.py index d8709335..82696768 100644 --- a/cps/db.py +++ b/cps/db.py @@ -395,7 +395,7 @@ class AlchemyEncoder(json.JSONEncoder): if isinstance(o.__class__, DeclarativeMeta): # an SQLAlchemy class fields = {} - for field in [x for x in dir(o) if not x.startswith('_') and x != 'metadata' and x!="password"]: + for field in [x for x in dir(o) if not x.startswith('_') and x != 'metadata' and x != "password"]: if field == 'books': continue data = o.__getattribute__(field) @@ -404,8 +404,11 @@ class AlchemyEncoder(json.JSONEncoder): data = data.replace("'", "\'") elif isinstance(data, InstrumentedList): el = list() + # ele = None for ele in data: - if ele.get: + if hasattr(ele, 'value'): # converter for custom_column values + el = [str(ele.value)] + elif ele.get: el.append(ele.get()) else: el.append(json.dumps(ele, cls=AlchemyEncoder)) diff --git a/cps/editbooks.py b/cps/editbooks.py index d3e1f01e..e44d30c5 100644 --- a/cps/editbooks.py +++ b/cps/editbooks.py @@ -573,10 +573,19 @@ def edit_cc_data_string(book, c, to_save, cc_db_value, cc_string): getattr(book, cc_string).append(new_cc) return changed, to_save +def edit_single_cc_data(book_id, book, column_id, to_save): + cc = (calibre_db.session.query(db.Custom_Columns) + .filter(db.Custom_Columns.datatype.notin_(db.cc_exceptions)) + .filter(db.Custom_Columns.id == column_id) + .all()) + return edit_cc_data(book_id, book, to_save, cc) -def edit_cc_data(book_id, book, to_save): - changed = False +def edit_all_cc_data(book_id, book, to_save): cc = calibre_db.session.query(db.Custom_Columns).filter(db.Custom_Columns.datatype.notin_(db.cc_exceptions)).all() + return edit_cc_data(book_id, book, to_save, cc) + +def edit_cc_data(book_id, book, to_save, cc): + changed = False for c in cc: cc_string = "custom_column_" + str(c.id) if not c.is_multiple: @@ -811,7 +820,7 @@ def edit_book(book_id): # handle book ratings modif_date |= edit_book_ratings(to_save, book) # handle cc data - modif_date |= edit_cc_data(book_id, book, to_save) + modif_date |= edit_all_cc_data(book_id, book, to_save) if to_save["pubdate"]: try: @@ -1131,10 +1140,6 @@ def edit_list_book(param): lang_names = list() for lang in book.languages: lang_names.append(isoLanguages.get_language_name(get_locale(), lang.lang_code)) - #try: - # lang_names.append(LC.parse(lang.lang_code).get_language_name(get_locale())) - #except UnknownLocaleError: - # lang_names.append(_(isoLanguages.get(part3=lang.lang_code).name)) ret = Response(json.dumps({'success': True, 'newValue': ', '.join(lang_names)}), mimetype='application/json') elif param =='author_sort': @@ -1157,6 +1162,13 @@ def edit_list_book(param): ret = Response(json.dumps({'success': True, 'newValue': ' & '.join([author.replace('|',',') for author in input_authors])}), mimetype='application/json') + elif param.startswith("custom_column_"): + new_val = dict() + new_val[param] = vals['value'] + edit_single_cc_data(book.id, book, param[14:], new_val) + ret = Response(json.dumps({'success': True, 'newValue': vals['value']}), + mimetype='application/json') + book.last_modified = datetime.utcnow() try: calibre_db.session.commit() diff --git a/cps/static/js/table.js b/cps/static/js/table.js index a55ec5d1..ac597c4a 100644 --- a/cps/static/js/table.js +++ b/cps/static/js/table.js @@ -639,6 +639,10 @@ function singlecheckboxFormatter(value, row){ return ''; } +function ratingFormatter(value, row) { + return (value/2); +} + /* Do some hiding disabling after user list is loaded */ function loadSuccess() { diff --git a/cps/templates/book_table.html b/cps/templates/book_table.html index f26e488d..3722d6c1 100644 --- a/cps/templates/book_table.html +++ b/cps/templates/book_table.html @@ -59,6 +59,17 @@ {{ text_table_row('languages', _('Enter Languages'),_('Languages'), false, true) }} {{ text_table_row('publishers', _('Enter Publishers'),_('Publishers'), false, true) }} + {% for c in cc %} + {% if c.datatype == "int" %} +