У меня есть функция, с помощью которой при срабатывании переменной на True пользователь перенаправляется на другую страницу:
def first_function(request):
if settings.TRIGGER:
with transaction.atomic():
if not order_lock.can_edit(request.user):
is_locked = not order_lock.can_edit(request.user)
from django.core.urlresolvers import reverse
return HttpResponseRedirect(reverse(some_function))
else:
is_locked = False
order_lock.lock_edit(request.user)
def some_function(request):
orders = Order.objects.all().order_by('status','created')
return render(
request,
'myapp/index.html',
{
'orders': orders,
},
)
Проблема в том, что я пробовал различные варианты парсинга переменной is_locked
в return HttpResponseRedirect(reverse(some_function))
но безрезультатно, так что мой some_function
адаптирован к:
def some_function(request, is_updated=None):
orders = Order.objects.all().order_by('status','created')
return render(
request,
'myapp/index.html',
{
'orders': orders,
'is_updated': is_updated,
},
)
Есть ли способ решить эту проблему, чтобы переменная is_updated
могла быть проанализирована при обратном перенаправлении? Намерение состоит в том, чтобы вызвать в html (из-за is_updated) всплывающее окно, которое уведомляет пользователя.
РЕДАКТИРОВАТЬ:
view.py
def edit_order(request, id = None, order_id = None)
with transaction.atomic():
order_lock = get_object_or_404(Order.objects.select_for_update(), id=id)
if not order_lock.can_edit(request.user):
is_locked = not order_lock.can_edit(request.user)
from django.shortcuts import redirect
from django.core.urlresolvers import reverse
return redirect(idx_order, kwargs={'is_locked': is_locked}) # Use this when url matter is resolved
def idx_order(request, is_locked=None):
orders = Order.objects.all().order_by('status','deadline','created','lastUpdate').exclude(status=2)
return render(
request,
'myapp/index_pimped.html',
{
'is_locked': is_locked
},
)
urls.py
url(r'^$', idx_order, name='idx_order'), # This works fine....
#url(r'^(?P<is_locked>[-\w]+)/$', idx_order, name='idx_order'), # ...but this doesn't