data:image/s3,"s3://crabby-images/c5e1e/c5e1e7735b66ef960e8000f0bf85782c88fc478f" alt=""
data:image/s3,"s3://crabby-images/f1140/f1140dd72278b673b8a82708669750ba243e0249" alt=""
data:image/s3,"s3://crabby-images/8ee77/8ee77c9c476c3db45fa3b829e4bf1c7c3708432a" alt=""
data:image/s3,"s3://crabby-images/492db/492db62c6df908350d8ceda27a93347ab39c0379" alt=""
data:image/s3,"s3://crabby-images/c4dec/c4dec67d69b5658d91668d1ab2e8fc54c8d2f406" alt=""
This article describes how to override a view from an external Django app which is a FAQ on StackOverflow and IRC.
You should understand that your urls.py is a really central and critical part of your django project.
You are not supposed to edit the code from an external app. Unless you fork it first on github.
If you want to override templates/userena/activate_fail.html, then all you have to do is create your own templates/userena
directory and make your own activate_fail.html
in it.
Probably the first thing you should check in an external app is its urls.py. Views that are properly coded should support plenty of arguments. For example, userena has a signup view with such a signature (at the time of writing):
def signup(request, signup_form=SignupForm,
template_name='userena/signup_form.html', success_url=None,
extra_context=None):
This means that you can replace the form used by the signup view. To do so, open your urls.py
, add what we are going to need at the top:
from userena import views as userena_views
from yourforms import YourSignupForm
Then, find the include the external app’s urls, something like:
url(r'^userena/', include('userena.urls')),
Before that, add your url override:
url(r'^userena/signup/$', userena_views.signup, {'signup_form': YourSignupForm}, name='userena_signup'),
url(r'^userena/', include('userena.urls')),
Now, your custom url definition will be the first to be hit when a visitor hits /userena/signup/. Which means that /userena/signup/
will use YourSignupForm
instead of userena’s signup form.
This trick works with any view argument. The ones you should see the most often are:
template_name
: lets you change the template nameextra_context
: lets you add a dict that will be added to the contextAlmost every view should have these arguments.
Overriding a view requires to override the url of the view you want to replace. If you want your own signup view to be used, then just override the url:
import yourviews
# ...
url(r'^userena/signup/$', yourviews.yoursignup, name='userena_signup'),
url(r'^userena/', include('userena.urls')),
Decorating a view is like overriding a view, but reuses the external app’s view. Basically, it’s the same than overriding a view (see above), but your view will look like this
from userena import views as userena_views
def yoursignup(request):
# do stuff before userena signup view is called
# call the original view
response = userena_views.signup(request)
# do stuff after userena signup view is done
# return the response
return response
If you are not familiar with pip and virtualenv first, please read the post about using pip and virtualenv first.
For example:
pip install django-userena
pip uninstall django-userena
pip install -e git+git@github.com:your-username/django-userena.git#egg=django-userena
yourenv/src/django-userena
lauxley from #django@irc.freenode.net proofreaded this article.
Thanks !