From bcaa6a0c08ef7ed517f73f55084938c7aed58c14 Mon Sep 17 00:00:00 2001 From: Ryan Sullivan Date: Thu, 29 Feb 2024 16:45:06 -0500 Subject: [PATCH] Breaks up AbstractMedia into AbstractMediaFieldAdditions and AbstractMediaBase so that WagtailMedia may be used with Wagtail's Document model as a storage and serve backend. --- src/wagtailmedia/models.py | 36 +++++++++++++++++++++++------------- 1 file changed, 23 insertions(+), 13 deletions(-) diff --git a/src/wagtailmedia/models.py b/src/wagtailmedia/models.py index d6cdbb9..9e2f032 100644 --- a/src/wagtailmedia/models.py +++ b/src/wagtailmedia/models.py @@ -28,10 +28,26 @@ class MediaQuerySet(SearchableQuerySetMixin, models.QuerySet): pass -class AbstractMedia(CollectionMember, index.Indexed, models.Model): +class AbstractMediaFieldAdditions(CollectionMember, models.Model): title = models.CharField(max_length=255, verbose_name=_("title")) file = models.FileField(upload_to="media", verbose_name=_("file")) + created_at = models.DateTimeField(verbose_name=_("created at"), auto_now_add=True) + uploaded_by_user = models.ForeignKey( + settings.AUTH_USER_MODEL, + verbose_name=_("uploaded by user"), + null=True, + blank=True, + editable=False, + on_delete=models.SET_NULL, + ) + tags = TaggableManager(help_text=None, blank=True, verbose_name=_("tags")) + + class Meta: + abstract = True + verbose_name = _("media") + +class AbstractMediaBase(index.Indexed, models.Model): type = models.CharField( choices=MediaType.choices, max_length=255, blank=False, null=False ) @@ -50,18 +66,6 @@ class AbstractMedia(CollectionMember, index.Indexed, models.Model): upload_to="media_thumbnails", blank=True, verbose_name=_("thumbnail") ) - created_at = models.DateTimeField(verbose_name=_("created at"), auto_now_add=True) - uploaded_by_user = models.ForeignKey( - settings.AUTH_USER_MODEL, - verbose_name=_("uploaded by user"), - null=True, - blank=True, - editable=False, - on_delete=models.SET_NULL, - ) - - tags = TaggableManager(help_text=None, blank=True, verbose_name=_("tags")) - objects = MediaQuerySet.as_manager() search_fields = CollectionMember.search_fields + [ @@ -155,6 +159,12 @@ class Meta: verbose_name = _("media") +class AbstractMedia(AbstractMediaBase, AbstractMediaFieldAdditions): + class Meta: + abstract = True + verbose_name = _("media") + + class Media(AbstractMedia): pass