import BaseUIElement from "../BaseUIElement"; import { Translation } from "../i18n/Translation"; import Translations from "../i18n/Translations"; /** * A 'TextFieldValidator' contains various methods to check and cleanup an entered value or to give feedback. * They also double as an index of supported types for textfields in MapComplete */ export abstract class Validator { public readonly name: string /* * An explanation for the theme builder. * This can indicate which special input element is used, ... * */ public readonly explanation: string /** * What HTML-inputmode to use */ public readonly inputmode?: 'none' | 'text' | 'tel' | 'url' | 'email' | 'numeric' | 'decimal' | 'search' public readonly textArea: boolean constructor( name: string, explanation: string | BaseUIElement, inputmode?: 'none' | 'text' | 'tel' | 'url' | 'email' | 'numeric' | 'decimal' | 'search', textArea?: false | boolean ) { this.name = name this.inputmode = inputmode this.textArea = textArea ?? false if (this.name.endsWith("textfield")) { this.name = this.name.substr(0, this.name.length - "TextField".length) } if (this.name.endsWith("textfielddef")) { this.name = this.name.substr(0, this.name.length - "TextFieldDef".length) } if (typeof explanation === "string") { this.explanation = explanation } else { this.explanation = explanation.AsMarkdown() } } /** * Gets a piece of feedback. By default, validation. will be used, resulting in a generic 'not a valid '. * However, inheritors might overwrite this to give more specific feedback * * Returns 'undefined' if the element is valid */ public getFeedback(s: string, _?: () => string): Translation | undefined { if (this.isValid(s)) { return undefined } const tr = Translations.t.validation[this.name] if (tr !== undefined) { return tr["feedback"] } } public getPlaceholder() { return Translations.t.validation[this.name].description } public isValid(key: string, getCountry?: () => string): boolean { return true } /** * Reformats for the human */ public reformat(s: string, _?: () => string): string { return s } }