- 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
31 lines
933 B
JavaScript
31 lines
933 B
JavaScript
import normalizeArguments from './normalizeArguments.js'
|
|
import parsePhoneNumberWithError from './parsePhoneNumberWithError_.js'
|
|
import ParseError from './ParseError.js'
|
|
import Metadata from './metadata.js'
|
|
import checkNumberLength from './helpers/checkNumberLength.js'
|
|
|
|
export default function validatePhoneNumberLength() {
|
|
let { text, options, metadata } = normalizeArguments(arguments)
|
|
options = {
|
|
...options,
|
|
extract: false
|
|
}
|
|
|
|
// Parse phone number.
|
|
try {
|
|
const phoneNumber = parsePhoneNumberWithError(text, options, metadata)
|
|
metadata = new Metadata(metadata)
|
|
metadata.selectNumberingPlan(phoneNumber.countryCallingCode)
|
|
const result = checkNumberLength(phoneNumber.nationalNumber, phoneNumber.country, metadata)
|
|
if (result !== 'IS_POSSIBLE') {
|
|
return result
|
|
}
|
|
} catch (error) {
|
|
/* istanbul ignore else */
|
|
if (error instanceof ParseError) {
|
|
return error.message
|
|
} else {
|
|
throw error
|
|
}
|
|
}
|
|
} |