Skip to content

Latest commit

 

History

History
103 lines (82 loc) · 2.99 KB

README.md

File metadata and controls

103 lines (82 loc) · 2.99 KB

honkjs/forms

Greenkeeper badge

A helper for keeping track of a forms model state changes.

An experiment originally designed for use with choo.

npm install @honkjs/forms

Basics

import { createForm, bindInput } from '@honks/forms';

// the model is any basic object
const myModel = {
  name: 'Kel',
  items: [{ id: 0, description: 'cool item' }, { id: 1, description: 'another cool item' }],
};

// the context is where you store meta information about your model like validation errors.
const context = { errors: [] };

function onFormChange(form) {
  // do things when the form changes
}

// the form helper takes a model, context, and an onchange event handler
const form = createForm(myModel, context, onFormChange);

// All the real magic is in the bind helpers
// bindInput attaches the onchange event to the form based on the field name
// with typescript, the 'name' is only valid if the field exists on the model
export function editorForm(form) {
  return html`
    <form>
      <input
        type="text"
        value=${form.model.Name || ''}
        onchange=${bindInput(form, 'name')}
        placeholder="Name" required=true />
    </form>`;
}

Validation

The bind helpers take an optional array of 'validators'.

function myValidator(value, fieldName, form) {
  if (!value) {
    // there's no requirement in how these work
    // track errors and form info anyway you need to
    form.context.errors.push('Name is required!');

    // by default, the model value will be changed
    // after all validators are ran.
    // throw an error if that's undesired.
  }
}

bindInput(form, 'name', [myValidator]

Converters

Similar to validators, you can create a custom input converter. (By default it makes a best 'guest' based on the input field type)

function myConverter(event) {
  // do any magic necessary to pull your value from the input event
  return event.target.value;
}

bindInput(form, 'name', [], myConverter);