Как визуализировать django modelformset_factory формы вручную

Я использую форму django modelformset_factory для загрузки и редактирования изображений. В настоящее время, когда я отображаю формы, он показывает формы с существующими данными следующим образом:

  • имя поля: в настоящее время: ссылка на изображение (например: images/filename.jpg)
  • Изменить: поле ввода изображения
  • флажок для удаления

Как я могу изменить отображение (в настоящее время: ссылка на изображение (например: images/filename.jpg))? хотел бы изменить ссылку на изображение для отображения имени изображения и открыть его в новом окне, когда пользователь щелкнет по нему. Я проверил документацию django для ручной визуализации формы, но не смог найти соответствующую информацию.

Спасибо!

Модели:

class BaseImageAbstractModel(models.Model):
    content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
    object_id = models.PositiveIntegerField()
    content_object = GenericForeignKey('content_type','object_id')

    class Meta:
        abstract = True

class ImageAbstractModel(BaseImageAbstractModel):
        user = models.ForeignKey(User, null=True, blank=True, on_delete=models.CASCADE)
        name = models.CharField(max_length=50, blank=True)
        description = models.TextField(max_length=3000)
        picture = models.ImageField(upload_to='images')
        submit_date = models.DateTimeField(default=None)
        is_public = models.BooleanField(default=True)
        is_removed = models.BooleanField(default=False)

        class Meta:
            abstract = True

        def __str__(self):
            pass

class Image(ImageAbstractModel):    
    class Meta:
        verbose_name = "Image"
        verbose_name_plural = "Images"

        def __str__(self):
            return self.name
class ImageForm(BootstrapForm, ModelForm):

    class Meta:
        model = Image
        fields = ('picture', 'name')

ImgFormSet = modelformset_factory(Image, form=ImageForm, extra=5, can_delete=True)

1 ответ

Решение состоит в том, чтобы создать подкласс класса ClearableFileInput и переопределить следующее:

class image_widget(ClearableFileInput):
     initial_text = ugettext_lazy('')
     template_with_initial = ('%(initial_text)s <a target="_blank" href="%(initial_url)s">%(initial)s</a> '
    '%(clear_template)s<br />%(input_text)s: %(input)s')

    def get_template_substitution_values(self, value):
       return {
           'initial': 'Current Picture',
           'initial_url': conditional_escape(value.url),
    }

class ImageForm(BootstrapForm, ModelForm):

    class Meta:
        model = Image
        fields = ('picture', 'name')
        widgets = {'picture': image_widget,}

Теперь вывод выглядит так:

  • Имя поля: текущее изображение
  • Изменить: поле ввода изображения
  • Флажок для удаления

Джанго справочная документация

Другие вопросы по тегам