fix(deps): update dependency material-icons to ^0.7.0
GitOrigin-RevId: a5bcfd6a69fff3a38a7dff4f8e163cdc6143fc8f
diff --git a/node_modules/dialog-polyfill/README.md b/node_modules/dialog-polyfill/README.md
index fa907ec..749f9ae 100644
--- a/node_modules/dialog-polyfill/README.md
+++ b/node_modules/dialog-polyfill/README.md
@@ -1,5 +1,5 @@
dialog-polyfill.js is a polyfill for `<dialog>` and `<form method="dialog">`.
-Check out [some demos](http://demo.agektmr.com/dialog/)!
+Check out [some demos](https://googlechrome.github.io/dialog-polyfill/)!
`<dialog>` is an element for a popup box in a web page, including a modal option which will make the rest of the page inert during use.
This could be useful to block a user's interaction until they give you a response, or to confirm an action.
@@ -16,14 +16,14 @@
There are several ways that to include the dialog polyfill:
-* include `dialog-polyfill.js` script directly in your HTML, which exposes a global `dialogPolyfill` function.
+* include `dist/dialog-polyfill.js` script directly in your HTML, which exposes a global `dialogPolyfill` function.
* `import` (es modules)
* `require` (commonjs/node)
```javascript
// direct import (script module, deno)
-import dialogPolyfill from './node_modules/dialog-polyfill/index.js';
+import dialogPolyfill from './node_modules/dialog-polyfill/dist/dialog-polyfill.esm.js';
// *OR*
@@ -39,11 +39,13 @@
### Supports
-This polyfill works on modern versions of all major browsers. It also supports IE9 and above.
+This polyfill works on modern versions of all major browsers.
+It also supports IE9 and above.
+It can work when used inside Shadow DOM, but it's not recommended.
### Steps
-1. Include the CSS in the `<head>` of your document, and the Javascript anywhere before referencing `dialogPolyfill`.
+1. Include the CSS in the `<head>` of your document, and the JS anywhere before referencing `dialogPolyfill`.
2. Create your dialog elements within the document. See [limitations](#limitations) for more details.
3. Register the elements using `dialogPolyfill.registerDialog()`, passing it one node at a time. This polyfill won't replace native support.
4. Use your `<dialog>` elements!
@@ -65,7 +67,7 @@
<script>
var dialog = document.querySelector('dialog');
dialogPolyfill.registerDialog(dialog);
- // Now dialog acts like a native <dialog>.
+ // Now dialog always acts like a native <dialog>.
dialog.showModal();
</script>
</body>
@@ -114,6 +116,9 @@
}
```
+This is also provided as a helper CSS class in the polyfill CSS, `.fixed`.
+You can apply by using HTML like `<dialog class="fixed">`.
+
## Extensions
### Focus
diff --git a/node_modules/dialog-polyfill/dist/dialog-polyfill.esm.js b/node_modules/dialog-polyfill/dist/dialog-polyfill.esm.js
index d866b94..471f55e 100644
--- a/node_modules/dialog-polyfill/dist/dialog-polyfill.esm.js
+++ b/node_modules/dialog-polyfill/dist/dialog-polyfill.esm.js
@@ -11,6 +11,22 @@
}
/**
+ * Dispatches the passed event to both an "on<type>" handler as well as via the
+ * normal dispatch operation. Does not bubble.
+ *
+ * @param {!EventTarget} target
+ * @param {!Event} event
+ * @return {boolean}
+ */
+function safeDispatchEvent(target, event) {
+ var check = 'on' + event.type.toLowerCase();
+ if (typeof target[check] === 'function') {
+ target[check](event);
+ }
+ return target.dispatchEvent(event);
+}
+
+/**
* @param {Element} el to check for stacking context
* @return {boolean} whether this el or its parents creates a stacking context
*/
@@ -20,7 +36,7 @@
var invalid = function(k, ok) {
return !(s[k] === undefined || s[k] === ok);
};
-
+
if (s.opacity < 1 ||
invalid('zIndex', 'auto') ||
invalid('transform', 'none') ||
@@ -61,6 +77,11 @@
* @param {Element} el to blur
*/
function safeBlur(el) {
+ // Find the actual focused element when the active element is inside a shadow root
+ while (el && el.shadowRoot && el.shadowRoot.activeElement) {
+ el = el.shadowRoot.activeElement;
+ }
+
if (el && el.blur && el !== document.body) {
el.blur();
}
@@ -92,6 +113,110 @@
}
/**
+ * @param {!DocumentFragment|!Element} hostElement
+ * @return {?Element}
+ */
+function findFocusableElementWithin(hostElement) {
+ // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
+ // alternative involves stepping through and trying to focus everything.
+ var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
+ var query = opts.map(function(el) {
+ return el + ':not([disabled])';
+ });
+ // TODO(samthor): tabindex values that are not numeric are not focusable.
+ query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
+ var target = hostElement.querySelector(query.join(', '));
+
+ if (!target && 'attachShadow' in Element.prototype) {
+ // If we haven't found a focusable target, see if the host element contains an element
+ // which has a shadowRoot.
+ // Recursively search for the first focusable item in shadow roots.
+ var elems = hostElement.querySelectorAll('*');
+ for (var i = 0; i < elems.length; i++) {
+ if (elems[i].tagName && elems[i].shadowRoot) {
+ target = findFocusableElementWithin(elems[i].shadowRoot);
+ if (target) {
+ break;
+ }
+ }
+ }
+ }
+ return target;
+}
+
+/**
+ * Determines if an element is attached to the DOM.
+ * @param {Element} element to check
+ * @return {Boolean} whether the element is in DOM
+ */
+function isConnected(element) {
+ return element.isConnected || document.body.contains(element);
+}
+
+/**
+ * @param {!Event} event
+ */
+function findFormSubmitter(event) {
+ if (event.submitter) {
+ return event.submitter;
+ }
+
+ var form = event.target;
+ if (!(form instanceof HTMLFormElement)) {
+ return null;
+ }
+
+ var submitter = dialogPolyfill.formSubmitter;
+ if (!submitter) {
+ var target = event.target;
+ var root = ('getRootNode' in target && target.getRootNode() || document);
+ submitter = root.activeElement;
+ }
+
+ if (submitter.form !== form) {
+ return null;
+ }
+ return submitter;
+}
+
+/**
+ * @param {!Event} event
+ */
+function maybeHandleSubmit(event) {
+ if (event.defaultPrevented) {
+ return;
+ }
+ var form = /** @type {!HTMLFormElement} */ (event.target);
+
+ // We'd have a value if we clicked on an imagemap.
+ var value = dialogPolyfill.useValue;
+ var submitter = findFormSubmitter(event);
+ if (value === null && submitter) {
+ value = submitter.value;
+ }
+
+ // There should always be a dialog as this handler is added specifically on them, but check just
+ // in case.
+ var dialog = findNearestDialog(form);
+ if (!dialog) {
+ return;
+ }
+
+ // Prefer formmethod on the button.
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod !== 'dialog') {
+ return;
+ }
+ event.preventDefault();
+
+ if (submitter) {
+ dialog.close(value);
+ } else {
+ dialog.close();
+ }
+}
+
+/**
* @param {!HTMLDialogElement} dialog to upgrade
* @constructor
*/
@@ -109,6 +234,8 @@
dialog.showModal = this.showModal.bind(this);
dialog.close = this.close.bind(this);
+ dialog.addEventListener('submit', maybeHandleSubmit, false);
+
if (!('returnValue' in dialog)) {
dialog.returnValue = '';
}
@@ -147,10 +274,12 @@
this.backdrop_ = document.createElement('div');
this.backdrop_.className = 'backdrop';
- this.backdrop_.addEventListener('click', this.backdropClick_.bind(this));
+ this.backdrop_.addEventListener('mouseup' , this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('mousedown', this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('click' , this.backdropMouseEvent_.bind(this));
}
-dialogPolyfillInfo.prototype = {
+dialogPolyfillInfo.prototype = /** @type {HTMLDialogElement.prototype} */ ({
get dialog() {
return this.dialog_;
@@ -162,7 +291,7 @@
* longer open or is no longer part of the DOM.
*/
maybeHideModal: function() {
- if (this.dialog_.hasAttribute('open') && document.body.contains(this.dialog_)) { return; }
+ if (this.dialog_.hasAttribute('open') && isConnected(this.dialog_)) { return; }
this.downgradeModal();
},
@@ -200,12 +329,12 @@
},
/**
- * Handles clicks on the fake .backdrop element, redirecting them as if
+ * Handles mouse events ('mouseup', 'mousedown', 'click') on the fake .backdrop element, redirecting them as if
* they were on the dialog itself.
*
* @param {!Event} e to redirect
*/
- backdropClick_: function(e) {
+ backdropMouseEvent_: function(e) {
if (!this.dialog_.hasAttribute('tabindex')) {
// Clicking on the backdrop should move the implicit cursor, even if dialog cannot be
// focused. Create a fake thing to focus on. If the backdrop was _before_ the dialog, this
@@ -238,15 +367,7 @@
target = this.dialog_;
}
if (!target) {
- // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
- // alternative involves stepping through and trying to focus everything.
- var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
- var query = opts.map(function(el) {
- return el + ':not([disabled])';
- });
- // TODO(samthor): tabindex values that are not numeric are not focusable.
- query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
- target = this.dialog_.querySelector(query.join(', '));
+ target = findFocusableElementWithin(this.dialog_);
}
safeBlur(document.activeElement);
target && target.focus();
@@ -283,7 +404,7 @@
if (this.dialog_.hasAttribute('open')) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is already open, and therefore cannot be opened modally.');
}
- if (!document.body.contains(this.dialog_)) {
+ if (!isConnected(this.dialog_)) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is not in a Document.');
}
if (!dialogPolyfill.dm.pushDialog(this)) {
@@ -336,10 +457,10 @@
bubbles: false,
cancelable: false
});
- this.dialog_.dispatchEvent(closeEvent);
+ safeDispatchEvent(this.dialog_, closeEvent);
}
-};
+});
var dialogPolyfill = {};
@@ -526,24 +647,26 @@
};
dialogPolyfill.DialogManager.prototype.handleFocus_ = function(event) {
- if (this.containedByTopDialog_(event.target)) { return; }
+ var target = event.composedPath ? event.composedPath()[0] : event.target;
+
+ if (this.containedByTopDialog_(target)) { return; }
if (document.activeElement === document.documentElement) { return; }
event.preventDefault();
event.stopPropagation();
- safeBlur(/** @type {Element} */ (event.target));
+ safeBlur(/** @type {Element} */ (target));
if (this.forwardTab_ === undefined) { return; } // move focus only from a tab key
var dpi = this.pendingDialogStack[0];
var dialog = dpi.dialog;
- var position = dialog.compareDocumentPosition(event.target);
+ var position = dialog.compareDocumentPosition(target);
if (position & Node.DOCUMENT_POSITION_PRECEDING) {
if (this.forwardTab_) {
// forward
dpi.focus_();
- } else if (event.target !== document.documentElement) {
+ } else if (target !== document.documentElement) {
// backwards if we're not already focused on <html>
document.documentElement.focus();
}
@@ -562,7 +685,7 @@
cancelable: true
});
var dpi = this.pendingDialogStack[0];
- if (dpi && dpi.dialog.dispatchEvent(cancelEvent)) {
+ if (dpi && safeDispatchEvent(dpi.dialog, cancelEvent)) {
dpi.dialog.close();
}
} else if (event.keyCode === 9) {
@@ -649,6 +772,7 @@
return realGet.call(this);
};
var realSet = methodDescriptor.set;
+ /** @this {HTMLElement} */
methodDescriptor.set = function(v) {
if (typeof v === 'string' && v.toLowerCase() === 'dialog') {
return this.setAttribute('method', v);
@@ -670,6 +794,10 @@
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission
var target = /** @type {Element} */ (ev.target);
+ if ('composedPath' in ev) {
+ var path = ev.composedPath();
+ target = path.shift() || target;
+ }
if (!target || !isFormMethodDialog(target.form)) { return; }
var valid = (target.type === 'submit' && ['button', 'input'].indexOf(target.localName) > -1);
@@ -687,6 +815,24 @@
}, false);
/**
+ * Global 'submit' handler. This handles submits of `method="dialog"` which are invalid, i.e.,
+ * outside a dialog. They get prevented.
+ */
+ document.addEventListener('submit', function(ev) {
+ var form = ev.target;
+ var dialog = findNearestDialog(form);
+ if (dialog) {
+ return; // ignore, handle there
+ }
+
+ var submitter = findFormSubmitter(ev);
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod === 'dialog') {
+ ev.preventDefault();
+ }
+ });
+
+ /**
* Replace the native HTMLFormElement.submit() method, as it won't fire the
* submit event and give us a chance to respond.
*/
@@ -699,30 +845,6 @@
dialog && dialog.close();
};
HTMLFormElement.prototype.submit = replacementFormSubmit;
-
- /**
- * Global form 'dialog' method handler. Closes a dialog correctly on submit
- * and possibly sets its return value.
- */
- document.addEventListener('submit', function(ev) {
- var form = /** @type {HTMLFormElement} */ (ev.target);
- if (!isFormMethodDialog(form)) { return; }
- ev.preventDefault();
-
- var dialog = findNearestDialog(form);
- if (!dialog) { return; }
-
- // Forms can only be submitted via .submit() or a click (?), but anyway: sanity-check that
- // the submitter is correct before using its value as .returnValue.
- var s = dialogPolyfill.formSubmitter;
- if (s && s.form === form) {
- dialog.close(dialogPolyfill.useValue || s.value);
- } else {
- dialog.close();
- }
- dialogPolyfill.formSubmitter = null;
-
- }, true);
}
export default dialogPolyfill;
diff --git a/node_modules/dialog-polyfill/dist/dialog-polyfill.js b/node_modules/dialog-polyfill/dist/dialog-polyfill.js
index 72a4ab9..bd60a70 100644
--- a/node_modules/dialog-polyfill/dist/dialog-polyfill.js
+++ b/node_modules/dialog-polyfill/dist/dialog-polyfill.js
@@ -17,6 +17,22 @@
}
/**
+ * Dispatches the passed event to both an "on<type>" handler as well as via the
+ * normal dispatch operation. Does not bubble.
+ *
+ * @param {!EventTarget} target
+ * @param {!Event} event
+ * @return {boolean}
+ */
+ function safeDispatchEvent(target, event) {
+ var check = 'on' + event.type.toLowerCase();
+ if (typeof target[check] === 'function') {
+ target[check](event);
+ }
+ return target.dispatchEvent(event);
+ }
+
+ /**
* @param {Element} el to check for stacking context
* @return {boolean} whether this el or its parents creates a stacking context
*/
@@ -26,7 +42,7 @@
var invalid = function(k, ok) {
return !(s[k] === undefined || s[k] === ok);
};
-
+
if (s.opacity < 1 ||
invalid('zIndex', 'auto') ||
invalid('transform', 'none') ||
@@ -67,6 +83,11 @@
* @param {Element} el to blur
*/
function safeBlur(el) {
+ // Find the actual focused element when the active element is inside a shadow root
+ while (el && el.shadowRoot && el.shadowRoot.activeElement) {
+ el = el.shadowRoot.activeElement;
+ }
+
if (el && el.blur && el !== document.body) {
el.blur();
}
@@ -98,6 +119,110 @@
}
/**
+ * @param {!DocumentFragment|!Element} hostElement
+ * @return {?Element}
+ */
+ function findFocusableElementWithin(hostElement) {
+ // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
+ // alternative involves stepping through and trying to focus everything.
+ var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
+ var query = opts.map(function(el) {
+ return el + ':not([disabled])';
+ });
+ // TODO(samthor): tabindex values that are not numeric are not focusable.
+ query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
+ var target = hostElement.querySelector(query.join(', '));
+
+ if (!target && 'attachShadow' in Element.prototype) {
+ // If we haven't found a focusable target, see if the host element contains an element
+ // which has a shadowRoot.
+ // Recursively search for the first focusable item in shadow roots.
+ var elems = hostElement.querySelectorAll('*');
+ for (var i = 0; i < elems.length; i++) {
+ if (elems[i].tagName && elems[i].shadowRoot) {
+ target = findFocusableElementWithin(elems[i].shadowRoot);
+ if (target) {
+ break;
+ }
+ }
+ }
+ }
+ return target;
+ }
+
+ /**
+ * Determines if an element is attached to the DOM.
+ * @param {Element} element to check
+ * @return {Boolean} whether the element is in DOM
+ */
+ function isConnected(element) {
+ return element.isConnected || document.body.contains(element);
+ }
+
+ /**
+ * @param {!Event} event
+ */
+ function findFormSubmitter(event) {
+ if (event.submitter) {
+ return event.submitter;
+ }
+
+ var form = event.target;
+ if (!(form instanceof HTMLFormElement)) {
+ return null;
+ }
+
+ var submitter = dialogPolyfill.formSubmitter;
+ if (!submitter) {
+ var target = event.target;
+ var root = ('getRootNode' in target && target.getRootNode() || document);
+ submitter = root.activeElement;
+ }
+
+ if (submitter.form !== form) {
+ return null;
+ }
+ return submitter;
+ }
+
+ /**
+ * @param {!Event} event
+ */
+ function maybeHandleSubmit(event) {
+ if (event.defaultPrevented) {
+ return;
+ }
+ var form = /** @type {!HTMLFormElement} */ (event.target);
+
+ // We'd have a value if we clicked on an imagemap.
+ var value = dialogPolyfill.useValue;
+ var submitter = findFormSubmitter(event);
+ if (value === null && submitter) {
+ value = submitter.value;
+ }
+
+ // There should always be a dialog as this handler is added specifically on them, but check just
+ // in case.
+ var dialog = findNearestDialog(form);
+ if (!dialog) {
+ return;
+ }
+
+ // Prefer formmethod on the button.
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod !== 'dialog') {
+ return;
+ }
+ event.preventDefault();
+
+ if (submitter) {
+ dialog.close(value);
+ } else {
+ dialog.close();
+ }
+ }
+
+ /**
* @param {!HTMLDialogElement} dialog to upgrade
* @constructor
*/
@@ -115,6 +240,8 @@
dialog.showModal = this.showModal.bind(this);
dialog.close = this.close.bind(this);
+ dialog.addEventListener('submit', maybeHandleSubmit, false);
+
if (!('returnValue' in dialog)) {
dialog.returnValue = '';
}
@@ -153,10 +280,12 @@
this.backdrop_ = document.createElement('div');
this.backdrop_.className = 'backdrop';
- this.backdrop_.addEventListener('click', this.backdropClick_.bind(this));
+ this.backdrop_.addEventListener('mouseup' , this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('mousedown', this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('click' , this.backdropMouseEvent_.bind(this));
}
- dialogPolyfillInfo.prototype = {
+ dialogPolyfillInfo.prototype = /** @type {HTMLDialogElement.prototype} */ ({
get dialog() {
return this.dialog_;
@@ -168,7 +297,7 @@
* longer open or is no longer part of the DOM.
*/
maybeHideModal: function() {
- if (this.dialog_.hasAttribute('open') && document.body.contains(this.dialog_)) { return; }
+ if (this.dialog_.hasAttribute('open') && isConnected(this.dialog_)) { return; }
this.downgradeModal();
},
@@ -206,12 +335,12 @@
},
/**
- * Handles clicks on the fake .backdrop element, redirecting them as if
+ * Handles mouse events ('mouseup', 'mousedown', 'click') on the fake .backdrop element, redirecting them as if
* they were on the dialog itself.
*
* @param {!Event} e to redirect
*/
- backdropClick_: function(e) {
+ backdropMouseEvent_: function(e) {
if (!this.dialog_.hasAttribute('tabindex')) {
// Clicking on the backdrop should move the implicit cursor, even if dialog cannot be
// focused. Create a fake thing to focus on. If the backdrop was _before_ the dialog, this
@@ -244,15 +373,7 @@
target = this.dialog_;
}
if (!target) {
- // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
- // alternative involves stepping through and trying to focus everything.
- var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
- var query = opts.map(function(el) {
- return el + ':not([disabled])';
- });
- // TODO(samthor): tabindex values that are not numeric are not focusable.
- query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
- target = this.dialog_.querySelector(query.join(', '));
+ target = findFocusableElementWithin(this.dialog_);
}
safeBlur(document.activeElement);
target && target.focus();
@@ -289,7 +410,7 @@
if (this.dialog_.hasAttribute('open')) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is already open, and therefore cannot be opened modally.');
}
- if (!document.body.contains(this.dialog_)) {
+ if (!isConnected(this.dialog_)) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is not in a Document.');
}
if (!dialogPolyfill.dm.pushDialog(this)) {
@@ -342,10 +463,10 @@
bubbles: false,
cancelable: false
});
- this.dialog_.dispatchEvent(closeEvent);
+ safeDispatchEvent(this.dialog_, closeEvent);
}
- };
+ });
var dialogPolyfill = {};
@@ -532,24 +653,26 @@
};
dialogPolyfill.DialogManager.prototype.handleFocus_ = function(event) {
- if (this.containedByTopDialog_(event.target)) { return; }
+ var target = event.composedPath ? event.composedPath()[0] : event.target;
+
+ if (this.containedByTopDialog_(target)) { return; }
if (document.activeElement === document.documentElement) { return; }
event.preventDefault();
event.stopPropagation();
- safeBlur(/** @type {Element} */ (event.target));
+ safeBlur(/** @type {Element} */ (target));
if (this.forwardTab_ === undefined) { return; } // move focus only from a tab key
var dpi = this.pendingDialogStack[0];
var dialog = dpi.dialog;
- var position = dialog.compareDocumentPosition(event.target);
+ var position = dialog.compareDocumentPosition(target);
if (position & Node.DOCUMENT_POSITION_PRECEDING) {
if (this.forwardTab_) {
// forward
dpi.focus_();
- } else if (event.target !== document.documentElement) {
+ } else if (target !== document.documentElement) {
// backwards if we're not already focused on <html>
document.documentElement.focus();
}
@@ -568,7 +691,7 @@
cancelable: true
});
var dpi = this.pendingDialogStack[0];
- if (dpi && dpi.dialog.dispatchEvent(cancelEvent)) {
+ if (dpi && safeDispatchEvent(dpi.dialog, cancelEvent)) {
dpi.dialog.close();
}
} else if (event.keyCode === 9) {
@@ -655,6 +778,7 @@
return realGet.call(this);
};
var realSet = methodDescriptor.set;
+ /** @this {HTMLElement} */
methodDescriptor.set = function(v) {
if (typeof v === 'string' && v.toLowerCase() === 'dialog') {
return this.setAttribute('method', v);
@@ -676,6 +800,10 @@
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission
var target = /** @type {Element} */ (ev.target);
+ if ('composedPath' in ev) {
+ var path = ev.composedPath();
+ target = path.shift() || target;
+ }
if (!target || !isFormMethodDialog(target.form)) { return; }
var valid = (target.type === 'submit' && ['button', 'input'].indexOf(target.localName) > -1);
@@ -693,6 +821,24 @@
}, false);
/**
+ * Global 'submit' handler. This handles submits of `method="dialog"` which are invalid, i.e.,
+ * outside a dialog. They get prevented.
+ */
+ document.addEventListener('submit', function(ev) {
+ var form = ev.target;
+ var dialog = findNearestDialog(form);
+ if (dialog) {
+ return; // ignore, handle there
+ }
+
+ var submitter = findFormSubmitter(ev);
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod === 'dialog') {
+ ev.preventDefault();
+ }
+ });
+
+ /**
* Replace the native HTMLFormElement.submit() method, as it won't fire the
* submit event and give us a chance to respond.
*/
@@ -705,30 +851,6 @@
dialog && dialog.close();
};
HTMLFormElement.prototype.submit = replacementFormSubmit;
-
- /**
- * Global form 'dialog' method handler. Closes a dialog correctly on submit
- * and possibly sets its return value.
- */
- document.addEventListener('submit', function(ev) {
- var form = /** @type {HTMLFormElement} */ (ev.target);
- if (!isFormMethodDialog(form)) { return; }
- ev.preventDefault();
-
- var dialog = findNearestDialog(form);
- if (!dialog) { return; }
-
- // Forms can only be submitted via .submit() or a click (?), but anyway: sanity-check that
- // the submitter is correct before using its value as .returnValue.
- var s = dialogPolyfill.formSubmitter;
- if (s && s.form === form) {
- dialog.close(dialogPolyfill.useValue || s.value);
- } else {
- dialog.close();
- }
- dialogPolyfill.formSubmitter = null;
-
- }, true);
}
return dialogPolyfill;
diff --git a/node_modules/dialog-polyfill/index.d.ts b/node_modules/dialog-polyfill/index.d.ts
new file mode 100644
index 0000000..2d4de1d
--- /dev/null
+++ b/node_modules/dialog-polyfill/index.d.ts
@@ -0,0 +1,18 @@
+
+interface DialogPolyfillType {
+ registerDialog(dialog: HTMLDialogElement): void;
+ forceRegisterDialog(dialog: HTMLDialogElement): void;
+}
+
+/**
+ * If used as CJS, then "dialogPolyfill" is added to the global scope. Just assert it exists.
+ */
+declare global {
+ const dialogPolyfill: DialogPolyfillType;
+}
+
+/**
+ * If used as ESM, then we export a const of type "DialogPolyfillType" as the default.
+ */
+declare const dialogPolyfill: DialogPolyfillType
+export default dialogPolyfill;
diff --git a/node_modules/dialog-polyfill/index.js b/node_modules/dialog-polyfill/index.js
index e4db8da..3643014 100644
--- a/node_modules/dialog-polyfill/index.js
+++ b/node_modules/dialog-polyfill/index.js
@@ -12,6 +12,22 @@
}
/**
+ * Dispatches the passed event to both an "on<type>" handler as well as via the
+ * normal dispatch operation. Does not bubble.
+ *
+ * @param {!EventTarget} target
+ * @param {!Event} event
+ * @return {boolean}
+ */
+function safeDispatchEvent(target, event) {
+ var check = 'on' + event.type.toLowerCase();
+ if (typeof target[check] === 'function') {
+ target[check](event);
+ }
+ return target.dispatchEvent(event);
+}
+
+/**
* @param {Element} el to check for stacking context
* @return {boolean} whether this el or its parents creates a stacking context
*/
@@ -21,7 +37,7 @@
var invalid = function(k, ok) {
return !(s[k] === undefined || s[k] === ok);
};
-
+
if (s.opacity < 1 ||
invalid('zIndex', 'auto') ||
invalid('transform', 'none') ||
@@ -62,6 +78,11 @@
* @param {Element} el to blur
*/
function safeBlur(el) {
+ // Find the actual focused element when the active element is inside a shadow root
+ while (el && el.shadowRoot && el.shadowRoot.activeElement) {
+ el = el.shadowRoot.activeElement;
+ }
+
if (el && el.blur && el !== document.body) {
el.blur();
}
@@ -93,6 +114,110 @@
}
/**
+ * @param {!DocumentFragment|!Element} hostElement
+ * @return {?Element}
+ */
+function findFocusableElementWithin(hostElement) {
+ // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
+ // alternative involves stepping through and trying to focus everything.
+ var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
+ var query = opts.map(function(el) {
+ return el + ':not([disabled])';
+ });
+ // TODO(samthor): tabindex values that are not numeric are not focusable.
+ query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
+ var target = hostElement.querySelector(query.join(', '));
+
+ if (!target && 'attachShadow' in Element.prototype) {
+ // If we haven't found a focusable target, see if the host element contains an element
+ // which has a shadowRoot.
+ // Recursively search for the first focusable item in shadow roots.
+ var elems = hostElement.querySelectorAll('*');
+ for (var i = 0; i < elems.length; i++) {
+ if (elems[i].tagName && elems[i].shadowRoot) {
+ target = findFocusableElementWithin(elems[i].shadowRoot);
+ if (target) {
+ break;
+ }
+ }
+ }
+ }
+ return target;
+}
+
+/**
+ * Determines if an element is attached to the DOM.
+ * @param {Element} element to check
+ * @return {Boolean} whether the element is in DOM
+ */
+function isConnected(element) {
+ return element.isConnected || document.body.contains(element);
+}
+
+/**
+ * @param {!Event} event
+ */
+function findFormSubmitter(event) {
+ if (event.submitter) {
+ return event.submitter;
+ }
+
+ var form = event.target;
+ if (!(form instanceof HTMLFormElement)) {
+ return null;
+ }
+
+ var submitter = dialogPolyfill.formSubmitter;
+ if (!submitter) {
+ var target = event.target;
+ var root = ('getRootNode' in target && target.getRootNode() || document);
+ submitter = root.activeElement;
+ }
+
+ if (submitter.form !== form) {
+ return null;
+ }
+ return submitter;
+}
+
+/**
+ * @param {!Event} event
+ */
+function maybeHandleSubmit(event) {
+ if (event.defaultPrevented) {
+ return;
+ }
+ var form = /** @type {!HTMLFormElement} */ (event.target);
+
+ // We'd have a value if we clicked on an imagemap.
+ var value = dialogPolyfill.useValue;
+ var submitter = findFormSubmitter(event);
+ if (value === null && submitter) {
+ value = submitter.value;
+ }
+
+ // There should always be a dialog as this handler is added specifically on them, but check just
+ // in case.
+ var dialog = findNearestDialog(form);
+ if (!dialog) {
+ return;
+ }
+
+ // Prefer formmethod on the button.
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod !== 'dialog') {
+ return;
+ }
+ event.preventDefault();
+
+ if (submitter) {
+ dialog.close(value);
+ } else {
+ dialog.close();
+ }
+}
+
+/**
* @param {!HTMLDialogElement} dialog to upgrade
* @constructor
*/
@@ -110,6 +235,8 @@
dialog.showModal = this.showModal.bind(this);
dialog.close = this.close.bind(this);
+ dialog.addEventListener('submit', maybeHandleSubmit, false);
+
if (!('returnValue' in dialog)) {
dialog.returnValue = '';
}
@@ -148,10 +275,12 @@
this.backdrop_ = document.createElement('div');
this.backdrop_.className = 'backdrop';
- this.backdrop_.addEventListener('click', this.backdropClick_.bind(this));
+ this.backdrop_.addEventListener('mouseup' , this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('mousedown', this.backdropMouseEvent_.bind(this));
+ this.backdrop_.addEventListener('click' , this.backdropMouseEvent_.bind(this));
}
-dialogPolyfillInfo.prototype = {
+dialogPolyfillInfo.prototype = /** @type {HTMLDialogElement.prototype} */ ({
get dialog() {
return this.dialog_;
@@ -163,7 +292,7 @@
* longer open or is no longer part of the DOM.
*/
maybeHideModal: function() {
- if (this.dialog_.hasAttribute('open') && document.body.contains(this.dialog_)) { return; }
+ if (this.dialog_.hasAttribute('open') && isConnected(this.dialog_)) { return; }
this.downgradeModal();
},
@@ -201,12 +330,12 @@
},
/**
- * Handles clicks on the fake .backdrop element, redirecting them as if
+ * Handles mouse events ('mouseup', 'mousedown', 'click') on the fake .backdrop element, redirecting them as if
* they were on the dialog itself.
*
* @param {!Event} e to redirect
*/
- backdropClick_: function(e) {
+ backdropMouseEvent_: function(e) {
if (!this.dialog_.hasAttribute('tabindex')) {
// Clicking on the backdrop should move the implicit cursor, even if dialog cannot be
// focused. Create a fake thing to focus on. If the backdrop was _before_ the dialog, this
@@ -239,15 +368,7 @@
target = this.dialog_;
}
if (!target) {
- // Note that this is 'any focusable area'. This list is probably not exhaustive, but the
- // alternative involves stepping through and trying to focus everything.
- var opts = ['button', 'input', 'keygen', 'select', 'textarea'];
- var query = opts.map(function(el) {
- return el + ':not([disabled])';
- });
- // TODO(samthor): tabindex values that are not numeric are not focusable.
- query.push('[tabindex]:not([disabled]):not([tabindex=""])'); // tabindex != "", not disabled
- target = this.dialog_.querySelector(query.join(', '));
+ target = findFocusableElementWithin(this.dialog_);
}
safeBlur(document.activeElement);
target && target.focus();
@@ -284,7 +405,7 @@
if (this.dialog_.hasAttribute('open')) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is already open, and therefore cannot be opened modally.');
}
- if (!document.body.contains(this.dialog_)) {
+ if (!isConnected(this.dialog_)) {
throw new Error('Failed to execute \'showModal\' on dialog: The element is not in a Document.');
}
if (!dialogPolyfill.dm.pushDialog(this)) {
@@ -337,10 +458,10 @@
bubbles: false,
cancelable: false
});
- this.dialog_.dispatchEvent(closeEvent);
+ safeDispatchEvent(this.dialog_, closeEvent);
}
-};
+});
var dialogPolyfill = {};
@@ -527,24 +648,26 @@
};
dialogPolyfill.DialogManager.prototype.handleFocus_ = function(event) {
- if (this.containedByTopDialog_(event.target)) { return; }
+ var target = event.composedPath ? event.composedPath()[0] : event.target;
+
+ if (this.containedByTopDialog_(target)) { return; }
if (document.activeElement === document.documentElement) { return; }
event.preventDefault();
event.stopPropagation();
- safeBlur(/** @type {Element} */ (event.target));
+ safeBlur(/** @type {Element} */ (target));
if (this.forwardTab_ === undefined) { return; } // move focus only from a tab key
var dpi = this.pendingDialogStack[0];
var dialog = dpi.dialog;
- var position = dialog.compareDocumentPosition(event.target);
+ var position = dialog.compareDocumentPosition(target);
if (position & Node.DOCUMENT_POSITION_PRECEDING) {
if (this.forwardTab_) {
// forward
dpi.focus_();
- } else if (event.target !== document.documentElement) {
+ } else if (target !== document.documentElement) {
// backwards if we're not already focused on <html>
document.documentElement.focus();
}
@@ -565,7 +688,7 @@
cancelable: true
});
var dpi = this.pendingDialogStack[0];
- if (dpi && dpi.dialog.dispatchEvent(cancelEvent)) {
+ if (dpi && safeDispatchEvent(dpi.dialog, cancelEvent)) {
dpi.dialog.close();
}
} else if (event.keyCode === 9) {
@@ -652,6 +775,7 @@
return realGet.call(this);
};
var realSet = methodDescriptor.set;
+ /** @this {HTMLElement} */
methodDescriptor.set = function(v) {
if (typeof v === 'string' && v.toLowerCase() === 'dialog') {
return this.setAttribute('method', v);
@@ -673,6 +797,10 @@
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission
var target = /** @type {Element} */ (ev.target);
+ if ('composedPath' in ev) {
+ var path = ev.composedPath();
+ target = path.shift() || target;
+ }
if (!target || !isFormMethodDialog(target.form)) { return; }
var valid = (target.type === 'submit' && ['button', 'input'].indexOf(target.localName) > -1);
@@ -690,6 +818,24 @@
}, false);
/**
+ * Global 'submit' handler. This handles submits of `method="dialog"` which are invalid, i.e.,
+ * outside a dialog. They get prevented.
+ */
+ document.addEventListener('submit', function(ev) {
+ var form = ev.target;
+ var dialog = findNearestDialog(form);
+ if (dialog) {
+ return; // ignore, handle there
+ }
+
+ var submitter = findFormSubmitter(ev);
+ var formmethod = submitter && submitter.getAttribute('formmethod') || form.getAttribute('method');
+ if (formmethod === 'dialog') {
+ ev.preventDefault();
+ }
+ });
+
+ /**
* Replace the native HTMLFormElement.submit() method, as it won't fire the
* submit event and give us a chance to respond.
*/
@@ -702,30 +848,6 @@
dialog && dialog.close();
};
HTMLFormElement.prototype.submit = replacementFormSubmit;
-
- /**
- * Global form 'dialog' method handler. Closes a dialog correctly on submit
- * and possibly sets its return value.
- */
- document.addEventListener('submit', function(ev) {
- var form = /** @type {HTMLFormElement} */ (ev.target);
- if (!isFormMethodDialog(form)) { return; }
- ev.preventDefault();
-
- var dialog = findNearestDialog(form);
- if (!dialog) { return; }
-
- // Forms can only be submitted via .submit() or a click (?), but anyway: sanity-check that
- // the submitter is correct before using its value as .returnValue.
- var s = dialogPolyfill.formSubmitter;
- if (s && s.form === form) {
- dialog.close(dialogPolyfill.useValue || s.value);
- } else {
- dialog.close();
- }
- dialogPolyfill.formSubmitter = null;
-
- }, true);
}
diff --git a/node_modules/dialog-polyfill/package-lock.json b/node_modules/dialog-polyfill/package-lock.json
deleted file mode 100644
index fcc690e..0000000
--- a/node_modules/dialog-polyfill/package-lock.json
+++ /dev/null
@@ -1,697 +0,0 @@
-{
- "name": "dialog-polyfill",
- "version": "0.4.10",
- "lockfileVersion": 1,
- "requires": true,
- "dependencies": {
- "@types/estree": {
- "version": "0.0.39",
- "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz",
- "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==",
- "dev": true
- },
- "@types/node": {
- "version": "11.9.5",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-11.9.5.tgz",
- "integrity": "sha512-vVjM0SVzgaOUpflq4GYBvCpozes8OgIIS5gVXVka+OfK3hvnkC1i93U8WiY2OtNE4XUWyyy/86Kf6e0IHTQw1Q==",
- "dev": true
- },
- "acorn": {
- "version": "6.1.0",
- "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.0.tgz",
- "integrity": "sha512-MW/FjM+IvU9CgBzjO3UIPCE2pyEwUsoFl+VGdczOPEdxfGFjuKny/gN54mOuX7Qxmb9Rg9MCn2oKiSUeW+pjrw==",
- "dev": true
- },
- "ansi-styles": {
- "version": "3.2.1",
- "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
- "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
- "dev": true,
- "requires": {
- "color-convert": "^1.9.0"
- }
- },
- "array-filter": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz",
- "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=",
- "dev": true
- },
- "array-map": {
- "version": "0.0.0",
- "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz",
- "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=",
- "dev": true
- },
- "array-reduce": {
- "version": "0.0.0",
- "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz",
- "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=",
- "dev": true
- },
- "assertion-error": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz",
- "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==",
- "dev": true
- },
- "balanced-match": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
- "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
- "dev": true
- },
- "brace-expansion": {
- "version": "1.1.11",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
- "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
- "dev": true,
- "requires": {
- "balanced-match": "^1.0.0",
- "concat-map": "0.0.1"
- }
- },
- "browser-stdout": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz",
- "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==",
- "dev": true
- },
- "chai": {
- "version": "4.2.0",
- "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz",
- "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==",
- "dev": true,
- "requires": {
- "assertion-error": "^1.1.0",
- "check-error": "^1.0.2",
- "deep-eql": "^3.0.1",
- "get-func-name": "^2.0.0",
- "pathval": "^1.1.0",
- "type-detect": "^4.0.5"
- }
- },
- "chalk": {
- "version": "2.4.2",
- "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
- "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
- "dev": true,
- "requires": {
- "ansi-styles": "^3.2.1",
- "escape-string-regexp": "^1.0.5",
- "supports-color": "^5.3.0"
- }
- },
- "check-error": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz",
- "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=",
- "dev": true
- },
- "color-convert": {
- "version": "1.9.3",
- "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
- "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
- "dev": true,
- "requires": {
- "color-name": "1.1.3"
- }
- },
- "color-name": {
- "version": "1.1.3",
- "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
- "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
- "dev": true
- },
- "commander": {
- "version": "2.15.1",
- "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz",
- "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==",
- "dev": true
- },
- "concat-map": {
- "version": "0.0.1",
- "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
- "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
- "dev": true
- },
- "cross-spawn": {
- "version": "6.0.5",
- "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
- "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
- "dev": true,
- "requires": {
- "nice-try": "^1.0.4",
- "path-key": "^2.0.1",
- "semver": "^5.5.0",
- "shebang-command": "^1.2.0",
- "which": "^1.2.9"
- }
- },
- "debug": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz",
- "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==",
- "dev": true,
- "requires": {
- "ms": "2.0.0"
- }
- },
- "deep-eql": {
- "version": "3.0.1",
- "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz",
- "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==",
- "dev": true,
- "requires": {
- "type-detect": "^4.0.0"
- }
- },
- "define-properties": {
- "version": "1.1.3",
- "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz",
- "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==",
- "dev": true,
- "requires": {
- "object-keys": "^1.0.12"
- }
- },
- "diff": {
- "version": "3.5.0",
- "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz",
- "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==",
- "dev": true
- },
- "error-ex": {
- "version": "1.3.2",
- "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
- "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
- "dev": true,
- "requires": {
- "is-arrayish": "^0.2.1"
- }
- },
- "es-abstract": {
- "version": "1.13.0",
- "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz",
- "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==",
- "dev": true,
- "requires": {
- "es-to-primitive": "^1.2.0",
- "function-bind": "^1.1.1",
- "has": "^1.0.3",
- "is-callable": "^1.1.4",
- "is-regex": "^1.0.4",
- "object-keys": "^1.0.12"
- }
- },
- "es-to-primitive": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz",
- "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==",
- "dev": true,
- "requires": {
- "is-callable": "^1.1.4",
- "is-date-object": "^1.0.1",
- "is-symbol": "^1.0.2"
- }
- },
- "escape-string-regexp": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
- "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
- "dev": true
- },
- "fs.realpath": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
- "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
- "dev": true
- },
- "function-bind": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
- "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==",
- "dev": true
- },
- "get-func-name": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz",
- "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=",
- "dev": true
- },
- "glob": {
- "version": "7.1.2",
- "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz",
- "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==",
- "dev": true,
- "requires": {
- "fs.realpath": "^1.0.0",
- "inflight": "^1.0.4",
- "inherits": "2",
- "minimatch": "^3.0.4",
- "once": "^1.3.0",
- "path-is-absolute": "^1.0.0"
- }
- },
- "graceful-fs": {
- "version": "4.1.15",
- "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz",
- "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==",
- "dev": true
- },
- "growl": {
- "version": "1.10.5",
- "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz",
- "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==",
- "dev": true
- },
- "has": {
- "version": "1.0.3",
- "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz",
- "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==",
- "dev": true,
- "requires": {
- "function-bind": "^1.1.1"
- }
- },
- "has-flag": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
- "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
- "dev": true
- },
- "has-symbols": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz",
- "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=",
- "dev": true
- },
- "he": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz",
- "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=",
- "dev": true
- },
- "hosted-git-info": {
- "version": "2.7.1",
- "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz",
- "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==",
- "dev": true
- },
- "inflight": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
- "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
- "dev": true,
- "requires": {
- "once": "^1.3.0",
- "wrappy": "1"
- }
- },
- "inherits": {
- "version": "2.0.3",
- "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
- "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=",
- "dev": true
- },
- "is-arrayish": {
- "version": "0.2.1",
- "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
- "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
- "dev": true
- },
- "is-callable": {
- "version": "1.1.4",
- "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz",
- "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==",
- "dev": true
- },
- "is-date-object": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz",
- "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=",
- "dev": true
- },
- "is-regex": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz",
- "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=",
- "dev": true,
- "requires": {
- "has": "^1.0.1"
- }
- },
- "is-symbol": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz",
- "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==",
- "dev": true,
- "requires": {
- "has-symbols": "^1.0.0"
- }
- },
- "isexe": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
- "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
- "dev": true
- },
- "json-parse-better-errors": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz",
- "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==",
- "dev": true
- },
- "jsonify": {
- "version": "0.0.0",
- "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz",
- "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=",
- "dev": true
- },
- "load-json-file": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz",
- "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=",
- "dev": true,
- "requires": {
- "graceful-fs": "^4.1.2",
- "parse-json": "^4.0.0",
- "pify": "^3.0.0",
- "strip-bom": "^3.0.0"
- }
- },
- "memorystream": {
- "version": "0.3.1",
- "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz",
- "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=",
- "dev": true
- },
- "minimatch": {
- "version": "3.0.4",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
- "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
- "dev": true,
- "requires": {
- "brace-expansion": "^1.1.7"
- }
- },
- "minimist": {
- "version": "0.0.8",
- "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz",
- "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=",
- "dev": true
- },
- "mkdirp": {
- "version": "0.5.1",
- "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz",
- "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=",
- "dev": true,
- "requires": {
- "minimist": "0.0.8"
- }
- },
- "mocha": {
- "version": "5.2.0",
- "resolved": "https://registry.npmjs.org/mocha/-/mocha-5.2.0.tgz",
- "integrity": "sha512-2IUgKDhc3J7Uug+FxMXuqIyYzH7gJjXECKe/w43IGgQHTSj3InJi+yAA7T24L9bQMRKiUEHxEX37G5JpVUGLcQ==",
- "dev": true,
- "requires": {
- "browser-stdout": "1.3.1",
- "commander": "2.15.1",
- "debug": "3.1.0",
- "diff": "3.5.0",
- "escape-string-regexp": "1.0.5",
- "glob": "7.1.2",
- "growl": "1.10.5",
- "he": "1.1.1",
- "minimatch": "3.0.4",
- "mkdirp": "0.5.1",
- "supports-color": "5.4.0"
- }
- },
- "ms": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
- "dev": true
- },
- "nice-try": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
- "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
- "dev": true
- },
- "normalize-package-data": {
- "version": "2.5.0",
- "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz",
- "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==",
- "dev": true,
- "requires": {
- "hosted-git-info": "^2.1.4",
- "resolve": "^1.10.0",
- "semver": "2 || 3 || 4 || 5",
- "validate-npm-package-license": "^3.0.1"
- }
- },
- "npm-run-all": {
- "version": "4.1.5",
- "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz",
- "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==",
- "dev": true,
- "requires": {
- "ansi-styles": "^3.2.1",
- "chalk": "^2.4.1",
- "cross-spawn": "^6.0.5",
- "memorystream": "^0.3.1",
- "minimatch": "^3.0.4",
- "pidtree": "^0.3.0",
- "read-pkg": "^3.0.0",
- "shell-quote": "^1.6.1",
- "string.prototype.padend": "^3.0.0"
- }
- },
- "object-keys": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.0.tgz",
- "integrity": "sha512-6OO5X1+2tYkNyNEx6TsCxEqFfRWaqx6EtMiSbGrw8Ob8v9Ne+Hl8rBAgLBZn5wjEz3s/s6U1WXFUFOcxxAwUpg==",
- "dev": true
- },
- "once": {
- "version": "1.4.0",
- "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
- "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
- "dev": true,
- "requires": {
- "wrappy": "1"
- }
- },
- "parse-json": {
- "version": "4.0.0",
- "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz",
- "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=",
- "dev": true,
- "requires": {
- "error-ex": "^1.3.1",
- "json-parse-better-errors": "^1.0.1"
- }
- },
- "path-is-absolute": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
- "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
- "dev": true
- },
- "path-key": {
- "version": "2.0.1",
- "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
- "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
- "dev": true
- },
- "path-parse": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz",
- "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==",
- "dev": true
- },
- "path-type": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz",
- "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==",
- "dev": true,
- "requires": {
- "pify": "^3.0.0"
- }
- },
- "pathval": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz",
- "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=",
- "dev": true
- },
- "pidtree": {
- "version": "0.3.0",
- "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.0.tgz",
- "integrity": "sha512-9CT4NFlDcosssyg8KVFltgokyKZIFjoBxw8CTGy+5F38Y1eQWrt8tRayiUOXE+zVKQnYu5BR8JjCtvK3BcnBhg==",
- "dev": true
- },
- "pify": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz",
- "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=",
- "dev": true
- },
- "read-pkg": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz",
- "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=",
- "dev": true,
- "requires": {
- "load-json-file": "^4.0.0",
- "normalize-package-data": "^2.3.2",
- "path-type": "^3.0.0"
- }
- },
- "resolve": {
- "version": "1.10.0",
- "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz",
- "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==",
- "dev": true,
- "requires": {
- "path-parse": "^1.0.6"
- }
- },
- "rollup": {
- "version": "1.3.0",
- "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.3.0.tgz",
- "integrity": "sha512-QiT0wFmu0IzkGgT5LvzRK5hezHcJW8T9MQdvdC+FylrNpsprpz0gTOpcyY9iM6Sda1fD1SatwNutCxcQd3Y/Lg==",
- "dev": true,
- "requires": {
- "@types/estree": "0.0.39",
- "@types/node": "^11.9.5",
- "acorn": "^6.1.0"
- }
- },
- "semver": {
- "version": "5.6.0",
- "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz",
- "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==",
- "dev": true
- },
- "shebang-command": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
- "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
- "dev": true,
- "requires": {
- "shebang-regex": "^1.0.0"
- }
- },
- "shebang-regex": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
- "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
- "dev": true
- },
- "shell-quote": {
- "version": "1.6.1",
- "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz",
- "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=",
- "dev": true,
- "requires": {
- "array-filter": "~0.0.0",
- "array-map": "~0.0.0",
- "array-reduce": "~0.0.0",
- "jsonify": "~0.0.0"
- }
- },
- "spdx-correct": {
- "version": "3.1.0",
- "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz",
- "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==",
- "dev": true,
- "requires": {
- "spdx-expression-parse": "^3.0.0",
- "spdx-license-ids": "^3.0.0"
- }
- },
- "spdx-exceptions": {
- "version": "2.2.0",
- "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz",
- "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==",
- "dev": true
- },
- "spdx-expression-parse": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz",
- "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==",
- "dev": true,
- "requires": {
- "spdx-exceptions": "^2.1.0",
- "spdx-license-ids": "^3.0.0"
- }
- },
- "spdx-license-ids": {
- "version": "3.0.3",
- "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz",
- "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==",
- "dev": true
- },
- "string.prototype.padend": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.0.0.tgz",
- "integrity": "sha1-86rvfBcZ8XDF6rHDK/eA2W4h8vA=",
- "dev": true,
- "requires": {
- "define-properties": "^1.1.2",
- "es-abstract": "^1.4.3",
- "function-bind": "^1.0.2"
- }
- },
- "strip-bom": {
- "version": "3.0.0",
- "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz",
- "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=",
- "dev": true
- },
- "supports-color": {
- "version": "5.4.0",
- "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz",
- "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==",
- "dev": true,
- "requires": {
- "has-flag": "^3.0.0"
- }
- },
- "type-detect": {
- "version": "4.0.8",
- "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz",
- "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==",
- "dev": true
- },
- "validate-npm-package-license": {
- "version": "3.0.4",
- "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
- "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
- "dev": true,
- "requires": {
- "spdx-correct": "^3.0.0",
- "spdx-expression-parse": "^3.0.0"
- }
- },
- "which": {
- "version": "1.3.1",
- "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
- "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
- "dev": true,
- "requires": {
- "isexe": "^2.0.0"
- }
- },
- "wrappy": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
- "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
- "dev": true
- }
- }
-}
diff --git a/node_modules/dialog-polyfill/package.json b/node_modules/dialog-polyfill/package.json
index 6b3bcd0..4ecce16 100644
--- a/node_modules/dialog-polyfill/package.json
+++ b/node_modules/dialog-polyfill/package.json
@@ -1,52 +1,22 @@
{
- "_from": "dialog-polyfill",
- "_id": "dialog-polyfill@0.5.0",
- "_inBundle": false,
- "_integrity": "sha512-fOj68T8KB6UIsDFmK7zYbmORJMLYkRmtsLM1W6wbCVUWu4Hdcud5bqbvuueTxO84JXtK9HcpCHV9vNwlWUdCIw==",
- "_location": "/dialog-polyfill",
- "_phantomChildren": {},
- "_requested": {
- "type": "tag",
- "registry": true,
- "raw": "dialog-polyfill",
- "name": "dialog-polyfill",
- "escapedName": "dialog-polyfill",
- "rawSpec": "",
- "saveSpec": null,
- "fetchSpec": "latest"
- },
- "_requiredBy": [
- "#USER",
- "/"
- ],
- "_resolved": "https://registry.npmjs.org/dialog-polyfill/-/dialog-polyfill-0.5.0.tgz",
- "_shasum": "bf67bc67abaf538e44fff80f2f71ff132befadd7",
- "_spec": "dialog-polyfill",
- "_where": "/var/www/html/hores",
- "author": {
- "name": "The Chromium Authors"
- },
- "bugs": {
- "url": "https://github.com/GoogleChrome/dialog-polyfill/issues"
- },
- "bundleDependencies": false,
- "deprecated": false,
+ "name": "dialog-polyfill",
+ "version": "0.5.4",
"description": "Polyfill for the dialog element",
+ "main": "dist/dialog-polyfill.js",
+ "module": "dist/dialog-polyfill.esm.js",
+ "repository": {
+ "type": "git",
+ "url": "https://github.com/GoogleChrome/dialog-polyfill.git"
+ },
+ "author": "The Chromium Authors",
+ "license": "BSD",
+ "homepage": "https://github.com/GoogleChrome/dialog-polyfill",
"devDependencies": {
"chai": "^4.2.0",
"mocha": "^6.0.2",
"npm-run-all": "^4.1.5",
"rollup": "^1.3.0"
},
- "homepage": "https://github.com/GoogleChrome/dialog-polyfill",
- "license": "BSD",
- "main": "dist/dialog-polyfill.js",
- "module": "dist/dialog-polyfill.esm.js",
- "name": "dialog-polyfill",
- "repository": {
- "type": "git",
- "url": "git+https://github.com/GoogleChrome/dialog-polyfill.git"
- },
"scripts": {
"build": "npm-run-all -p build:*",
"build:css": "cp dialog-polyfill.css dist/dialog-polyfill.css",
@@ -54,6 +24,5 @@
"build:umd": "rollup index.js --file dist/dialog-polyfill.js --format umd --name dialogPolyfill",
"prepublishOnly": "npm run build",
"test": "open test.html"
- },
- "version": "0.5.0"
+ }
}
diff --git a/node_modules/dialog-polyfill/suite.js b/node_modules/dialog-polyfill/suite.js
deleted file mode 100644
index 943f17d..0000000
--- a/node_modules/dialog-polyfill/suite.js
+++ /dev/null
@@ -1,790 +0,0 @@
-/*
- * Copyright 2015 Google Inc. All rights reserved.
- *
- * Licensed under the Apache License, Version 2.0 (the "License"); you may not
- * use this file except in compliance with the License. You may obtain a copy of
- * the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
- * License for the specific language governing permissions and limitations under
- * the License.
- */
-
-
-void function() {
-
- /**
- * Asserts that the displayed dialog is in the center of the screen.
- *
- * @param {HTMLDialogElement?} opt_dialog to check, or test default
- */
- function checkDialogCenter(opt_dialog) {
- var d = opt_dialog || dialog;
- var expectedTop = (window.innerHeight - d.offsetHeight) / 2;
- var expectedLeft = (window.innerWidth - d.offsetWidth) / 2;
- var rect = d.getBoundingClientRect();
- assert.closeTo(rect.top, expectedTop, 1, 'top should be nearby');
- assert.closeTo(rect.left, expectedLeft, 1, 'left should be nearby');
- }
-
- /**
- * Creates a fake KeyboardEvent.
- *
- * @param {number} keyCode to press
- * @param {string?} opt_type to use, default keydown
- * @return {!Event} event
- */
- function createKeyboardEvent(keyCode, opt_type) {
- var ev = document.createEvent('Events');
- ev.initEvent(opt_type || 'keydown', true, true);
- ev.keyCode = keyCode;
- ev.which = keyCode;
- return ev;
- }
-
- /**
- * Cleans up any passed DOM elements.
- *
- * @param {!Element} el to clean up
- * @return {!Element} the same element, for chaining
- */
- var cleanup = (function() {
- var e = [];
- teardown(function() {
- e.forEach(function(el) {
- try {
- el.close(); // try to close dialogs
- } catch (e) {}
- el.parentElement && el.parentElement.removeChild(el);
- });
- e = [];
- });
-
- return function(el) {
- e.push(el);
- return el;
- };
- })();
-
- /**
- * Creates a dialog for testing that will be cleaned up later.
- *
- * @param {string?} opt_content to be used as innerHTML
- */
- function createDialog(opt_content) {
- var dialog = document.createElement('dialog');
- dialog.innerHTML = opt_content || 'Dialog #' + (cleanup.length);
- document.body.appendChild(dialog);
- if (window.location.search == '?force') {
- dialogPolyfill.forceRegisterDialog(dialog);
- } else {
- dialogPolyfill.registerDialog(dialog);
- }
- return cleanup(dialog);
- }
-
- var dialog; // global dialog for all tests
- setup(function() {
- dialog = createDialog('Default Dialog');
- });
-
- suite('basic', function() {
- test('show and close', function() {
- assert.isFalse(dialog.hasAttribute('open'));
- dialog.show();
- assert.isTrue(dialog.hasAttribute('open'));
- assert.isTrue(dialog.open);
-
- var returnValue = 1234;
- dialog.close(returnValue);
- assert.isFalse(dialog.hasAttribute('open'));
- assert.equal(dialog.returnValue, returnValue);
-
- dialog.show();
- dialog.close();
- assert.isFalse(dialog.open);
- assert.equal(dialog.returnValue, returnValue);
- });
- test('open property', function() {
- assert.isFalse(dialog.hasAttribute('open'));
- dialog.show();
- assert.isTrue(dialog.hasAttribute('open'));
- assert.isTrue(dialog.open);
-
- dialog.open = false;
- assert.isFalse(dialog.open);
- assert.isFalse(dialog.hasAttribute('open'),
- 'open property should clear attribute');
- assert.throws(dialog.close);
-
- var overlay = document.querySelector('._dialog_overlay');
- assert.isNull(overlay);
- });
- test('show/showModal interaction', function() {
- assert.isFalse(dialog.hasAttribute('open'));
- dialog.show();
-
- // If the native dialog is being tested, show/showModal are not already
- // bound, so wrap them in helper methods for throws/doesNotThrow.
- var show = function() { dialog.show(); };
- var showModal = function() { dialog.showModal(); };
-
- assert.doesNotThrow(show);
- assert.throws(showModal);
-
- dialog.open = false;
- assert.doesNotThrow(showModal);
- assert.doesNotThrow(show); // show after showModal does nothing
- assert.throws(showModal);
- // TODO: check dialog is still modal
-
- assert.isTrue(dialog.open);
- });
- test('setAttribute reflects property', function() {
- dialog.setAttribute('open', '');
- assert.isTrue(dialog.open, 'attribute opens dialog');
- });
- test('changing open to dummy value is ignored', function() {
- dialog.showModal();
-
- dialog.setAttribute('open', 'dummy, ignored');
- assert.isTrue(dialog.open, 'dialog open with dummy open value');
-
- var overlay = document.querySelector('._dialog_overlay');
- assert(overlay, 'dialog is still modal');
- });
- test('show/showModal outside document', function() {
- dialog.open = false;
- dialog.parentNode.removeChild(dialog);
-
- assert.throws(function() { dialog.showModal(); });
-
- assert.doesNotThrow(function() { dialog.show(); });
- assert.isTrue(dialog.open, 'can open non-modal outside document');
- assert.isFalse(document.body.contains(dialog));
- });
- test('has a11y property', function() {
- assert.equal(dialog.getAttribute('role'), 'dialog', 'role should be dialog');
- });
- });
-
- suite('DOM', function() {
- setup(function(done) {
- // DOM tests wait for modal to settle, so MutationOberver doesn't coalesce attr changes
- dialog.showModal();
- window.setTimeout(done, 0);
- });
- test('DOM direct removal', function(done) {
- assert.isTrue(dialog.open);
- assert.isNotNull(document.querySelector('.backdrop'));
-
- var parentNode = dialog.parentNode;
- parentNode.removeChild(dialog);
-
- // DOMNodeRemoved defers its task a frame (since it occurs before removal, not after). This
- // doesn't effect MutationObserver, just delays the test a frame.
- window.setTimeout(function() {
- assert.isNull(document.querySelector('.backdrop'), 'dialog removal should clear modal');
-
- assert.isTrue(dialog.open, 'removed dialog should still be open');
- parentNode.appendChild(dialog);
-
- assert.isTrue(dialog.open, 're-added dialog should still be open');
- assert.isNull(document.querySelector('.backdrop'), 're-add dialog should not be modal');
-
- done();
- }, 0);
- });
- test('DOM removal inside other element', function(done) {
- var div = cleanup(document.createElement('div'));
- document.body.appendChild(div);
- div.appendChild(dialog);
-
- document.body.removeChild(div);
-
- window.setTimeout(function() {
- assert.isNull(document.querySelector('.backdrop'), 'dialog removal should clear modal');
- assert.isTrue(dialog.open, 'removed dialog should still be open');
- done();
- }, 0);
- });
- test('DOM instant remove/add', function(done) {
- var div = cleanup(document.createElement('div'));
- document.body.appendChild(div);
- dialog.parentNode.removeChild(dialog);
- div.appendChild(dialog);
-
- window.setTimeout(function() {
- assert.isNull(document.querySelector('.backdrop'), 'backdrop should disappear');
- assert.isTrue(dialog.open);
- done();
- }, 0);
- });
- });
-
- suite('position', function() {
- test('non-modal is not centered', function() {
- var el = cleanup(document.createElement('div'));
- dialog.parentNode.insertBefore(el, dialog);
- var testRect = el.getBoundingClientRect();
-
- dialog.show();
- var rect = dialog.getBoundingClientRect();
-
- assert.equal(rect.top, testRect.top, 'dialog should not be centered');
- });
- test('default modal centering', function() {
- dialog.showModal();
- checkDialogCenter();
- assert.ok(dialog.style.top, 'expected top to be set');
- dialog.close();
- assert.notOk(dialog.style.top, 'expected top to be cleared');
- });
- test('modal respects static position', function() {
- dialog.style.top = '10px';
- dialog.showModal();
-
- var rect = dialog.getBoundingClientRect();
- assert.equal(rect.top, 10);
- });
- test('modal recentering', function() {
- var pX = document.body.scrollLeft;
- var pY = document.body.scrollTop;
- var big = cleanup(document.createElement('div'));
- big.style.height = '200vh'; // 2x view height
- document.body.appendChild(big);
-
- try {
- var scrollValue = 200; // don't use incredibly large values
- dialog.showModal();
- dialog.close();
-
- window.scrollTo(0, scrollValue);
- dialog.showModal();
- checkDialogCenter(); // must be centered, even after scroll
- var rectAtScroll = dialog.getBoundingClientRect();
-
- // after scroll, we aren't recentered, check offset
- window.scrollTo(0, 0);
- var rect = dialog.getBoundingClientRect();
- assert.closeTo(rectAtScroll.top + scrollValue, rect.top, 1);
- } finally {
- window.scrollTo(pX, pY);
- }
- });
- test('clamped to top of page', function() {
- var big = cleanup(document.createElement('div'));
- big.style.height = '200vh'; // 2x view height
- document.body.appendChild(big);
- document.documentElement.scrollTop = document.documentElement.scrollHeight / 2;
-
- dialog.style.height = document.documentElement.scrollHeight + 200 + 'px';
- dialog.showModal();
-
- var visibleRect = dialog.getBoundingClientRect();
- assert.equal(visibleRect.top, 0, 'large dialog should be visible at top of page');
-
- var style = window.getComputedStyle(dialog);
- assert.equal(style.top, document.documentElement.scrollTop + 'px',
- 'large dialog should be absolutely positioned at scroll top');
- });
- });
-
- suite('backdrop', function() {
- test('backdrop div on modal', function() {
- dialog.showModal();
- var foundBackdrop = document.querySelector('.backdrop');
- assert.isNotNull(foundBackdrop);
-
- var sibling = dialog.nextElementSibling;
- assert.strictEqual(foundBackdrop, sibling);
- });
- test('no backdrop on non-modal', function() {
- dialog.show();
- assert.isNull(document.querySelector('.backdrop'));
- dialog.close();
- });
- test('backdrop click appears as dialog', function() {
- dialog.showModal();
- var backdrop = dialog.nextElementSibling;
-
- var clickFired = 0;
- var helper = function(ev) {
- assert.equal(ev.target, dialog);
- ++clickFired;
- };
-
- dialog.addEventListener('click', helper)
- backdrop.click();
- assert.equal(clickFired, 1);
- });
- test('backdrop click focuses dialog', function() {
- dialog.showModal();
- dialog.tabIndex = 0;
-
- var input = document.createElement('input');
- input.type = 'text';
- dialog.appendChild(input);
-
- // TODO: It would be nice to check `input` instead here, but there's no more reliable ways
- // to emulate a browser tab event (Firefox, Chrome etc have made it a security violation).
-
- var backdrop = dialog.nextElementSibling;
- backdrop.click();
- assert.equal(document.activeElement, dialog);
- });
- });
-
- suite('form focus', function() {
- test('non-modal inside modal is focusable', function() {
- var sub = createDialog();
- dialog.appendChild(sub);
-
- var input = document.createElement('input');
- input.type = 'text';
- sub.appendChild(input);
-
- dialog.showModal();
- sub.show();
-
- input.focus();
- assert.equal(input, document.activeElement);
- });
- test('clear focus when nothing focusable in modal', function() {
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- document.body.appendChild(input);
- input.focus();
-
- var previous = document.activeElement;
- dialog.showModal();
- assert.notEqual(previous, document.activeElement);
- });
- test('default focus on modal', function() {
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- dialog.appendChild(input);
-
- var anotherInput = cleanup(document.createElement('input'));
- anotherInput.type = 'text';
- dialog.appendChild(anotherInput);
-
- dialog.showModal();
- assert.equal(document.activeElement, input);
- });
- test('default focus on non-modal', function() {
- var div = cleanup(document.createElement('div'));
- div.tabIndex = 4;
- dialog.appendChild(div);
-
- dialog.show();
- assert.equal(document.activeElement, div);
- });
- test('autofocus element chosen', function() {
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- dialog.appendChild(input);
-
- var inputAF = cleanup(document.createElement('input'));
- inputAF.type = 'text';
- inputAF.autofocus = true;
- dialog.appendChild(inputAF);
-
- dialog.showModal();
- assert.equal(document.activeElement, inputAF);
- });
- test('child modal dialog', function() {
- dialog.showModal();
-
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- dialog.appendChild(input);
- input.focus();
- assert.equal(document.activeElement, input);
-
- // NOTE: This is a single sub-test, but all the above tests could be run
- // again in a sub-context (i.e., dialog within dialog).
- var child = createDialog();
- child.showModal();
- assert.notEqual(document.activeElement, input,
- 'additional modal dialog should clear parent focus');
-
- child.close();
- assert.notEqual(document.activeElement, input,
- 'parent focus should not be restored');
- });
- test('don\'t scroll anything into focus', function() {
- // https://github.com/GoogleChrome/dialog-polyfill/issues/119
-
- var div = cleanup(document.createElement('div'));
- document.body.appendChild(div);
-
- var inner = document.createElement('div');
- inner.style.height = '10000px';
- div.appendChild(inner);
-
- div.appendChild(dialog);
-
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- dialog.appendChild(input);
-
- var prev = document.documentElement.scrollTop;
- dialog.showModal();
- assert.equal(document.documentElement.scrollTop, prev);
- });
- });
-
- suite('top layer / inert', function() {
- test('background focus allowed on non-modal', function() {
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- document.body.appendChild(input);
- input.focus();
-
- dialog.show();
- assert.notEqual(document.activeElement, input,
- 'non-modal dialog should clear focus, even with no dialog content');
-
- document.body.focus();
- input.focus();
- assert.equal(document.activeElement, input,
- 'non-modal should allow background focus');
- });
- test('modal disallows background focus', function() {
- var input = cleanup(document.createElement('input'));
- input.type = 'text';
- document.body.appendChild(input);
-
- dialog.showModal();
- input.focus();
-
- if (!document.hasFocus()) {
- // Browsers won't trigger a focus event if they're not in the
- // foreground, so we can't intercept it. However, they'll fire one when
- // restored, before a user can get to any incorrectly focused element.
- console.warn('background focus test requires document focus');
- document.documentElement.focus();
- }
- assert.notEqual(document.activeElement, input,
- 'modal should disallow background focus');
- });
- test('overlay is a sibling of topmost dialog', function() {
- var stacking = cleanup(document.createElement('div'));
- stacking.style.opacity = 0.8; // creates stacking context
- document.body.appendChild(stacking);
- stacking.appendChild(dialog);
- dialog.showModal();
-
- var overlay = document.querySelector('._dialog_overlay');
- assert.isNotNull(overlay);
- assert.equal(overlay.parentNode, dialog.parentNode);
- });
- test('overlay is between topmost and remaining dialogs', function() {
- dialog.showModal();
-
- var other = cleanup(createDialog());
- document.body.appendChild(other);
- other.showModal();
-
- var overlay = document.querySelector('._dialog_overlay');
- assert.isNotNull(overlay);
- assert.equal(overlay.parentNode, other.parentNode);
-
- assert.isAbove(+other.style.zIndex, +overlay.style.zIndex, 'top-most dialog above overlay');
- assert.isAbove(+overlay.style.zIndex, +dialog.style.zIndex, 'overlay above other dialogs');
- });
- });
-
- suite('events', function() {
- test('close event', function() {
- var closeFired = 0;
- dialog.addEventListener('close', function() {
- ++closeFired;
- });
-
- dialog.show();
- assert.equal(closeFired, 0);
-
- dialog.close();
- assert.equal(closeFired, 1);
-
- assert.throws(dialog.close); // can't close already closed dialog
- assert.equal(closeFired, 1);
-
- dialog.showModal();
- dialog.close();
- assert.equal(closeFired, 2);
- });
- test('cancel event', function() {
- dialog.showModal();
- dialog.dispatchEvent(createKeyboardEvent(27));
- assert.isFalse(dialog.open, 'esc should close modal');
-
- var cancelFired = 0;
- dialog.addEventListener('cancel', function() {
- ++cancelFired;
- });
- dialog.showModal();
- dialog.dispatchEvent(createKeyboardEvent(27));
- assert.equal(cancelFired, 1, 'expected cancel to be fired');
- assert.isFalse(dialog.open), 'esc should close modal again';
-
- // Sanity-check that non-modals aren't effected.
- dialog.show();
- dialog.dispatchEvent(createKeyboardEvent(27));
- assert.isTrue(dialog.open, 'esc should only close modal dialog');
- assert.equal(cancelFired, 1);
- });
- test('overlay click is prevented', function() {
- dialog.showModal();
-
- var overlay = document.querySelector('._dialog_overlay');
- assert.isNotNull(overlay);
-
- var helper = function(ev) {
- throw Error('body should not be clicked');
- };
- try {
- document.body.addEventListener('click', helper);
- overlay.click();
- } finally {
- document.body.removeEventListener('click', helper);
- }
- });
- });
-
- suite('form', function() {
- test('method attribute is translated to property', function() {
- var form = document.createElement('form');
- form.method = 'dialog';
- assert.equal(form.method, 'dialog');
-
- form.method = 'PoSt';
- assert.equal(form.method, 'post');
- assert.equal(form.getAttribute('method'), 'PoSt');
- });
- test('dialog method input', function() {
- var value = 'ExpectedValue' + Math.random();
-
- var form = document.createElement('form');
- try {
- form.method = 'dialog';
- } catch (e) {
- // Setting the method directly throws an exception in <=IE9.
- form.setAttribute('method', 'dialog');
- }
- dialog.appendChild(form);
-
- var input = document.createElement('input');
- input.type = 'submit';
- input.value = value;
- form.appendChild(input);
-
- var closeCount = 0;
- dialog.addEventListener('close', function() {
- ++closeCount;
- });
-
- dialog.show();
- input.focus(); // emulate user focus action
- input.click();
-
- assert.isFalse(dialog.open);
- assert.equal(dialog.returnValue, value);
- assert.equal(closeCount, 1);
- });
- test('dialog with button preventDefault does not trigger submit', function() {
- var form = document.createElement('form');
- form.setAttribute('method', 'dialog');
- dialog.appendChild(form);
-
- var button = document.createElement('button');
- button.value = 'does not matter';
- form.appendChild(button);
- button.addEventListener('click', function(ev) {
- ev.preventDefault();
- });
-
- dialog.showModal();
- button.click();
-
- assert.isTrue(dialog.open, 'dialog should remain open');
- assert.equal(dialog.returnValue, '');
- });
- test('dialog programmatic submit does not change returnValue', function() {
- var form = document.createElement('form');
- form.setAttribute('method', 'dialog');
-
- dialog.returnValue = 'manually set'; // set before appending
- dialog.appendChild(form);
-
- dialog.showModal();
- form.submit();
- assert.isFalse(dialog.open);
-
- assert.equal(dialog.returnValue, 'manually set', 'returnValue should not change');
- });
- test('dialog method button', function() {
- var value = 'ExpectedValue' + Math.random();
-
- var form = document.createElement('form');
- form.setAttribute('method', 'dialog');
- dialog.appendChild(form);
-
- var button = document.createElement('button');
- button.value = value;
- form.appendChild(button);
-
- dialog.showModal();
- button.focus(); // emulate user focus action
- button.click();
-
- assert.isFalse(dialog.open);
- assert.equal(dialog.returnValue, value);
-
- // Clear button value, confirm textContent is not used as value.
- button.value = 'blah blah';
- button.removeAttribute('value');
- button.textContent = value;
- dialog.show();
- button.focus(); // emulate user focus action
- button.click();
-
- assert.equal(dialog.returnValue, button.value,
- 'don\'t take button textContent as value');
- });
- test('boring form inside dialog', function() {
- var form = document.createElement('form');
- dialog.appendChild(form); // don't specify method
- form.addEventListener('submit', function(ev) {
- ev.preventDefault();
- });
-
- var button = document.createElement('button');
- button.value = 'Moot';
- form.appendChild(button);
-
- dialog.showModal();
- button.focus(); // emulate user focus action
- button.click();
-
- assert.isTrue(dialog.open, 'non-dialog form should not close dialog')
- assert(!dialog.returnValue);
- });
- test('type="image" submitter', function() {
- var form = document.createElement('form');
- form.setAttribute('method', 'dialog');
- dialog.appendChild(form);
- dialog.show();
-
- var image = document.createElement('input');
- image.type = 'image';
- image.src = '';
- image.setAttribute('value', 'image should not accept value');
- form.appendChild(image);
- image.click();
-
- assert.notEqual(image.getAttribute('value'), dialog.returnValue);
- assert.equal(dialog.returnValue, '0,0');
- });
- test('form submitter across dialogs', function() {
- var form1 = document.createElement('form');
- form1.setAttribute('method', 'dialog');
- dialog.appendChild(form1);
-
- var button1 = document.createElement('button');
- button1.value = 'from form1: first value';
- form1.appendChild(button1);
- dialog.showModal();
-
- var dialog2 = createDialog();
- dialog2.returnValue = 'dialog2 default close value';
- var form2 = document.createElement('form');
- form2.setAttribute('method', 'dialog');
- dialog2.appendChild(form2);
- dialog2.showModal();
-
- button1.click();
- assert.isFalse(dialog.open);
-
- // nb. this never fires 'submit' so the .returnValue can't be wrong: is there another way
- // to submit a form that doesn't involve a click (enter implicitly 'clicks') or submit?
- form2.submit();
- assert.isFalse(dialog2.open);
-
- assert.equal(dialog2.returnValue, 'dialog2 default close value',
- 'second dialog shouldn\'t reuse formSubmitter');
- });
- });
-
- suite('order', function() {
- test('non-modal unchanged', function() {
- var one = createDialog();
- var two = createDialog();
-
- one.style.zIndex = 100;
- two.style.zIndex = 200;
- one.show();
- two.show();
-
- assert.equal(window.getComputedStyle(one).zIndex, 100);
- assert.equal(window.getComputedStyle(two).zIndex, 200);
-
- two.close();
- assert.equal(window.getComputedStyle(two).zIndex, 200);
- });
- test('modal stacking order', function() {
- dialog.showModal();
-
- // Create incorrectly-named dialogs: front has a lower z-index, and back
- // has a higher z-index.
- var front = createDialog();
- var back = createDialog();
- front.style.zIndex = 100;
- back.style.zIndex = 200;
-
- // Show back first, then front. Thus we expect back to be behind front.
- back.showModal();
- front.showModal();
-
- var zf = +window.getComputedStyle(front).zIndex;
- var zb = +window.getComputedStyle(back).zIndex;
- assert.isAbove(zf, zb, 'showModal order dictates z-index');
-
- var backBackdrop = back.nextElementSibling;
- var zbb = +window.getComputedStyle(backBackdrop).zIndex;
- assert.equal(backBackdrop.className, 'backdrop');
- assert.isBelow(zbb, zb, 'backdrop below dialog');
-
- var frontBackdrop = front.nextElementSibling;
- var zfb = +window.getComputedStyle(frontBackdrop).zIndex
- assert.equal(frontBackdrop.className, 'backdrop');
- assert.isBelow(zfb, zf,' backdrop below dialog');
-
- assert.isAbove(zfb, zb, 'front backdrop is above back dialog');
-
- front.close();
- assert.notOk(front.style.zIndex, 'modal close should clear zindex');
- });
- });
-
- suite('press tab key', function() {
- test('tab key', function() {
- var dialog = createDialog();
- dialog.showModal();
-
- document.documentElement.dispatchEvent(createKeyboardEvent(9));
-
- var ev = document.createEvent('Events');
- ev.initEvent('focus', true, true);
- document.documentElement.dispatchEvent(ev);
-
- dialog.close();
- });
- });
-}();
diff --git a/node_modules/dialog-polyfill/test-invalid.html b/node_modules/dialog-polyfill/test-invalid.html
new file mode 100644
index 0000000..70bc984
--- /dev/null
+++ b/node_modules/dialog-polyfill/test-invalid.html
@@ -0,0 +1 @@
+This page should not load.
\ No newline at end of file
diff --git a/node_modules/dialog-polyfill/test.html b/node_modules/dialog-polyfill/test.html
deleted file mode 100644
index 03e9b0b..0000000
--- a/node_modules/dialog-polyfill/test.html
+++ /dev/null
@@ -1,49 +0,0 @@
-<!--
- Copyright 2015 Google Inc. All rights reserved.
-
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
--->
-<!DOCTYPE html>
-<meta charset="UTF-8" />
-<link rel="stylesheet" href="node_modules/mocha/mocha.css" />
-<script src="node_modules/mocha/mocha.js"></script>
-<script src="node_modules/chai/chai.js"></script>
-<link rel="stylesheet" type="text/css" href="dist/dialog-polyfill.css" />
-<script src="dist/dialog-polyfill.js"></script>
-<script>
-
-var assert = chai.assert;
-mocha.setup({ ui: 'tdd' });
-
-(function() {
- var pageError = null;
-
- window.addEventListener('error', function(event) {
- pageError = event.filename + ':' + event.lineno + ' ' + event.message;
- });
-
- window.addEventListener('load', function() {
- if (pageError) {
- suite('page-script-errors', function() {
- test('no script errors on page', function() {
- assert.fail(null, null, pageError);
- });
- });
- }
- mocha.run();
- });
-})();
-
-</script>
-<div id="mocha"></div>
-<script src="suite.js"></script>
diff --git a/node_modules/dialog-polyfill/tests/actionbar.html b/node_modules/dialog-polyfill/tests/actionbar.html
deleted file mode 100644
index 3af6c75..0000000
--- a/node_modules/dialog-polyfill/tests/actionbar.html
+++ /dev/null
@@ -1,188 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta name="viewport" content="initial-scale=1" />
-<meta charset="UTF-8" />
-<head>
- <script src="../dist/dialog-polyfill.js"></script>
- <link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
- <style>
-
- dialog.actionbar {
- position: fixed;
- border: 0;
- box-sizing: border-box;
- width: 100%;
- bottom: 0;
- background: #fff;
- transform: translate(0, 100%);
- transition: transform 0.25s ease-in-out;
- margin: 0;
- padding: 0;
- box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);
- }
- dialog.actionbar.appear {
- transform: translate(0);
- }
-
- dialog.actionbar .holder {
- display: flex;
- justify-content: space-around;
- flex-flow: wrap;
- }
- dialog.actionbar .holder button {
- flex-grow: 1;
- min-width: 200px;
- margin: 8px;
- border: 0;
- font-family: Roboto, Arial, Sans-Serif;
- font-size: 23px;
- line-height: 33px;
- font-weight: 400;
- color: #666;
- border-radius: 2px;
- background: #ccc;
- display: block;
- box-sizing: border-box;
- border: 2px solid transparent;
- }
- dialog.actionbar .holder button:focus {
- outline: 0;
- border-color: rgba(0, 0, 0, 0.125);
- }
- dialog.actionbar .holder button.cancel {
- background: #fcc;
- }
-
- dialog.actionbar::backdrop {
- background: rgba(0, 0, 0, 0.25);
- opacity: 0;
- transition: opacity 0.25s ease-in-out;
- }
- dialog.actionbar + .backdrop {
- background: rgba(0, 0, 0, 0.25);
- opacity: 0;
- transition: opacity 0.25s ease-in-out;
- }
- dialog.actionbar.appear::backdrop {
- opacity: 1;
- }
- dialog.actionbar.appear + .backdrop {
- opacity: 1;
- }
-
- </style>
-</head>
-<body>
-
-<p>Builds an action bar from a modal dialog.</p>
-
-<button id="show">Show</button>
-
-<script>
-
-var ActionBar = function() {
- this.options_ = [];
- this.cancelButton_ = true;
- this.dialog_ = null;
-};
-
-ActionBar.prototype.enableCancelButton = function(value) {
- this.cancelButton_ = vaue;
-};
-
-ActionBar.prototype.addOption = function(name, opt_callback) {
- this.options_.push({name: name, callback: opt_callback || null});
-};
-
-ActionBar.prototype.show = function(opt_callback) {
- if (this.dialog_ != null) {
- throw "Can't show ActionBar, already visible";
- }
-
- var dialog = document.createElement('dialog');
- if (!('showModal' in dialog)) {
- dialogPolyfill.registerDialog(dialog);
- }
- dialog.className = 'actionbar';
-
- var holder = document.createElement('div');
- holder.className = 'holder';
- dialog.appendChild(holder);
-
- dialog.addEventListener('click', function(ev) {
- if (ev.target == dialog) {
- dialog.close();
- }
- });
-
- dialog.addEventListener('close', function() {
- opt_callback && opt_callback(dialog.returnValue);
-
- var cloneDialog = dialog.cloneNode(true);
- if (!('showModal' in cloneDialog)) {
- dialogPolyfill.registerDialog(cloneDialog);
- }
-
- document.body.appendChild(cloneDialog);
- cloneDialog.showModal();
- cloneDialog.classList.remove('appear');
- window.setTimeout(function() {
- cloneDialog.close(); // TODO: needed until DOM removal is safe
- cloneDialog.parentNode.removeChild(cloneDialog);
- }, 250);
-
- if (dialog.parentNode) {
- dialog.parentNode.removeChild(dialog);
- }
- if (this.dialog_ == dialog) {
- this.dialog_ = null;
- }
- }.bind(this));
-
- this.options_.forEach(function(option) {
- var button = document.createElement('button');
- button.textContent = option.name;
- button.addEventListener('click', function() {
- if (option.callback) {
- window.setTimeout(option.callback, 0);
- }
- dialog.close(option.name);
- });
- holder.appendChild(button);
- });
-
- if (this.cancelButton_) {
- var cancelButton = document.createElement('button');
- cancelButton.className = 'cancel';
- cancelButton.textContent = 'Cancel';
- cancelButton.addEventListener('click', function() {
- dialog.close();
- });
- holder.appendChild(cancelButton);
- }
-
- document.body.appendChild(dialog);
- dialog.showModal();
- dialog.classList.add('appear');
-
- this.dialog_ = dialog;
-};
-
-////// DEMO
-
-show.addEventListener('click', function() {
- var ab = new ActionBar();
- ab.addOption('Display');
- ab.addOption('Options');
- ab.addOption('Longer Choice');
- ab.addOption('Alert', function() {
- alert('you hit Alert');
- });
- ab.show(function(choice) {
- console.info('choice was', choice);
- });
-});
-
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/backdrop.html b/node_modules/dialog-polyfill/tests/backdrop.html
deleted file mode 100644
index 77c6d81..0000000
--- a/node_modules/dialog-polyfill/tests/backdrop.html
+++ /dev/null
@@ -1,38 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
-dialog {
- height: 100px;
- width: 100px;
-}
-
-dialog + .backdrop {
- background-color: rgba(0,255,0,0.5);
-}
-</style>
-</head>
-<body>
-<p>Test for backdrop. The test passes if you see a green background behind the
-box.</p>
-<div id="console"></div>
-<dialog></dialog>
-<button id="inert-button">Can't click me</button>
-<script>
-function writeToConsole(s) {
- var console = document.getElementById('console');
- var span = document.createElement('span');
- span.textContent = s;
- console.appendChild(span);
- console.appendChild(document.createElement('br'));
-}
-
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.showModal();
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/dialog-centering.html b/node_modules/dialog-polyfill/tests/dialog-centering.html
deleted file mode 100644
index 0eaff60..0000000
--- a/node_modules/dialog-polyfill/tests/dialog-centering.html
+++ /dev/null
@@ -1,41 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-</head>
-<body>
-<p>Test that dialog is centered in the viewport. The test passes if you see a
-box in the center of the screen.</p>
-<div id="console"></div>
-<dialog>Hello</dialog>
-<script>
-function writeToConsole(s) {
- var console = document.getElementById('console');
- var span = document.createElement('span');
- span.textContent = s;
- console.appendChild(span);
- console.appendChild(document.createElement('br'));
-}
-
-function checkCentered(dialog) {
- var expectedTop = (window.innerHeight - dialog.offsetHeight) / 2;
- var expectedLeft = (window.innerWidth - dialog.offsetWidth) / 2;
- var rect = dialog.getBoundingClientRect();
- if (rect.top == expectedTop && rect.left == expectedLeft) {
- writeToConsole('SUCCESS');
- } else {
- writeToConsole('FAIL: expected dialog top,left to be ' +
- expectedTop + ',' + expectedLeft + ' and was actually ' +
- rect.top + ',' + rect.left);
- }
-}
-
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.show();
-checkCentered(dialog);
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/dialog-recentering.html b/node_modules/dialog-polyfill/tests/dialog-recentering.html
deleted file mode 100644
index 5d09f21..0000000
--- a/node_modules/dialog-polyfill/tests/dialog-recentering.html
+++ /dev/null
@@ -1,65 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
-body {
- height: 10000px;
-}
-dialog {
- width: 100px;
-}
-#console {
- position: fixed;
-}
-#ruler {
- position: absolute;
- left: 0;
- width: 100%;
-}
-</style>
-</head>
-<body>
-<p>Test that dialog is recentered if reopened. The test passes if you see a
-box in the center of the screen.</p>
-<div id="ruler"></div>
-<div id="console"></div>
-<dialog></dialog>
-<script>
-function writeToConsole(s) {
- var console = document.getElementById('console');
- var span = document.createElement('span');
- span.textContent = s;
- console.appendChild(span);
- console.appendChild(document.createElement('br'));
-}
-
-function windowWidthMinusScrollbar() {
- return document.getElementById('ruler').offsetWidth;
-}
-
-function checkCentered(dialog) {
- var expectedTop = (window.innerHeight - dialog.offsetHeight) / 2;
- var expectedLeft = (windowWidthMinusScrollbar() - dialog.offsetWidth) / 2;
- var rect = dialog.getBoundingClientRect();
- if (rect.top == expectedTop && rect.left == expectedLeft) {
- writeToConsole('SUCCESS');
- } else {
- writeToConsole('FAIL: expected dialog top,left to be ' +
- expectedTop + ',' + expectedLeft + ' and was actually ' +
- rect.top + ',' + rect.left);
- }
-}
-
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.show();
-dialog.close();
-window.scrollTo(0, 500);
-dialog.show();
-checkCentered(dialog);
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/fancy-modal-dialog.html b/node_modules/dialog-polyfill/tests/fancy-modal-dialog.html
deleted file mode 100644
index 3e10740..0000000
--- a/node_modules/dialog-polyfill/tests/fancy-modal-dialog.html
+++ /dev/null
@@ -1,270 +0,0 @@
-<!DOCTYPE html>
-<html>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
-#close-button {
- position: absolute;
- top: 7px;
- right: 7px;
- height: 14px;
- width: 14px;
- margin: 0;
- background-image: url('resources/close_dialog.png');
-}
-
-#close-button:hover {
- background-image: url('resources/close_dialog_hover.png');
-}
-
-dialog {
-/* width: 50%;
- border-radius: 3px;
- opacity: 0;
- background: white;
- box-shadow: 0 4px 23px 5px rgba(0, 0, 0, 0.2), 0 2px 6px rgba(0,0,0,0.15);
- color: #333;
- min-width: 400px;
- padding: 0;
- z-index: 100;
- border: 0;
- padding: 15px;
-*/}
-
-dialog + .backdrop {
- position: fixed;
- top: 0;
- bottom: 0;
- left: 0;
- right: 0;
-}
-
-dialog.no-backdrop + .backdrop {
- display: none;
-}
-
-.dialog-setting {
- margin: 30px;
-}
-
-/* keyframes used to pulse the overlay */
-@-webkit-keyframes pulse {
- 0% {
- -webkit-transform: scale(1);
- }
- 40% {
- -webkit-transform: scale(1.05);
- }
- 60% {
- -webkit-transform: scale(1.05);
- }
- 100% {
- -webkit-transform: scale(1);
- }
-}
-
-.pulse {
- -webkit-animation-duration: 180ms;
- -webkit-animation-iteration-count: 1;
- -webkit-animation-name: pulse;
- -webkit-animation-timing-function: ease-in-out;
-}
-#messages {
- background-color: red;
-}
-body {
- font-family: sans-serif;
-}
-
-#open-button {
- position: fixed;
- bottom: 0;
- left: 0;
- background-color: lightgray;
- border: 1px solid;
- margin: 10px;
- padding: 15px;
-}
-
-#open-button:active {
- background-color: lime;
- margin: 9px;
-}
-
-#backdrop {
- display: none;
- position: fixed;
- top:0;
- right:0;
- bottom:0;
- left:0;
- background: rgba(0,0,0,0.5);
- z-index: 10;
-}
-.post {
- margin: 10px;
- padding: 5px;
- border: 2px solid;
-}
-
-.post-buttons {
- margin: 5px;
- text-align: right;
-}
-.post-button:hover {
- color: green;
- font-weight: bold;
-}
-</style>
-<body>
-<div id="messages"></div>
-<dialog id="dialog" class="_dialog_fixed">
- <h3>Reshare</h3>
- <input type="text" style="width: 75%" value="I am resharing this."><br>
- <div class="dialog-setting">
- <input id="click-outside-to-close" type="checkbox">
- <label for="click-outside-to-close">Close dialog upon clicking outside</label>
- </div>
- <div class="dialog-setting">
- <input id="enable-backdrop" type="checkbox" checked>
- <label for="enable-backdrop">Enable ::backdrop</label>
- </div>
- <div id="close-button"></div>
-</dialog>
-<div id="post-container"></div>
-<script>
-var dialog = document.getElementById('dialog');
-dialogPolyfill.registerDialog(dialog);
-
-function createPostButton(container, text) {
- var link = document.createElement('a');
- link.href = 'javascript:void(0)';
- link.textContent = text;
- link.className = 'post-button';
- container.appendChild(link);
- var span = document.createElement('span');
- span.textContent = ' ';
- container.appendChild(span);
- return link;
-}
-
-SampleText = 'From this spot I rise not, valiant knight, until your ' +
- 'courtesy grants me the boon I seek, one that will redound ' +
- 'to your praise and the benefit of the human race.';
-
-function createPost(container) {
- var post = document.createElement('div');
- post.className = 'post';
- var postContent = document.createElement('div');
- postContent.className = 'post-content';
- postContent.textContent = SampleText;
- post.appendChild(postContent);
- var postButtons = document.createElement('div');
- postButtons.className = 'post-buttons';
- post.appendChild(postButtons);
- var reshare = createPostButton(postButtons, 'Reshare');
- reshare.addEventListener('click', openDialog);
- var reply = createPostButton(postButtons, 'Reply');
- reply.addEventListener('click', openDialog);
- createPostButton(postButtons, 'Enjoyed this post');
-
- container.appendChild(post);
- return post;
-}
-
-function initPosts() {
- var container = document.getElementById('post-container');
- for (var i = 0; i < 25; ++i) {
- var post = createPost(container);
- }
-}
-
-function shouldCloseDialogOnClickOutside() {
- return document.getElementById('click-outside-to-close').checked;
-}
-
-function closeDialog() {
- if (dialog.open)
- dialog.close();
-}
-
-function computeCenteredTop(dialog) {
- dialog.style.transition = '';
- dialog.showModal();
- var computedTopPx = window.getComputedStyle(dialog).top;
- var computedTop = parseInt(computedTopPx.substring(0, computedTopPx.length - 2), 10);
- dialog.close();
- return computedTop;
-}
-
-function openDialog() {
- dialog.style.opacity = 0;
- dialog.style.transition = 'all 250ms ease';
-
- dialog.showModal();
-
- dialog.style.opacity = 1;
-}
-
-function pulseDialog() {
- if (!dialog.style.webkitAnimation) {
- return;
- }
- // classList isn't supported in IE8, but it's safe to use here as this only
- // runs inside WebKit/Chrome anyway.
- dialog.classList.add('pulse');
- dialog.addEventListener('webkitAnimationEnd', function(e) {
- dialog.classList.remove('pulse');
- });
-}
-
-function clickedInDialog(mouseEvent) {
- var rect = dialog.getBoundingClientRect();
- return rect.top <= mouseEvent.clientY && mouseEvent.clientY <= rect.top + rect.height
- && rect.left <= mouseEvent.clientX && mouseEvent.clientX <= rect.left + rect.width;
-}
-
-function handleClickOutsideDialog() {
- if (!shouldCloseDialogOnClickOutside()) {
- pulseDialog();
- return
- }
- closeDialog();
-}
-
-document.body.addEventListener('keydown', function(e) {
- if (e.keyCode == 27)
- closeDialog();
-});
-
-var enableBackdrop = document.getElementById('enable-backdrop');
-enableBackdrop.addEventListener('change', function(e) {
- if (this.checked) {
- dialog.className = '';
- } else {
- dialog.className = 'no-backdrop';
- }
-});
-
-var closeButton = document.getElementById('close-button');
-closeButton.addEventListener('click', function(e) { closeDialog(); });
-
-document.body.addEventListener('click', function(e) {
- console.info('document body click', e.target);
- if (!dialog.open)
- return;
- if (e.target != document.body)
- return;
- handleClickOutsideDialog();
-});
-
-dialog.addEventListener('click', function(e) {
- if (clickedInDialog(e))
- return;
- handleClickOutsideDialog();
-});
-initPosts();
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/form.html b/node_modules/dialog-polyfill/tests/form.html
deleted file mode 100644
index 75e1645..0000000
--- a/node_modules/dialog-polyfill/tests/form.html
+++ /dev/null
@@ -1,48 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-</head>
-<body>
-
- <p>
-Enter a value and submit the form. The close event will be fired and the <code>returnValue</code> of the dialog will be alerted.
- </p>
-
-<input type="text" placeholder="Focusable pre" />
-
-<dialog>
- <form method="dialog">
- <input type="text" placeholder="Enter value" />
- <input type="reset" value="Reset" />
- <input type="submit" value="Stuff" />
- <input type="submit" value="Done" />
- <button type="submit" value="Button Value Is Different Than Text">Button Submit</button>
- <button value="Regular Button Value">Button</button>
- </form>
-</dialog>
-
-<button id="show">Show Dialog</button>
-
-<input type="text" placeholder="Focusable post" />
-
-
-<script>
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.showModal();
-
-dialog.addEventListener('close', function() {
- var valueEl = dialog.querySelector('input[type="text"]');
- alert(dialog.returnValue);
-});
-
-show.addEventListener('click', function() {
- dialog.showModal();
-});
-
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/modal-dialog-stacking.html b/node_modules/dialog-polyfill/tests/modal-dialog-stacking.html
deleted file mode 100644
index e111ee4..0000000
--- a/node_modules/dialog-polyfill/tests/modal-dialog-stacking.html
+++ /dev/null
@@ -1,89 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
-dialog {
- padding: 0px;
- border: none;
- margin: 0px;
-}
-
-#bottom + .backdrop {
- top: 100px;
- left: 100px;
- height: 300px;
- width: 300px;
- background-color: rgb(0, 50, 0);
- z-index: 100; /* z-index has no effect. */
-}
-
-#bottom {
- top: 125px;
- left: 125px;
- height: 250px;
- width: 250px;
- background-color: rgb(0, 90, 0);
-}
-
-#middle + .backdrop {
- top: 150px;
- left: 150px;
- height: 200px;
- width: 200px;
- background-color: rgb(0, 130, 0);
- z-index: -100; /* z-index has no effect. */
-}
-
-#middle {
- top: 175px;
- left: 175px;
- height: 150px;
- width: 150px;
- background-color: rgb(0, 170, 0);
-}
-
-#top + .backdrop {
- top: 200px;
- left: 200px;
- height: 100px;
- width: 100px;
- background-color: rgb(0, 210, 0);
- z-index: 0; /* z-index has no effect. */
-}
-
-#top {
- top: 225px;
- left: 225px;
- height: 50px;
- width: 50px;
- background-color: rgb(0, 255, 0);
- z-index: -1000; /* z-index has no effect. */
-}
-</style>
-</head>
-<body>
-Test for modal dialog and backdrop stacking order. The test passes if there are
-6 boxes enclosed in each other, becoming increasingly smaller and brighter
-green.
-<dialog id="top"></dialog>
-<dialog id="middle"></dialog>
-<dialog id="bottom"></dialog>
-<script>
-var topDialog = document.getElementById('top');
-dialogPolyfill.registerDialog(topDialog);
-var middleDialog = document.getElementById('middle');
-dialogPolyfill.registerDialog(middleDialog);
-var bottomDialog = document.getElementById('bottom');
-dialogPolyfill.registerDialog(bottomDialog);
-
-topDialog.showModal();
-bottomDialog.showModal();
-topDialog.close(); // Just to shuffle the top layer order around a little.
-middleDialog.showModal();
-topDialog.showModal();
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/modal-dialog.html b/node_modules/dialog-polyfill/tests/modal-dialog.html
deleted file mode 100644
index be98e91..0000000
--- a/node_modules/dialog-polyfill/tests/modal-dialog.html
+++ /dev/null
@@ -1,62 +0,0 @@
-<!DOCTYPE html>
-<html tabindex="0">
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<meta name="viewport" content="width=device-width, user-scalable=no">
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
- html {
- border: 4px solid white;
- }
- html:focus {
- border-color: red;
- }
-dialog {
- width: 100px;
-}
-</style>
-</head>
-<body>
-<p>Test for modal dialog. The test passes if you can click on "Click me" button,
-but can't click or tab to the "Can't click me!" button</p>
-<div id="console"></div>
-
-<input type="text" placeholder="Test 1" tabindex="1" />
-<input type="text" placeholder="Test 2" tabindex="2" />
-<input type="text" placeholder="Test 2.1" tabindex="2" />
-<input type="text" placeholder="Test 3" tabindex="3" />
-
-<input type="text" placeholder="Before dialog" />
-<dialog>
- <button id="dialog-button">Click me</button>
- <input type="text" placeholder="Focus me" />
- <input type="text" placeholder="Focus me again" />
-</dialog>
-<button id="inert-button">Can't click me</button>
-<input type="text" placeholder="Can't focus me" />
-<script>
-function writeToConsole(s) {
- var console = document.getElementById('console');
- var span = document.createElement('span');
- span.textContent = s;
- console.appendChild(span);
- console.appendChild(document.createElement('br'));
-}
-
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.showModal();
-
-var dialogButton = document.getElementById('dialog-button');
-dialogButton.addEventListener('click', function(e) {
- writeToConsole("SUCCESS: dialog's button was clicked");
-});
-
-var inertButton = document.getElementById('inert-button');
-inertButton.addEventListener('click', function(e) {
- writeToConsole('FAIL: inert button was clicked');
-});
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/resources/close_dialog.png b/node_modules/dialog-polyfill/tests/resources/close_dialog.png
deleted file mode 100644
index 793f60e..0000000
--- a/node_modules/dialog-polyfill/tests/resources/close_dialog.png
+++ /dev/null
Binary files differ
diff --git a/node_modules/dialog-polyfill/tests/resources/close_dialog_hover.png b/node_modules/dialog-polyfill/tests/resources/close_dialog_hover.png
deleted file mode 100644
index fe896f9..0000000
--- a/node_modules/dialog-polyfill/tests/resources/close_dialog_hover.png
+++ /dev/null
Binary files differ
diff --git a/node_modules/dialog-polyfill/tests/respect-positioned-dialog.html b/node_modules/dialog-polyfill/tests/respect-positioned-dialog.html
deleted file mode 100644
index 1272136..0000000
--- a/node_modules/dialog-polyfill/tests/respect-positioned-dialog.html
+++ /dev/null
@@ -1,59 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-<style>
-dialog {
- display: none;
- height: 50px;
- width: 50px;
- padding: 0;
- margin: 0;
-}
-
-dialog.left {
- top: 100px;
- left: 100px;
-}
-
-#middle {
- top: 100px;
- left: 200px;
-}
-</style>
-</head>
-<body>
-<p>Test that dialogs with an explicit static position don't get auto-centered.
-The test passes if there are three boxes aligned in a single row.</p>
-<div id="console"></div>
-<dialog id="left" class="left"></dialog>
-<dialog id="middle"></dialog>
-<dialog id="right"></dialog>
-<script>
-function writeToConsole(s) {
- var console = document.getElementById('console');
- var span = document.createElement('span');
- span.textContent = s;
- console.appendChild(span);
- console.appendChild(document.createElement('br'));
-}
-
-var dialogs = document.querySelectorAll('dialog');
-for (var i = 0; i < dialogs.length; ++i)
- dialogPolyfill.registerDialog(dialogs[i]);
-
-var leftDialog = document.getElementById('left');
-leftDialog.show();
-
-var middleDialog = document.getElementById('middle');
-middleDialog.show();
-
-var rightDialog = document.getElementById('right');
-rightDialog.style.top = '100px';
-rightDialog.style.left = '300px';
-rightDialog.show();
-</script>
-</body>
-</html>
diff --git a/node_modules/dialog-polyfill/tests/stacking.html b/node_modules/dialog-polyfill/tests/stacking.html
deleted file mode 100644
index 54de723..0000000
--- a/node_modules/dialog-polyfill/tests/stacking.html
+++ /dev/null
@@ -1,41 +0,0 @@
-<!DOCTYPE html>
-<html>
-<meta charset='utf-8'>
-<head>
-<script src="../dist/dialog-polyfill.js"></script>
-<link rel="stylesheet" type="text/css" href="../dist/dialog-polyfill.css">
-</head>
-<body>
-
- <p>
-The dialog below is incorrectly positioned within a stacking context.
-It should generate a console warning message, and place the <code>_dialog_overlay</code> in a different place in order to try to work around the problem without moving the dialog itself.
- </p>
-
-<div style="position: absolute; top: 100px; left: 10vw; width: 80vw; height: 400px; background: blue; opacity: 0.7;">
-
-<dialog>
- <form method="dialog">
- <input type="submit" />
- </form>
- <p>
- Help, I'm inside an extra stacking context D:
- </p>
-</dialog>
-
-</div>
-
-<button id="show">Show Dialog</button>
-
-<script>
-var dialog = document.querySelector('dialog');
-dialogPolyfill.registerDialog(dialog);
-dialog.showModal();
-
-show.addEventListener('click', function() {
- dialog.showModal();
-});
-
-</script>
-</body>
-</html>