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(_: string, __?: () => string): boolean { return true } /** * Reformats for the human */ public reformat(s: string, _?: () => string): string { return s } }