mapcomplete/src/UI/InputElement/Validator.ts

75 lines
2.4 KiB
TypeScript
Raw Normal View History

2023-08-08 20:44:34 +02:00
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
*/
2023-08-08 20:44:34 +02:00
public readonly inputmode?: 'none' | 'text' | 'tel' | 'url' | 'email' | 'numeric' | 'decimal' | 'search'
public readonly textArea: boolean
constructor(
name: string,
explanation: string | BaseUIElement,
2023-08-08 20:44:34 +02:00
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
*/
2023-06-02 08:42:08 +02:00
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
}
2023-06-02 08:42:08 +02:00
public isValid(_: string, __?: () => string): boolean {
return true
}
2023-04-21 20:50:38 +02:00
/**
* Reformats for the human
*/
2023-06-02 08:42:08 +02:00
public reformat(s: string, _?: () => string): string {
return s
}
}