A simple, easy to use form state and validation handler for Svelte.
Table of Content
npm install @vkhalikov/svelte-easy-form
Live example with different options is available here.
createForm  import createForm from '@vkhalikov/svelte-easy-form';
   
  // Declare a schema with initial values and validators
  const schema = {
    username: {
      value: 'admin',
      validators: [required('Login is required')],
    },
    password: {
      validators: [required('Password is required')],
    },
  };
  const { values, errors, onInput, onSubmit } = createForm(schema);
NOTE: Validators are not included in the package. See validator for details.
 <form on:submit="{onSubmit}" action="https://myformhandler.com" method="post">
 </form>
submitHandler option.  <form on:submit="{onSubmit}" action="https://myformhandler.com" method="post">
    <input type="text" name="username" value="{$values.username}" on:input="{onInput}" />
    <input type="password" name="password" value="{$values.password}" on:input="{onInput}" />
  </form>
NOTE: attributes
name,value,on:inputare required.
NOTE:
valuesis asveltestore, therefore you can access it with a$prefix.
  <form on:submit="{onSubmit}" action="https://myformhandler.com" method="post">
    <input type="text" name="username" value="{$values.username}" on:input="{onInput}" />
    {#if $errors.username}
       {$errors.username}  // Render it as is
    {/if}
    <input type="password" name="password" value="{$values.password}" on:input="{onInput}" />
    <ValidationError error="{$errors.password}" /> // Or create a component
  </form>
NOTE:
errorsis asveltestore, therefore you can access it with a$prefix.
createFormtype CreateForm = (schema: Schema, options?: Options) => FormModel;
SchemaA schema is an object, that contains Fields which are used to construct a FormModel.
interface Schema {
  [fieldName: string]: Field;
}
Fieldinterface Field {
  value?: any; // Initial value
  validators?: [Validator];
}
NOTE: If you don't need to set an initial value and validators for a field, you should still define a
FieldinSchemaas an empty object:
const schema = {
  name: {},
}
ValidatorValidator is a function that receives a field value and returns a validation error in any form if the value is invalid or null.
type Validator = (value: any) => any;
Optionsinterface Options {
  validateOnInput?: boolean;
  submitHandler?: SubmitHandler;
}
validateOnInputDefaults to true
Defines whether the field should be validated immediately after a change. As user types in a symbol for example.
If set to false, the field is validated on blur and submit.
submitHandlerDefaults to undefined
type SubmitHandler = (values: Writable, event: Event) => void;
If provided, SubmitHandler will be used instead of a default browser submit handler.
FormModelA form model that is returned from createForm function.
interface FormModel {
  values: Writable;
  errors: Writable;
  onInput: (e: Event) => void;
  onSubmit: (e: Event) => void;
}
values and errorsA Writable svelte stores, that contain current values and errors, that are accessible via $ prefix.
If you are unfamiliar with svelte stores, see the tutorial.
onInputAn event handler that updates and validates a value.
Should be passed to an input as on:input attribute.
NOTE: A value is not validated on input if the
validateOnInputoption is set tofalse.
onSubmitAn event handler that does 2 things:
SubmitHandler is provided, it will be called with the following arguments: (values, originalEvent)onSubmit should be passed to a form as on:submit attribute.
Any feedback is welcomed. If you want to propose changes follow these steps:
Fork the repo
Clone the fork
Create a branch - git checkout -b {prefix}/new-feature
 Prefixes: feat for features, fix for fixes
Make your changes and commit git commit -a - m "short description"
Push changes git push origin {prefix}/new-feature
Create new Pull Request
NOTE: Please provide a description to your changes and link an issue if it's a bugfix
The project is in beta, therefore anything might be changed in the future