open-webui/src/lib/components/common/Tooltip.svelte

67 lines
1.4 KiB
Svelte
Raw Normal View History

<script lang="ts">
import DOMPurify from 'dompurify';
import { onDestroy } from 'svelte';
2024-06-15 10:32:18 +00:00
import tippy from 'tippy.js';
2025-07-22 07:19:40 +00:00
export let elementId = '';
export let placement = 'top';
export let content = `I'm a tooltip!`;
2024-03-02 09:27:01 +00:00
export let touch = true;
export let className = 'flex';
2024-07-08 22:26:43 +00:00
export let theme = '';
2025-01-12 04:23:26 +00:00
export let offset = [0, 4];
export let allowHTML = true;
2024-09-23 13:48:12 +00:00
export let tippyOptions = {};
2025-08-08 10:04:44 +00:00
export let interactive = false;
let tooltipElement;
let tooltipInstance;
2025-07-22 07:19:40 +00:00
$: if (tooltipElement && (content || elementId)) {
let tooltipContent = null;
if (elementId) {
tooltipContent = document.getElementById(`${elementId}`);
} else {
tooltipContent = DOMPurify.sanitize(content);
}
if (tooltipInstance) {
2025-07-22 07:19:40 +00:00
tooltipInstance.setContent(tooltipContent);
2024-03-02 09:20:50 +00:00
} else {
2025-07-22 07:19:40 +00:00
if (content) {
tooltipInstance = tippy(tooltipElement, {
content: tooltipContent,
placement: placement,
allowHTML: allowHTML,
touch: touch,
...(theme !== '' ? { theme } : { theme: 'dark' }),
arrow: false,
offset: offset,
2025-08-08 10:04:44 +00:00
interactive: interactive,
2025-07-22 07:19:40 +00:00
...tippyOptions
});
}
}
2024-06-04 18:13:43 +00:00
} else if (tooltipInstance && content === '') {
if (tooltipInstance) {
tooltipInstance.destroy();
}
}
onDestroy(() => {
if (tooltipInstance) {
2024-03-02 09:20:50 +00:00
tooltipInstance.destroy();
}
});
</script>
<div bind:this={tooltipElement} class={className}>
<slot />
</div>
2025-07-22 07:19:40 +00:00
<slot name="tooltip"></slot>