#35115 closed Cleanup/optimization (fixed)

Empty footer element in main section of admin layout

Reported by: Marijke Luttekes Owned by: Marijke Luttekes
Component: contrib.admin Version: 5.0
Severity: Normal Keywords: HTML
Cc: Tom Carrick Triage Stage: Accepted
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: yes UI/UX: no

Description

The Django admin layout has an empty div#footer in the main element.

Location

Find the code in django/contrib/admin/templates/admin/base.html:

{% block footer %}<div id="footer"></div>{% endblock %}

The code was last touched about four years ago when someone fixed the indentation on this template.

Proposed solutions

There are two ways to go about this:

  1. Remove it, as there appears to be no immediate use for this element.
  2. Keep it, but in the spirit of semantic HTML, replace it with a <footer> element outside the <main> element.

Change History (11)

comment:1 by Natalia Bidart, 10 months ago

Cc: Tom Carrick added

Hello! Thank you for your report. I do see the empty section as you describe, but I also see some specific CSS that was defined for this:

https://github.com/django/django/blob/main/django/contrib/admin/static/admin/css/base.css#L896

I'm going to add Tom to this ticket to see if they have any further feedback/insight.

comment:2 by Baptiste Mispelon, 10 months ago

Using git log -S footer -- django/contrib/admin I found what I think is the commit that added the line: 2673aa366a3def5ba7afc26badf6c194b515b3bf

The commit message seems to indicate it was added an an extension point.

In my opinion that means we could instead leave the {% block footer %} empty, and delete any css associated with #footer.

comment:3 by Tom Carrick, 10 months ago

Yeah I think this is intended to be overridden. I agree with removing the CSS, and also with moving it out of the main element and to use a semantic footer element by default.

This is backwards incompatible however, as it may affect a user's overridden template. Since this isn't explicitly documented I would find it acceptable. It would be nice to see if this is used much in the wild but searching for {% block footer %} will yield more false positives than anything else. I think it would at least need something in the release notes explaining it.

in reply to:  3 comment:4 by Mariusz Felisiak, 10 months ago

Triage Stage: UnreviewedAccepted

Replying to Tom Carrick:

Yeah I think this is intended to be overridden. I agree with removing the CSS, and also with moving it out of the main element and to use a semantic footer element by default.

Sounds like a plan.

  • django/contrib/admin/templates/admin/base.html

    diff --git a/django/contrib/admin/templates/admin/base.html b/django/contrib/admin/templates/admin/base.html
    index 1ca50e508d..46d75c6090 100644
    a b  
    108108          <br class="clear">
    109109        </div>
    110110        <!-- END Content -->
    111         {% block footer %}<div id="footer"></div>{% endblock %}
    112111      </main>
     112      {% block footer %}<footer></footer>{% endblock %}
    113113    </div>
    114114</div>
    115115<!-- END Container -->

comment:5 by Thibaud Colas, 10 months ago

I have two concerns with this that I’d recommend investigating further:

  • Do screen readers announce landmark regions like footer that are empty? If so that would be problematic. You should be able to test this with VoiceOver on mac, and in particular the rotor: https://support.apple.com/en-gb/guide/voiceover/mchlp2719/mac. If that feels like too much, please say so and we’ll have the Django accessibility team picking this up
  • Is it clear enough to people who would override this, that with it outside main, they’d definitely need to use a <footer> tag? Otherwise their content would be outside a landmark (https://dequeuniversity.com/rules/axe/4.3/region).

in reply to:  5 comment:6 by Mariusz Felisiak, 10 months ago

Replying to Thibaud Colas:

I have two concerns with this that I’d recommend investigating further:

  • Do screen readers announce landmark regions like footer that are empty? If so that would be problematic. You should be able to test this with VoiceOver on mac, and in particular the rotor: https://support.apple.com/en-gb/guide/voiceover/mchlp2719/mac. If that feels like too much, please say so and we’ll have the Django accessibility team picking this up
  • Is it clear enough to people who would override this, that with it outside main, they’d definitely need to use a <footer> tag? Otherwise their content would be outside a landmark (https://dequeuniversity.com/rules/axe/4.3/region).

I wanted do keep <footer> as a guide for others. We can also force them to use it by:

<footer>{% block footer %}{% endblock %}</footer>

This, of course, does not answer your first question.

comment:7 by Thibaud Colas, 10 months ago

Owner: changed from nobody to Marijke Luttekes
Status: newassigned

Thanks Mariusz, yep, I think that’s a good way to achieve this. I believe Marijke intends to work on this so will assign her. Am happy to do the screen reader testing if it helps.

comment:8 by Marijke Luttekes, 10 months ago

Thank you, I will pick it up!

comment:9 by Marijke Luttekes, 10 months ago

I've added a patch.

I have used macOS VoiceOver (VO) to test spoken text of this landmark, and Firefox's built-in accessiblity inspector.

The accessiblity inspector describes this element with having role contentinfo.

VO ignores the element when it is empty.

When putting a link in the footer, VO reads it. When selecting the parent using Rotor (VO modifier + shift + up arrow), it only spoke "content".

comment:10 by Marijke Luttekes, 10 months ago

Has patch: set

comment:11 by Mariusz Felisiak, 10 months ago

Resolution: fixed
Status: assignedclosed
Note: See TracTickets for help on using tickets.
Back to Top