mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Updated AjaxView
- Aded "AjaxMixin" - Base mixin does NOT require a form (allowing more generic json views) - Add in any other context data with get_data() function
This commit is contained in:
parent
a6fdda1c1a
commit
2d35116c79
@ -4,6 +4,7 @@ from __future__ import unicode_literals
|
|||||||
from django.template.loader import render_to_string
|
from django.template.loader import render_to_string
|
||||||
from django.http import JsonResponse
|
from django.http import JsonResponse
|
||||||
|
|
||||||
|
from django.views import View
|
||||||
from django.views.generic import UpdateView, CreateView, DeleteView
|
from django.views.generic import UpdateView, CreateView, DeleteView
|
||||||
from rest_framework import views
|
from rest_framework import views
|
||||||
from django.http import JsonResponse
|
from django.http import JsonResponse
|
||||||
@ -49,12 +50,15 @@ class TreeSerializer(views.APIView):
|
|||||||
return JsonResponse(response, safe=False)
|
return JsonResponse(response, safe=False)
|
||||||
|
|
||||||
|
|
||||||
class AjaxView(object):
|
class AjaxMixin(object):
|
||||||
|
|
||||||
ajax_form_action = ''
|
ajax_form_action = ''
|
||||||
ajax_form_title = ''
|
ajax_form_title = ''
|
||||||
ajax_submit_text = 'Submit'
|
ajax_submit_text = 'Submit'
|
||||||
|
|
||||||
|
def get_data(self):
|
||||||
|
return {}
|
||||||
|
|
||||||
def getAjaxTemplate(self):
|
def getAjaxTemplate(self):
|
||||||
if hasattr(self, 'ajax_template_name'):
|
if hasattr(self, 'ajax_template_name'):
|
||||||
return self.ajax_template_name
|
return self.ajax_template_name
|
||||||
@ -63,8 +67,10 @@ class AjaxView(object):
|
|||||||
|
|
||||||
def renderJsonResponse(self, request, form, data={}):
|
def renderJsonResponse(self, request, form, data={}):
|
||||||
|
|
||||||
context = {'form': form
|
context = {}
|
||||||
}
|
|
||||||
|
if form:
|
||||||
|
context['form'] = form
|
||||||
|
|
||||||
data['title'] = self.ajax_form_title
|
data['title'] = self.ajax_form_title
|
||||||
|
|
||||||
@ -76,10 +82,27 @@ class AjaxView(object):
|
|||||||
request=request
|
request=request
|
||||||
)
|
)
|
||||||
|
|
||||||
return JsonResponse(data)
|
# Custom feedback`data
|
||||||
|
fb = self.get_data()
|
||||||
|
|
||||||
|
for key in fb.keys():
|
||||||
|
data[key] = fb[key]
|
||||||
|
|
||||||
|
return JsonResponse(data, safe=False)
|
||||||
|
|
||||||
|
|
||||||
class AjaxCreateView(AjaxView, CreateView):
|
class AjaxView(AjaxMixin, View):
|
||||||
|
""" Bare-bones AjaxView """
|
||||||
|
|
||||||
|
def post(self, request, *args, **kwargs):
|
||||||
|
return JsonResponse('', safe=False)
|
||||||
|
|
||||||
|
def get(self, request, *args, **kwargs):
|
||||||
|
|
||||||
|
return self.renderJsonResponse(request, None)
|
||||||
|
|
||||||
|
|
||||||
|
class AjaxCreateView(AjaxMixin, CreateView):
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
def post(self, request, *args, **kwargs):
|
||||||
|
|
||||||
@ -114,7 +137,7 @@ class AjaxCreateView(AjaxView, CreateView):
|
|||||||
return response
|
return response
|
||||||
|
|
||||||
|
|
||||||
class AjaxUpdateView(AjaxView, UpdateView):
|
class AjaxUpdateView(AjaxMixin, UpdateView):
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
def post(self, request, *args, **kwargs):
|
||||||
|
|
||||||
@ -148,7 +171,7 @@ class AjaxUpdateView(AjaxView, UpdateView):
|
|||||||
return response
|
return response
|
||||||
|
|
||||||
|
|
||||||
class AjaxDeleteView(AjaxView, DeleteView):
|
class AjaxDeleteView(AjaxMixin, DeleteView):
|
||||||
|
|
||||||
def post(self, request, *args, **kwargs):
|
def post(self, request, *args, **kwargs):
|
||||||
|
|
||||||
@ -160,7 +183,7 @@ class AjaxDeleteView(AjaxView, DeleteView):
|
|||||||
data = {'id': pk,
|
data = {'id': pk,
|
||||||
'delete': True}
|
'delete': True}
|
||||||
|
|
||||||
return JsonResponse(data)
|
return self.renderJsonResponse(request, None, data)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
return super(DeleteView, self).post(request, *args, **kwargs)
|
return super(DeleteView, self).post(request, *args, **kwargs)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user