Compare commits
5 Commits
Author | SHA1 | Date |
---|---|---|
|
de089b6348 | |
|
06039e55c9 | |
|
4a8b4405b2 | |
|
eb664afa8f | |
|
06b0cfc20a |
12
CHANGELOG.md
12
CHANGELOG.md
|
@ -1,3 +1,15 @@
|
||||||
|
## v3.0.1
|
||||||
|
|
||||||
|
- Исправлена работа событий
|
||||||
|
|
||||||
|
## v3.0.0
|
||||||
|
|
||||||
|
- Исправлено название опции с `virtialReference` на `virtualReference`
|
||||||
|
|
||||||
|
## v2.1.0
|
||||||
|
|
||||||
|
- Для опции `appendTo` добавлена возможность указать значение `parent`
|
||||||
|
|
||||||
## v2.0.0
|
## v2.0.0
|
||||||
|
|
||||||
- К `_tooltip.$tooltip` добавлено свойство `_reference` для доступа к элементу, на котором был вызван `createTooltip`
|
- К `_tooltip.$tooltip` добавлено свойство `_reference` для доступа к элементу, на котором был вызван `createTooltip`
|
||||||
|
|
|
@ -44,7 +44,7 @@ createTooltip(document.querySelector('button'), 'Подсказка', {
|
||||||
shiftPadding: [8, 0],
|
shiftPadding: [8, 0],
|
||||||
theme: 'light',
|
theme: 'light',
|
||||||
trigger: 'mouseenter',
|
trigger: 'mouseenter',
|
||||||
virtialReference: undefined,
|
virtualReference: undefined,
|
||||||
zIndex: '',
|
zIndex: '',
|
||||||
// Callback-функции, по-умолчанию не заданы
|
// Callback-функции, по-умолчанию не заданы
|
||||||
onCreate(instance) {},
|
onCreate(instance) {},
|
||||||
|
@ -56,7 +56,7 @@ createTooltip(document.querySelector('button'), 'Подсказка', {
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
||||||
##### virtialReference
|
##### virtualReference
|
||||||
|
|
||||||
Настройка используется для кастомного позиционирования, ожидает объект с методом `getBoundingClientRect`.
|
Настройка используется для кастомного позиционирования, ожидает объект с методом `getBoundingClientRect`.
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ createTooltip(document.querySelector('button'), 'Подсказка', {
|
||||||
|
|
||||||
```js
|
```js
|
||||||
createTooltip(document.querySelector('button'), 'Подсказка', {
|
createTooltip(document.querySelector('button'), 'Подсказка', {
|
||||||
virtialReference: {
|
virtualReference: {
|
||||||
getBoundingClientRect() {
|
getBoundingClientRect() {
|
||||||
return {
|
return {
|
||||||
x: 0,
|
x: 0,
|
||||||
|
|
69
index.js
69
index.js
|
@ -26,7 +26,7 @@ export const createTooltip = ($el, content, options) => {
|
||||||
shiftPadding: [8, 0],
|
shiftPadding: [8, 0],
|
||||||
theme: 'light',
|
theme: 'light',
|
||||||
trigger: 'mouseenter',
|
trigger: 'mouseenter',
|
||||||
virtialReference: undefined,
|
virtualReference: undefined,
|
||||||
zIndex: '',
|
zIndex: '',
|
||||||
...options,
|
...options,
|
||||||
};
|
};
|
||||||
|
@ -42,6 +42,7 @@ export const createTooltip = ($el, content, options) => {
|
||||||
};
|
};
|
||||||
|
|
||||||
setOptionFromDataAttribute('tooltipAnimation');
|
setOptionFromDataAttribute('tooltipAnimation');
|
||||||
|
setOptionFromDataAttribute('tooltipAppendTo');
|
||||||
setOptionFromDataAttribute('tooltipArrow');
|
setOptionFromDataAttribute('tooltipArrow');
|
||||||
setOptionFromDataAttribute('tooltipDelay');
|
setOptionFromDataAttribute('tooltipDelay');
|
||||||
setOptionFromDataAttribute('tooltipDuration');
|
setOptionFromDataAttribute('tooltipDuration');
|
||||||
|
@ -166,7 +167,7 @@ export const createTooltip = ($el, content, options) => {
|
||||||
const $arrow = $el._tooltip.$tooltip.querySelector('.tooltip__arrow');
|
const $arrow = $el._tooltip.$tooltip.querySelector('.tooltip__arrow');
|
||||||
|
|
||||||
const { x, y, placement, middlewareData } = await computePosition(
|
const { x, y, placement, middlewareData } = await computePosition(
|
||||||
options.virtialReference ?? $el,
|
options.virtualReference ?? $el,
|
||||||
$el._tooltip.$tooltip,
|
$el._tooltip.$tooltip,
|
||||||
{
|
{
|
||||||
placement: options.placement,
|
placement: options.placement,
|
||||||
|
@ -280,10 +281,26 @@ export const createTooltip = ($el, content, options) => {
|
||||||
showTimeout = setTimeout(
|
showTimeout = setTimeout(
|
||||||
async () => {
|
async () => {
|
||||||
if (!$el._tooltip.isVisible) {
|
if (!$el._tooltip.isVisible) {
|
||||||
|
if (options.appendTo === 'parent') {
|
||||||
|
$el.parentElement.append($el._tooltip.$tooltip);
|
||||||
|
} else {
|
||||||
options.appendTo.append($el._tooltip.$tooltip);
|
options.appendTo.append($el._tooltip.$tooltip);
|
||||||
|
}
|
||||||
$el._tooltip.isVisible = true;
|
$el._tooltip.isVisible = true;
|
||||||
autoUpdateCleanup = autoUpdate($el, $el._tooltip.$tooltip, $el._tooltip.updatePosition);
|
autoUpdateCleanup = autoUpdate($el, $el._tooltip.$tooltip, $el._tooltip.updatePosition);
|
||||||
|
|
||||||
|
if (
|
||||||
|
options.hideOnClick &&
|
||||||
|
(options.trigger.includes('click') || options.trigger.includes('manual'))
|
||||||
|
) {
|
||||||
|
document.body.addEventListener('click', $el._tooltip.hideOnClickListener);
|
||||||
|
listeners.push({
|
||||||
|
el: document.body,
|
||||||
|
event: 'click',
|
||||||
|
listener: $el._tooltip.hideOnClickListener,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
if (options.onShow) {
|
if (options.onShow) {
|
||||||
options.onShow($el._tooltip);
|
options.onShow($el._tooltip);
|
||||||
}
|
}
|
||||||
|
@ -332,39 +349,29 @@ export const createTooltip = ($el, content, options) => {
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
const hideOnClickListener = ({ target }) => {
|
$el._tooltip.hideOnClickListener = ({ target }) => {
|
||||||
if (
|
if (
|
||||||
$el._tooltip.isVisible &&
|
$el._tooltip.isVisible &&
|
||||||
(options.hideOnClick === 'all' ||
|
(options.hideOnClick === 'all' ||
|
||||||
$el.contains(target) ||
|
$el.contains(target) ||
|
||||||
(options.hideOnClick !== 'toggle' && !$el._tooltip.$tooltip.contains(target)))
|
(options.hideOnClick !== 'toggle' && !$el._tooltip.$tooltip.contains(target)))
|
||||||
) {
|
) {
|
||||||
document.body.removeEventListener('click', hideOnClickListener);
|
document.body.removeEventListener('click', $el._tooltip.hideOnClickListener);
|
||||||
$el._tooltip.hide();
|
$el._tooltip.hide();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const clickListener = () => {
|
$el._tooltip.clickListener = () => {
|
||||||
if (!$el._tooltip.isVisible) {
|
if (!$el._tooltip.isVisible) {
|
||||||
$el._tooltip.show();
|
$el._tooltip.show();
|
||||||
if (options.hideOnClick) {
|
|
||||||
setTimeout(() => {
|
|
||||||
document.body.addEventListener('click', hideOnClickListener);
|
|
||||||
listeners.push({
|
|
||||||
el: document.body,
|
|
||||||
event: 'click',
|
|
||||||
listener: hideOnClickListener,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const mouseEnterListener = () => {
|
$el._tooltip.mouseEnterListener = () => {
|
||||||
$el._tooltip.show();
|
$el._tooltip.show();
|
||||||
};
|
};
|
||||||
|
|
||||||
const mouseLeaveListener = ({ relatedTarget }) => {
|
$el._tooltip.mouseLeaveListener = ({ relatedTarget }) => {
|
||||||
if (options.interactive) {
|
if (options.interactive) {
|
||||||
if ($el._tooltip.$tooltip.contains(relatedTarget)) {
|
if ($el._tooltip.$tooltip.contains(relatedTarget)) {
|
||||||
$el._tooltip.$tooltip.addEventListener(
|
$el._tooltip.$tooltip.addEventListener(
|
||||||
|
@ -390,48 +397,36 @@ export const createTooltip = ($el, content, options) => {
|
||||||
for (const trigger of options.trigger.split(' ')) {
|
for (const trigger of options.trigger.split(' ')) {
|
||||||
switch (trigger) {
|
switch (trigger) {
|
||||||
case 'mouseenter': {
|
case 'mouseenter': {
|
||||||
$el.addEventListener('mouseenter', mouseEnterListener);
|
$el.addEventListener('mouseenter', $el._tooltip.mouseEnterListener);
|
||||||
listeners.push({
|
listeners.push({
|
||||||
el: $el,
|
el: $el,
|
||||||
event: 'mouseenter',
|
event: 'mouseenter',
|
||||||
listener: mouseEnterListener,
|
listener: $el._tooltip.mouseEnterListener,
|
||||||
});
|
});
|
||||||
|
|
||||||
$el.addEventListener('mouseleave', mouseLeaveListener);
|
$el.addEventListener('mouseleave', $el._tooltip.mouseLeaveListener);
|
||||||
listeners.push({
|
listeners.push({
|
||||||
el: $el,
|
el: $el,
|
||||||
event: 'mouseleave',
|
event: 'mouseleave',
|
||||||
listener: mouseLeaveListener,
|
listener: $el._tooltip.mouseLeaveListener,
|
||||||
});
|
});
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'click': {
|
case 'click': {
|
||||||
$el.addEventListener('click', clickListener);
|
$el.addEventListener('click', $el._tooltip.clickListener);
|
||||||
listeners.push({
|
listeners.push({
|
||||||
el: $el,
|
el: $el,
|
||||||
event: 'click',
|
event: 'click',
|
||||||
listener: clickListener,
|
listener: $el._tooltip.clickListener,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!options.interactive) {
|
if (!options.interactive) {
|
||||||
$el.addEventListener('mouseleave', mouseLeaveListener);
|
$el.addEventListener('mouseleave', $el._tooltip.mouseLeaveListener);
|
||||||
listeners.push({
|
listeners.push({
|
||||||
el: $el,
|
el: $el,
|
||||||
event: 'mouseleave',
|
event: 'mouseleave',
|
||||||
listener: mouseLeaveListener,
|
listener: $el._tooltip.mouseLeaveListener,
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'manual': {
|
|
||||||
if (options.hideOnClick) {
|
|
||||||
document.body.addEventListener('click', hideOnClickListener);
|
|
||||||
listeners.push({
|
|
||||||
el: document.body,
|
|
||||||
event: 'click',
|
|
||||||
listener: hideOnClickListener,
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "@advdominion/tooltip",
|
"name": "@advdominion/tooltip",
|
||||||
"version": "2.0.0",
|
"version": "3.0.1",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"packageManager": "yarn@4.5.3",
|
"packageManager": "yarn@4.5.3",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
|
|
Loading…
Reference in New Issue