@proso-io/fobu
v1.0.25
Published
A robust form builder and renderer with a customizable API and a beautiful out-of-the-box experience.
Downloads
36
Readme
Fobu is a lightweight form builder built with extensive customization, straight-forward API and beautiful out-of-the-box experience in mind. Its built using React.
Demo URL - https://codesandbox.io/s/awesome-platform-s01vj?fontsize=14&hidenavigation=1&theme=dark&view=preview
Background
Who are we? Just a bunch of guys who genuinely like to build software and think that doing live projects is the best way to learn. No dummy calculator projects, or static sites that do nothing. Real, useful software.
We have been working with the non-profit Goonj, with software they need to be more effective in their operations (for free, we don't charge non-profits for this). Goonj uses the under-utilized and excess urban household material as a tool for rural development across 23 states in India. They need a way of centrally managing all their activities and its associated data. Fobu started as a subcomponent within that project.
Fobu needs to be proficient at the following -
- Fobu should allow a wide variety of form inputs - radio buttons, textboxes, text areas, checkboxes, image inputs, automcomplete fields etc. This list should be extendable by design.
- Fobu should be flexible - it should allow overrides.
- Fobu needs to handle image input like a pro. Activity data for Goonj has a lot of image assets and they need to be handled well.
- Fobu has to be fault tolerant. If network conditions aren't supportive, Fobu should be able to save form state and resume uploads whenever network conditions are favourable. Special mention - image uploads.
- Fobu has to be PWA compatible.
How to contribute
Fobu is very young but has big plans. If you want to be an early contributor, now is a good time. We are literally just getting started. Unlike other projects, we want to help new developers get into this. Make mistakes, write shitty code so that we can tell you how to get better.
We will be using GitHub issues to create tasks for this project. Feel free to comment on the issue that you see unassigned at the moment with your intention to take up. Here's the process once you have picked a issue -
- Fork the repo.
- Follow the issue instructions and build your component / function.
- Add your story in the storybook. For more info, go here.
- Push your changes and raise a pull request. Check out this article to see how to raise a PR across forks.
If any of this doesn't make sense to you, raise an issue with the question tag / tweet