Fix Non-English Anchor Popover Positioning Issue and Update Type Hint (#1252)
- [Major] Changed `hash` passed to `querySelector` to `decodeURIComponent(hash)` to fix the issue where non-English anchors were not correctly positioning the popover content to the corresponding title.
- [Minor] Updated the type hint from `HTMLLinkElement` to `HTMLAnchorElement` as the passed element is an `<a>` element, not a `<link>` element (reference: https://developer.mozilla.org/en-US/docs/Web/API/HTMLLinkElement).
| | |
| | | |
| | | const p = new DOMParser() |
| | | async function mouseEnterHandler( |
| | | this: HTMLLinkElement, |
| | | this: HTMLAnchorElement, |
| | | { clientX, clientY }: { clientX: number; clientY: number }, |
| | | ) { |
| | | const link = this |
| | |
| | | thisUrl.hash = "" |
| | | thisUrl.search = "" |
| | | const targetUrl = new URL(link.href) |
| | | const hash = targetUrl.hash |
| | | const hash = decodeURIComponent(targetUrl.hash) |
| | | targetUrl.hash = "" |
| | | targetUrl.search = "" |
| | | |
| | |
| | | } |
| | | |
| | | document.addEventListener("nav", () => { |
| | | const links = [...document.getElementsByClassName("internal")] as HTMLLinkElement[] |
| | | const links = [...document.getElementsByClassName("internal")] as HTMLAnchorElement[] |
| | | for (const link of links) { |
| | | link.addEventListener("mouseenter", mouseEnterHandler) |
| | | window.addCleanup(() => link.removeEventListener("mouseenter", mouseEnterHandler)) |