Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gcanti/tcomb-form
Forms library for react
https://github.com/gcanti/tcomb-form
Last synced: 8 days ago
JSON representation
Forms library for react
- Host: GitHub
- URL: https://github.com/gcanti/tcomb-form
- Owner: gcanti
- License: mit
- Archived: true
- Created: 2014-09-05T14:31:50.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2020-02-18T09:31:53.000Z (almost 5 years ago)
- Last Synced: 2024-05-17T10:02:46.220Z (8 months ago)
- Language: JavaScript
- Homepage: https://gcanti.github.io/tcomb-form
- Size: 3.82 MB
- Stars: 1,160
- Watchers: 31
- Forks: 136
- Open Issues: 48
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-components-all - tcomb-form - Forms library for react. (Uncategorized / Uncategorized)
- awesome-react - tcomb-form - UI library for developing forms writing less code
- awesome-list - tcomb-form - Forms library for react. (Code Design / Form Logic)
- awesome-react-components - tcomb-form - Forms library for react. (Code Design / Form Logic)
- awesome-react-components - tcomb-form - Forms library for react. (Code Design / Form Logic)
- starred-awesome - tcomb-form - Forms library for react (JavaScript)
README
[![build status](https://img.shields.io/travis/gcanti/tcomb-form/master.svg?style=flat-square)](https://travis-ci.org/gcanti/tcomb-form)
[![dependency status](https://img.shields.io/david/gcanti/tcomb-form.svg?style=flat-square)](https://david-dm.org/gcanti/tcomb-form)
![npm downloads](https://img.shields.io/npm/dm/tcomb-form.svg)> "Simplicity is the ultimate sophistication" (Leonardo da Vinci)
# Notice
`tcomb-form` is looking for maintainers. If you're interested in helping a great way to get started would just be to start weighing-in on GitHub issues, reviewing and testing some PRs.
# Domain Driven Forms
The [tcomb library](https://github.com/gcanti/tcomb) provides a concise but expressive way to define domain models in JavaScript.
The [tcomb-validation library](https://github.com/gcanti/tcomb-validation) builds on tcomb, providing validation functions for tcomb domain models.
This library builds on those two and **realizes an old dream of mine**.
# Playground
This [playground](https://gcanti.github.io/resources/tcomb-form/playground/playground.html), while a bit outdated, gives you the general idea.
# Benefits
With tcomb-form you simply call `` to generate a form based on that domain model. What does this get you?
1. Write a lot less HTML
2. Usability and accessibility for free (automatic labels, inline validation, etc)
3. No need to update forms when domain model changes# Flexibility
- tcomb-forms lets you override automatic features or add additional information to forms.
- You often don't want to use your domain model directly for a form. You can easily create a form specific model with tcomb that captures the details of a particular feature, and then define a function that uses that model to process the main domain model.# Example
```js
import t from 'tcomb-form'const FormSchema = t.struct({
name: t.String, // a required string
age: t.maybe(t.Number), // an optional number
rememberMe: t.Boolean // a boolean
})const App = React.createClass({
onSubmit(evt) {
evt.preventDefault()
const value = this.refs.form.getValue()
if (value) {
console.log(value)
}
},render() {
return (
Save
)
}})
```**Output**. Labels are automatically generated.
![](docs/example.png)
# Documentation
[GUIDE.md](GUIDE.md)
**Browser compatibility**: same as React >=0.13.0
# Contributions
Thanks so much to [Chris Pearce](https://github.com/Chrisui) for pointing me in the right direction
and for supporting me in the v0.4 rewrite.Special thanks to [William Lubelski](https://github.com/lubelski) ([@uiwill](https://twitter.com/uiwill)), without him this library would be less magic.
Thanks to [Esa-Matti Suuronen](https://github.com/epeli) for the excellent `humanize()` function.
Thanks to [Andrey Popp](https://github.com/andreypopp) for writing [react-forms](https://github.com/prometheusresearch/react-forms), great inspiration for list management.
# Contributing
[CONTRIBUTING.md](CONTRIBUTING.md)