Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft: Add table sort classes and aria-sort attribute #142

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

ryandesign
Copy link
Contributor

@ryandesign ryandesign commented May 10, 2022

This PR works for me but I'm marking it as a draft because it may require more discussion before merging to decide the best approach.

I wanted to be able to apply a CSS style to the currently-sorted column but there didn't seem to be a way to do it (without JavaScript). This PR adds two classes to the table tag: one for sort criterion, one for sort direction/order. I also updated the template to use the sort criterion classes to shade the currently-sorted column a little darker.

I debated for awhile about what specific class names to use for the sort criterion. I couldn't determine if there was an established standard for that sort of thing. For now it uses numbered classes (e.g. sort-col-1) because that goes nicely with the way the CSS selector to target the column header has to be written (e.g. .sort-col-1 th:nth-of-type(1)). However, nth-of-type only has to be used because the column headers don't have any classes. (This also came up in #133.) Ideally I would like to add the classes that are already used in the table cells to the column headers as well. That will result in a slight confusion where the header of the name column has the class link. If it were up to me I would change class link everywhere to be class name. That would be a breaking change, but if the plan is to release a new major version next, like 0.6.0 or even 1.0.0, a breaking change should be ok if communicated clearly in the release notes. (Making a breaking change after 1.0.0 is less desirable.) If the class were renamed and classes were applied to the column headers as well, then nth-of-type wouldn't be needed anymore and the sort column class names could be changed from numbered to named (e.g. sort-by-name) and the CSS selector to style the column could be simplified to .sort-by-name .name). Using named rather than numbered classes would be advantageous if there is a desire to apply styles to specific columns (for example, to align the size column to the right) and also to allow the order of the columns to be changed (requested in #66).

In searching for a standard way to indicate table sort order I came across the aria-sort attribute intended originally for screen readers but also addressable from CSS. Initially this seemed perfect, so I implemented it first, but then realized that since this attribute is only set on the th tag, it cannot be used to style the corresponding td tags, so I still added the classes to the table tag as well.

Let me know if you have thoughts or concerns about any of the above or about what I've committed so far.

The quantity of template variables is about to increase and it's tedious
to renumber all subsequent variables just to keep them in numerical
order. One of the variables, t_parentdir_entry, already didn't have a
leading number, so this change makes the rest of the variables
consistent with that.
Add the aria-sort attribute to the th of the column by which the data is
sorted. This is conceivably useful to let screen readers know how the
table is sorted, but it also allows CSS styles to be applied, for
example to highlight the sorted column header or to change an icon in
the column header to indicate the sort direction.

This required breaking the start of the table into separate variables so
that the column headers can be addressed individually. This is a step
toward being able to reorder (aperezdc#66) or remove (aperezdc#133) columns.
Add a class "sort-col-1", "sort-col-2", or "sort-col-3" to the table tag
to indicate by which column the data is sorted, and a class "asc" or
"desc" to indicate whether it is sorted in ascending or descending
order. This is intended to be useful for applying a style to the sorted
column or its header.

Modify the default template to slightly darken the sorted column.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants