consul/ui/packages/consul-ui/app/utils/dom/click-first-anchor.js

44 lines
1.2 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: MPL-2.0
*/
const clickEvent = function ($el) {
['mousedown', 'mouseup', 'click']
.map(function (type) {
return new MouseEvent(type, {
bubbles: true,
cancelable: true,
view: window,
});
})
.forEach(function (event) {
$el.dispatchEvent(event);
});
};
export default function (closest, click = clickEvent) {
// TODO: Decide whether we should use `e` for ease
// or `target`/`el`
// TODO: currently, using a string stopElement to tell the func
// where to stop looking and currenlty default is 'tr' because
// it's backwards compatible.
// Long-term this func shouldn't default to 'tr'
return function (e, stopElement = 'tr') {
// click on row functionality
// so if you click the actual row but not a link
// find the first link and fire that instead
const name = e.target.nodeName.toLowerCase();
switch (name) {
case 'input':
case 'label':
case 'a':
case 'button':
return;
}
const $a = closest(stopElement, e.target).querySelector('a');
if ($a) {
click($a);
}
};
}