- 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
650 B
JavaScript
20 lines
650 B
JavaScript
import LRUCache from './LRUCache.js'
|
|
|
|
// A cache for frequently used country-specific regular expressions. Set to 32 to cover ~2-3
|
|
// countries being used for the same doc with ~10 patterns for each country. Some pages will have
|
|
// a lot more countries in use, but typically fewer numbers for each so expanding the cache for
|
|
// that use-case won't have a lot of benefit.
|
|
export default class RegExpCache {
|
|
constructor(size) {
|
|
this.cache = new LRUCache(size)
|
|
}
|
|
|
|
getPatternForRegExp(pattern) {
|
|
let regExp = this.cache.get(pattern)
|
|
if (!regExp) {
|
|
regExp = new RegExp('^' + pattern)
|
|
this.cache.put(pattern, regExp)
|
|
}
|
|
return regExp
|
|
}
|
|
} |