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

Updated Reflow understanding doc #4055

Draft
wants to merge 58 commits into
base: main
Choose a base branch
from

Conversation

scottaohara
Copy link
Member

@scottaohara scottaohara commented Sep 5, 2024

This initial commit takes the current draft from the google doc that had been worked on for quite some time now, and makes it into a PR for further editing and review.

Not all feedback from the google doc was directly taken/addressed, but there have been additional changes made that attempted to consider a good portion of the unresolved comments.

Marking this PR as a draft, as there is still work to do (and I also need to upload all the new graphics for the examples - and a few examples still need to be created, which are currently marked as comments in the HTML file).

  • identify all the reflow related issues this PR will close :)
  • add all the new graphics to this PR
  • make sure the added graphics render properly
  • add failure examples (per wg call requesting these)

Preview link

This initial commit takes the current draft from the google doc that had been worked on for quite some time now, and makes it into a PR for further editing and review.

Not all feedback from the google doc was directly taken/addressed, but there have been additional changes made that attempted to consider a good portion of the unresolved comments.  

Marking this PR as a draft, as there is still work to do (and I also need to upload all the new graphics for the examples - and a few examples still need to be created, which are currently marked as comments in the HTML file)
Copy link

netlify bot commented Sep 5, 2024

Deploy Preview for wcag2 ready!

Name Link
🔨 Latest commit 75cd4c4
🔍 Latest deploy log https://app.netlify.com/sites/wcag2/deploys/6774233989bcbb0008d1a102
😎 Deploy Preview https://deploy-preview-4055--wcag2.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

fix some missing/stray markup end tags
understanding/21/reflow.html Outdated Show resolved Hide resolved
@bruce-usab
Copy link
Contributor

Briefly discussed on backlog call 9/6.

attempt at further addressing issues: 2043 and 366
trying this text out to see what people think.  again i'm wary about saying viewport here since that's not always what is needed.
attempting to briefly address  issue 3311 and 648
@scottaohara
Copy link
Member Author

scottaohara commented Sep 13, 2024

making notes of existing issues addressed with this PR (more to come):

add in the carousel/swimlane examples that were noticed as missing during today's call.

fix the broken animated gif and put it into a disclosure widget so that someone who doesn't want to see the animation can open/close it.
@bruce-usab
Copy link
Contributor

Discussed on backlog call 9/13, thank you @scottaohara! A preview is available but a reminder that the PR is still a work in progress. Most (but not all) content from Google Doc drafting has been pulled in and Scott has placeholders and inline notes-to-self. Looking really good! Outstanding question to @iadawn about replacing 4mb animated gif with an MP4, but where should a multimedia file go? TF would be okay with publishing without (and adding later) as the MVP need not be perfect.

thanks @mfairchild365  for suggestions in simplifying my wordy intro paragraphs.
- wording updates per feedback i received off-github
- added content to replace the "todo" placeholder content for section that introduces the carousel example
- spelling mistakes corrected
- wording modifications to in brief section
- expand tabular data section to call out grid-based UI, incorporating from off-github suggestion to reference "electronic program guides"
part 1 of at least 2.  various wording adjustments for things that people commented could have been clearer.  

comment in the html to add a failing example (line 96)
the images were rather large - so made them a bit smaller to hopefully make the doc feel less 'broken up' by them
move the scoping of exceptions section into the exceptions section (preceded it, and that was weird)

also fixes a paragraph with a missing start tag
@scottaohara
Copy link
Member Author

I intentionally designed the card to be 320px wide to fit the viewport exactly. While there’s some padding that ensures users can still read the content without needing to horizontally scroll, the card technically isn't fully visible within the 320 CSS pixels. This means a horizontal scroll is required to view the entire card.

at least the way a browser calculates its viewport, it's the area that is not considered part of the browser chrome (its ui). this is why it's a bit of a misnomer to say that a 1280 resolution with a browser set to 100% would always mean you could zoom in 400% to get a 320px wide viewport. That's not true in all cases. For instance, if i set my OS resolution to 1280px wide and i maximize my browser, if i'm viewing a page with a scrollbar the viewport actually has a max width of 1272px. This maybe is your issue with creating something that's 320px wide, but it not neatly fitting into the viewport - because your viewport isn't actually 320px?

but, regardless of that point, if the text is fully visible within the 320px wide area, but the border/padding of the card isn't completely in view - i don't think that should be considered a failure. One can read the content without having to scroll in two directions - that's the point of the SC.

@bruce-usab
Copy link
Contributor

Discussed on TF call 12/13. Request to work on second sentence of Intent.

understanding/21/reflow.html Outdated Show resolved Hide resolved
understanding/21/reflow.html Outdated Show resolved Hide resolved
understanding/21/reflow.html Outdated Show resolved Hide resolved
scottaohara and others added 5 commits December 18, 2024 11:55
Co-authored-by: Alastair Campbell <[email protected]>
resolved some comments left by @fstrr 

pulled in a version of the suggestions made by @mbgower and @alastc - but i did not delete the text "in regards to the text's intended direction of reading" - as that is meant to tie into the next paragraph.  

if people still have an issue with this, then happy to look at ways to reword.  but i think it's important to make this aspect of the intent clearer
@scottaohara
Copy link
Member Author

scottaohara commented Dec 19, 2024

one thing that was briefly brought up in the last call was about how there should be a note/clarification added to acknowledge that a 1280x1024 viewport does not necessarily equate to using a 1280x1024 screen resolution.

here are some notes i've written on that for our own documentation on reflow, which i think would be helpful here;

For instance, with minimal browser chrome (address bar, bookmark bar and tabs at the top - and the viewport's scrollbar on the side) and the Windows task bar positioned at the bottom of the display – at a 1024 by 768 resolution the Edge browser when maximized has a viewport size of 1016px by 608px. There's already the issue that one would need to zoom in 320% to get a 320px viewport at 1024 - that not being a zoom feature provided by browsers. But with the actual viewport size, one would need to be able to zoom in around 317% to get a 320.5px viewport width.

At 1280 x 1040 display resolution, again a browser with the same setup would have an actual starting viewport of 1272 by 864px. At 400% zoom the viewport becomes 318 by 216px. Only 2px off from the normative 320px, but the height is far below the normative 256 – for when that sizing requirement is applicable. The only way to actually get a 320x256 viewport is to either have a larger resolution and resize one's browser so that the viewport is of the necessary base size - or at the 1280x1040 resolution - make the browser go full screen, so all the UI of the browser and OS is hidden...

@mraccess77
Copy link

I would reiterate my position that 320x256 is not required by the criterion - only 320 CSS for horizontal text (and 256 height for vertical text). In my opinion as long as a width of 320 can be tested a height is not mandated by the criterion for horizontal text.

However, I do acknowledge that sites can respond differently in mobile views vs. desktop reflowed views and that blocking edge cases can come up depending on implementation where testing at 320 on mobile view in the browser responds differently than test 320 with desktop mode in browser.

@patrickhlauke
Copy link
Member

I would reiterate my position that 320x256 is not required by the criterion

and again, https://deploy-preview-4055--wcag2.netlify.app/understanding/reflow does not make any claim that this is required

@mbgower
Copy link
Contributor

mbgower commented Jan 3, 2025

I would reiterate my position that 320x256 is not required by the criterion - only 320 CSS for horizontal text (and 256 height for vertical text). In my opinion as long as a width of 320 can be tested a height is not mandated by the criterion for horizontal text.

@mraccess77 while I understand that the basis for your perspective at least partially reflects the foundational motivation of making this requirement not just horizontal-language dependent, I believe the actual wording of the text does not reflect the notion that 320 width was intended exclusively for horizontal languages and 256 height was intended exclusively for vertical languages.

The wording talks about "vertical" and "horizontal scrolling content". That is, as soon as one has content that scrolls horizontally, on a page that also scrolls vertically, then the horizontally scrolling content appears to be constrained by the height equivalent of 256 (unless it is constrained by content that "requires two-dimensional layout".)

As an aside, let me acknowledge the use of the word "requires" in the SC language, instead of using the defined term "essential".
With the phrase "requires" the SC exception tends to be something of a self-fulfilling exception; if one has used content that requires two-dimensional layout to work, then it is excepted and allowed to scroll on both axes.

Nonetheless, some of the examples developed by Scott demonstrate how reflow measurements can be used to improve the user experience even with two-dimensional content. For example, if one does employ horizontal scrolling in a section of content, it is obviously much easier for everyone to use if each chunk of content fits within those 256x320 dimensions. So while I agree that the constraint is not required by the SC, there are certainly use cases where constraining content in either or both dimensions is beneficial.

@mraccess77
Copy link

I would reiterate my position that 320x256 is not required by the criterion - only 320 CSS for horizontal text (and 256 height for vertical text). In my opinion as long as a width of 320 can be tested a height is not mandated by the criterion for horizontal text.

@mraccess77 while I understand that the basis for your perspective at least partially reflects the foundational motivation of making this requirement not just horizontal-language dependent, I believe the actual wording of the text does not reflect the notion that 320 width was intended exclusively for horizontal languages and 256 height was intended exclusively for vertical languages.

The wording talks about "vertical" and "horizontal scrolling content". That is, as soon as one has content that scrolls horizontally, on a page that also scrolls vertically, then the horizontally scrolling content appears to be constrained by the height equivalent of 256 (unless it is constrained by content that "requires two-dimensional layout".)

I do agree that if there is horizontally scrolling content then it can not be greater than 256px high as that would then require scrolling in 2-dimensions. I agree that horizontally scrolling content can exist as long as you don't have to scroll 2 dimensions to read it.

@WW3
Copy link

WW3 commented Jan 6, 2025

One repeating uncertainty regarding reflow is whether this SC 2-dirctional scrolling guidelines applies to views greater than 320px (putting aside all the known exceptions). A straightforward assertion would greatly improve the understanding of this perceived ambiguity.

A second concern, less impactful and much less common, is whether a horizontal navigation that turns into a "hamburger" menu, should be regarded as a case of loss of content/functionality.

@mbgower
Copy link
Contributor

mbgower commented Jan 6, 2025

One repeating uncertainty regarding reflow is whether this SC 2-dirctional scrolling guidelines applies to views greater than 320px (putting aside all the known exceptions). A straightforward assertion would greatly improve the understanding of this perceived ambiguity.

Can you please expound on this, @WW3? I think I understand what you're saying, but I want to be certain.

@mraccess77
Copy link

One repeating uncertainty regarding reflow is whether this SC 2-dirctional scrolling guidelines applies to views greater than 320px (putting aside all the known exceptions). A straightforward assertion would greatly improve the understanding of this perceived ambiguity.

I think what you are saying is does this only apply at 320CSS exactly and thus it would not apply at 400px.

A second concern, less impactful and much less common, is whether a horizontal navigation that turns into a "hamburger" menu, should be regarded as a case of loss of content/functionality.

In my opinion this is not a loss of content or functionality it's changing form but is still availalbe.

@scottaohara
Copy link
Member Author

@mraccess77 fwiw, i rewrote the reflow doc sharing the same position. i brought up examples in task force meetings (largely around tables) where it would be much better UX if the table height accounted for a shorter viewport height - but it was agreed in the meetings that the table didn't "have" to have a 256 height.

I think clearing this up more is probably a good thing - especially per the comment i left before going on vacation for the end of the year (i'll work on adding this soon). Since the 320x256 viewport size is not entirely accurate for a standard windows desktop / browser setup unless making the browser go full screen.

otherwise, maximizing a browser with a bookmark bar, and simply maximizing the browser with the windows taskbar still in view, the best i can get for a 1280x1024 resolution is a viewport of 318x216 viewport. that's clearly less than the 256...

@mraccess77
Copy link

@mraccess77 fwiw, i rewrote the reflow doc sharing the same position. i brought up examples in task force meetings (largely around tables) where it would be much better UX if the table height accounted for a shorter viewport height - but it was agreed in the meetings that the table didn't "have" to have a 256 height.

My two cents - while a table itself can be wider than 320 CSS pixels and taller 256 CSS pixels - I'd say an individual table cell itself shouldn't require two dimensional scrolling. That means if it's wider than 320 then it can't require vertical scrolling - likely meaning it should be no more than 256 pixels. If it's less than 320 pixels wide then it doesn't require horizontal scrolling and can be as tall as it needs to be. Each table cell could be treated as it's own block of content that needs to conform to the criterion.

@scottaohara
Copy link
Member Author

yup, i agree with you @mraccess77

@dabrams888
Copy link

dabrams888 commented Jan 7, 2025

@scottaohara the examples for sticky content don't touch on the potential loss of information/functionality from within the sticky content itself. They focus more on the other content which gets obscured by the sticky content.

For example, a vertically scrolling page at 320 wide has a sticky region with a dropdown. The expanded dropdown's position is anchored to its sticky trigger and has content which extends past the bottom of the viewport. Would it be possible to include clarification on if this type of example is meant to be covered by 1.4.10, or if such a loss of content isn't currently a WCAG failure?

1.4.10 doesn't specify a max-dimension in the scroll direction. But for practical reasons since devices have fixed sizes, it would be nice to clarify how to approach this scenario.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.