84 lines
2.5 KiB
TypeScript
84 lines
2.5 KiB
TypeScript
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
|
|
|
|
public readonly isMeta?: 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.<type> will be used, resulting in a generic 'not a valid <type>'.
|
|
* 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
|
|
}
|
|
}
|