- 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
78 lines
2.2 KiB
JavaScript
78 lines
2.2 KiB
JavaScript
'use strict';
|
|
const singleComment = Symbol('singleComment');
|
|
const multiComment = Symbol('multiComment');
|
|
const stripWithoutWhitespace = () => '';
|
|
const stripWithWhitespace = (string, start, end) => string.slice(start, end).replace(/\S/g, ' ');
|
|
|
|
const isEscaped = (jsonString, quotePosition) => {
|
|
let index = quotePosition - 1;
|
|
let backslashCount = 0;
|
|
|
|
while (jsonString[index] === '\\') {
|
|
index -= 1;
|
|
backslashCount += 1;
|
|
}
|
|
|
|
return Boolean(backslashCount % 2);
|
|
};
|
|
|
|
module.exports = (jsonString, options = {}) => {
|
|
if (typeof jsonString !== 'string') {
|
|
throw new TypeError(`Expected argument \`jsonString\` to be a \`string\`, got \`${typeof jsonString}\``);
|
|
}
|
|
|
|
const strip = options.whitespace === false ? stripWithoutWhitespace : stripWithWhitespace;
|
|
|
|
let insideString = false;
|
|
let insideComment = false;
|
|
let offset = 0;
|
|
let result = '';
|
|
|
|
for (let i = 0; i < jsonString.length; i++) {
|
|
const currentCharacter = jsonString[i];
|
|
const nextCharacter = jsonString[i + 1];
|
|
|
|
if (!insideComment && currentCharacter === '"') {
|
|
const escaped = isEscaped(jsonString, i);
|
|
if (!escaped) {
|
|
insideString = !insideString;
|
|
}
|
|
}
|
|
|
|
if (insideString) {
|
|
continue;
|
|
}
|
|
|
|
if (!insideComment && currentCharacter + nextCharacter === '//') {
|
|
result += jsonString.slice(offset, i);
|
|
offset = i;
|
|
insideComment = singleComment;
|
|
i++;
|
|
} else if (insideComment === singleComment && currentCharacter + nextCharacter === '\r\n') {
|
|
i++;
|
|
insideComment = false;
|
|
result += strip(jsonString, offset, i);
|
|
offset = i;
|
|
continue;
|
|
} else if (insideComment === singleComment && currentCharacter === '\n') {
|
|
insideComment = false;
|
|
result += strip(jsonString, offset, i);
|
|
offset = i;
|
|
} else if (!insideComment && currentCharacter + nextCharacter === '/*') {
|
|
result += jsonString.slice(offset, i);
|
|
offset = i;
|
|
insideComment = multiComment;
|
|
i++;
|
|
continue;
|
|
} else if (insideComment === multiComment && currentCharacter + nextCharacter === '*/') {
|
|
i++;
|
|
insideComment = false;
|
|
result += strip(jsonString, offset, i + 1);
|
|
offset = i + 1;
|
|
continue;
|
|
}
|
|
}
|
|
|
|
return result + (insideComment ? strip(jsonString.slice(offset)) : jsonString.slice(offset));
|
|
};
|