mirror of
				https://github.com/janeczku/calibre-web
				synced 2025-10-31 07:13:02 +00:00 
			
		
		
		
	Refactored list checkbox sort
This commit is contained in:
		
							
								
								
									
										22
									
								
								cps/admin.py
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								cps/admin.py
									
									
									
									
									
								
							| @@ -246,15 +246,16 @@ def list_users(): | |||||||
|     limit = int(request.args.get("limit") or 10) |     limit = int(request.args.get("limit") or 10) | ||||||
|     search = request.args.get("search") |     search = request.args.get("search") | ||||||
|     sort = request.args.get("sort", "state") |     sort = request.args.get("sort", "state") | ||||||
|     order = request.args.get("order") |     order = request.args.get("order", "").lower() | ||||||
|     state = None |     state = None | ||||||
|     if sort != "state" and order: |  | ||||||
|         order = text(sort + " " + order) |  | ||||||
|     else: |  | ||||||
|         order = ub.User.name.desc() |  | ||||||
|     if sort == "state": |     if sort == "state": | ||||||
|         state = json.loads(request.args.get("state")) |         state = json.loads(request.args.get("state")) | ||||||
|  |  | ||||||
|  |     if sort != "state" and order: | ||||||
|  |         order = text(sort + " " + order) | ||||||
|  |     elif not state: | ||||||
|  |         order = ub.User.name.desc() | ||||||
|  |  | ||||||
|     all_user = ub.session.query(ub.User) |     all_user = ub.session.query(ub.User) | ||||||
|     if not config.config_anonbrowse: |     if not config.config_anonbrowse: | ||||||
|         all_user = all_user.filter(ub.User.role.op('&')(constants.ROLE_ANONYMOUS) != constants.ROLE_ANONYMOUS) |         all_user = all_user.filter(ub.User.role.op('&')(constants.ROLE_ANONYMOUS) != constants.ROLE_ANONYMOUS) | ||||||
| @@ -266,16 +267,7 @@ def list_users(): | |||||||
|                                     func.lower(ub.User.kindle_mail).ilike("%" + search + "%"), |                                     func.lower(ub.User.kindle_mail).ilike("%" + search + "%"), | ||||||
|                                     func.lower(ub.User.email).ilike("%" + search + "%"))) |                                     func.lower(ub.User.email).ilike("%" + search + "%"))) | ||||||
|     if state: |     if state: | ||||||
|         outcome = list() |         users = calibre_db.get_checkbox_sorted(all_user.all(), state, off, limit, request.args.get("order", "").lower()) | ||||||
|         userlist = {user.id:user for user in all_user.all()} |  | ||||||
|         for entry in state: |  | ||||||
|             outcome.append(userlist[entry]) |  | ||||||
|             del userlist[entry] |  | ||||||
|         for entry in userlist: |  | ||||||
|             outcome.append(userlist[entry]) |  | ||||||
|         if request.args.get("order", "").lower() == "asc": |  | ||||||
|             outcome.reverse() |  | ||||||
|         users = outcome[off:off + limit] |  | ||||||
|     else: |     else: | ||||||
|         users = all_user.order_by(order).offset(off).limit(limit).all() |         users = all_user.order_by(order).offset(off).limit(limit).all() | ||||||
|     if search: |     if search: | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								cps/db.py
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								cps/db.py
									
									
									
									
									
								
							| @@ -616,6 +616,19 @@ class CalibreDB(): | |||||||
|         return and_(lang_filter, pos_content_tags_filter, ~neg_content_tags_filter, |         return and_(lang_filter, pos_content_tags_filter, ~neg_content_tags_filter, | ||||||
|                     pos_content_cc_filter, ~neg_content_cc_filter, archived_filter) |                     pos_content_cc_filter, ~neg_content_cc_filter, archived_filter) | ||||||
|  |  | ||||||
|  |     @staticmethod | ||||||
|  |     def get_checkbox_sorted(inputlist, state, offset, limit, order): | ||||||
|  |         outcome = list() | ||||||
|  |         elementlist = {ele.id: ele for ele in inputlist} | ||||||
|  |         for entry in state: | ||||||
|  |             outcome.append(elementlist[entry]) | ||||||
|  |             del elementlist[entry] | ||||||
|  |         for entry in elementlist: | ||||||
|  |             outcome.append(elementlist[entry]) | ||||||
|  |         if order == "asc": | ||||||
|  |             outcome.reverse() | ||||||
|  |         return outcome[offset:offset + limit] | ||||||
|  |  | ||||||
|     # Fill indexpage with all requested data from database |     # Fill indexpage with all requested data from database | ||||||
|     def fill_indexpage(self, page, pagesize, database, db_filter, order, *join): |     def fill_indexpage(self, page, pagesize, database, db_filter, order, *join): | ||||||
|         return self.fill_indexpage_with_archived_books(page, pagesize, database, db_filter, order, False, *join) |         return self.fill_indexpage_with_archived_books(page, pagesize, database, db_filter, order, False, *join) | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								cps/web.py
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								cps/web.py
									
									
									
									
									
								
							| @@ -757,33 +757,26 @@ def list_books(): | |||||||
|     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", "state") |     sort = request.args.get("sort", "state") | ||||||
|     order = request.args.get("order") |     order = request.args.get("order", "").lower() | ||||||
|     state = None |     state = None | ||||||
|     if sort != "state" and order: |  | ||||||
|         order = [text(sort + " " + order)] |  | ||||||
|     else: |  | ||||||
|         order = [db.Books.timestamp.desc()] |  | ||||||
|     if sort == "state": |     if sort == "state": | ||||||
|         state = json.loads(request.args.get("state")) |         state = json.loads(request.args.get("state")) | ||||||
|  |  | ||||||
|  |     if sort != "state" and order: | ||||||
|  |         order = [text(sort + " " + order)] | ||||||
|  |     elif not state: | ||||||
|  |         order = [db.Books.timestamp.desc()] | ||||||
|  |  | ||||||
|     total_count = filtered_count = calibre_db.session.query(db.Books).count() |     total_count = filtered_count = calibre_db.session.query(db.Books).count() | ||||||
|  |  | ||||||
|     if state: |     if state: | ||||||
|         outcome = list() |  | ||||||
|         if search: |         if search: | ||||||
|             books = calibre_db.search_query(search) |             books = calibre_db.search_query(search) | ||||||
|             filtered_count = len(books) |             filtered_count = len(books) | ||||||
|         else: |         else: | ||||||
|             books = calibre_db.session.query(db.Books).filter(calibre_db.common_filters()).all() |             books = calibre_db.session.query(db.Books).filter(calibre_db.common_filters()).all() | ||||||
|         booklist = {book.id: book for book in books} |         entries = calibre_db.get_checkbox_sorted(books, state, off, limit,order) | ||||||
|         for entry in state: |  | ||||||
|             outcome.append(booklist[entry]) |  | ||||||
|             del booklist[entry] |  | ||||||
|         for entry in booklist: |  | ||||||
|             outcome.append(booklist[entry]) |  | ||||||
|         if request.args.get("order", "").lower() == "asc": |  | ||||||
|             outcome.reverse() |  | ||||||
|         entries = outcome[off:off + limit] |  | ||||||
|     elif search: |     elif search: | ||||||
|         entries, filtered_count, __ = calibre_db.get_search_results(search, off, order, limit) |         entries, filtered_count, __ = calibre_db.get_search_results(search, off, order, limit) | ||||||
|     else: |     else: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Ozzie Isaacs
					Ozzie Isaacs