aboutsummaryrefslogtreecommitdiff
path: root/src/lib/GlobalTooltip.svelte
blob: 61e5514c5bb47892eb849936c1920a7904d43090 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
<script lang="ts">
	import { onMount } from 'svelte'

	let tooltipEl

	// this script handles the item hover lore tooltip
	onMount(() => {
		const itemEls = document.getElementsByClassName('item')
		let tooltipLocked = false
		function moveTooltipToMouse(e) {
			const mouseX = e.pageX
			const mouseY = e.pageY
			console.log(mouseY + tooltipEl.offsetHeight, window.innerHeight + window.scrollY - 10)
			// if it's going to be off the bottom of the screen, move it up
			if (mouseY + tooltipEl.offsetHeight > window.innerHeight + window.scrollY - 10) {
				// put it at the bottom of the screen
				tooltipEl.style.top = `${
					window.innerHeight + window.scrollY - 10 - tooltipEl.offsetHeight
				}px`
			} else {
				// otherwise, put it at the mouse's y position
				tooltipEl.style.top = mouseY + 'px'
			}
			// if it's going to be off the right of the screen, move it left
			if (mouseX + tooltipEl.offsetWidth > window.innerWidth + window.scrollX - 10) {
				// put it at the right of the screen
				tooltipEl.style.left = `${
					window.innerWidth + window.scrollX - 10 - tooltipEl.offsetWidth
				}px`
			} else {
				// otherwise, put it at the mouse's x position
				tooltipEl.style.left = mouseX + 'px'
			}
		}
		document.addEventListener('mousemove', e => {
			if (!tooltipLocked && tooltipEl.style.display !== 'none') {
				moveTooltipToMouse(e)
			}
		})

		for (const itemEl of itemEls) {
			if (!(itemEl instanceof HTMLElement)) continue

			// if the item doesn't have lore or a name, that must mean it's air
			if (!itemEl.dataset.loreHtml && !itemEl.dataset.nameHtml) continue

			itemEl.addEventListener('mouseover', e => {
				if (!tooltipLocked) {
					moveTooltipToMouse(e)
					const loreHtml = itemEl.dataset.loreHtml
						.replace(/&lt;/g, '<')
						.replace(/&gt;/g, '>')
						.replace(/&quot;/g, '"')
					const nameHtml = itemEl.dataset.nameHtml
						.replace(/&lt;/g, '<')
						.replace(/&gt;/g, '>')
						.replace(/&quot;/g, '"')
					tooltipEl.innerHTML = `<p class="item-lore-name">${nameHtml}</p><p class="item-lore-text">${loreHtml}</p>`
				}
				tooltipEl.style.display = 'block'
			})
			itemEl.addEventListener('mouseout', () => {
				if (!tooltipLocked) {
					tooltipEl.innerHTML = ''
					tooltipEl.style.display = 'none'
				}
			})
			itemEl.addEventListener('click', e => {
				tooltipLocked = !tooltipLocked
				moveTooltipToMouse(e)
				tooltipEl.style.display = 'block'
				if (tooltipLocked) {
					tooltipEl.style.userSelect = 'auto'
					tooltipEl.style.pointerEvents = 'auto'
				} else {
					tooltipEl.style.userSelect = null
					tooltipEl.style.pointerEvents = null
				}
				const loreHtml = itemEl.dataset.loreHtml
					.replace(/&lt;/g, '<')
					.replace(/&gt;/g, '>')
					.replace(/&quot;/g, '"')
				const nameHtml = itemEl.dataset.nameHtml
					.replace(/&lt;/g, '<')
					.replace(/&gt;/g, '>')
					.replace(/&quot;/g, '"')
				tooltipEl.innerHTML = `<p class="item-lore-name">${nameHtml}</p><p class="item-lore-text">${loreHtml}</p>`
			})
			document.addEventListener('mousedown', e => {
				if (tooltipLocked && !tooltipEl.contains(e.target)) {
					tooltipLocked = false
					tooltipEl.style.userSelect = null
					tooltipEl.style.pointerEvents = null
					tooltipEl.style.display = 'none'
				}
			})
		}
	})
</script>

<div id="global-tooltip" style="display: none" bind:this={tooltipEl} />