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

feat(ui5-menu): Enhance keyboard navigation #10243

Open
wants to merge 17 commits into
base: main
Choose a base branch
from

Conversation

Todor-ads
Copy link
Member

@Todor-ads Todor-ads commented Nov 25, 2024

After this change, it will be possible to navigate through the elements added to the endContent using the left and right arrow keys on the keyboard

BGSOFUIBALKAN-8852

packages/main/src/Menu.ts Outdated Show resolved Hide resolved
@Todor-ads Todor-ads changed the title feat(ui5-menu): endContent is now accessible via keyboard feat(ui5-menu): Enhance keyboard navigation Nov 25, 2024
packages/main/src/Menu.ts Outdated Show resolved Hide resolved
packages/main/src/Menu.ts Outdated Show resolved Hide resolved
packages/main/src/Menu.ts Show resolved Hide resolved
@unazko unazko self-requested a review December 19, 2024 23:50
Comment on lines +220 to +222
get _navigableItems() {
return [...this.endContent] as Array<HTMLElement>;
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will be better to have it as a return type of the getter.

get _navigableItems() : Array<HTMLElement> {
		return [...this.endContent];
	}

Comment on lines +359 to +363
if (isRight(e)) {
item._navigateToEndContent();
} else if (isLeft(e)) {
item._navigateToEndContent(true);
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this can be merged into one if, but it's up to you, just a suggestion

If ( isRight or isLeft) then item,_navigateToEndContent(isLeft)


if (shouldOpenMenu) {
this._openItemSubMenu(item);
} else if ((shouldCloseMenu || isTabNextPrevoius) && parentElement._popover) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know this parentElement._popover check is just moved. but we can think of a better one. like parentElement === opener, or we can just remove the parent element and use the opener.

if (shouldOpenMenu) {
this._openItemSubMenu(item);
} else if ((shouldCloseMenu || isTabNextPrevoius) && parentElement._popover) {
parentElement._popover.open = false;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this in future should also be changed. if we want to change "parent" property, we fire an event and the parent changes the property based on that.

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.

3 participants