package.src.vaadin-menu-bar-button.js Maven / Gradle / Ivy
The newest version!
/**
* @license
* Copyright (c) 2019 - 2024 Vaadin Ltd.
* This program is available under Apache License Version 2.0, available at https://vaadin.com/license/
*/
import { Button } from '@vaadin/button/src/vaadin-button.js';
import { defineCustomElement } from '@vaadin/component-base/src/define.js';
import { css, registerStyles } from '@vaadin/vaadin-themable-mixin/vaadin-themable-mixin.js';
registerStyles(
'vaadin-menu-bar-button',
css`
:host {
flex-shrink: 0;
}
:host([slot='overflow']) {
margin-inline-end: 0;
}
`,
{ moduleId: 'vaadin-menu-bar-button-styles' },
);
/**
* An element used internally by ``. Not intended to be used separately.
*
* @customElement
* @extends Button
* @private
*/
class MenuBarButton extends Button {
static get is() {
return 'vaadin-menu-bar-button';
}
/**
* Override method inherited from `ButtonMixin`. Sets a flag based on whether the key is an active key. Unlike a mouse click, Enter and Space should also focus the first item. This flag is used in menu bar to identify the action that triggered the click.
*
* @param {KeyboardEvent} event
* @protected
* @override
*/
_onKeyDown(event) {
this.__triggeredWithActiveKeys = this._activeKeys.includes(event.key);
super._onKeyDown(event);
this.__triggeredWithActiveKeys = null;
}
}
defineCustomElement(MenuBarButton);
© 2015 - 2025 Weber Informatics LLC | Privacy Policy