- 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
709 B
JavaScript
20 lines
709 B
JavaScript
function replaceClassName(origClass, classToRemove) {
|
|
return origClass.replace(new RegExp("(^|\\s)" + classToRemove + "(?:\\s|$)", 'g'), '$1').replace(/\s+/g, ' ').replace(/^\s*|\s*$/g, '');
|
|
}
|
|
/**
|
|
* Removes a CSS class from a given element.
|
|
*
|
|
* @param element the element
|
|
* @param className the CSS class name
|
|
*/
|
|
|
|
|
|
export default function removeClass(element, className) {
|
|
if (element.classList) {
|
|
element.classList.remove(className);
|
|
} else if (typeof element.className === 'string') {
|
|
element.className = replaceClassName(element.className, className);
|
|
} else {
|
|
element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));
|
|
}
|
|
} |