- 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
29 lines
821 B
JavaScript
29 lines
821 B
JavaScript
"use strict";
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
exports.__esModule = true;
|
|
exports.default = closest;
|
|
|
|
var _matches = _interopRequireDefault(require("./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
|
|
*/
|
|
function closest(node, selector, stopAt) {
|
|
if (node.closest && !stopAt) node.closest(selector);
|
|
var nextNode = node;
|
|
|
|
do {
|
|
if ((0, _matches.default)(nextNode, selector)) return nextNode;
|
|
nextNode = nextNode.parentElement;
|
|
} while (nextNode && nextNode !== stopAt && nextNode.nodeType === document.ELEMENT_NODE);
|
|
|
|
return null;
|
|
}
|
|
|
|
module.exports = exports["default"]; |