consul/ui/packages/consul-ui/app/utils/dom/click-first-anchor.js
John Cowen 6589cbbd0d
ui: Move to Workspaced Structure (#8994)
* ui: Add the most basic workspace root in /ui

* We already have a LICENSE file in the repository root

* Change directory path in build scripts ui-v2 -> ui

* Make yarn install flags configurable from elsewhere

* Minimal workspace root makefile

* Call the new docker specific target

* Update yarn in the docker build image

* Reconfigure the netlify target and move to the higher makefile

* Move ui-v2 -> ui/packages/consul-ui

* Change repo root to refleect new folder structure

* Temporarily don't hoist consul-api-double

* Fixup CI configuration

* Fixup lint errors

* Fixup Netlify target
2020-10-21 15:23:16 +01:00

39 lines
1.1 KiB
JavaScript

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);
}
};
}