ИМ
Игорь Максимов24 березня 2022 р. 09: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 р. 08:15

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

                Илья Чичак
                • 26 березня 2022 р. 18:46

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

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

                  ИМ
                  • 27 березня 2022 р. 17:31

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

                    Илья Чичак
                    • 28 березня 2022 р. 06:10

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

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

                      ИМ
                      • 28 березня 2022 р. 15:53

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

                        Коментарі

                        Only authorized users can post comments.
                        Please, Log in or Sign up
                        Ua

                        Qt - Тест 001. Сигналы и слоты

                        • Результат:84бали,
                        • Рейтинг балів4
                        Ua

                        Qt - Тест 001. Сигналы и слоты

                        • Результат:42бали,
                        • Рейтинг балів-8
                        ОК

                        Qt - Тест 001. Сигналы и слоты

                        • Результат:47бали,
                        • Рейтинг балів-6
                        Останні коментарі
                        ИМ
                        Игорь Максимов22 листопада 2024 р. 11:51
                        Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                        Evgenii Legotckoi
                        Evgenii Legotckoi31 жовтня 2024 р. 14:37
                        Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                        A
                        ALO1ZE19 жовтня 2024 р. 08:19
                        Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                        ИМ
                        Игорь Максимов05 жовтня 2024 р. 07:51
                        Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                        d
                        dblas505 липня 2024 р. 11:02
                        QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                        Тепер обговоріть на форумі
                        Дмитрий
                        Дмитрий03 лютого 2025 р. 06:24
                        Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                        NW
                        Nayo Wai30 січня 2025 р. 09:22
                        не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                        n
                        nkly03 січня 2025 р. 02:52
                        Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                        M
                        Marsel16 серпня 2023 р. 14:26
                        OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
                        Evgenii Legotckoi
                        Evgenii Legotckoi24 червня 2024 р. 15:11
                        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.

                        Слідкуйте за нами в соціальних мережах