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

Allow programmatic focus and focus the first focussable nested element in a modal #1531

Closed
2 tasks done
Aiderlei opened this issue Oct 23, 2024 · 3 comments · Fixed by #1588
Closed
2 tasks done

Allow programmatic focus and focus the first focussable nested element in a modal #1531

Aiderlei opened this issue Oct 23, 2024 · 3 comments · Fixed by #1588
Labels
triage We discuss this topic in our internal weekly Workflow: Issue created JIRA issue is created and will be analyzed

Comments

@Aiderlei
Copy link

Aiderlei commented Oct 23, 2024

Prerequisites

  • I have read the Contributing Guidelines.
  • I have not leaked any internal/restricted information like screenshots, videos, code snippets, links etc.

What happened?

I encountered an issue when trying to set the initial focus on a button within a confirmation modal using the ix-modal component.

My approach was to use the focus method from the native browser API in combination with ViewChild, within the AfterViewInit lifecycle hook. However, the focus state did not appear on the button, even though I could manually trigger it via keyboard tabbing.

Additionally, I was unable to set the focus state through Chrome DevTools by forcing focus on the DOM node of the ix-button or its encapsulated button element. Calling the focus method directly on these nodes also did not result in the expected focus behavior.

I suggest that all iX components should support a programmatic way to set focus.

Upon further investigation, I discovered that the native dialog HTML element, which the ix-modal component uses internally, automatically focuses the first focusable nested element. This is a built-in accessibility feature in browsers (see MDN for more details).
I created a codepen to demonstrate this behavior.

However, this behavior is not present in the ix-modal component. I propose adding this default behavior to ensure better accessibility and consistency.

What type of frontend framework are you seeing the problem on?

Angular

Which version of iX do you use?

v2.5.0

Code to produce this issue.

I’ve included a StackBlitz example to demonstrate that:

  • Elements cannot be focused programmatically.
  • The modal does not focus the first focusable nested element by default.
@Aiderlei Aiderlei added the triage We discuss this topic in our internal weekly label Oct 23, 2024
@matthiashader matthiashader added the Workflow: Issue created JIRA issue is created and will be analyzed label Oct 24, 2024
Copy link
Contributor

github-actions bot commented Oct 24, 2024

🤖 Hello @Aiderlei

Your issue will be analyzed and is part of our internal workflow.
To get informed about our workflow please checkout the Contributing Guidelines

JIRA: IX-1886

@danielleroux
Copy link
Collaborator

danielleroux commented Dec 6, 2024

@Aiderlei Autofocus should work with the next release also within a ix-modal. Just keep in mind that using autofocus decrease the level of accessibility e.g https://www.boia.org/blog/accessibility-tips-be-cautious-when-using-autofocus

@Aiderlei
Copy link
Author

@danielleroux Thanks for fixing and letting me know that!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
triage We discuss this topic in our internal weekly Workflow: Issue created JIRA issue is created and will be analyzed
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants