Wiederverwendbarer Stuff zum vereinfachten Handling reaktiver Formulare - instant Validierung für verschiedene Feldtypen, Validierung für gesamtes Formular, Prüfung auf Browser-Support für Datepicker, und anderes.
npm install --save @phoenixreisen/form
Konfig & Types importieren:
import {DateConfig, ValidationTypes, UserTypes} from '@phoenixreisen/form';
Felder importieren:
import {text, int, email, bookingnr} from '@phoenixreisen/form';
Funktionen importieren:
import {isValidInput, isDateSupported} from '@phoenixreisen/form';
Formular deklarieren:
(Parameter-Signatur der einzelnen Felder beachten, weitere Beispiele in Ordner spec
)
const form = {
prename: text(true, input => { // Text
console.log('hooked')
input = input.trim();
return input;
}),
surname: text(), // Text
age: int(false), // optionales Feld, Int Validierung
bookingnr: bookingnr() // Validierung auf gültige Buchungsnr.
};
Form-Feld an ein bestimmtes HTML-Feld binden:
<input
type="text"
placeholder="Beispiel..."
value={form.surname.value()}
oninput={e => form.surname.validate(e.target.value)}
/>
{form.surname.complaint && form.surname.complaint === ValidationTypes.empty ?
<div class="alert alert--warning">
Bitte ausfüllen
</div>
}
Bei Submit alles validieren lassen:
function submit(form) {
if(!Form.isValidInput(form)) {
// bei invaliden Feldern wurde property "complaint"
// auf true oder einen der ValidationTypes (string) gesetzt.
return;
}
// code...
}
[npm install] # Abhängigkeiten installieren
npm version [major|minor|patch] # increase version x.x.x => major.minor.patch
npm publish # upload to npm
git push