- 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
21 lines
994 B
JavaScript
21 lines
994 B
JavaScript
import { nat } from './nat.js';
|
|
import { indexToMappedConstantMapperFor, indexToMappedConstantUnmapperFor, } from './_internals/mappers/IndexToMappedConstant.js';
|
|
import { Error } from '../utils/globals.js';
|
|
function computeNumChoices(options) {
|
|
if (options.length === 0)
|
|
throw new Error(`fc.mapToConstant expects at least one option`);
|
|
let numChoices = 0;
|
|
for (let idx = 0; idx !== options.length; ++idx) {
|
|
if (options[idx].num < 0)
|
|
throw new Error(`fc.mapToConstant expects all options to have a number of entries greater or equal to zero`);
|
|
numChoices += options[idx].num;
|
|
}
|
|
if (numChoices === 0)
|
|
throw new Error(`fc.mapToConstant expects at least one choice among options`);
|
|
return numChoices;
|
|
}
|
|
export function mapToConstant(...entries) {
|
|
const numChoices = computeNumChoices(entries);
|
|
return nat({ max: numChoices - 1 }).map(indexToMappedConstantMapperFor(entries), indexToMappedConstantUnmapperFor(entries));
|
|
}
|