mirror of
https://github.com/netbox-community/netbox.git
synced 2025-08-26 17:26:10 -06:00
Fix JSON rendering
This commit is contained in:
parent
2fa87131cb
commit
574b5f991d
@ -1,6 +1,7 @@
|
|||||||
|
import json
|
||||||
|
|
||||||
from django import forms
|
from django import forms
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.http import QueryDict
|
|
||||||
from django.utils.translation import gettext as _
|
from django.utils.translation import gettext as _
|
||||||
|
|
||||||
from dcim.models import DeviceRole, DeviceType, Location, Platform, Region, Site, SiteGroup
|
from dcim.models import DeviceRole, DeviceType, Location, Platform, Region, Site, SiteGroup
|
||||||
@ -128,11 +129,10 @@ class SavedFilterForm(BootstrapMixin, forms.ModelForm):
|
|||||||
|
|
||||||
def __init__(self, *args, initial=None, **kwargs):
|
def __init__(self, *args, initial=None, **kwargs):
|
||||||
|
|
||||||
# Convert any parameters delivered via initial data to a dictionary
|
# Convert any parameters delivered via initial data to JSON data
|
||||||
if initial and 'parameters' in initial:
|
if initial and 'parameters' in initial:
|
||||||
if type(initial['parameters']) is str:
|
if type(initial['parameters']) is str:
|
||||||
# TODO: Make a utility function for this
|
initial['parameters'] = json.loads(initial['parameters'])
|
||||||
initial['parameters'] = dict(QueryDict(initial['parameters']).lists())
|
|
||||||
|
|
||||||
super().__init__(*args, initial=initial, **kwargs)
|
super().__init__(*args, initial=initial, **kwargs)
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import json
|
||||||
from collections import defaultdict
|
from collections import defaultdict
|
||||||
from functools import cached_property
|
from functools import cached_property
|
||||||
|
|
||||||
@ -110,13 +111,12 @@ class CloningMixin(models.Model):
|
|||||||
|
|
||||||
for field_name in getattr(self, 'clone_fields', []):
|
for field_name in getattr(self, 'clone_fields', []):
|
||||||
field = self._meta.get_field(field_name)
|
field = self._meta.get_field(field_name)
|
||||||
if isinstance(field, models.ManyToManyField):
|
|
||||||
m2m = getattr(self, field.name)
|
|
||||||
if m2m:
|
|
||||||
attrs[field_name] = [f.pk for f in m2m.all()]
|
|
||||||
else:
|
|
||||||
field_value = field.value_from_object(self)
|
field_value = field.value_from_object(self)
|
||||||
if field_value not in (None, ''):
|
if field_value and isinstance(field, models.ManyToManyField):
|
||||||
|
attrs[field_name] = [v.pk for v in field_value]
|
||||||
|
elif field_value and isinstance(field, models.JSONField):
|
||||||
|
attrs[field_name] = json.dumps(field_value)
|
||||||
|
elif field_value not in (None, ''):
|
||||||
attrs[field_name] = field_value
|
attrs[field_name] = field_value
|
||||||
|
|
||||||
# Include tags (if applicable)
|
# Include tags (if applicable)
|
||||||
|
Loading…
Reference in New Issue
Block a user