diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-21 16:26:24 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-04-21 16:26:24 +0200 |
commit | 42fe76e7bb82923acefed07b2e700d1e1ef88e1e (patch) | |
tree | a922533e2f1112b4657dc9526f42bec35de4ac87 /ishtar_common/wizards.py | |
parent | e2541a5b4dfb0425b06748e6f31d5ca24eadd376 (diff) | |
download | Ishtar-42fe76e7bb82923acefed07b2e700d1e1ef88e1e.tar.bz2 Ishtar-42fe76e7bb82923acefed07b2e700d1e1ef88e1e.zip |
Wizards: fix serialization of ImageFileField
Diffstat (limited to 'ishtar_common/wizards.py')
-rw-r--r-- | ishtar_common/wizards.py | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/ishtar_common/wizards.py b/ishtar_common/wizards.py index fd8d24366..e64d259e7 100644 --- a/ishtar_common/wizards.py +++ b/ishtar_common/wizards.py @@ -1,6 +1,6 @@ #!/usr/bin/env python # -*- coding: utf-8 -*- -# Copyright (C) 2010-2016 Étienne Loks <etienne.loks_AT_peacefrogsDOTnet> +# Copyright (C) 2010-2017 Étienne Loks <etienne.loks_AT_peacefrogsDOTnet> # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as @@ -24,12 +24,13 @@ import logging from django.conf import settings from formtools.wizard.views import NamedUrlWizardView, normalize_name, \ get_storage, StepsHelper + from django.contrib.sites.models import Site from django.core.exceptions import ObjectDoesNotExist from django.core.files.images import ImageFile from django.core.files.storage import default_storage from django.core.mail import send_mail -from django.db.models.fields.files import FileField +from django.db.models.fields.files import FileField, ImageFieldFile from django.db.models.fields.related import ManyToManyField from django.db.models.fields import NOT_PROVIDED @@ -1107,7 +1108,13 @@ class Wizard(NamedUrlWizardView): continue if hasattr(value, 'pk'): value = value.pk - if value in (True, False) or \ + if isinstance(value, ImageFieldFile) \ + or isinstance(value, FileField): + try: + initial[base_field] = value.path + except ValueError: + pass + elif value in (True, False) or \ isinstance(value, FileField) or \ isinstance(value, ImageFile): initial[base_field] = value |