- @lion/checkbox-group@0.10.4 - @lion/fieldset@0.13.4 - @lion/form-core@0.1.4 - @lion/form-integrations@0.1.6 - @lion/form@0.6.4 - @lion/input-amount@0.7.4 - @lion/input-date@0.7.4 - @lion/input-datepicker@0.14.4 - @lion/input-email@0.8.4 - @lion/input-iban@0.9.4 - @lion/input-range@0.4.4 - @lion/input@0.7.4 - @lion/radio-group@0.10.4 - @lion/select-rich@0.18.5 - @lion/select@0.7.4 - @lion/switch@0.10.5 - @lion/textarea@0.7.4 - @lion/validate-messages@0.1.4 |
||
|---|---|---|
| .. | ||
| src | ||
| test | ||
| CHANGELOG.md | ||
| index.js | ||
| lion-form.js | ||
| package.json | ||
| README.md | ||
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>