- 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
25 lines
669 B
JavaScript
25 lines
669 B
JavaScript
import ownerDocument from './ownerDocument';
|
|
/**
|
|
* Returns the actively focused element safely.
|
|
*
|
|
* @param doc the document to check
|
|
*/
|
|
|
|
export default function activeElement(doc) {
|
|
if (doc === void 0) {
|
|
doc = ownerDocument();
|
|
}
|
|
|
|
// Support: IE 9 only
|
|
// IE9 throws an "Unspecified error" accessing document.activeElement from an <iframe>
|
|
try {
|
|
var active = doc.activeElement; // IE11 returns a seemingly empty object in some cases when accessing
|
|
// document.activeElement from an <iframe>
|
|
|
|
if (!active || !active.nodeName) return null;
|
|
return active;
|
|
} catch (e) {
|
|
/* ie throws if no active element */
|
|
return doc.body;
|
|
}
|
|
} |