mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Converted internal link generation in the admin and admin document generator to use named URLs.
Thanks to Florian Apolloner for both the initial patch and his final push to get this fixed, to Dario Ocles for his great work on the admin templates and switching the admin_doc application to also use named URLs, to Mikko Hellsing for his comments and to Jannis and Julien for their review and design guidance. Fixes #15294. git-svn-id: http://code.djangoproject.com/svn/django/trunk@16857 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -11,6 +11,7 @@ from django.contrib import messages | |||||||
| from django.views.decorators.csrf import csrf_protect | from django.views.decorators.csrf import csrf_protect | ||||||
| from django.core.exceptions import PermissionDenied, ValidationError | from django.core.exceptions import PermissionDenied, ValidationError | ||||||
| from django.core.paginator import Paginator | from django.core.paginator import Paginator | ||||||
|  | from django.core.urlresolvers import reverse | ||||||
| from django.db import models, transaction, router | from django.db import models, transaction, router | ||||||
| from django.db.models.related import RelatedObject | from django.db.models.related import RelatedObject | ||||||
| from django.db.models.fields import BLANK_CHOICE_DASH, FieldDoesNotExist | from django.db.models.fields import BLANK_CHOICE_DASH, FieldDoesNotExist | ||||||
| @@ -776,9 +777,12 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|             # redirect to the change-list page for this object. Otherwise, |             # redirect to the change-list page for this object. Otherwise, | ||||||
|             # redirect to the admin index. |             # redirect to the admin index. | ||||||
|             if self.has_change_permission(request, None): |             if self.has_change_permission(request, None): | ||||||
|                 post_url = '../' |                 post_url = reverse('admin:%s_%s_changelist' % | ||||||
|  |                                    (opts.app_label, opts.module_name), | ||||||
|  |                                    current_app=self.admin_site.name) | ||||||
|             else: |             else: | ||||||
|                 post_url = '../../../' |                 post_url = reverse('admin:index', | ||||||
|  |                                    current_app=self.admin_site.name) | ||||||
|             return HttpResponseRedirect(post_url) |             return HttpResponseRedirect(post_url) | ||||||
|  |  | ||||||
|     def response_change(self, request, obj): |     def response_change(self, request, obj): | ||||||
| @@ -787,11 +791,14 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         """ |         """ | ||||||
|         opts = obj._meta |         opts = obj._meta | ||||||
|  |  | ||||||
|         # Handle proxy models automatically created by .only() or .defer() |         # Handle proxy models automatically created by .only() or .defer(). | ||||||
|  |         # Refs #14529 | ||||||
|         verbose_name = opts.verbose_name |         verbose_name = opts.verbose_name | ||||||
|  |         module_name = opts.module_name | ||||||
|         if obj._deferred: |         if obj._deferred: | ||||||
|             opts_ = opts.proxy_for_model._meta |             opts_ = opts.proxy_for_model._meta | ||||||
|             verbose_name = opts_.verbose_name |             verbose_name = opts_.verbose_name | ||||||
|  |             module_name = opts_.module_name | ||||||
|  |  | ||||||
|         pk_value = obj._get_pk_val() |         pk_value = obj._get_pk_val() | ||||||
|  |  | ||||||
| @@ -805,19 +812,28 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         elif "_saveasnew" in request.POST: |         elif "_saveasnew" in request.POST: | ||||||
|             msg = _('The %(name)s "%(obj)s" was added successfully. You may edit it again below.') % {'name': force_unicode(verbose_name), 'obj': obj} |             msg = _('The %(name)s "%(obj)s" was added successfully. You may edit it again below.') % {'name': force_unicode(verbose_name), 'obj': obj} | ||||||
|             self.message_user(request, msg) |             self.message_user(request, msg) | ||||||
|             return HttpResponseRedirect("../%s/" % pk_value) |             return HttpResponseRedirect(reverse('admin:%s_%s_change' % | ||||||
|  |                                         (opts.app_label, module_name), | ||||||
|  |                                         args=(pk_value,), | ||||||
|  |                                         current_app=self.admin_site.name)) | ||||||
|         elif "_addanother" in request.POST: |         elif "_addanother" in request.POST: | ||||||
|             self.message_user(request, msg + ' ' + (_("You may add another %s below.") % force_unicode(verbose_name))) |             self.message_user(request, msg + ' ' + (_("You may add another %s below.") % force_unicode(verbose_name))) | ||||||
|             return HttpResponseRedirect("../add/") |             return HttpResponseRedirect(reverse('admin:%s_%s_add' % | ||||||
|  |                                         (opts.app_label, module_name), | ||||||
|  |                                         current_app=self.admin_site.name)) | ||||||
|         else: |         else: | ||||||
|             self.message_user(request, msg) |             self.message_user(request, msg) | ||||||
|             # Figure out where to redirect. If the user has change permission, |             # Figure out where to redirect. If the user has change permission, | ||||||
|             # redirect to the change-list page for this object. Otherwise, |             # redirect to the change-list page for this object. Otherwise, | ||||||
|             # redirect to the admin index. |             # redirect to the admin index. | ||||||
|             if self.has_change_permission(request, None): |             if self.has_change_permission(request, None): | ||||||
|                 return HttpResponseRedirect('../') |                 post_url = reverse('admin:%s_%s_changelist' % | ||||||
|  |                                    (opts.app_label, module_name), | ||||||
|  |                                    current_app=self.admin_site.name) | ||||||
|             else: |             else: | ||||||
|                 return HttpResponseRedirect('../../../') |                 post_url = reverse('admin:index', | ||||||
|  |                                    current_app=self.admin_site.name) | ||||||
|  |             return HttpResponseRedirect(post_url) | ||||||
|  |  | ||||||
|     def response_action(self, request, queryset): |     def response_action(self, request, queryset): | ||||||
|         """ |         """ | ||||||
| @@ -990,7 +1006,9 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|             raise Http404(_('%(name)s object with primary key %(key)r does not exist.') % {'name': force_unicode(opts.verbose_name), 'key': escape(object_id)}) |             raise Http404(_('%(name)s object with primary key %(key)r does not exist.') % {'name': force_unicode(opts.verbose_name), 'key': escape(object_id)}) | ||||||
|  |  | ||||||
|         if request.method == 'POST' and "_saveasnew" in request.POST: |         if request.method == 'POST' and "_saveasnew" in request.POST: | ||||||
|             return self.add_view(request, form_url='../add/') |             return self.add_view(request, form_url=reverse('admin:%s_%s_add' % | ||||||
|  |                                     (opts.app_label, opts.module_name), | ||||||
|  |                                     current_app=self.admin_site.name)) | ||||||
|  |  | ||||||
|         ModelForm = self.get_form(request, obj) |         ModelForm = self.get_form(request, obj) | ||||||
|         formsets = [] |         formsets = [] | ||||||
| @@ -1246,8 +1264,11 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|             self.message_user(request, _('The %(name)s "%(obj)s" was deleted successfully.') % {'name': force_unicode(opts.verbose_name), 'obj': force_unicode(obj_display)}) |             self.message_user(request, _('The %(name)s "%(obj)s" was deleted successfully.') % {'name': force_unicode(opts.verbose_name), 'obj': force_unicode(obj_display)}) | ||||||
|  |  | ||||||
|             if not self.has_change_permission(request, None): |             if not self.has_change_permission(request, None): | ||||||
|                 return HttpResponseRedirect("../../../../") |                 return HttpResponseRedirect(reverse('admin:index', | ||||||
|             return HttpResponseRedirect("../../") |                                                     current_app=self.admin_site.name)) | ||||||
|  |             return HttpResponseRedirect(reverse('admin:%s_%s_changelist' % | ||||||
|  |                                         (opts.app_label, opts.module_name), | ||||||
|  |                                         current_app=self.admin_site.name)) | ||||||
|  |  | ||||||
|         object_name = force_unicode(opts.verbose_name) |         object_name = force_unicode(opts.verbose_name) | ||||||
|  |  | ||||||
| @@ -1292,6 +1313,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|             'module_name': capfirst(force_unicode(opts.verbose_name_plural)), |             'module_name': capfirst(force_unicode(opts.verbose_name_plural)), | ||||||
|             'object': obj, |             'object': obj, | ||||||
|             'app_label': app_label, |             'app_label': app_label, | ||||||
|  |             'opts': opts, | ||||||
|         } |         } | ||||||
|         context.update(extra_context or {}) |         context.update(extra_context or {}) | ||||||
|         return TemplateResponse(request, self.object_history_template or [ |         return TemplateResponse(request, self.object_history_template or [ | ||||||
|   | |||||||
| @@ -339,9 +339,11 @@ class AdminSite(object): | |||||||
|                 # Check whether user has any perm for this module. |                 # Check whether user has any perm for this module. | ||||||
|                 # If so, add the module to the model_list. |                 # If so, add the module to the model_list. | ||||||
|                 if True in perms.values(): |                 if True in perms.values(): | ||||||
|  |                     info = (app_label, model._meta.module_name) | ||||||
|                     model_dict = { |                     model_dict = { | ||||||
|                         'name': capfirst(model._meta.verbose_name_plural), |                         'name': capfirst(model._meta.verbose_name_plural), | ||||||
|                         'admin_url': mark_safe('%s/%s/' % (app_label, model.__name__.lower())), |                         'admin_url': reverse('admin:%s_%s_changelist' % info, current_app=self.name), | ||||||
|  |                         'add_url': reverse('admin:%s_%s_add' % info, current_app=self.name), | ||||||
|                         'perms': perms, |                         'perms': perms, | ||||||
|                     } |                     } | ||||||
|                     if app_label in app_dict: |                     if app_label in app_dict: | ||||||
| @@ -349,7 +351,7 @@ class AdminSite(object): | |||||||
|                     else: |                     else: | ||||||
|                         app_dict[app_label] = { |                         app_dict[app_label] = { | ||||||
|                             'name': app_label.title(), |                             'name': app_label.title(), | ||||||
|                             'app_url': app_label + '/', |                             'app_url': reverse('admin:app_list', kwargs={'app_label': app_label}, current_app=self.name), | ||||||
|                             'has_module_perms': has_module_perms, |                             'has_module_perms': has_module_perms, | ||||||
|                             'models': [model_dict], |                             'models': [model_dict], | ||||||
|                         } |                         } | ||||||
| @@ -383,9 +385,11 @@ class AdminSite(object): | |||||||
|                     # Check whether user has any perm for this module. |                     # Check whether user has any perm for this module. | ||||||
|                     # If so, add the module to the model_list. |                     # If so, add the module to the model_list. | ||||||
|                     if True in perms.values(): |                     if True in perms.values(): | ||||||
|  |                         info = (app_label, model._meta.module_name) | ||||||
|                         model_dict = { |                         model_dict = { | ||||||
|                             'name': capfirst(model._meta.verbose_name_plural), |                             'name': capfirst(model._meta.verbose_name_plural), | ||||||
|                             'admin_url': '%s/' % model.__name__.lower(), |                             'admin_url': reverse('admin:%s_%s_changelist' % info, current_app=self.name), | ||||||
|  |                             'add_url': reverse('admin:%s_%s_add' % info, current_app=self.name), | ||||||
|                             'perms': perms, |                             'perms': perms, | ||||||
|                         } |                         } | ||||||
|                         if app_dict: |                         if app_dict: | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="/">{% trans "Home" %}</a> › {% trans "Server error" %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Server error' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Server error (500)' %}{% endblock %} | {% block title %}{% trans 'Server error (500)' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,15 +1,17 @@ | |||||||
| {% extends "admin/index.html" %} | {% extends "admin/index.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% if not is_popup %} | {% if not is_popup %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %} | {% block breadcrumbs %} | ||||||
| <div class="breadcrumbs"><a href="../"> | <div class="breadcrumbs"> | ||||||
| {% trans "Home" %}</a> ›  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › | ||||||
| {% for app in app_list %} | {% for app in app_list %} | ||||||
| {% blocktrans with app.name as name %}{{ name }}{% endblocktrans %} | {% blocktrans with app.name as name %}{{ name }}{% endblocktrans %} | ||||||
| {% endfor %}</div>{% endblock %} | {% endfor %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% endif %} | {% endif %} | ||||||
|  |  | ||||||
| {% block sidebar %}{% endblock %} | {% block sidebar %}{% endblock %} | ||||||
| @@ -1,21 +1,24 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n admin_static admin_modify %} | {% load i18n admin_static admin_modify %} | ||||||
| {% load url from future %} | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block extrahead %}{{ block.super }} | {% block extrahead %}{{ block.super }} | ||||||
| {% url 'admin:jsi18n' as jsi18nurl %} | {% url 'admin:jsi18n' as jsi18nurl %} | ||||||
| <script type="text/javascript" src="{{ jsi18nurl|default:"../../../../jsi18n/" }}"></script> | <script type="text/javascript" src="{{ jsi18nurl|default:"../../../../jsi18n/" }}"></script> | ||||||
| {% endblock %} | {% endblock %} | ||||||
| {% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %} | {% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %} | ||||||
| {% block bodyclass %}{{ opts.app_label }}-{{ opts.object_name.lower }} change-form{% endblock %} | {% block bodyclass %}{{ opts.app_label }}-{{ opts.object_name.lower }} change-form{% endblock %} | ||||||
| {% block breadcrumbs %}{% if not is_popup %} | {% if not is_popup %} | ||||||
| <div class="breadcrumbs"> | {% block breadcrumbs %} | ||||||
|      <a href="../../../../">{% trans "Home" %}</a> › | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|      <a href="../../../">{{ opts.app_label|capfirst|escape }}</a> › | › <a href="{% url 'admin:app_list' app_label=opts.app_label %}">{{ opts.app_label|capfirst|escape }}</a> | ||||||
|      <a href="../../">{{ opts.verbose_name_plural|capfirst }}</a> › | › <a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst }}</a> | ||||||
|      <a href="../">{{ original|truncatewords:"18" }}</a> › | › <a href="{% url opts|admin_urlname:'changelist' %}{{ original.pk }}">{{ original|truncatewords:"18" }}</a> | ||||||
|      {% trans 'Change password' %} | › {% trans 'Change password' %} | ||||||
| </div> | </div> | ||||||
| {% endif %}{% endblock %} | {% endblock %} | ||||||
|  | {% endif %} | ||||||
| {% block content %}<div id="content-main"> | {% block content %}<div id="content-main"> | ||||||
| <form action="{{ form_url }}" method="post" id="{{ opts.module_name }}_form">{% csrf_token %}{% block form_top %}{% endblock %} | <form action="{{ form_url }}" method="post" id="{{ opts.module_name }}_form">{% csrf_token %}{% block form_top %}{% endblock %} | ||||||
| <div> | <div> | ||||||
|   | |||||||
| @@ -32,17 +32,20 @@ | |||||||
|                 {% if docsroot %} |                 {% if docsroot %} | ||||||
|                     <a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / |                     <a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / | ||||||
|                 {% endif %} |                 {% endif %} | ||||||
|                 <a href="{% url 'admin:password_change' %}"> |                 <a href="{% url 'admin:password_change' %}">{% trans 'Change password' %}</a> / | ||||||
|                 {% trans 'Change password' %}</a> / |                 <a href="{% url 'admin:logout' %}">{% trans 'Log out' %}</a> | ||||||
|                 <a href="{% url 'admin:logout' %}"> |  | ||||||
|                 {% trans 'Log out' %}</a> |  | ||||||
|             {% endblock %} |             {% endblock %} | ||||||
|         </div> |         </div> | ||||||
|         {% endif %} |         {% endif %} | ||||||
|         {% block nav-global %}{% endblock %} |         {% block nav-global %}{% endblock %} | ||||||
|     </div> |     </div> | ||||||
|     <!-- END Header --> |     <!-- END Header --> | ||||||
|     {% block breadcrumbs %}<div class="breadcrumbs"><a href="/">{% trans 'Home' %}</a>{% if title %} › {{ title }}{% endif %}</div>{% endblock %} |     {% block breadcrumbs %} | ||||||
|  |     <div class="breadcrumbs"> | ||||||
|  |     <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  |     {% if title %} › {{ title }}{% endif %} | ||||||
|  |     </div> | ||||||
|  |     {% endblock %} | ||||||
|     {% endif %} |     {% endif %} | ||||||
|  |  | ||||||
|     {% block messages %} |     {% block messages %} | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n admin_static admin_modify %} | {% load i18n admin_static admin_modify %} | ||||||
| {% load url from future %} | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block extrahead %}{{ block.super }} | {% block extrahead %}{{ block.super }} | ||||||
| {% url 'admin:jsi18n' as jsi18nurl %} | {% url 'admin:jsi18n' as jsi18nurl %} | ||||||
| @@ -14,14 +15,15 @@ | |||||||
|  |  | ||||||
| {% block bodyclass %}{{ opts.app_label }}-{{ opts.object_name.lower }} change-form{% endblock %} | {% block bodyclass %}{{ opts.app_label }}-{{ opts.object_name.lower }} change-form{% endblock %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}{% if not is_popup %} | {% if not is_popup %} | ||||||
| <div class="breadcrumbs"> | {% block breadcrumbs %} | ||||||
|      <a href="../../../">{% trans "Home" %}</a> › | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|      <a href="../../">{{ app_label|capfirst|escape }}</a> › | › <a href="{% url 'admin:app_list' app_label=opts.app_label %}">{{ app_label|capfirst|escape }}</a> | ||||||
|      {% if has_change_permission %}<a href="../">{{ opts.verbose_name_plural|capfirst }}</a>{% else %}{{ opts.verbose_name_plural|capfirst }}{% endif %} › | › {% if has_change_permission %}<a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst }}</a>{% else %}{{ opts.verbose_name_plural|capfirst }}{% endif %} | ||||||
|      {% if add %}{% trans "Add" %} {{ opts.verbose_name }}{% else %}{{ original|truncatewords:"18" }}{% endif %} | › {% if add %}{% trans 'Add' %} {{ opts.verbose_name }}{% else %}{{ original|truncatewords:"18" }}{% endif %} | ||||||
| </div> | </div> | ||||||
| {% endif %}{% endblock %} | {% endblock %} | ||||||
|  | {% endif %} | ||||||
|  |  | ||||||
| {% block content %}<div id="content-main"> | {% block content %}<div id="content-main"> | ||||||
| {% block object-tools %} | {% block object-tools %} | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n admin_static admin_list %} | {% load i18n admin_static admin_list %} | ||||||
| {% load url from future %} | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block extrastyle %} | {% block extrastyle %} | ||||||
|   {{ block.super }} |   {{ block.super }} | ||||||
|   <link rel="stylesheet" type="text/css" href="{% static "admin/css/changelists.css" %}" /> |   <link rel="stylesheet" type="text/css" href="{% static "admin/css/changelists.css" %}" /> | ||||||
| @@ -36,19 +38,13 @@ | |||||||
| {% block bodyclass %}change-list{% endblock %} | {% block bodyclass %}change-list{% endblock %} | ||||||
|  |  | ||||||
| {% if not is_popup %} | {% if not is_popup %} | ||||||
|   {% block breadcrumbs %} | {% block breadcrumbs %} | ||||||
|     <div class="breadcrumbs"> | <div class="breadcrumbs"> | ||||||
|       <a href="../../"> | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|         {% trans "Home" %} | › <a href="{% url 'admin:app_list' app_label=cl.opts.app_label %}">{{ app_label|capfirst|escape }}</a> | ||||||
|       </a> | › {{ cl.opts.verbose_name_plural|capfirst }} | ||||||
|        › | </div> | ||||||
|        <a href="../"> | {% endblock %} | ||||||
|          {{ app_label|capfirst }} |  | ||||||
|       </a> |  | ||||||
|       › |  | ||||||
|       {{ cl.opts.verbose_name_plural|capfirst }} |  | ||||||
|     </div> |  | ||||||
|   {% endblock %} |  | ||||||
| {% endif %} | {% endif %} | ||||||
|  |  | ||||||
| {% block coltype %}flex{% endblock %} | {% block coltype %}flex{% endblock %} | ||||||
| @@ -60,7 +56,7 @@ | |||||||
|         <ul class="object-tools"> |         <ul class="object-tools"> | ||||||
|           {% block object-tools-items %} |           {% block object-tools-items %} | ||||||
|             <li> |             <li> | ||||||
|               <a href="add/{% if is_popup %}?_popup=1{% endif %}" class="addlink"> |               <a href="{% url cl.opts|admin_urlname:'add' %}{% if is_popup %}?_popup=1{% endif %}" class="addlink"> | ||||||
|                 {% blocktrans with cl.opts.verbose_name as name %}Add {{ name }}{% endblocktrans %} |                 {% blocktrans with cl.opts.verbose_name as name %}Add {{ name }}{% endblocktrans %} | ||||||
|               </a> |               </a> | ||||||
|             </li> |             </li> | ||||||
|   | |||||||
| @@ -1,13 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %} | {% block breadcrumbs %} | ||||||
| <div class="breadcrumbs"> | <div class="breadcrumbs"> | ||||||
|      <a href="../../../../">{% trans "Home" %}</a> › | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|      <a href="../../../">{{ app_label|capfirst }}</a> ›  | › <a href="{% url 'admin:app_list' app_label=opts.app_label %}">{{ app_label|capfirst }}</a> | ||||||
|      <a href="../../">{{ opts.verbose_name_plural|capfirst }}</a> › | › <a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst|escape }}</a> | ||||||
|      <a href="../">{{ object|truncatewords:"18" }}</a> › | › <a href="{% url opts|admin_urlname:'changelist' %}{{ object.pk }}">{{ object|truncatewords:"18" }}</a> | ||||||
|      {% trans 'Delete' %} | › {% trans 'Delete' %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,12 +1,14 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n l10n %} | {% load i18n l10n %} | ||||||
|  | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %} | {% block breadcrumbs %} | ||||||
| <div class="breadcrumbs"> | <div class="breadcrumbs"> | ||||||
|      <a href="../../">{% trans "Home" %}</a> › | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|      <a href="../">{{ app_label|capfirst }}</a> › | › <a href="{% url 'admin:app_list' app_label=app_label %}">{{ app_label|capfirst|escape }}</a> | ||||||
|      <a href="./">{{ opts.verbose_name_plural|capfirst }}</a> › | › <a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst }}</a> | ||||||
|      {% trans 'Delete multiple objects' %} | › {% trans 'Delete multiple objects' %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ | |||||||
|             {% endif %} |             {% endif %} | ||||||
|  |  | ||||||
|             {% if model.perms.add %} |             {% if model.perms.add %} | ||||||
|                 <td><a href="{{ model.admin_url }}add/" class="addlink">{% trans 'Add' %}</a></td> |                 <td><a href="{{ model.add_url }}" class="addlink">{% trans 'Add' %}</a></td> | ||||||
|             {% else %} |             {% else %} | ||||||
|                 <td> </td> |                 <td> </td> | ||||||
|             {% endif %} |             {% endif %} | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">{% trans 'Home' %}</a> › {{ title }}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {{ title }} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
| <p>{% trans "Something's wrong with your database installation. Make sure the appropriate database tables have been created, and make sure the database is readable by the appropriate user." %}</p> | <p>{% trans "Something's wrong with your database installation. Make sure the appropriate database tables have been created, and make sure the database is readable by the appropriate user." %}</p> | ||||||
|   | |||||||
| @@ -1,13 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  | {% load admin_urls %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %} | {% block breadcrumbs %} | ||||||
| <div class="breadcrumbs"> | <div class="breadcrumbs"> | ||||||
|     <a href="../../../../">{% trans 'Home' %}</a> ›  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|     <a href="../../../">{{ app_label|capfirst }}</a> ›  | › <a href="{% url 'admin:app_list' app_label=app_label %}">{{ app_label|capfirst|escape }}</a> | ||||||
|     <a href="../../">{{ module_name }}</a> ›  | › <a href="{% url opts|admin_urlname:'changelist' %}">{{ module_name }}</a> | ||||||
|     <a href="../">{{ object|truncatewords:"18" }}</a> ›  | › <a href="{% url opts|admin_urlname:'changelist' %}{{ object.pk }}">{{ object|truncatewords:"18" }}</a> | ||||||
|     {% trans 'History' %} | › {% trans 'History' %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,12 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">{% trans 'Home' %}</a></div>{% endblock %} | {% block breadcrumbs %}<div class="breadcrumbs"><a href="{% url 'admin:index' %}">{% trans 'Home' %}</a></div>{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|  |  | ||||||
| <p>{% trans "Thanks for spending some quality time with the Web site today." %}</p> | <p>{% trans "Thanks for spending some quality time with the Web site today." %}</p> | ||||||
|  |  | ||||||
| <p><a href="../">{% trans 'Log in again' %}</a></p> | <p><a href="{% url 'admin:index' %}">{% trans 'Log in again' %}</a></p> | ||||||
|  |  | ||||||
| {% endblock %} | {% endblock %} | ||||||
|   | |||||||
| @@ -1,8 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
| {% load url from future %} | {% load url from future %} | ||||||
| {% block userlinks %}{% url 'django-admindocs-docroot' as docsroot %}{% if docsroot %}<a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / {% endif %}{% trans 'Change password' %} / <a href="../../logout/">{% trans 'Log out' %}</a>{% endblock %} | {% block userlinks %}{% url 'django-admindocs-docroot' as docsroot %}{% if docsroot %}<a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / {% endif %}{% trans 'Change password' %} / <a href="{% url 'admin:logout' %}">{% trans 'Log out' %}</a>{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">{% trans 'Home' %}</a> › {% trans 'Password change' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password change' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Password change successful' %}{% endblock %} | {% block title %}{% trans 'Password change successful' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,8 +2,13 @@ | |||||||
| {% load i18n static %} | {% load i18n static %} | ||||||
| {% load url from future %} | {% load url from future %} | ||||||
| {% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %} | {% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %} | ||||||
| {% block userlinks %}{% url 'django-admindocs-docroot' as docsroot %}{% if docsroot %}<a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / {% endif %} {% trans 'Change password' %} / <a href="../logout/">{% trans 'Log out' %}</a>{% endblock %} | {% block userlinks %}{% url 'django-admindocs-docroot' as docsroot %}{% if docsroot %}<a href="{{ docsroot }}">{% trans 'Documentation' %}</a> / {% endif %} {% trans 'Change password' %} / <a href="{% url 'admin:logout' %}">{% trans 'Log out' %}</a>{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">{% trans 'Home' %}</a> › {% trans 'Password change' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password change' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Password change' %}{% endblock %} | {% block title %}{% trans 'Password change' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">{% trans 'Home' %}</a> › {% trans 'Password reset' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password reset' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Password reset complete' %}{% endblock %} | {% block title %}{% trans 'Password reset complete' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">{% trans 'Home' %}</a> › {% trans 'Password reset confirmation' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password reset confirmation' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Password reset' %}{% endblock %} | {% block title %}{% trans 'Password reset' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">{% trans 'Home' %}</a> › {% trans 'Password reset' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password reset' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans 'Password reset successful' %}{% endblock %} | {% block title %}{% trans 'Password reset successful' %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">{% trans 'Home' %}</a> › {% trans 'Password reset' %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Password reset' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}{% trans "Password reset" %}{% endblock %} | {% block title %}{% trans "Password reset" %}{% endblock %} | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								django/contrib/admin/templatetags/admin_urls.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								django/contrib/admin/templatetags/admin_urls.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | from django.core.urlresolvers import reverse, NoReverseMatch | ||||||
|  | from django import template | ||||||
|  |  | ||||||
|  | register = template.Library() | ||||||
|  |  | ||||||
|  | @register.filter | ||||||
|  | def admin_urlname(value, arg): | ||||||
|  |     return 'admin:%s_%s_%s' % (value.app_label, value.module_name, arg) | ||||||
| @@ -1,6 +1,14 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
|  | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}{% load i18n %}<div class="breadcrumbs"><a href="../../">{% trans "Home" %}</a> › <a href="../">{% trans "Documentation" %}</a> › {% trans "Bookmarklets" %}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Bookmarklets' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}{% trans "Documentation bookmarklets" %}{% endblock %} | {% block title %}{% trans "Documentation bookmarklets" %}{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|   | |||||||
| @@ -1,6 +1,13 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="{{ root_path }}">Home</a> › Documentation</div>{% endblock %} | {% load url from future %} | ||||||
|  |  | ||||||
|  | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Documentation' %}</a> | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}Documentation{% endblock %} | {% block title %}Documentation{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|   | |||||||
| @@ -1,6 +1,12 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../">Home</a> › Documentation</div>{% endblock %} | {% load url from future %} | ||||||
|  |  | ||||||
|  | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › {% trans 'Documentation' %}</a> | ||||||
|  | </div> | ||||||
| {% block title %}Please install docutils{% endblock %} | {% block title %}Please install docutils{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block extrahead %} | {% block extrahead %} | ||||||
| {{ block.super }} | {{ block.super }} | ||||||
| <style type="text/css"> | <style type="text/css"> | ||||||
| @@ -8,7 +10,14 @@ | |||||||
| </style> | </style> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../../">Home</a> › <a href="../../">Documentation</a> › <a href="../">Models</a> › {{ name }}</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-models-index' %}">{% trans 'Models' %}</a> | ||||||
|  | › {{ name }} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}Model: {{ name }}{% endblock %} | {% block title %}Model: {{ name }}{% endblock %} | ||||||
|  |  | ||||||
| @@ -41,6 +50,6 @@ | |||||||
| </table> | </table> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
| <p class="small"><a href="../">‹ Back to Models Documentation</a></p> | <p class="small"><a href="{% url 'django-admindocs-models-index' %}">‹ Back to Models Documentation</a></p> | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|   | |||||||
| @@ -1,7 +1,16 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block coltype %}colSM{% endblock %} | {% block coltype %}colSM{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">Home</a> › <a href="../">Documentation</a> › Models</div>{% endblock %} |  | ||||||
|  | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Models' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}Models{% endblock %} | {% block title %}Models{% endblock %} | ||||||
|  |  | ||||||
| @@ -19,7 +28,7 @@ | |||||||
| <table class="xfull"> | <table class="xfull"> | ||||||
| {% for model in group.list %} | {% for model in group.list %} | ||||||
| <tr> | <tr> | ||||||
| <th><a href="{{ model.app_label }}.{{ model.object_name.lower }}/">{{ model.object_name }}</a></th> | <th><a href="{% url 'django-admindocs-models-detail' app_label=model.app_label model_name=model.object_name.lower %}">{{ model.object_name }}</a></th> | ||||||
| </tr> | </tr> | ||||||
| {% endfor %} | {% endfor %} | ||||||
| </table> | </table> | ||||||
|   | |||||||
| @@ -1,6 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../../">Home</a> › <a href="../../">Documentation</a> › Templates › {{ name }}</div>{% endblock %} | {% load url from future %} | ||||||
|  |  | ||||||
|  | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Templates' %} | ||||||
|  | › {{ name }} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
|  |  | ||||||
| {% block title %}Template: {{ name }}{% endblock %} | {% block title %}Template: {{ name }}{% endblock %} | ||||||
|  |  | ||||||
| @@ -17,5 +26,5 @@ | |||||||
|     </ol> |     </ol> | ||||||
| {% endfor %} | {% endfor %} | ||||||
|  |  | ||||||
| <p class="small"><a href="../../">‹ Back to Documentation</a></p> | <p class="small"><a href="{% url 'django-admindocs-docroot' %}">‹ Back to Documentation</a></p> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|   | |||||||
| @@ -1,7 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block coltype %}colSM{% endblock %} | {% block coltype %}colSM{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">Home</a> › <a href="../">Documentation</a> › filters</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Filters' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}Template filters{% endblock %} | {% block title %}Template filters{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|   | |||||||
| @@ -1,7 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block coltype %}colSM{% endblock %} | {% block coltype %}colSM{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">Home</a> › <a href="../">Documentation</a> › Tags</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Tags' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}Template tags{% endblock %} | {% block title %}Template tags{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
|   | |||||||
| @@ -1,6 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../../">Home</a> › <a href="../../">Documentation</a> › <a href="../">Views</a> › {{ name }}</div>{% endblock %} | {% load url from future %} | ||||||
|  |  | ||||||
|  | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-views-index' %}">{% trans 'Views' %}</a> | ||||||
|  | › {{ name }} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}View: {{ name }}{% endblock %} | {% block title %}View: {{ name }}{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
| @@ -21,5 +30,5 @@ | |||||||
| <p>{{ meta.Templates }}</p> | <p>{{ meta.Templates }}</p> | ||||||
| {% endif %} | {% endif %} | ||||||
|  |  | ||||||
| <p class="small"><a href="../">‹ Back to Views Documentation</a></p> | <p class="small"><a href="{% url 'django-admindocs-views-index' %}">‹ Back to Views Documentation</a></p> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|   | |||||||
| @@ -1,7 +1,15 @@ | |||||||
| {% extends "admin/base_site.html" %} | {% extends "admin/base_site.html" %} | ||||||
| {% load i18n %} | {% load i18n %} | ||||||
|  | {% load url from future %} | ||||||
|  |  | ||||||
| {% block coltype %}colSM{% endblock %} | {% block coltype %}colSM{% endblock %} | ||||||
| {% block breadcrumbs %}<div class="breadcrumbs"><a href="../../">Home</a> › <a href="../">Documentation</a> › Views</div>{% endblock %} | {% block breadcrumbs %} | ||||||
|  | <div class="breadcrumbs"> | ||||||
|  | <a href="{% url 'admin:index' %}">{% trans 'Home' %}</a> | ||||||
|  | › <a href="{% url 'django-admindocs-docroot' %}">{% trans 'Documentation' %}</a> | ||||||
|  | › {% trans 'Views' %} | ||||||
|  | </div> | ||||||
|  | {% endblock %} | ||||||
| {% block title %}Views{% endblock %} | {% block title %}Views{% endblock %} | ||||||
|  |  | ||||||
| {% block content %} | {% block content %} | ||||||
| @@ -29,8 +37,8 @@ | |||||||
|  |  | ||||||
| {% for view in site_views.list|dictsort:"url" %} | {% for view in site_views.list|dictsort:"url" %} | ||||||
| {% ifchanged %} | {% ifchanged %} | ||||||
| <h3><a href="{{ view.module }}.{{ view.name }}/">{{ view.url }}</a></h3> | <h3><a href="{% url 'django-admindocs-views-detail' view=view.full_name %}">{{ view.url }}</a></h3> | ||||||
| <p class="small quiet">View function: {{ view.module }}.{{ view.name }}</p> | <p class="small quiet">View function: {{ view.full_name }}</p> | ||||||
| <p>{{ view.title }}</p> | <p>{{ view.title }}</p> | ||||||
| <hr /> | <hr /> | ||||||
| {% endifchanged %} | {% endifchanged %} | ||||||
|   | |||||||
| @@ -136,8 +136,7 @@ def view_index(request): | |||||||
|             site_obj = GenericSite() |             site_obj = GenericSite() | ||||||
|         for (func, regex) in view_functions: |         for (func, regex) in view_functions: | ||||||
|             views.append({ |             views.append({ | ||||||
|                 'name': getattr(func, '__name__', func.__class__.__name__), |                 'full_name': '%s.%s' % (func.__module__, getattr(func, '__name__', func.__class__.__name__)), | ||||||
|                 'module': func.__module__, |  | ||||||
|                 'site_id': settings_mod.SITE_ID, |                 'site_id': settings_mod.SITE_ID, | ||||||
|                 'site': site_obj, |                 'site': site_obj, | ||||||
|                 'url': simplify_regex(regex), |                 'url': simplify_regex(regex), | ||||||
|   | |||||||
| @@ -1960,3 +1960,18 @@ if you specifically wanted the admin view from the admin instance named | |||||||
|  |  | ||||||
| For more details, see the documentation on :ref:`reversing namespaced URLs | For more details, see the documentation on :ref:`reversing namespaced URLs | ||||||
| <topics-http-reversing-url-namespaces>`. | <topics-http-reversing-url-namespaces>`. | ||||||
|  |  | ||||||
|  | To allow easier reversing of the admin urls in templates, Django provides an  | ||||||
|  | ``admin_url`` filter which takes an action as argument: | ||||||
|  |  | ||||||
|  | .. code-block:: html+django | ||||||
|  |  | ||||||
|  |     {% load admin_urls %} | ||||||
|  |     {% load url from future %} | ||||||
|  |     <a href="{% url opts|admin_urlname:'add' %}">Add user</a> | ||||||
|  |     <a href="{% url opts|admin_urlname:'delete' user.pk %}">Delete this user</a> | ||||||
|  |  | ||||||
|  | The action in the examples above match the last part of the URL names for | ||||||
|  | :class:`ModelAdmin` instances described above. The ``opts`` variable can be any | ||||||
|  | object which has an ``app_label`` and ``module_name`` and is usually supplied  | ||||||
|  | by the admin views for the current model. | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								tests/regressiontests/admin_custom_urls/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								tests/regressiontests/admin_custom_urls/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | # | ||||||
| @@ -0,0 +1,44 @@ | |||||||
|  | [ | ||||||
|  |   { | ||||||
|  |     "pk": "delete",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "Remove things." | ||||||
|  |     } | ||||||
|  |   },  | ||||||
|  |   { | ||||||
|  |     "pk": "rename",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "Gives things other names." | ||||||
|  |     } | ||||||
|  |   },  | ||||||
|  |   { | ||||||
|  |     "pk": "add",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "Add things." | ||||||
|  |     } | ||||||
|  |   },  | ||||||
|  |   { | ||||||
|  |     "pk": "path/to/file/",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "An action with '/' in its name." | ||||||
|  |     } | ||||||
|  |   },  | ||||||
|  |   { | ||||||
|  |     "pk": "path/to/html/document.html",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "An action with a name similar to a HTML doc path." | ||||||
|  |     } | ||||||
|  |   },  | ||||||
|  |   { | ||||||
|  |     "pk": "javascript:alert('Hello world');\">Click here</a>",  | ||||||
|  |     "model": "admin_custom_urls.action",  | ||||||
|  |     "fields": { | ||||||
|  |       "description": "An action with a name suspected of being a XSS attempt" | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | ] | ||||||
							
								
								
									
										20
									
								
								tests/regressiontests/admin_custom_urls/fixtures/users.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								tests/regressiontests/admin_custom_urls/fixtures/users.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | [ | ||||||
|  |   { | ||||||
|  |     "pk": 100, | ||||||
|  |     "model": "auth.user", | ||||||
|  |     "fields": { | ||||||
|  |       "username": "super", | ||||||
|  |       "first_name": "Super", | ||||||
|  |       "last_name": "User", | ||||||
|  |       "is_active": true, | ||||||
|  |       "is_superuser": true, | ||||||
|  |       "is_staff": true, | ||||||
|  |       "last_login": "2007-05-30 13:20:10", | ||||||
|  |       "groups": [], | ||||||
|  |       "user_permissions": [], | ||||||
|  |       "password": "sha1$995a3$6011485ea3834267d719b4c801409b8b1ddd0158", | ||||||
|  |       "email": "super@example.com", | ||||||
|  |       "date_joined": "2007-05-30 13:20:10" | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | ] | ||||||
							
								
								
									
										50
									
								
								tests/regressiontests/admin_custom_urls/models.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								tests/regressiontests/admin_custom_urls/models.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | from functools import update_wrapper | ||||||
|  |  | ||||||
|  | from django.contrib import admin | ||||||
|  | from django.db import models | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Action(models.Model): | ||||||
|  |     name = models.CharField(max_length=50, primary_key=True) | ||||||
|  |     description = models.CharField(max_length=70) | ||||||
|  |  | ||||||
|  |     def __unicode__(self): | ||||||
|  |         return self.name | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class ActionAdmin(admin.ModelAdmin): | ||||||
|  |     """ | ||||||
|  |     A ModelAdmin for the Action model that changes the URL of the add_view | ||||||
|  |     to '<app name>/<model name>/!add/' | ||||||
|  |     The Action model has a CharField PK. | ||||||
|  |     """ | ||||||
|  |  | ||||||
|  |     list_display = ('name', 'description') | ||||||
|  |  | ||||||
|  |     def remove_url(self, name): | ||||||
|  |         """ | ||||||
|  |         Remove all entries named 'name' from the ModelAdmin instance URL | ||||||
|  |         patterns list | ||||||
|  |         """ | ||||||
|  |         return filter(lambda e: e.name != name, super(ActionAdmin, self).get_urls()) | ||||||
|  |  | ||||||
|  |     def get_urls(self): | ||||||
|  |         # Add the URL of our custom 'add_view' view to the front of the URLs | ||||||
|  |         # list.  Remove the existing one(s) first | ||||||
|  |         from django.conf.urls.defaults import patterns, url | ||||||
|  |  | ||||||
|  |         def wrap(view): | ||||||
|  |             def wrapper(*args, **kwargs): | ||||||
|  |                 return self.admin_site.admin_view(view)(*args, **kwargs) | ||||||
|  |             return update_wrapper(wrapper, view) | ||||||
|  |  | ||||||
|  |         info = self.model._meta.app_label, self.model._meta.module_name | ||||||
|  |  | ||||||
|  |         view_name = '%s_%s_add' % info | ||||||
|  |  | ||||||
|  |         return patterns('', | ||||||
|  |             url(r'^!add/$', wrap(self.add_view), name=view_name), | ||||||
|  |         ) + self.remove_url(view_name) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | admin.site.register(Action, ActionAdmin) | ||||||
							
								
								
									
										72
									
								
								tests/regressiontests/admin_custom_urls/tests.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								tests/regressiontests/admin_custom_urls/tests.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | |||||||
|  | from django.core.urlresolvers import reverse | ||||||
|  | from django.template.response import TemplateResponse | ||||||
|  | from django.test import TestCase | ||||||
|  |  | ||||||
|  | from models import Action | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class AdminCustomUrlsTest(TestCase): | ||||||
|  |     fixtures = ['users.json', 'actions.json'] | ||||||
|  |  | ||||||
|  |     def setUp(self): | ||||||
|  |         self.client.login(username='super', password='secret') | ||||||
|  |  | ||||||
|  |     def tearDown(self): | ||||||
|  |         self.client.logout() | ||||||
|  |  | ||||||
|  |     def testBasicAddGet(self): | ||||||
|  |         """ | ||||||
|  |         A smoke test to ensure GET on the add_view works. | ||||||
|  |         """ | ||||||
|  |         response = self.client.get('/custom_urls/admin/admin_custom_urls/action/!add/') | ||||||
|  |         self.assertIsInstance(response, TemplateResponse) | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |  | ||||||
|  |     def testAddWithGETArgs(self): | ||||||
|  |         response = self.client.get('/custom_urls/admin/admin_custom_urls/action/!add/', {'name': 'My Action'}) | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |         self.assertTrue( | ||||||
|  |             'value="My Action"' in response.content, | ||||||
|  |             "Couldn't find an input with the right value in the response." | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def testBasicAddPost(self): | ||||||
|  |         """ | ||||||
|  |         A smoke test to ensure POST on add_view works. | ||||||
|  |         """ | ||||||
|  |         post_data = { | ||||||
|  |             '_popup': u'1', | ||||||
|  |             "name": u'Action added through a popup', | ||||||
|  |             "description": u"Description of added action", | ||||||
|  |         } | ||||||
|  |         response = self.client.post('/custom_urls/admin/admin_custom_urls/action/!add/', post_data) | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |         self.assertContains(response, 'dismissAddAnotherPopup') | ||||||
|  |         self.assertContains(response, 'Action added through a popup') | ||||||
|  |  | ||||||
|  |     def testAdminUrlsNoClash(self): | ||||||
|  |         """ | ||||||
|  |         Test that some admin URLs work correctly. The model has a CharField | ||||||
|  |         PK and the add_view URL has been customized. | ||||||
|  |         """ | ||||||
|  |         # Should get the change_view for model instance with PK 'add', not show | ||||||
|  |         # the add_view | ||||||
|  |         response = self.client.get('/custom_urls/admin/admin_custom_urls/action/add/') | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |         self.assertContains(response, 'Change action') | ||||||
|  |  | ||||||
|  |         # Ditto, but use reverse() to build the URL | ||||||
|  |         path = reverse('admin:%s_action_change' % Action._meta.app_label, | ||||||
|  |                 args=('add',)) | ||||||
|  |         response = self.client.get(path) | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |         self.assertContains(response, 'Change action') | ||||||
|  |  | ||||||
|  |         # Should correctly get the change_view for the model instance with the | ||||||
|  |         # funny-looking PK | ||||||
|  |         path = reverse('admin:%s_action_change' % Action._meta.app_label, | ||||||
|  |                 args=("path/to/html/document.html",)) | ||||||
|  |         response = self.client.get(path) | ||||||
|  |         self.assertEqual(response.status_code, 200) | ||||||
|  |         self.assertContains(response, 'Change action') | ||||||
|  |         self.assertContains(response, 'value="path/to/html/document.html"') | ||||||
							
								
								
									
										7
									
								
								tests/regressiontests/admin_custom_urls/urls.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/regressiontests/admin_custom_urls/urls.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | from django.conf.urls.defaults import * | ||||||
|  | from django.contrib import admin | ||||||
|  |  | ||||||
|  | urlpatterns = patterns('', | ||||||
|  |     (r'^admin/', include(admin.site.urls)), | ||||||
|  | ) | ||||||
|  |  | ||||||
| @@ -595,7 +595,7 @@ class SaveAsTests(TestCase): | |||||||
|         self.assertTrue(response.context['save_as']) |         self.assertTrue(response.context['save_as']) | ||||||
|         post_data = {'_saveasnew':'', 'name':'John M', 'gender':3, 'alive':'checked'} |         post_data = {'_saveasnew':'', 'name':'John M', 'gender':3, 'alive':'checked'} | ||||||
|         response = self.client.post('/test_admin/admin/admin_views/person/1/', post_data) |         response = self.client.post('/test_admin/admin/admin_views/person/1/', post_data) | ||||||
|         self.assertEqual(response.context['form_url'], '../add/') |         self.assertEqual(response.context['form_url'], '/test_admin/admin/admin_views/person/add/') | ||||||
|  |  | ||||||
| class CustomModelAdminTest(AdminViewBasicTest): | class CustomModelAdminTest(AdminViewBasicTest): | ||||||
|     urls = "regressiontests.admin_views.urls" |     urls = "regressiontests.admin_views.urls" | ||||||
| @@ -842,7 +842,7 @@ class AdminViewPermissionsTest(TestCase): | |||||||
|         self.client.post('/test_admin/admin/', self.adduser_login) |         self.client.post('/test_admin/admin/', self.adduser_login) | ||||||
|         addpage = self.client.get('/test_admin/admin/admin_views/article/add/') |         addpage = self.client.get('/test_admin/admin/admin_views/article/add/') | ||||||
|         self.assertEqual(addpage.status_code, 200) |         self.assertEqual(addpage.status_code, 200) | ||||||
|         change_list_link = '<a href="../">Articles</a> ›' |         change_list_link = '› <a href="/test_admin/admin/admin_views/article/">Articles</a>' | ||||||
|         self.assertFalse(change_list_link in addpage.content, |         self.assertFalse(change_list_link in addpage.content, | ||||||
|                     'User restricted to add permission is given link to change list view in breadcrumbs.') |                     'User restricted to add permission is given link to change list view in breadcrumbs.') | ||||||
|         post = self.client.post('/test_admin/admin/admin_views/article/add/', add_dict) |         post = self.client.post('/test_admin/admin/admin_views/article/add/', add_dict) | ||||||
|   | |||||||
| @@ -1,6 +1,5 @@ | |||||||
| from django.conf.urls import patterns, include | from django.conf.urls import patterns, include | ||||||
|  |  | ||||||
|  |  | ||||||
| urlpatterns = patterns('', | urlpatterns = patterns('', | ||||||
|     # test_client modeltest urls |     # test_client modeltest urls | ||||||
|     (r'^test_client/', include('modeltests.test_client.urls')), |     (r'^test_client/', include('modeltests.test_client.urls')), | ||||||
| @@ -25,4 +24,7 @@ urlpatterns = patterns('', | |||||||
|     # admin widget tests |     # admin widget tests | ||||||
|     (r'widget_admin/', include('regressiontests.admin_widgets.urls')), |     (r'widget_admin/', include('regressiontests.admin_widgets.urls')), | ||||||
|  |  | ||||||
|  |     # admin custom URL tests | ||||||
|  |     (r'^custom_urls/', include('regressiontests.admin_custom_urls.urls')), | ||||||
|  |  | ||||||
| ) | ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user