boost-crud

Framework agnostic CRUD front-end utilities for the web

boost-crud

Create, update, read and delete UI utilities for the web.

To Do

  • [ ] Static data source
  • [ ] Enable disabling sort on certain columns
  • [ ] Unit tests
    • [x] Forms Utils
    • [ ] Form reducers
    • [ ] DataTable reducers
  • [ ] Strip out unnecessary stuff from form utils and models
    • [ ] Submit
  • [x] Integrate form library
    • [x] Type detection
    • [x] Human friendly column titles
    • [ ]
  • [ ] Support for filter form
  • [ ] CRUD UI service
    • [x] List service
    • [ ] Details
    • [ ] Edit
    • [ ] Create
    • [ ] Delete
  • [ ] Documentation

Getting Started

Install boost-crud using npm or yarn as:

npm i boost-crud

Using Form Utilities

First, setup a javascript object representing a form as:

const forObj = {
    email: "",
    password: "",
    confirmPassword: "",
    rememberMe: true
}

Then, get your form state as:

import {getFormService} from "boost-crud";

const formService = getFormService()
const formState = formService.getInitialState(forObj)

Then you can use your form state in any framework (react, svelte, vue, etc.).

In react:

const [formState, setFormState] = useState(formService.getInitialState(forObj))

function onFieldChange(e) {
    const newState = formService.hangeFieldValue(formState, e.target.name, e.target.value)
    setFormState(newState)
}

const MyForm = () => {
  return <form>
    <label>Email:
      <input name="password" onChange={onFieldChange}/></label>
    <label>Password:
      <input name="password" onChange={onFieldChange}/></label>
    <label>Confim Password:
      <input name="confirmPassword" onChange={onFieldChange}/></label>
    <label>
      <input type="checkbox" name="rememberMe" value={true} onChange={onFieldChange} />Remember Me?</label>
  </form>
}