lion/packages/form
CircleCI 7573ecf53e chore: release new versions
- @lion/calendar@0.9.3
 - @lion/checkbox-group@0.10.3
 - @lion/fieldset@0.13.3
 - @lion/form-core@0.1.3
 - @lion/form-integrations@0.1.5
 - @lion/form@0.6.3
 - @lion/input-amount@0.7.3
 - @lion/input-date@0.7.3
 - @lion/input-datepicker@0.14.3
 - @lion/input-email@0.8.3
 - @lion/input-iban@0.9.3
 - @lion/input-range@0.4.3
 - @lion/input@0.7.3
 - @lion/localize@0.12.0
 - @lion/radio-group@0.10.3
 - @lion/select-rich@0.18.4
 - @lion/select@0.7.3
 - @lion/switch@0.10.4
 - @lion/textarea@0.7.3
 - @lion/validate-messages@0.1.3
2020-06-08 12:49:57 +00:00
..
src fix(form): remove correct reset event listener on teardown 2020-03-19 10:25:40 +01:00
test feat: merge field/validate/choice-input/form-group into @lion/form-core 2020-05-29 17:01:15 +02:00
CHANGELOG.md chore: release new versions 2020-06-08 12:49:57 +00:00
index.js feat: release inital public lion version 2019-04-26 10:37:57 +02:00
lion-form.js feat: release inital public lion version 2019-04-26 10:37:57 +02:00
package.json chore: release new versions 2020-06-08 12:49:57 +00:00
README.md chore: fix broken docs links 2020-06-03 13:49:48 +02:00

Form

lion-form is a webcomponent that enhances the functionality of the native form component. It is designed to interact with (instances of) the form controls.

import { html } from 'lit-html';
import '@lion/input/lion-input.js';
import './lion-form.js';

export default {
  title: 'Forms/Form/Overview',
};
export const main = () => html`
  <lion-form id="form">
    <form>
      <lion-input name="firstName" label="First Name" .modelValue=${'Foo'}></lion-input>
      <lion-input name="lastName" label="Last Name" .modelValue=${'Bar'}></lion-input>
    </form>
  </lion-form>
`;

Features

  • Data synchronization with models
  • Easy retrieval of form data based on field names
  • Advanced validation possibilities
  • Advanced user interaction scenarios via interaction states
  • Registration mechanism for form controls
  • Accessible out of the box

For more information about fields that are designed for lion-form, please read forms.

How to use

Installation

npm i --save @lion/form
import '@lion/form/lion-form.js';

Example

<lion-form>
  <form>
    <lion-fieldset name="fullName">
      <lion-input label="First Name" name="firstName"></lion-input>
    </lion-fieldset>
  </form>
</lion-form>