Skip to content

Commit

Permalink
fix possible .submitter being null
Browse files Browse the repository at this point in the history
  • Loading branch information
samthor committed Jan 11, 2021
1 parent 75df500 commit 90764c6
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 22 deletions.
16 changes: 9 additions & 7 deletions dist/dialog-polyfill.esm.js
Original file line number Diff line number Diff line change
Expand Up @@ -153,14 +153,15 @@ function findFocusableElementWithin(hostElement) {
/**
* Determines if an element is attached to the DOM.
* @param {Element} element to check
* @return {Boolean} whether the element is in DOM
* @return {boolean} whether the element is in DOM
*/
function isConnected(element) {
return element.isConnected || document.body.contains(element);
}

/**
* @param {!Event} event
* @return {?Element}
*/
function findFormSubmitter(event) {
if (event.submitter) {
Expand All @@ -173,7 +174,7 @@ function findFormSubmitter(event) {
}

var submitter = dialogPolyfill.formSubmitter;
if (!submitter) {
if (!submitter || submitter.form !== form) {
var target = event.target;
var root = ('getRootNode' in target && target.getRootNode() || document);
submitter = root.activeElement;
Expand All @@ -195,7 +196,7 @@ function maybeHandleSubmit(event) {
var form = /** @type {!HTMLFormElement} */ (event.target);

// We'd have a value if we clicked on an imagemap.
var value = dialogPolyfill.useValue;
var value = dialogPolyfill.imagemapUseValue;
var submitter = findFormSubmitter(event);
if (value === null && submitter) {
value = submitter.value;
Expand All @@ -215,7 +216,8 @@ function maybeHandleSubmit(event) {
}
event.preventDefault();

if (submitter) {
if (value != null) {
// nb. we explicitly check against null/undefined
dialog.close(value);
} else {
dialog.close();
Expand Down Expand Up @@ -751,7 +753,7 @@ dialogPolyfill.DialogManager.prototype.removeDialog = function(dpi) {

dialogPolyfill.dm = new dialogPolyfill.DialogManager();
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;

/**
* Installs global handlers, such as click listers and native method overrides. These are needed
Expand Down Expand Up @@ -796,7 +798,7 @@ if (window.HTMLDialogElement === undefined) {
*/
document.addEventListener('click', function(ev) {
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission

var target = /** @type {Element} */ (ev.target);
Expand All @@ -810,7 +812,7 @@ if (window.HTMLDialogElement === undefined) {
if (!valid) {
if (!(target.localName === 'input' && target.type === 'image')) { return; }
// this is a <input type="image">, which can submit forms
dialogPolyfill.useValue = ev.offsetX + ',' + ev.offsetY;
dialogPolyfill.imagemapUseValue = ev.offsetX + ',' + ev.offsetY;
}

var dialog = findNearestDialog(target);
Expand Down
16 changes: 9 additions & 7 deletions dist/dialog-polyfill.js
Original file line number Diff line number Diff line change
Expand Up @@ -159,14 +159,15 @@
/**
* Determines if an element is attached to the DOM.
* @param {Element} element to check
* @return {Boolean} whether the element is in DOM
* @return {boolean} whether the element is in DOM
*/
function isConnected(element) {
return element.isConnected || document.body.contains(element);
}

/**
* @param {!Event} event
* @return {?Element}
*/
function findFormSubmitter(event) {
if (event.submitter) {
Expand All @@ -179,7 +180,7 @@
}

var submitter = dialogPolyfill.formSubmitter;
if (!submitter) {
if (!submitter || submitter.form !== form) {
var target = event.target;
var root = ('getRootNode' in target && target.getRootNode() || document);
submitter = root.activeElement;
Expand All @@ -201,7 +202,7 @@
var form = /** @type {!HTMLFormElement} */ (event.target);

// We'd have a value if we clicked on an imagemap.
var value = dialogPolyfill.useValue;
var value = dialogPolyfill.imagemapUseValue;
var submitter = findFormSubmitter(event);
if (value === null && submitter) {
value = submitter.value;
Expand All @@ -221,7 +222,8 @@
}
event.preventDefault();

if (submitter) {
if (value != null) {
// nb. we explicitly check against null/undefined
dialog.close(value);
} else {
dialog.close();
Expand Down Expand Up @@ -757,7 +759,7 @@

dialogPolyfill.dm = new dialogPolyfill.DialogManager();
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;

/**
* Installs global handlers, such as click listers and native method overrides. These are needed
Expand Down Expand Up @@ -802,7 +804,7 @@
*/
document.addEventListener('click', function(ev) {
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission

var target = /** @type {Element} */ (ev.target);
Expand All @@ -816,7 +818,7 @@
if (!valid) {
if (!(target.localName === 'input' && target.type === 'image')) { return; }
// this is a <input type="image">, which can submit forms
dialogPolyfill.useValue = ev.offsetX + ',' + ev.offsetY;
dialogPolyfill.imagemapUseValue = ev.offsetX + ',' + ev.offsetY;
}

var dialog = findNearestDialog(target);
Expand Down
16 changes: 9 additions & 7 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -154,14 +154,15 @@ function findFocusableElementWithin(hostElement) {
/**
* Determines if an element is attached to the DOM.
* @param {Element} element to check
* @return {Boolean} whether the element is in DOM
* @return {boolean} whether the element is in DOM
*/
function isConnected(element) {
return element.isConnected || document.body.contains(element);
}

/**
* @param {!Event} event
* @return {?Element}
*/
function findFormSubmitter(event) {
if (event.submitter) {
Expand All @@ -174,7 +175,7 @@ function findFormSubmitter(event) {
}

var submitter = dialogPolyfill.formSubmitter;
if (!submitter) {
if (!submitter || submitter.form !== form) {
var target = event.target;
var root = ('getRootNode' in target && target.getRootNode() || document);
submitter = root.activeElement;
Expand All @@ -196,7 +197,7 @@ function maybeHandleSubmit(event) {
var form = /** @type {!HTMLFormElement} */ (event.target);

// We'd have a value if we clicked on an imagemap.
var value = dialogPolyfill.useValue;
var value = dialogPolyfill.imagemapUseValue;
var submitter = findFormSubmitter(event);
if (value === null && submitter) {
value = submitter.value;
Expand All @@ -216,7 +217,8 @@ function maybeHandleSubmit(event) {
}
event.preventDefault();

if (submitter) {
if (value != null) {
// nb. we explicitly check against null/undefined
dialog.close(value);
} else {
dialog.close();
Expand Down Expand Up @@ -754,7 +756,7 @@ dialogPolyfill.DialogManager.prototype.removeDialog = function(dpi) {

dialogPolyfill.dm = new dialogPolyfill.DialogManager();
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;

/**
* Installs global handlers, such as click listers and native method overrides. These are needed
Expand Down Expand Up @@ -799,7 +801,7 @@ if (window.HTMLDialogElement === undefined) {
*/
document.addEventListener('click', function(ev) {
dialogPolyfill.formSubmitter = null;
dialogPolyfill.useValue = null;
dialogPolyfill.imagemapUseValue = null;
if (ev.defaultPrevented) { return; } // e.g. a submit which prevents default submission

var target = /** @type {Element} */ (ev.target);
Expand All @@ -813,7 +815,7 @@ if (window.HTMLDialogElement === undefined) {
if (!valid) {
if (!(target.localName === 'input' && target.type === 'image')) { return; }
// this is a <input type="image">, which can submit forms
dialogPolyfill.useValue = ev.offsetX + ',' + ev.offsetY;
dialogPolyfill.imagemapUseValue = ev.offsetX + ',' + ev.offsetY;
}

var dialog = findNearestDialog(target);
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "dialog-polyfill",
"version": "0.5.5",
"version": "0.5.6",
"description": "Polyfill for the dialog element",
"main": "dist/dialog-polyfill.js",
"module": "dist/dialog-polyfill.esm.js",
Expand Down

0 comments on commit 90764c6

Please sign in to comment.