- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
20 lines
599 B
JavaScript
20 lines
599 B
JavaScript
import matches from './matches';
|
|
/**
|
|
* Returns the closest parent element that matches a given selector.
|
|
*
|
|
* @param node the reference element
|
|
* @param selector the selector to match
|
|
* @param stopAt stop traversing when this element is found
|
|
*/
|
|
|
|
export default function closest(node, selector, stopAt) {
|
|
if (node.closest && !stopAt) node.closest(selector);
|
|
var nextNode = node;
|
|
|
|
do {
|
|
if (matches(nextNode, selector)) return nextNode;
|
|
nextNode = nextNode.parentElement;
|
|
} while (nextNode && nextNode !== stopAt && nextNode.nodeType === document.ELEMENT_NODE);
|
|
|
|
return null;
|
|
} |