- 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
24 lines
457 B
JavaScript
24 lines
457 B
JavaScript
/**
|
|
* Merges two arrays.
|
|
* @param {*} a
|
|
* @param {*} b
|
|
* @return {*}
|
|
*/
|
|
export default function mergeArrays(a, b) {
|
|
const merged = a.slice()
|
|
|
|
for (const element of b) {
|
|
if (a.indexOf(element) < 0) {
|
|
merged.push(element)
|
|
}
|
|
}
|
|
|
|
return merged.sort((a, b) => a - b)
|
|
|
|
// ES6 version, requires Set polyfill.
|
|
// let merged = new Set(a)
|
|
// for (const element of b) {
|
|
// merged.add(i)
|
|
// }
|
|
// return Array.from(merged).sort((a, b) => a - b)
|
|
} |