Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@vaadin/overlay

Package Overview
Dependencies
Maintainers
12
Versions
291
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@vaadin/overlay - npm Package Compare versions

Comparing version 24.1.0-alpha9 to 24.1.0-beta1

14

package.json
{
"name": "@vaadin/overlay",
"version": "24.1.0-alpha9",
"version": "24.1.0-beta1",
"publishConfig": {

@@ -39,7 +39,7 @@ "access": "public"

"@polymer/polymer": "^3.0.0",
"@vaadin/a11y-base": "24.1.0-alpha9",
"@vaadin/component-base": "24.1.0-alpha9",
"@vaadin/vaadin-lumo-styles": "24.1.0-alpha9",
"@vaadin/vaadin-material-styles": "24.1.0-alpha9",
"@vaadin/vaadin-themable-mixin": "24.1.0-alpha9"
"@vaadin/a11y-base": "24.1.0-beta1",
"@vaadin/component-base": "24.1.0-beta1",
"@vaadin/vaadin-lumo-styles": "24.1.0-beta1",
"@vaadin/vaadin-material-styles": "24.1.0-beta1",
"@vaadin/vaadin-themable-mixin": "24.1.0-beta1"
},

@@ -52,3 +52,3 @@ "devDependencies": {

},
"gitHead": "db4fe44603a6702b85b0da2a6d033ddf8ffea5c4"
"gitHead": "f0ddb6576073a6af05ab29867bc5ec82e334f9d7"
}

@@ -9,2 +9,3 @@ /**

import { FocusTrapController } from '@vaadin/a11y-base/src/focus-trap-controller.js';
import { getDeepActiveElement } from '@vaadin/a11y-base/src/focus-utils.js';
import { isIOS } from '@vaadin/component-base/src/browser-utils.js';

@@ -486,4 +487,6 @@ import { ControllerMixin } from '@vaadin/component-base/src/controller-mixin.js';

if (opened) {
// Store focused node.
this.__restoreFocusNode = this._getActiveElement();
if (this.restoreFocusOnClose) {
this.__storeFocus();
}
this._animatedOpening();

@@ -510,2 +513,6 @@

if (this.restoreFocusOnClose) {
this.__restoreFocus();
}
this._animatedClosing();

@@ -522,2 +529,48 @@

/** @private */
__storeFocus() {
// Store the focused node.
this.__restoreFocusNode = getDeepActiveElement();
// Determine and store the node that has the `focus-ring` attribute
// in order to restore the attribute when the overlay closes.
const restoreFocusNode = this.restoreFocusNode || this.__restoreFocusNode;
if (restoreFocusNode) {
const restoreFocusNodeHost = (restoreFocusNode.assignedSlot || restoreFocusNode).getRootNode().host;
this.__restoreFocusRingNode = [restoreFocusNode, restoreFocusNodeHost].find((node) => {
return node && node.hasAttribute('focus-ring');
});
}
}
/** @private */
__restoreFocus() {
// If the activeElement is `<body>` or inside the overlay,
// we are allowed to restore the focus. In all the other
// cases focus might have been moved elsewhere by another
// component or by the user interaction (e.g. click on a
// button outside the overlay).
const activeElement = getDeepActiveElement();
if (activeElement !== document.body && !this._deepContains(activeElement)) {
return;
}
// Use restoreFocusNode if specified, otherwise fallback to the node
// which was focused before opening the overlay.
const restoreFocusNode = this.restoreFocusNode || this.__restoreFocusNode;
if (restoreFocusNode) {
// Focusing the restoreFocusNode doesn't always work synchronously on Firefox and Safari
// (e.g. combo-box overlay close on outside click).
setTimeout(() => restoreFocusNode.focus());
this.__restoreFocusNode = null;
}
// Restore the `focus-ring` attribute if it was present
// when the overlay was opening.
if (this.__restoreFocusRingNode) {
this.__restoreFocusRingNode.setAttribute('focus-ring', '');
this.__restoreFocusRingNode = null;
}
}
/** @private */
_hiddenChanged(hidden) {

@@ -618,23 +671,2 @@ if (hidden && this.hasAttribute('closing')) {

this._exitModalState();
// Use this.restoreFocusNode if specified, otherwise fallback to the node
// which was focused before opening the overlay.
const restoreFocusNode = this.restoreFocusNode || this.__restoreFocusNode;
if (this.restoreFocusOnClose && restoreFocusNode) {
// If the activeElement is `<body>` or inside the overlay,
// we are allowed to restore the focus. In all the other
// cases focus might have been moved elsewhere by another
// component or by the user interaction (e.g. click on a
// button outside the overlay).
const activeElement = this._getActiveElement();
if (activeElement === document.body || this._deepContains(activeElement)) {
// Focusing the restoreFocusNode doesn't always work synchronously on Firefox and Safari
// (e.g. combo-box overlay close on outside click).
setTimeout(() => restoreFocusNode.focus());
}
this.__restoreFocusNode = null;
}
this.setAttribute('closing', '');

@@ -756,16 +788,2 @@ this.dispatchEvent(new CustomEvent('vaadin-overlay-closing'));

/**
* @return {!Element}
* @private
*/
_getActiveElement() {
// Document.activeElement can be null
// https://developer.mozilla.org/en-US/docs/Web/API/Document/activeElement
let active = document.activeElement || document.body;
while (active.shadowRoot && active.shadowRoot.activeElement) {
active = active.shadowRoot.activeElement;
}
return active;
}
/**
* @param {!Node} node

@@ -772,0 +790,0 @@ * @return {boolean}

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc