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

Browser search finds text from all tabs instead of only active one #80

Open
Vishkujo opened this issue Feb 10, 2023 · 9 comments
Open
Labels
enhancement New feature or request help wanted Extra attention is needed

Comments

@Vishkujo
Copy link

When searching on your browser with Ctrl F, it shows results from all tabs instead of only the currently active one. As a result, it highlights hidden content from the other tabs. Since the tab doesn't change, you can't see what was found unless you manually switch the tabs. Users reported that the older Tabber extension did not do this and only showed results from the current tab.

Ideally I think it should either show only the current tab's results, or if possible, automatically switch the tab if it highlights text from a different tab.

Example of where you can see this happening (try searching for any month like January, and you'll see there's 100 results instead of only 12 for the first tab).

@alistair3149
Copy link
Member

This is definitely a bug. Ideally tabber should switch to the tab where the text is highlighted.
I am not sure how to achieve that though. If anyone knows how, any help is appreciated!

@alistair3149 alistair3149 added bug Something isn't working help wanted Extra attention is needed labels Jul 6, 2023
@ferdnyc
Copy link

ferdnyc commented Nov 1, 2023

@alistair3149 It might be possible to handle this by placing a focus event listener on all of the content panes for the tabber, and switching to whichever one gains focus anytime the event fires. (I assume that the browser's search highlighting moves focus to the current search match, as it's cycling through them.)

@alistair3149
Copy link
Member

This is tricky.

Browsers do not fire any event or do any DOM modifications when a match is found. It is quite difficult to exclude HTML from Find in text. I am not sure if it is even fixable...

@alistair3149 alistair3149 added enhancement New feature or request and removed bug Something isn't working labels Jun 20, 2024
@ferdnyc
Copy link

ferdnyc commented Jun 21, 2024

Hmm. That's unfortunate.

I guess the old tabber must've only populated the current tab with content, and left all the other tabs empty until it performed an AJAX request when they were switched to. (And/or deleted the content when they were switched away from). That's the only other way I can think of, that it would've avoided matching text from other tabs.

(EDIT: Actually it wouldn't need to use AJAX, just store the content for the other tabs outside of the DOM somewhere locally, and only insert it into the DOM when a tab becomes active.)

@alistair3149
Copy link
Member

Hmm. That's unfortunate.

I guess the old tabber must've only populated the current tab with content, and left all the other tabs empty until it performed an AJAX request when they were switched to. (And/or deleted the content when they were switched away from). That's the only other way I can think of, that it would've avoided matching text from other tabs.

(EDIT: Actually it wouldn't need to use AJAX, just store the content for the other tabs outside of the DOM somewhere locally, and only insert it into the DOM when a tab becomes active.)

The old Tabber applies a display:none directly on the whole panel, which effectively hides the whole tab from everything, including screen readers. Lazy loading from AJAX or attribute might not be a good idea too because it takes the content away from the DOM, which means web crawlers can't get them.

@ferdnyc
Copy link

ferdnyc commented Jun 21, 2024

(!) According to Chrome, there is an event that fires on matches: beforematch. At least, in supporting browsers.

(There's also an HTML attribute, hidden=until-found, that can be combined with the event to make collapsed content auto-expand when there's an inner search match, tho it's not immediately clear how that would help tabbed content.)

MDN lists beforematch as supported in recent Chrome, Edge, and Opera, but not Firefox or Safari.

@ferdnyc
Copy link

ferdnyc commented Jun 21, 2024

Ah, here's the rub, from MDN:

An element receives a beforematch event when it is in the hidden until found state and the browser is about to reveal its content because the user has found the content through the "find in page" feature or through fragment navigation.

So, even in supporting browsers, beforematch only works when combined with hidden=until-found.

It's also kind of strange, how it works in practice.

In the example they give at the end of the article, in Firefox (which doesn't support hidden=until-found / beforematch), the second <div> is completely hidden at all times, and the example doesn't work:

image

In Chrome (which purports to support hidden=until-found and beforematch), the second <div> is actually visible even before the navigation event causes the beforematch handler to fire. The event then inserts content into the already-visible <div>:

Before

image

After

image

@ferdnyc
Copy link

ferdnyc commented Jun 21, 2024

It seems that, even in Chrome, you also have to style the hidden="until-found" content as hidden, in order to actually hide it. Then, you can update the styling in the onbeforematch handler to reveal it. AFAICT hidden="until-found" only affects the receivability of beforematch, not the content's actual visibility. It's very odd.

@alistair3149
Copy link
Member

alistair3149 commented Nov 22, 2024

Just putting here as a note, this might take a while to fix:
This is caused by the overflow: hidden rule on .tabber__section, which prevents the browser to scroll to the container.
In order to fix this, we need to do these things:

  1. Use some kind of scroll listener to update the active tab/indicator and tabber height. It is current bound to click listener and will not react to scroll like the browser find text.
  2. Find a consistent way to hide the scrollbar, it is not standardized across browsers and we need to figure out a way.
  3. Finally we can disable the overflow: hidden rule.

It seems that, even in Chrome, you also have to style the hidden="until-found" content as hidden, in order to actually hide it. Then, you can update the styling in the onbeforematch handler to reveal it. AFAICT hidden="until-found" only affects the receivability of beforematch, not the content's actual visibility. It's very odd.

Both hidden="until-found" and beforematch are not stable to use at the moment. And we avoid the use of the hidden attribute because it would hide the content from screen readers as well.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

3 participants