Page MenuHomePhabricator

Large tables created by editors are not responsive
Open, HighPublic

Description

Background

Many tables generated by wikitext are bigger than 320px. On a 320px screen, this causes the entire viewport to grow to the size of the table and can break the experience of the entire site. This stretches the search bar and makes the mobile site very unusable.

On Vector 2022 the large tables often overlap sidebar menus for similar reasons.

Current solution (hack)

Ths current hack only applies to mobile. It potentially could be applied to desktop.

Currently the mobile site deals with this situation by forcing the table to have width 100% and adding overflow scrolling (which is enabled by making the table a block element). This solution is not perfect as overflow-x is not fully supported across all mobile devices. To see an example of the sort of table this rule targets the table on the presidental election results page [2] provides a good example.

Per T342505 this also interferes with voice-over capabilities.

Side note: We may also want to make it possible for templates in the short term to opt out of the styling hack e.g. using a nohacks class

Long term solution

Ideally it should be possible for templates to define their own behaviour for tables on mobile devices.

There are various responsive tables [1] techniques but there is no one fit for all solution. Note some tables [2] do not even scale well on even desktop devices.

It should be possible for template editors to use media queries to style tables differently with the closure of the templating RFC [3] so that we can kill this table hack.

Other solutions are welcomed.

Further information/history

See T66516: table width is marked !important and T38936: Tables in mobile

[1] http://css-tricks.com/responsive-data-tables/
[2] https://en.m.wikipedia.org/wiki/List_of_United_States_presidential_election_results_by_state#section_1
[3] https://www.mediawiki.org/wiki/Requests_for_comment/Allow_styling_in_templates


Version: unspecified
Severity: normal

Details

Reference
bz64577

Related Objects

StatusSubtypeAssignedTask
Openovasileva
InvalidNone
ResolvedTgr
ResolvedAnomie
Resolvedtstarling
Resolvedcoren
ResolvedAnomie
DeclinedBUG REPORTNone
ResolvedAnomie
ResolvedEsanders
ResolvedEsanders
Resolvedssastry
ResolvedAnomie
ResolvedCKoerner_WMF
Resolvedjhsoby
ResolvedTgr
DeclinedTgr
Resolvedcoren
ResolvedAnomie
ResolvedTgr
DeclinedNone
Resolvedssastry
ResolvedTgr
ResolvedTgr
ResolvedTgr
Resolved Deskana
ResolvedCKoerner_WMF
Resolved Whatamidoing-WMF
ResolvedTgr
ResolvedTgr
ResolvedTgr
ResolvedUrbanecm
ResolvedTgr
ResolvedTacsipacsi
ResolvedTgr
ResolvedCKoerner_WMF
ResolvedJdlrobson
Openovasileva

Event Timeline

There are a very large number of changes, so older changes are hidden. Show Older Changes
Jhernandez added a project: Design.

@Nirzar any thoughts? Is there any design input on this?

I've been playing with a little idea for a while now.. and I now have some small JS to play this idea.

The problem with the current overflow, is that it is very hard for users to figure out that this is something that they can scroll, especially on iOS where you don't get to see scrollbars by default. Normally i'd say add inset borders/shadows, but due to the nature of display:table, this is actually quite hard to achieve.

So my idea was.. What if use a bit of JS, to show a <-> arrow on top, for a little while, when elements come into view that are scrollable. The following JS fragment allows you to experiment with this idea. It's not perfect, i just tossed the first image i could find in there. Ideally it would use a bit of a horizontal wobble to indicate the interactivity better.
Unfortunately, there are no user styles on mobile, so you will have to use your browsers capabilities to add this on the fly (using console, or browser scripts).

1$.getScript( 'https://cdnjs.cloudflare.com/ajax/libs/jquery.appear/0.3.3/jquery.appear.js' ).done( function() {
2 function isElementOverflowing( el ) {
3 var isOverflowing = el.clientWidth < el.scrollWidth - 2;
4 return isOverflowing;
5 }
6 $( function() {
7 $('table').appear()
8 .on( 'appear', function( e, $affected ) {
9 $affected.not('.overflow-indicator').each( function( index, element ) {
10 if ( isElementOverflowing( element ) ) {
11 $(element).addClass( 'overflow-indicator' );
12 }
13 } );
14 } ).on ('disappear', function( e, $affected ) {
15 $affected.removeClass( 'overflow-indicator' );
16 } );
17 } );
18} );
19mw.util.addCSS( '@keyframes fadeOut {from {opacity: 1;} to { opacity: 0; } } .overflow-indicator:before { content: ""; position:absolute; margin: 10px; width: 36px;height:36px; animation: fadeOut 3s ease-in forwards; background-size: cover; background-image:url("") } ' );

Volker_E renamed this task from Tables do not render well under 320px to Tables do not render well at 320px viewport.Mar 18 2020, 4:59 PM

To summarize my positions on this, with the years of trying to find proper solutions for this issue.

  1. We should have an indicator that something is overflowing and is swipeable, because mobile devices don't have always on scrollbars
  2. Finding a generic solution to make arbitrary data sized spreadsheets (which is basically what we are talking about here) working on a mobile device has been tried. They simply don't exist. Responsive tables are a known problem area and all solutions are custom solutions, either requiring significant editor input, or only suited to certain types of tables. (and forget about row/colspans).
  3. We have so many tables that custom solutions (based on editor input) might as well not be implemented. The gains will be too small to make a significant impact on the general problem.
  4. Personally I do think that having some sort of 'make this table fullscreen' option is required. Last time I tried that though, I ran into the problem of the viewport of the original document limiting the zoom and size of the render surface. I think you would need to have a dialog open and then insert an iframe into that dialog with a different viewport and then clone the table into that temporary document. But with CSS and JS to be taken into account, that too quickly becomes complex.

I'm suggesting another long-term solution to this problem (T258382):

  • When the reader taps on a table rotate the screen and show the table in fullscreen. Don't show any other content of the table except eventually preceding or succeeding text that is directly referring to the table / descriptive of the table. The tap could be anywhere on the table but there should be a small image that indicates that the table has to be taped to be viewed better / that a tap makes it go fullscreen.

This is implemented in apps like the YouTube app where you can click a button to make a video go fullscreen and rotate the screen.

This is solution different from enabling/requiring editors to use media queries for tables and would not have its problems. Tables don't look well and are hard to navigate on smartphones if they aren't displayed in landscape mode in almost all cases. There could be a css class for tables to prevent such default behavior of tables if e.g. the table width is very small and/or whether or not the width is too small for the display could be detected automatically.

I agree with @TheDJ when he wrote "Personally I do think that having some sort of 'make this table fullscreen' option is required."


Furthermore, I would suggest (also at T258382):

  • When the table is displayed in rotated-screen-fullscreen show a large horizontal scrollbar at the bottom if some columns are still cut off. Maybe the scrollbar could be hidden until the user taps the screen. Maybe it would be best to allow scrolling horizontally by swiping left and right - if no scrollbar is displayed within the field of view to indicate that columns are cut off and that scrolling is possible there should be some other small icon/image, like a small arrow, to indicate this.

I agree with @TheDJ when he wrote: "We should have an indicator that something is overflowing and is swipeable".


While the fullscreen feature for tables may be relatively easily implementable in the Wikipedia mobile apps, it may be a bit harder for mobile browsers. Currently, I only know of two ways it could possibly be solved: CSS/JS tricks and a version of the "Screen Orientation API" - roughly outlined here.

Jdlrobson renamed this task from Tables do not render well at 320px viewport to Tables are not responsive.Aug 4 2022, 10:32 PM
Jdlrobson added a subscriber: AlexisJazz.

Now also becoming a problem in Vector as we make the skin more responsive.

Jdlrobson renamed this task from Tables are not responsive to Large tables created by editors are not responsive.Aug 4 2022, 10:33 PM

Now also becoming a problem in Vector as we make the skin more responsive.

And because you're capping the content width at some 1100px. (NB I have no personal issue with the max width, but let's be clear that this is also an issue on desktop now.)

As for the problem, it needs to have a skin-level solution. TemplateStyles, though apparently linked to this task, will not fix the vast majority of tables.

Probably need to do a state of the art review, but just from a look around Minerva is basically already there.

The only generic skin-level solution that can be applied here is to wrap a large table in a div container with horizontal overflow as suggested on the recommendations page.

It's not a perfect solution, but given the discussions we've had over the last 10 years around this, it's likely our only solution given wholescale template updates are hard. This would however require a change in how the parser outputs tables.

The only generic skin-level solution that can be applied here is to wrap a large table in a div container with horizontal overflow as suggested on the recommendations page.

Both Minerva and Timeless have solutions for this problem. That is what I mean by generic skin-level. Adding a div with overflow auto to every wide table, and even the the not-wide tables (to support mobile) is not a feasible solution given the quantity of tables.

@Xaosflux Minerva does not have a solution for this problem. If you view Minerva > 720px you'll see the content breaks out of the UI [1]. Those skins only have solutions for mobile resolutions (which only apply up to 720px)

Screen Shot 2023-01-29 at 7.54.23 AM.png (1×2 px, 286 KB)

Timeless wraps table in a div.content-table using JavaScript [2] to get around this issue, which is what we've been advocated on the editor size (try disabling JS to see the issue). We could do this in the server-side in the parser in T66577#8133045 but that is a disruptive change as it would break the ability for those tables to be sticky as well as floated so allowing editors to do that side steps this problem.

In short we definitely do not have solutions to this problem on the skin level.

Screen Shot 2023-01-29 at 7.57.47 AM.png (690×2 px, 202 KB)

[1] https://en.wikipedia.org/w/index.php?title=Brahmic_scripts&oldid=1136168431&useskin=minerva
[2]https://en.wikipedia.org/w/index.php?title=Brahmic_scripts&oldid=1136168431&useskin=timeless

Here's the Timeless JS solution: https://gerrit.wikimedia.org/g/mediawiki/skins/Timeless/+/f2c42dc84bde1c8d51c86d77358c24100be571a4/resources/main.js#47

This issue is causing the table of contents to be forced to appear above the article on certain tablets (pictured here: Samsung tablet)

image.png (1×800 px, 369 KB)

Adding a wrapper would be potentially disruptive in a number of ways:

  • Parsoid inherits some tricky "element fostering" behavior around tables from the HTML spec; we'd have to carefully work through how those fostered elements should interact with the added wrapper, both in the wt2html direction and the reverse.
  • VE would have to handle the wrapper. It could elect to strip the wrapper, like it currently does with the <section> tags emitted by Parsoid, but then the new table formatting wouldn't apply when using VE. If that's undesirable, the wrappers would have to be re-added in the widget VE uses for tables.
  • Potentially breaks client-side gadgets (sticky table headers, sortable tables, collapsable tables, etc) which will have to be updated to accomodate the new wrapper.

There are also implementation issues if this is expected to apply to both the legacy parser output and parsoid; the content transform team would obviously prefer to do this work only in a single code base.

That said, it's not too dissimilar to how we're handling the migration to new-style <media> output, and to how VE handles <section> tags. So adding a wrapper here is not unthinkable. If we go down this route I would like to try to add some more rigorous semantics/expectations around wrapper classes (there are a number of other wrappers proposed in https://www.mediawiki.org/wiki/Heading_HTML_changes ) by adding a consistent marker of some kind, perhaps rel="mw:Wrapper", to indicate that the wrapper has no semantic meaning and can be stripped by an editor without harming the html-to-wikitext round trip.

Not really sure why you pinged Xaosflux, but he's as good as any to have subscribed. :)

Minerva does not have a solution for this problem. If you view Minerva > 720px you'll see the content breaks out of the UI [1]. Those skins only have solutions for mobile resolutions (which only apply up to 720px)

Screen Shot 2023-01-29 at 7.54.23 AM.png (1×2 px, 286 KB)

That seems more like an artifact of Minerva having been moved to a proper skin somewhere a couple years ago and should have been assessed then, not because Minerva doesn't have a solution.... I am aware of an issue with Minerva's solution in that display: block for table was not accessibly-kosher at some point (https://www.accessibility-developer-guide.com/examples/tables/layout-changes/ last updated in 2018 as an example; https://adrianroselli.com/2018/02/tables-css-display-properties-and-aria.html updated 2022).

Timeless wraps table in a div.content-table using JavaScript [2] to get around this issue, which is what we've been advocated on the editor size (try disabling JS to see the issue).

Yes, I am aware of the Timeless solution, having filed the task that made it as reasonably pretty as it is today (T269912). I hadn't considered what a no-JS environment would be seeing though, but this would still be an improvement for Most People. (NB there are some things that script does that cause bad display of massive whitespace and I don't know why.)

We could at least start with supporting .wikitable rather than all tables.

We could do this in the server-side in the parser

Doing some part of it in core would be good if possible (yes, I see cscott's comment).

it would break the ability for those tables to be sticky

I saw stickiness the other day as having issues, at least for overflow-y. I'm not certain that's an issue for overflow-x, which is the problem child here, but I haven't looked? And anyway, Timeless's solution does work even with the stickiness supported by the gadget of interest. (You might be referring to some other sticky thing.)

as well as floated so allowing editors to do that side steps this problem.

I have no idea what you're referencing here regarding floating being disabled by this kind of solution. Timeless's solution does seem to make it work, but it's calculating whether the overflow solution is even needed (which might be viable in some world with pure CSS with container queries and some calc() in the near future, likely after some potential point at which core changes).

Of course, for the most part floating tables aren't the issue at hand in this task; they're categorically smaller than their container. When they aren't smaller, they don't need to float anyway.

Jdlrobson added a subscriber: ovasileva.

@ovasileva given page tools makes this worse should this be high and planned for this quarter/fiscal year?

ovasileva raised the priority of this task from Medium to High.Mar 10 2023, 7:01 PM
ovasileva moved this task from Not ready to estimate to Current Quarter on the Web-Team-Backlog board.

We need to talk to CT team about this one.

Jdlrobson moved this task from Incoming to Current Fiscal Year on the Web-Team-Backlog board.

Next step: T334528
This will allow us to understand the issue better and how to fix it.