Files
headroom/frontend/node_modules/happy-dom/lib/event/events/KeyboardEvent.js
Santhosh Janardhanan de2d83092e feat: Reinitialize frontend with SvelteKit and TypeScript
- 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
2026-02-17 16:19:59 -05:00

67 lines
1.9 KiB
JavaScript

import UIEvent from '../UIEvent.js';
/**
*
*/
export default class KeyboardEvent extends UIEvent {
static DOM_KEY_LOCATION_STANDARD = 0;
static DOM_KEY_LOCATION_LEFT = 1;
static DOM_KEY_LOCATION_RIGHT = 2;
static DOM_KEY_LOCATION_NUMPAD = 3;
altKey;
code;
ctrlKey;
isComposing;
key;
location;
metaKey;
repeat;
shiftKey;
/**
* @deprecated
*/
keyCode;
/**
* Constructor.
*
* @param type Event type.
* @param [eventInit] Event init.
*/
constructor(type, eventInit = null) {
super(type, eventInit);
this.altKey = eventInit?.altKey ?? false;
this.code = eventInit?.code ?? '';
this.ctrlKey = eventInit?.ctrlKey ?? false;
this.isComposing = eventInit?.isComposing ?? false;
this.key = eventInit?.key ?? '';
this.location = eventInit?.location ?? 0;
this.metaKey = eventInit?.metaKey ?? false;
this.repeat = eventInit?.repeat ?? false;
this.shiftKey = eventInit?.shiftKey ?? false;
this.keyCode = eventInit?.keyCode ?? 0;
}
/**
* Returns the state of a modifier key.
*
* @param key A modifier key value.
* @returns True if it's pressed, false otherwise.
*/
getModifierState(key) {
if (arguments.length < 1) {
throw new TypeError("Failed to execute 'getModifierState' on 'KeyboardEvent': 1 argument required, but only 0 present.");
}
switch (String(key).toLowerCase()) {
case 'alt':
case 'altgraph':
return this.altKey;
case 'control':
return this.ctrlKey;
case 'meta':
return this.metaKey;
case 'shift':
return this.shiftKey;
default:
return false;
}
}
}
//# sourceMappingURL=KeyboardEvent.js.map