mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
Merge pull request #10103 from arthanson/art-10094
Fix #10094 - Contact Assignments Create and Add Another
This commit is contained in:
@ -328,6 +328,12 @@ class ObjectEditView(GetReturnURLMixin, BaseObjectView):
|
|||||||
"""
|
"""
|
||||||
return obj
|
return obj
|
||||||
|
|
||||||
|
def get_extra_addanother_params(self, request):
|
||||||
|
"""
|
||||||
|
Return a dictionary of extra parameters to use on the Add Another button.
|
||||||
|
"""
|
||||||
|
return {}
|
||||||
|
|
||||||
#
|
#
|
||||||
# Request handlers
|
# Request handlers
|
||||||
#
|
#
|
||||||
@ -403,6 +409,7 @@ class ObjectEditView(GetReturnURLMixin, BaseObjectView):
|
|||||||
|
|
||||||
# If cloning is supported, pre-populate a new instance of the form
|
# If cloning is supported, pre-populate a new instance of the form
|
||||||
params = prepare_cloned_fields(obj)
|
params = prepare_cloned_fields(obj)
|
||||||
|
params.update(self.get_extra_addanother_params(request))
|
||||||
if params:
|
if params:
|
||||||
if 'return_url' in request.GET:
|
if 'return_url' in request.GET:
|
||||||
params['return_url'] = request.GET.get('return_url')
|
params['return_url'] = request.GET.get('return_url')
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
from django.http import QueryDict
|
||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
from circuits.models import Circuit
|
from circuits.models import Circuit
|
||||||
@ -365,6 +366,12 @@ class ContactAssignmentEditView(generic.ObjectEditView):
|
|||||||
instance.object = get_object_or_404(content_type.model_class(), pk=request.GET.get('object_id'))
|
instance.object = get_object_or_404(content_type.model_class(), pk=request.GET.get('object_id'))
|
||||||
return instance
|
return instance
|
||||||
|
|
||||||
|
def get_extra_addanother_params(self, request):
|
||||||
|
return {
|
||||||
|
'content_type': request.GET.get('content_type'),
|
||||||
|
'object_id': request.GET.get('object_id'),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
class ContactAssignmentDeleteView(generic.ObjectDeleteView):
|
class ContactAssignmentDeleteView(generic.ObjectDeleteView):
|
||||||
queryset = ContactAssignment.objects.all()
|
queryset = ContactAssignment.objects.all()
|
||||||
|
@ -285,7 +285,7 @@ def prepare_cloned_fields(instance):
|
|||||||
"""
|
"""
|
||||||
# Generate the clone attributes from the instance
|
# Generate the clone attributes from the instance
|
||||||
if not hasattr(instance, 'clone'):
|
if not hasattr(instance, 'clone'):
|
||||||
return QueryDict()
|
return QueryDict(mutable=True)
|
||||||
attrs = instance.clone()
|
attrs = instance.clone()
|
||||||
|
|
||||||
# Prepare querydict parameters
|
# Prepare querydict parameters
|
||||||
|
Reference in New Issue
Block a user