- 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
14 lines
461 B
JavaScript
14 lines
461 B
JavaScript
'use strict';
|
||
|
||
module.exports = string => {
|
||
if (typeof string !== 'string') {
|
||
throw new TypeError('Expected a string');
|
||
}
|
||
|
||
// Escape characters with special meaning either inside or outside character sets.
|
||
// Use a simple backslash escape when it’s always valid, and a \unnnn escape when the simpler form would be disallowed by Unicode patterns’ stricter grammar.
|
||
return string
|
||
.replace(/[|\\{}()[\]^$+*?.]/g, '\\$&')
|
||
.replace(/-/g, '\\x2d');
|
||
};
|