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

Fix/1854 #1886

Merged
merged 10 commits into from
Apr 20, 2021
Merged

Fix/1854 #1886

merged 10 commits into from
Apr 20, 2021

Conversation

amesplant
Copy link
Contributor

@amesplant amesplant commented Sep 10, 2020

Description of the Change

Resolves invalid HTML by:

  • Replacing invalid <input> checkboxes in facet links, and replace with presentational divs styled as checkboxes.
  • No longer adding the rel="nofollow" attribute to links without an href (i.e. empty terms).

Alternate Designs

One alternative option would be to remove the links and implement facets as a <form> element. Downsides of that approach are that it would either add the requirement to submit facets manually after selection, or the page would need to refresh upon selection, which would be unexpected behaviour for a form. Additionally, manual submission would require back-end changes to accommodate.

Benefits

Resolves invalid HTML of the current facets, and a custom design for the checkboxes would not imply standard form behaviour, which selecting an option does not follow.

Possible Drawbacks

Any custom styles site owners or theme authors may have applied to checkboxes, either generally or just for ElasticPress, would not apply to the new checkboxes.

Verification Process

Running a page with ElasticPress facets through the W3 Validator should not return any errors for facets. Make sure to check the HTML when some empty terms are in the list.

Checklist:

  • I have read the CONTRIBUTING document.
  • My code follows the code style of this project.
  • My change requires a change to the documentation.
  • I have updated the documentation accordingly.
  • I have added tests to cover my change.
  • All new and existing tests passed.

Applicable Issues

#1854

Changelog Entry

Fixed invalid HTML for facets by replacing the <input type="checkbox"> elements in option links with a custom .ep-checkbox presentational div.

@amesplant amesplant marked this pull request as draft September 10, 2020 15:46
@amesplant amesplant marked this pull request as ready for review September 15, 2020 16:32
@oscarssanchez
Copy link
Contributor

Do we want to assign someone and finish the PR per Ames comment here #1854 (comment) ?

@JakePT
Copy link
Contributor

JakePT commented Mar 1, 2021

As Ames mentioned on #1854, this will need back-end engineering to support the noscript implementation, so it probably can't be merged yet.

There's another direction we could go, however. We could just use <a> tags only, without the <form> or checkbox
<inputs>, as this would satisfy the original issue of invalid markup, but wouldn't require any back-end engineering to implement, as the links would work as they did before. Since the behaviour of selecting a facet is to direct the user to a new results page, rather than load results in with AJAX, I'd argue an anchor tag is probably the more appropriate tags to use accessibility-wise too.

<a href="/movie/?filter_genre=comedy" rel="nofollow">
  <span class="checkbox">Comedy</span>
</a>

The only missing piece would be that the links wouldn't look like checkboxes anymore, which would require some styling, but this PR includes custom styling for checkbox inputs which could be adapted to links fairly easy.

@mckdemps
Copy link
Contributor

mckdemps commented Mar 5, 2021

@JakePT Yes, we like this approach. And what does it look like to replace the checkbox?

@JakePT
Copy link
Contributor

JakePT commented Mar 8, 2021

@mckdemps It just means that the checkboxes would look like however we define them, rather than using the styles from the theme, or the default system/browser checkboxes. This is how Ames' checkboxes look in a bare-bones theme:

Screen Shot 2021-03-08 at 2 08 44 pm

Whereas the current checkboxes, if they aren't styled by the theme, would look like the Checklist checkboxes in the PR description above.

This also means that any custom styling users might've applied to facets will not apply to the new checkboxes.

An alternative approach would be to include an actual checkbox, but marked up as readonly and role="presentation", so that they are there purely for the visuals. This means that the appearance of the checkboxes would not change, but the spacing around them would, as we would need to 'cover' the checkboxes with the link, so that they're clickable.

I prefer the custom checkbox styling approach, as the results will be more consistent between themes, users will be able to more easily style them independently of other checkboxes in their theme, and they would not give the false impression that they will behave the same as system/browser checkboxes.

@brandwaffle
Copy link
Contributor

@JakePT I'm good with the custom checkboxes as well. Let's go with that approach.

@JakePT
Copy link
Contributor

JakePT commented Mar 9, 2021

@mckdemps @brandwaffle I have updated the PR to use links rather than forms, and I've tweaked the styling of the custom checkboxes to use em units so that they scale appropriately to the theme's font size, and I used flexbox for aligning the checkboxes for more consistent results across themes and font sizes/line heights.

@JakePT JakePT requested review from oscarssanchez and removed request for JakePT April 15, 2021 16:04
@oscarssanchez
Copy link
Contributor

Hi @JakePT code looks good and it works correctly. There's a minor space missing from what I can tell on widget.php https://github.com/10up/ElasticPress/pull/1886/checks?check_run_id=2063020128

Can you please take care of it and merge master into this branch? It seems some tests failed on EPIO but I wonder if they would go away once the branch is updated to the latest.

@JakePT
Copy link
Contributor

JakePT commented Apr 20, 2021

@oscarssanchez I've merged develop into this branch and fixed the coding standards errors. I'm not sure what the EP.io test you're referring to is so I'll let you have a look at that when the tests are finished.

@brandwaffle brandwaffle merged commit b41bd2c into develop Apr 20, 2021
@brandwaffle brandwaffle deleted the fix/1854 branch April 20, 2021 15:26
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Error: The element input must not appear as a descendant of the a element.
6 participants