2024-12-07 11:39:37 -08:00
|
|
|
class MagicMagnifier extends HTMLElement {
|
2024-12-28 16:08:28 -08:00
|
|
|
#internals = this.attachInternals();
|
|
|
|
|
2024-12-07 11:39:37 -08:00
|
|
|
connectedCallback() {
|
|
|
|
setTimeout(() => this.#attachLens(), 0);
|
|
|
|
this.addEventListener("mousemove", this.#onMouseMove);
|
|
|
|
}
|
|
|
|
|
|
|
|
#attachLens() {
|
|
|
|
const lens = document.createElement("magic-magnifier-lens");
|
|
|
|
lens.inert = true;
|
|
|
|
lens.useContent(this.children);
|
|
|
|
this.appendChild(lens);
|
|
|
|
}
|
|
|
|
|
|
|
|
#onMouseMove(e) {
|
|
|
|
const lens = this.querySelector("magic-magnifier-lens");
|
|
|
|
const rect = this.getBoundingClientRect();
|
2024-12-07 12:41:03 -08:00
|
|
|
const x = e.clientX - rect.left;
|
|
|
|
const y = e.clientY - rect.top;
|
2024-12-07 11:53:18 -08:00
|
|
|
this.style.setProperty("--magic-magnifier-x", x + "px");
|
|
|
|
this.style.setProperty("--magic-magnifier-y", y + "px");
|
2024-12-28 16:08:28 -08:00
|
|
|
this.#internals.states.add("ready");
|
2024-12-07 11:39:37 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class MagicMagnifierLens extends HTMLElement {
|
|
|
|
useContent(contentNodes) {
|
|
|
|
for (const contentNode of contentNodes) {
|
|
|
|
this.appendChild(contentNode.cloneNode(true));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
customElements.define("magic-magnifier", MagicMagnifier);
|
|
|
|
customElements.define("magic-magnifier-lens", MagicMagnifierLens);
|