132 lines
3.0 KiB
Markdown
132 lines
3.0 KiB
Markdown
# tooltip
|
||
|
||
## Требования
|
||
|
||
- [Floating UI](https://floating-ui.com) версии ^1.0.0
|
||
|
||
## Подключение и настройка
|
||
|
||
### HTML
|
||
|
||
```html
|
||
<button type="button">Кнопка</button>
|
||
```
|
||
|
||
### JS
|
||
|
||
#### Минимальные настройки
|
||
|
||
```js
|
||
import { createTooltip } from '@advdominion/tooltip';
|
||
|
||
createTooltip(document.querySelector('button'), 'Подсказка');
|
||
```
|
||
|
||
#### Все настройки со значениями по-умолчанию
|
||
|
||
```js
|
||
import { createTooltip } from '@advdominion/tooltip';
|
||
|
||
createTooltip(document.querySelector('button'), 'Подсказка', {
|
||
appendTo: document.body,
|
||
arrow: true,
|
||
delay: [0, 0],
|
||
duration: [0, 0],
|
||
easing: ['linear', 'linear'],
|
||
hideOnClick: true,
|
||
interactive: true,
|
||
offset: [0, 8],
|
||
placement: 'top',
|
||
theme: 'light',
|
||
trigger: 'mouseenter',
|
||
virtialReference: undefined,
|
||
zIndex: '',
|
||
// Callback-функции, по-умолчанию не заданы
|
||
onCreate(instance) {},
|
||
onMount(instance) {},
|
||
onShow(instance) {},
|
||
onShown(instance) {},
|
||
onHide(instance) {},
|
||
onHidden(instance) {},
|
||
});
|
||
```
|
||
|
||
##### virtialReference
|
||
|
||
Настройка используется для кастомного позиционирования, ожидает объект с методом `getBoundingClientRect`.
|
||
|
||
Например, позиционирование всплывающей подсказки относительно виртуального элемента размером 100×50, который располагается в левой верхней точке экрана:
|
||
|
||
```js
|
||
createTooltip(document.querySelector('button'), 'Подсказка', {
|
||
virtialReference: {
|
||
getBoundingClientRect() {
|
||
return {
|
||
x: 0,
|
||
y: 0,
|
||
top: 0,
|
||
left: 0,
|
||
bottom: 50,
|
||
right: 100,
|
||
width: 100,
|
||
height: 50,
|
||
};
|
||
},
|
||
},
|
||
});
|
||
```
|
||
|
||
#### Методы
|
||
|
||
##### setContent
|
||
|
||
```js
|
||
document.querySelector('button')._tooltip.setContent('Новая подсказка');
|
||
```
|
||
|
||
##### updateOptions
|
||
|
||
```js
|
||
document.querySelector('button')._tooltip.updateOptions({ placement: 'bottom' });
|
||
```
|
||
|
||
Настройки так же можно переназначать, используя data-атрибуты:
|
||
|
||
```html
|
||
<button type="button" data-tooltip-placement="bottom">Кнопка</button>
|
||
```
|
||
|
||
### Стили
|
||
|
||
```scss
|
||
$b: '.tooltip';
|
||
|
||
#{$b} {
|
||
left: 0;
|
||
max-width: calc(100vw - 32px);
|
||
position: absolute;
|
||
top: 0;
|
||
width: max-content;
|
||
z-index: 200;
|
||
|
||
@media (min-width: 900px) {
|
||
max-width: 300px;
|
||
}
|
||
|
||
&__arrow {
|
||
#{$b}_theme_light & {
|
||
background-color: white;
|
||
height: 8px;
|
||
width: 8px;
|
||
}
|
||
}
|
||
|
||
&__container {
|
||
#{$b}_theme_light & {
|
||
background-color: white;
|
||
box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.2);
|
||
}
|
||
}
|
||
}
|
||
```
|