fnp
/
wolnelektury.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Add support for fabfile_local.py
[wolnelektury.git]
/
apps
/
catalogue
/
fields.py
diff --git
a/apps/catalogue/fields.py
b/apps/catalogue/fields.py
index
9d7dcf2
..
d5cec2e
100644
(file)
--- a/
apps/catalogue/fields.py
+++ b/
apps/catalogue/fields.py
@@
-33,6
+33,11
@@
class EbookField(models.FileField):
super(EbookField, self).__init__(*args, **kwargs)
self.format_name = format_name
super(EbookField, self).__init__(*args, **kwargs)
self.format_name = format_name
+ def deconstruct(self):
+ name, path, args, kwargs = super(EbookField, self).deconstruct()
+ args.insert(0, self.format_name)
+ return name, path, args, kwargs
+
@property
def builder(self):
"""Finds a celery task suitable for the format of the field."""
@property
def builder(self):
"""Finds a celery task suitable for the format of the field."""
@@
-44,7
+49,7
@@
class EbookField(models.FileField):
def has(model_instance):
return bool(getattr(model_instance, self.attname, None))
has.__doc__ = None
def has(model_instance):
return bool(getattr(model_instance, self.attname, None))
has.__doc__ = None
- has.__name__ =
"has_%s" % self.attname
+ has.__name__ =
str("has_%s" % self.attname)
has.short_description = self.name
has.boolean = True
setattr(cls, 'has_%s' % self.attname, has)
has.short_description = self.name
has.boolean = True
setattr(cls, 'has_%s' % self.attname, has)
@@
-134,34
+139,28
@@
class BuildHtml(BuildEbook):
book = fieldfile.instance
book = fieldfile.instance
- meta_tags = list(book.tags.filter(
- category__in=('author', 'epoch', 'genre', 'kind')))
- book_tag = book.book_tag()
-
html_output = self.transform(
book.wldocument(parse_dublincore=False),
fieldfile)
html_output = self.transform(
book.wldocument(parse_dublincore=False),
fieldfile)
- lang = book.language
- lang = LANGUAGES_3TO2.get(lang, lang)
- if lang not in [ln[0] for ln in settings.LANGUAGES]:
- lang = None
+
+ # Delete old fragments, create from scratch if necessary.
+ book.fragments.all().delete()
if html_output:
if html_output:
+ meta_tags = list(book.tags.filter(
+ category__in=('author', 'epoch', 'genre', 'kind')))
+
+ lang = book.language
+ lang = LANGUAGES_3TO2.get(lang, lang)
+ if lang not in [ln[0] for ln in settings.LANGUAGES]:
+ lang = None
+
fieldfile.save(None, ContentFile(html_output.get_string()),
save=False)
type(book).objects.filter(pk=book.pk).update(**{
fieldfile.field.attname: fieldfile
})
fieldfile.save(None, ContentFile(html_output.get_string()),
save=False)
type(book).objects.filter(pk=book.pk).update(**{
fieldfile.field.attname: fieldfile
})
- # get ancestor l-tags for adding to new fragments
- ancestor_tags = []
- p = book.parent
- while p:
- ancestor_tags.append(p.book_tag())
- p = p.parent
-
- # Delete old fragments and create them from scratch
- book.fragments.all().delete()
# Extract fragments
closed_fragments, open_fragments = html.extract_fragments(fieldfile.path)
for fragment in closed_fragments.values():
# Extract fragments
closed_fragments, open_fragments = html.extract_fragments(fieldfile.path)
for fragment in closed_fragments.values():
@@
-200,11
+199,11
@@
class BuildHtml(BuildEbook):
short_text = truncate_html_words(text, 15)
if text == short_text:
short_text = ''
short_text = truncate_html_words(text, 15)
if text == short_text:
short_text = ''
- new_fragment = Fragment.objects.create(anchor=fragment.id,
+ new_fragment = Fragment.objects.create(anchor=fragment.id,
book=book, text=text, short_text=short_text)
new_fragment.save()
book=book, text=text, short_text=short_text)
new_fragment.save()
- new_fragment.tags = set(meta_tags + themes
+ [book_tag] + ancestor_tags
)
+ new_fragment.tags = set(meta_tags + themes)
book.html_built.send(sender=book)
return True
return False
book.html_built.send(sender=book)
return True
return False