You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hydro/packages/ui-default/components/tooltip/Tooltip.js

52 lines
1.1 KiB
JavaScript

import _ from 'lodash';
import Drop from 'tether-drop';
import DOMAttachedObject from 'vj/components/DOMAttachedObject';
export default class Tooltip extends DOMAttachedObject {
static DOMAttachKey = 'vjTooltipInstance';
constructor($dom, options = {}) {
super($dom, true);
this.dropRemoved = false;
this.drop = new Drop({
target: $dom[0],
classes: 'tooltip',
position: options.position || 'top center',
openOn: 'hover',
constrainToWindow: true,
constrainToScrollParent: false,
content: $dom.attr('data-tooltip'),
});
this.isOpen = false;
this.drop.on('open', this.onOpen, this);
this.drop.on('close', this.onClose, this);
this.delayDetach = _.debounce(this.detach.bind(this), 200);
}
onOpen() {
this.delayDetach.cancel();
}
onClose() {
this.delayDetach();
}
detach() {
if (this.detached) {
return;
}
super.detach();
this.drop.destroy();
}
close() {
this.drop.close();
}
open() {
this.drop.open();
}
}
_.assign(Tooltip, DOMAttachedObject);