ИМ
Игорь Максимов24 марта 2022 г. 9:34

Прикрутить форму к админ-панели

django, forms, adminmodel

Доброго времени суток! Прошу помощи прикрутить форму загрузки медиаконтента в админ-панели. Дано:

Модель контента

class MediaItem(models.Model):
    video = VideoField( upload_to = upload_to,
                        width_field = 'video_width', height_field = 'video_height',
                        rotation_field = 'video_rotation',
                        mimetype_field = 'video_mimetype',
                        duration_field = 'video_duration',
                        thumbnail_field = 'video_thumbnail')
    video_width = models.IntegerField(null = True, blank = True)
    video_height = models.IntegerField(null = True, blank = True)
    video_rotation = models.FloatField(null = True, blank = True)
    video_mimetype = models.CharField(max_length = 32, null = True, blank = True)
    video_duration = models.IntegerField(null = True, blank = True)
    video_thumbnail = models.ImageField(null = True, blank = True)
    video_mp4 = VideoSpecField(source = 'video', format = 'mp4')
    video_ogg = VideoSpecField(source = 'video', format = 'ogg')
    video_webm = VideoSpecField(source='video', format='webm')

    def __unicode__(self):
        return self.video.name

    def video_specs_generated(self):
        if self.video_mp4.generated() and self.video_ogg.generated():
            return True

        return False

Форма

from videokit.forms import VideoField

class MediaItemCreateForm(forms.Form):
    video = VideoField()

Представление

def item_create(request):
    template = 'app/item_create.html'

    item_create_form = MediaItemCreateForm()

    if request.method == 'POST':
        item_create_form = MediaItemCreateForm(request.POST, request.FILES)

        if item_create_form.is_valid():
            video = request.FILES.get('video', None)

            if video:
                media_item = MediaItem(video = video)
                media_item.save()

                media_item.video_webm.generate()

                return HttpResponseRedirect(reverse('list'))

    context = {
        'item_create_form' : item_create_form,
    }

    return render(request, template, context)

Ну и дефолтный класс в admin.py

class MediaItemAdmin(admin.ModelAdmin):
    pass

admin.site.register(MediaItem, MediaItemAdmin)

Вопрос заключается в следующем: что написать в дефолтном классе админки чтоб работала загрузка файла через админку а не с сайта.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

11
Илья Чичак
  • 24 марта 2022 г. 10:31
  • (ред.)

я думаю, для админки стоит сделать отдельную форму и указать ее в MediaItemAdmin

https://docs.djangoproject.com/en/4.0/ref/contrib/admin/#django.contrib.admin.ModelAdmin.form

    ИМ
    • 24 марта 2022 г. 10:40
    from django.contrib import admin
    from app.models import MediaItem
    from django import forms
    from videokit.forms import VideoField
    # Register your models here.
    
    class MediaItemForm(forms.ModelForm):
    
        class Meta:
            model = MediaItem
    
        video = VideoField()
    
    class MediaItemAdmin(admin.ModelAdmin):
        form = MediaItemForm
    
    admin.site.register(MediaItem, MediaItemAdmin)
    

    Как то так. Но ничего не работает.

      Илья Чичак
      • 24 марта 2022 г. 12:25

      ничего не работает - не очень информативное сообщение

      какие ошибки происходят?

      на что ругалось в первоначальном варианте?

        ИМ
        • 24 марта 2022 г. 12:38
        • (ред.)

        Просто загружается медиафайл, но не кодируется. Кодирование вызывает эта форма через представление. Мне же нужно это реализовать в админ-панели.

          Илья Чичак
          • 24 марта 2022 г. 15:44
          • Ответ был помечен как решение.

          это можно сделать через метод save в форме https://docs.djangoproject.com/en/4.0/topics/forms/modelforms/#the-save-method

          class MediaItemForm(forms.ModelForm):
          
              class Meta:
                  model = MediaItem
          
              video = VideoField()
          
              def save(self, *args, **kwargs)
                  item = super().save(*args, **kwargs)
                  item.video_webm.generate()
                  return item
          

          или через метод save_model класса админки
          https://docs.djangoproject.com/en/4.0/ref/contrib/admin/#django.contrib.admin.ModelAdmin.save_model

          хотя я бы посоветовал вынести все это в отдельную функцию/класс, который бы использовался и во view и в админке

            ИМ
            • 24 марта 2022 г. 16:10

            Благодарю вас. Все работает.

            хотя я бы посоветовал вынести все это в отдельную функцию/класс, который бы использовался и во view и в админке

            В том то и дело, что мне это пока не нужно. Нужна админка. Еще раз благодарю.

              Илья, простите за вопрос. У меня при повторном обновлении файла контента он не кодируется. Кодируется только при создании нового. Только что заметил этот баг. Что написать чтоб при обновлении он также кодировался как и при добавлении нового?

                Илья Чичак
                • 26 марта 2022 г. 18:46

                я думаю, стоит пернесети логику вызова кодирования в метод save() модели. Возможно, будет накладно, но с таким минимумом вводных ппредложить что-то лучше у меня врядли получится.

                только при этом, надо убрать вызов кодирования из view. оно будет вызываться так же из метода save модели

                  А вчем разница? все равно же вызывается метод из формы.

                    Илья Чичак
                    • 28 марта 2022 г. 6:10

                    А вчем разница? все равно же вызывается метод из формы.

                    разница между чем и чем?

                      ИМ
                      • 28 марта 2022 г. 15:53

                      Между вывом кодирования из модели и из формы

                        Комментарии

                        Только авторизованные пользователи могут публиковать комментарии.
                        Пожалуйста, авторизуйтесь или зарегистрируйтесь
                        e
                        • ehot
                        • 31 марта 2024 г. 19:29

                        C++ - Тест 003. Условия и циклы

                        • Результат:78баллов,
                        • Очки рейтинга2
                        B

                        C++ - Тест 002. Константы

                        • Результат:16баллов,
                        • Очки рейтинга-10
                        B

                        C++ - Тест 001. Первая программа и типы данных

                        • Результат:46баллов,
                        • Очки рейтинга-6
                        Последние комментарии
                        k
                        kmssr8 февраля 2024 г. 23:43
                        Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                        АК
                        Анатолий Кононенко5 февраля 2024 г. 6:50
                        Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                        EVA
                        EVA25 декабря 2023 г. 15:30
                        Boost - статическая линковка в CMake проекте под Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                        J
                        JonnyJo25 декабря 2023 г. 13:38
                        Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                        G
                        Gvozdik19 декабря 2023 г. 2:01
                        Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                        Сейчас обсуждают на форуме
                        a
                        a_vlasov14 апреля 2024 г. 11:41
                        Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                        Павел Дорофеев
                        Павел Дорофеев14 апреля 2024 г. 7:35
                        QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                        f
                        fastrex4 апреля 2024 г. 9:47
                        Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…
                        P
                        Pisych27 февраля 2023 г. 9:04
                        Как получить в массив значения из связанной модели? Спасибо, разобрался:))
                        AC
                        Alexandru Codreanu19 января 2024 г. 16:57
                        QML Обнулить значения SpinBox Доброго времени суток, не могу разобраться с обнулением значение SpinBox находящего в делегате. import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: tr…

                        Следите за нами в социальных сетях