36

GitHub - ianstormtaylor/react-values: A set of tiny React components for handlin...

 5 years ago
source link: https://github.com/ianstormtaylor/react-values
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

Readme.md

banner.png

A set of tiny, composable React components
for handling state with render props.


Why? · Principles · Examples · Documentation · Contributing!


68747470733a2f2f696d672e736869656c64732e696f2f6e706d2f64742f72656163742d76616c7565732e7376673f6d61784167653d33363030 68747470733a2f2f696d672e626164676573697a652e696f2f68747470733a2f2f756e706b672e636f6d2f72656163742d76616c7565732f646973742f72656163742d76616c7565732e6d696e2e6a733f636f6d7072657373696f6e3d677a6970266c6162656c3d72656163742d2d76616c756573 68747470733a2f2f7472617669732d63692e6f72672f69616e73746f726d7461796c6f722f72656163742d76616c7565732e7376673f6272616e63683d6d6173746572 68747470733a2f2f696d672e736869656c64732e696f2f6e706d2f762f72656163742d76616c7565732e7376673f6d61784167653d33363030266c6162656c3d72656163742d76616c75657326636f6c6f72423d303037656336 68747470733a2f2f696d672e736869656c64732e696f2f6e706d2f6c2f72656163742d76616c7565732e7376673f6d61784167653d33363030


react-values gives you a set of simple, composable helpers that let you build more complex, stateful UI components like toggles, dropdowns, lists, checkbox groups, popovers, tooltips, you name it!

It does this using a small render-prop-based API that exposes helpful transforms like toggle, increment, filter, etc. depending on the type of value, all based on JavaScripts native value types...

  • Any values provide simple transforms like set and clear.
  • Array values provide native methods like push, pop, filter, etc.
  • Boolean values provide toggle, which we've all re-implemented 100 times.
  • Date values provide really helpful transforms like setHours and incrementMonth.
  • Map values provide native methods like set, delete and clear.
  • Number values provide increment and decrement, which have also be re-written in every codebase ever.
  • Set values provide native methods like add, delete and clear.
  • String values provide native methods like concat, repeat, trim, etc.

This saves you from constantly re-writing the same state management logic, so you can keep your components focused on behavior and presentation.

For example, here's a <Toggle> implemented in just a few lines of code using a <BooleanValue>:

import { BooleanValue } from 'react-values'

const Toggle = ({ value, defaultValue, onChange }) => (
  <BooleanValue value={value} defaultValue={defaultValue} onChange={onChange}>
    {({ value: on, toggle }) => (
      <Track on={on} onClick={toggle}>
        <Thumb on={on} />
      </Track>
    )}
  </BooleanValue>
)

const Track = styled.div`
  position: relative;
  height: 25px;
  width: 50px;
  background-color: ${props => (props.on ? 'lightgreen' : 'lightgray')};
  border-radius: 50px;
`

const Thumb = styled.div`
  position: absolute;
  left: ${props => (props.on ? '25px' : '0')};
  height: 25px;
  width: 25px;
  background-color: white;
  border-radius: 50px;
`

Why?

While building an app with React, you end up building a lot of stateful components in the process. Whether at the UI kit level for things like toggles, tooltips, checkbox groups, dropdown, etc. Or at the app level for modals, popovers, sorting, filtering, etc.

In the process, you end up re-implementing run of the mill state handling logic all over the place—whether with this.setState or by building the same action creators over and over. And for your components to be nicely reusable across your application you augment them to handle both "controlled" and "uncontrolled" use cases using value or defaultValue. And to make things a bit more manageable, you re-invent common transforms like open, close, toggle, increment, decrement, etc. in lots of different components. And if you're working with a team, you end up doing all of this in slightly different ways throughout your codebase.

In the end, you're now maintaing a lot more logic than necessary, duplicated in many different places in slightly different ways. All while your app's bundle size gets larger and larger.

react-values solves all of that with a few principles...


Principles

  1. Leverage render props. It uses a render-prop-based API, exposing its state and a handful of convenient transform functions to you with the flexible function-as-children pattern.

  2. Follow React's conventions. Its components follow React's own naming conventions, using familiar concepts like value/defaultValue. This makes it extremely easy to slot into existing codebases or frameworks.

  3. Follow JavaScript's conventions. It exposes JavaScript's familiar, built-in methods like setDate/setHours, push/pop, filter, concat, etc. to avoid reinventing the wheel and forcing you to constantly read documentation.

  4. Be extremely lightweight. It's extremely lightweight (and tree-shakeable), with most components weighing just a few hundred bytes, so you can even import it from public-facing component libraries.

  5. Prioritize convenience. It's designed to provide convenient functions like increment, toggle, and smarter ones like incrementDate, decrementMonth, so you can build complex interactions in just a few lines of code.


Examples

To get a sense for how you might use react-values, check out a few of the examples:

  • Basic Toggle — using a Boolean to create a simple toggle component.
  • Reusable Toggle — showing how you might turn that toggle into a controlled component in your own UI kit.
  • Counter — a simple counter using a Number and its convenience transforms.
  • Time Picker — a more complex time picker component, using Date and its convenience transforms.
  • Filtering — a basic String value used for filtering a list.
  • Checkbox Set — using a Set to keep track of a checkbox group.
  • Simple Tooltip — a simplistic tooltip implemented as a Boolean.
  • Simple Modal — a simplistic modal implemented as a Boolean.

If you have an idea for an example that shows a common use case, pull request it!


Documentation

If you're using react-values for the first time, check out the Getting Started guide to familiarize yourself with how it works. Once you've done that, you'll probably want to check out the full API Reference.

If even that's not enough, you can always read the source itself, which is very simple!


Contributing!

All contributions are super welcome! Check out the Contributing instructions for more info!

Slate is MIT-licensed.


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK