X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/ab87154a392f53012eb62ca5da69536d6b4ac067..cc9a57b827d7303c37f3b2d271e7c2f661d30e45:/apps/dictionary/models.py?ds=sidebyside diff --git a/apps/dictionary/models.py b/apps/dictionary/models.py index f2a9ddf28..6238ccbf2 100644 --- a/apps/dictionary/models.py +++ b/apps/dictionary/models.py @@ -3,8 +3,7 @@ # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information. # from django.db import models - -from librarian import html +from celery.task import task from sortify import sortify from catalogue.models import Book @@ -20,12 +19,17 @@ class Note(models.Model): ordering = ['sort_key'] +@task(ignore_result=True) +def build_notes(book_id): + book = Book.objects.get(pk=book_id) + Note.objects.filter(book=book).delete() + if book.html_file: + from librarian import html + for anchor, text_str, html_str in html.extract_annotations(book.html_file.path): + Note.objects.create(book=book, anchor=anchor, + html=html_str, + sort_key=sortify(text_str).strip()[:128]) + +@Book.html_built.connect def notes_from_book(sender, **kwargs): - Note.objects.filter(book=sender).delete() - if sender.html_file: - for anchor, text_str, html_str in html.extract_annotations(sender.html_file.path): - Note.objects.create(book=sender, anchor=anchor, - html=html_str, sort_key=sortify(text_str)[:128]) - -# always re-extract notes after making a HTML in a Book -Book.html_built.connect(notes_from_book) + build_notes.delat(sender)