<tangy-form>
data:image/s3,"s3://crabby-images/c8f0d/c8f0de228a5117eafd96d8f855076a89ee3d9e1b" alt="Build Status"
An element for multipage forms.
- Conforms to Material Design guidelines.
- Loads of handy input elements such as
<tangy-gps>
. - Easy to write logic for the form for hiding / showing and disabling / enabled inputs.
Play with the demo on glitch.
data:image/s3,"s3://crabby-images/e4ca4/e4ca4c63c4e16bbfc65799aec82e9c680332026e" alt="screenshot"
<tangy-form id="my-form">
<tangy-form-item id="item1">
<tangy-input name="input1" label="What is your first name?"></tangy-input>
</tangy-form-item>
<tangy-form-item id="item2">
<tangy-input name="input2" label="What is your last name?"></tangy-input>
</tangy-form-item>
</tangy-form>
<script>
document.querySelector('#my-form').addEventListener('submit', event => {
event.preventDefault()
console.log(event.target.response)
console.log(event.target.inputs)
console.log(event.target.values)
})
</script>
Installation
<tangy-form>
is a Custom Element built with Polymer and can be used in frameworks such as Angular, React, and Vue. Check compatibility with your project's framework on Custom Elements Everywhere. If you are ready to go, run npm install --save tangy-form
to add it to your project. Depending on your build system/framework, there may be different steps to take to get Web Components loading.
Install in a Polymer v3 project
npm install --save tangy-form
Because React is not playing nicely with bundlers, you need to include it as a global dependency in a script tag as you will see in the demo/index.html
.
Then from any of your elements, import tangy-form.
import 'tangy-form/tangy-form.js'
Install in an Angular v4+ project
Run on the command line...
npm install --save tangy-form redux @webcomponents/webcomponentsjs
Then add to your ./polyfills.ts
file...
import * as Redux from 'redux';
(window as any).Redux = Redux;
import '@webcomponents/webcomponentsjs/webcomponents-sd-ce.js';
import 'tangy-form/tangy-form.js'
Lastly, any module where you are going to use a Web Component you need to let Angular know it can be flexible with the names of components by import CUSTOM_ELEMENTS_SCHEMA
. Note that just enabling on the app module level is not enough for children modules to also use flexible schema. You need to do the same for those children modules as well.
import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
...
@NgModule({
declarations: [
AppComponent
],
schemas: [ CUSTOM_ELEMENTS_SCHEMA ],
...
Run the demo
Requires node.js and npm installed.
git clone https://github.com/tangerine-community/tangy-form
cd tangy-form
npm install
npm install -g polymer-cli
polymer serve
Then open http://localhost:8080
Tests
One of the best places to learn about what Tangy Form is capable of is to take a look at the tests in test/tangy-form_test.html
. To run tests, use polymer test
command or just npm run test
to just run tests in Chrome. If you want to develop tests, open http://localhost:8080/test/tangy-form_test.html