|
1 | 1 | <script>
|
2 | 2 | // @ts-check
|
3 |
| -
|
4 | 3 | import { onMount, onDestroy } from 'svelte';
|
5 |
| - import { computeTooltipPosition, formatVariableKey, getMinWidth, isElementInViewport } from './helpers'; |
| 4 | +
|
| 5 | + import { |
| 6 | + computeTooltipPosition, |
| 7 | + formatVariableKey, |
| 8 | + getMinWidth, |
| 9 | + isElementInViewport |
| 10 | + } from './helpers'; |
| 11 | +
|
6 | 12 | import { inverse } from './constants';
|
7 | 13 |
|
8 | 14 | /** @type {HTMLElement | null} */
|
|
59 | 65 | /** @type {boolean} */
|
60 | 66 | let visible = false;
|
61 | 67 |
|
62 |
| - /** @type {{ bottom: number, top: number, right: number, left: number }} */ |
| 68 | + /** @type {any} */ |
63 | 69 | let coords = {
|
64 | 70 | bottom: 0,
|
65 | 71 | top: 0,
|
|
73 | 79 | if (tooltipRef !== null) {
|
74 | 80 | if (isComponent && !component) {
|
75 | 81 | // @ts-ignore
|
76 |
| - component = new content.component({ target: tooltipRef, props: { action, ...content.props } }); |
| 82 | + component = new content.component({ |
| 83 | + target: tooltipRef, |
| 84 | + // @ts-ignore |
| 85 | + props: { action, ...content.props } |
| 86 | + }); |
77 | 87 | }
|
78 | 88 |
|
79 | 89 | minWidth = getMinWidth(tooltipRef, maxWidth);
|
|
88 | 98 | }
|
89 | 99 | }
|
90 | 100 |
|
91 |
| - // @ts-ignore |
92 |
| - if (autoPosition && !isElementInViewport(tooltipRef, targetElement, position)) { |
| 101 | + if ( |
| 102 | + autoPosition && |
| 103 | + // @ts-ignore |
| 104 | + !isElementInViewport(tooltipRef, targetElement, position) |
| 105 | + ) { |
93 | 106 | // @ts-ignore
|
94 | 107 | position = inverse[position];
|
95 | 108 | }
|
96 | 109 |
|
97 |
| - coords = computeTooltipPosition(targetElement, tooltipRef, position, coords); |
| 110 | + coords = computeTooltipPosition( |
| 111 | + targetElement, |
| 112 | + tooltipRef, |
| 113 | + position, |
| 114 | + coords |
| 115 | + ); |
98 | 116 |
|
99 | 117 | if (animation) {
|
100 | 118 | animationEffect = animation;
|
|
112 | 130 |
|
113 | 131 | const onHandleResize = () => {
|
114 | 132 | if (visible) {
|
115 |
| - coords = computeTooltipPosition(targetElement, tooltipRef, position, coords); |
| 133 | + coords = computeTooltipPosition( |
| 134 | + targetElement, |
| 135 | + tooltipRef, |
| 136 | + position, |
| 137 | + coords |
| 138 | + ); |
116 | 139 | }
|
117 | 140 | };
|
118 | 141 |
|
119 | 142 | $: isComponent = typeof content === 'object';
|
120 |
| - $: tooltipRef && show ? setTimeout(() => (visible = true), animationDelay) : (visible = false); |
| 143 | + $: tooltipRef && show |
| 144 | + ? setTimeout(() => (visible = true), animationDelay) |
| 145 | + : (visible = false); |
121 | 146 | </script>
|
122 | 147 |
|
123 | 148 | {#if content}
|
|
146 | 171 | --tooltip-background-color: rgba(0, 0, 0, 0.9);
|
147 | 172 | --tooltip-border-radius: 4px;
|
148 | 173 | --tooltip-box-shadow: 0 1px 20px rgba(0, 0, 0, 0.25);
|
149 |
| - --tooltip-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, |
150 |
| - 'Helvetica Neue', sans-serif; |
| 174 | + --tooltip-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, |
| 175 | + Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif; |
151 | 176 | --tooltip-font-size: 14px;
|
152 | 177 | --tooltip-font-weight: 500;
|
153 | 178 | --tooltip-line-height: 1.25rem;
|
|
219 | 244 | .tooltip.bottom {
|
220 | 245 | bottom: 0;
|
221 | 246 | left: 50%;
|
222 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(100% + var(--tooltip-offset-y))); |
| 247 | + transform: translate( |
| 248 | + calc(-50% + var(--tooltip-offset-x)), |
| 249 | + calc(100% + var(--tooltip-offset-y)) |
| 250 | + ); |
223 | 251 | }
|
224 | 252 |
|
225 | 253 | .tooltip.bottom:after {
|
|
232 | 260 | .tooltip.top {
|
233 | 261 | left: 50%;
|
234 | 262 | top: 0;
|
235 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(-100% - var(--tooltip-offset-y))); |
| 263 | + transform: translate( |
| 264 | + calc(-50% + var(--tooltip-offset-x)), |
| 265 | + calc(-100% - var(--tooltip-offset-y)) |
| 266 | + ); |
236 | 267 | }
|
237 | 268 |
|
238 | 269 | .tooltip.top:after {
|
239 |
| - border-color: var(--tooltip-background-color) transparent transparent transparent; |
| 270 | + border-color: var(--tooltip-background-color) transparent transparent |
| 271 | + transparent; |
240 | 272 | bottom: 0;
|
241 | 273 | left: 50%;
|
242 | 274 | transform: translate(-50%, 99%);
|
|
245 | 277 | .tooltip.left {
|
246 | 278 | left: 0;
|
247 | 279 | top: 50%;
|
248 |
| - transform: translate(calc(-100% - var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))); |
| 280 | + transform: translate( |
| 281 | + calc(-100% - var(--tooltip-offset-x)), |
| 282 | + calc(-50% - var(--tooltip-offset-y)) |
| 283 | + ); |
249 | 284 | }
|
250 | 285 |
|
251 | 286 | .tooltip.left:after {
|
252 |
| - border-color: transparent transparent transparent var(--tooltip-background-color); |
| 287 | + border-color: transparent transparent transparent |
| 288 | + var(--tooltip-background-color); |
253 | 289 | right: 0;
|
254 | 290 | top: 50%;
|
255 | 291 | transform: translate(99%, -50%);
|
|
258 | 294 | .tooltip.right {
|
259 | 295 | right: 0;
|
260 | 296 | top: 50%;
|
261 |
| - transform: translate(calc(100% + var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))); |
| 297 | + transform: translate( |
| 298 | + calc(100% + var(--tooltip-offset-x)), |
| 299 | + calc(-50% - var(--tooltip-offset-y)) |
| 300 | + ); |
262 | 301 | }
|
263 | 302 |
|
264 | 303 | .tooltip.right:after {
|
265 |
| - border-color: transparent var(--tooltip-background-color) transparent transparent; |
| 304 | + border-color: transparent var(--tooltip-background-color) transparent |
| 305 | + transparent; |
266 | 306 | left: 0;
|
267 | 307 | top: 50%;
|
268 | 308 | transform: translate(-99%, -50%);
|
|
342 | 382 | .tooltip.left.animation-puff {
|
343 | 383 | filter: blur(2px);
|
344 | 384 | opacity: 0;
|
345 |
| - transform: translate(calc(-100% - var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))) scale(2, 2); |
| 385 | + transform: translate( |
| 386 | + calc(-100% - var(--tooltip-offset-x)), |
| 387 | + calc(-50% - var(--tooltip-offset-y)) |
| 388 | + ) |
| 389 | + scale(2, 2); |
346 | 390 | transform-origin: 50% 50%;
|
347 | 391 | transition:
|
348 | 392 | opacity 0.25s ease-in-out,
|
|
353 | 397 | .tooltip.left.animation-puff.show {
|
354 | 398 | filter: blur(0);
|
355 | 399 | opacity: 1;
|
356 |
| - transform: translate(calc(-100% - var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))) scale(1, 1); |
| 400 | + transform: translate( |
| 401 | + calc(-100% - var(--tooltip-offset-x)), |
| 402 | + calc(-50% - var(--tooltip-offset-y)) |
| 403 | + ) |
| 404 | + scale(1, 1); |
357 | 405 | }
|
358 | 406 |
|
359 | 407 | .tooltip.right.animation-puff {
|
360 | 408 | filter: blur(2px);
|
361 | 409 | opacity: 0;
|
362 |
| - transform: translate(calc(100% + var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))) scale(2, 2); |
| 410 | + transform: translate( |
| 411 | + calc(100% + var(--tooltip-offset-x)), |
| 412 | + calc(-50% - var(--tooltip-offset-y)) |
| 413 | + ) |
| 414 | + scale(2, 2); |
363 | 415 | transform-origin: 50% 50%;
|
364 | 416 | transition:
|
365 | 417 | opacity 0.25s ease-in-out,
|
|
370 | 422 | .tooltip.right.animation-puff.show {
|
371 | 423 | filter: blur(0);
|
372 | 424 | opacity: 1;
|
373 |
| - transform: translate(calc(100% + var(--tooltip-offset-x)), calc(-50% - var(--tooltip-offset-y))) scale(1, 1); |
| 425 | + transform: translate( |
| 426 | + calc(100% + var(--tooltip-offset-x)), |
| 427 | + calc(-50% - var(--tooltip-offset-y)) |
| 428 | + ) |
| 429 | + scale(1, 1); |
374 | 430 | }
|
375 | 431 |
|
376 | 432 | .tooltip.top.animation-puff {
|
377 | 433 | filter: blur(2px);
|
378 | 434 | opacity: 0;
|
379 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(-100% - var(--tooltip-offset-y))) scale(2, 2); |
| 435 | + transform: translate( |
| 436 | + calc(-50% + var(--tooltip-offset-x)), |
| 437 | + calc(-100% - var(--tooltip-offset-y)) |
| 438 | + ) |
| 439 | + scale(2, 2); |
380 | 440 | transform-origin: 50% 50%;
|
381 | 441 | transition:
|
382 | 442 | opacity 0.25s ease-in-out,
|
|
387 | 447 | .tooltip.top.animation-puff.show {
|
388 | 448 | filter: blur(0);
|
389 | 449 | opacity: 1;
|
390 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(-100% - var(--tooltip-offset-y))) scale(1, 1); |
| 450 | + transform: translate( |
| 451 | + calc(-50% + var(--tooltip-offset-x)), |
| 452 | + calc(-100% - var(--tooltip-offset-y)) |
| 453 | + ) |
| 454 | + scale(1, 1); |
391 | 455 | }
|
392 | 456 |
|
393 | 457 | .tooltip.bottom.animation-puff {
|
394 | 458 | filter: blur(2px);
|
395 | 459 | opacity: 0;
|
396 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(100% + var(--tooltip-offset-y))) scale(2, 2); |
| 460 | + transform: translate( |
| 461 | + calc(-50% + var(--tooltip-offset-x)), |
| 462 | + calc(100% + var(--tooltip-offset-y)) |
| 463 | + ) |
| 464 | + scale(2, 2); |
397 | 465 | transform-origin: 50% 50%;
|
398 | 466 | transition:
|
399 | 467 | opacity 0.25s ease-in-out,
|
|
404 | 472 | .tooltip.bottom.animation-puff.show {
|
405 | 473 | filter: blur(0);
|
406 | 474 | opacity: 1;
|
407 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(100% + var(--tooltip-offset-y))) scale(1, 1); |
| 475 | + transform: translate( |
| 476 | + calc(-50% + var(--tooltip-offset-x)), |
| 477 | + calc(100% + var(--tooltip-offset-y)) |
| 478 | + ) |
| 479 | + scale(1, 1); |
408 | 480 | }
|
409 | 481 |
|
410 | 482 | /* Bounce */
|
411 | 483 |
|
412 | 484 | .tooltip.left.animation-bounce {
|
413 | 485 | opacity: 0;
|
414 |
| - transform: translate(calc(-100% - var(--tooltip-offset-x)), calc(-50% + var(--tooltip-offset-y))) scale(1.2, 1.2); |
| 486 | + transform: translate( |
| 487 | + calc(-100% - var(--tooltip-offset-x)), |
| 488 | + calc(-50% + var(--tooltip-offset-y)) |
| 489 | + ) |
| 490 | + scale(1.2, 1.2); |
415 | 491 | transform-origin: 50% 50%;
|
416 | 492 | transition:
|
417 | 493 | opacity 0.25s ease-in-out,
|
|
420 | 496 |
|
421 | 497 | .tooltip.left.animation-bounce.show {
|
422 | 498 | opacity: 1;
|
423 |
| - transform: translate(calc(-100% - var(--tooltip-offset-x)), calc(-50% + var(--tooltip-offset-y))) scale(1, 1); |
| 499 | + transform: translate( |
| 500 | + calc(-100% - var(--tooltip-offset-x)), |
| 501 | + calc(-50% + var(--tooltip-offset-y)) |
| 502 | + ) |
| 503 | + scale(1, 1); |
424 | 504 | }
|
425 | 505 |
|
426 | 506 | .tooltip.right.animation-bounce {
|
427 | 507 | opacity: 0;
|
428 |
| - transform: translate(calc(100% + var(--tooltip-offset-x)), calc(-50% + var(--tooltip-offset-y))) scale(1.2, 1.2); |
| 508 | + transform: translate( |
| 509 | + calc(100% + var(--tooltip-offset-x)), |
| 510 | + calc(-50% + var(--tooltip-offset-y)) |
| 511 | + ) |
| 512 | + scale(1.2, 1.2); |
429 | 513 | transform-origin: 50% 50%;
|
430 | 514 | transition:
|
431 | 515 | opacity 0.25s ease-in-out,
|
|
434 | 518 |
|
435 | 519 | .tooltip.right.animation-bounce.show {
|
436 | 520 | opacity: 1;
|
437 |
| - transform: translate(calc(100% + var(--tooltip-offset-x)), calc(-50% + var(--tooltip-offset-y))) scale(1, 1); |
| 521 | + transform: translate( |
| 522 | + calc(100% + var(--tooltip-offset-x)), |
| 523 | + calc(-50% + var(--tooltip-offset-y)) |
| 524 | + ) |
| 525 | + scale(1, 1); |
438 | 526 | }
|
439 | 527 |
|
440 | 528 | .tooltip.top.animation-bounce {
|
441 | 529 | opacity: 0;
|
442 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(-100% - var(--tooltip-offset-y))) scale(1.2, 1.2); |
| 530 | + transform: translate( |
| 531 | + calc(-50% + var(--tooltip-offset-x)), |
| 532 | + calc(-100% - var(--tooltip-offset-y)) |
| 533 | + ) |
| 534 | + scale(1.2, 1.2); |
443 | 535 | transform-origin: 50% 50%;
|
444 | 536 | transition:
|
445 | 537 | opacity 0.25s ease-in-out,
|
|
448 | 540 |
|
449 | 541 | .tooltip.top.animation-bounce.show {
|
450 | 542 | opacity: 1;
|
451 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(-100% - var(--tooltip-offset-y))) scale(1, 1); |
| 543 | + transform: translate( |
| 544 | + calc(-50% + var(--tooltip-offset-x)), |
| 545 | + calc(-100% - var(--tooltip-offset-y)) |
| 546 | + ) |
| 547 | + scale(1, 1); |
452 | 548 | }
|
453 | 549 |
|
454 | 550 | .tooltip.bottom.animation-bounce {
|
455 | 551 | opacity: 0;
|
456 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(100% + var(--tooltip-offset-y))) scale(1.2, 1.2); |
| 552 | + transform: translate( |
| 553 | + calc(-50% + var(--tooltip-offset-x)), |
| 554 | + calc(100% + var(--tooltip-offset-y)) |
| 555 | + ) |
| 556 | + scale(1.2, 1.2); |
457 | 557 | transform-origin: 50% 50%;
|
458 | 558 | transition:
|
459 | 559 | opacity 0.25s ease-in-out,
|
|
462 | 562 |
|
463 | 563 | .tooltip.bottom.animation-bounce.show {
|
464 | 564 | opacity: 1;
|
465 |
| - transform: translate(calc(-50% + var(--tooltip-offset-x)), calc(100% + var(--tooltip-offset-y))) scale(1, 1); |
| 565 | + transform: translate( |
| 566 | + calc(-50% + var(--tooltip-offset-x)), |
| 567 | + calc(100% + var(--tooltip-offset-y)) |
| 568 | + ) |
| 569 | + scale(1, 1); |
466 | 570 | }
|
467 | 571 | </style>
|
0 commit comments