Detalhes do pacote

transition-hook

iamyoki32.6kMIT1.5.2

☄️ An extremely light-weight react transition animation hook which is simpler and easier to use than react-transition-group

react, transition, hooks, css

readme (leia-me)

☄️ transition-hook

🧪 Run Tests 🚀 Release The Package transition hook

An extremely light-weight(1kb) react transition animation hook which is simpler and easier to use than react-transition-group


example
See Example | See Example in Codesandbox

example example

example example

example example example

See More Examples in Codesandbox


Installation

Install with yarn

yarn add transition-hook

Or install with npm

npm install transition-hook --save

Usage

useTransition

This hook transforms a boolean state into transition stage('from' | 'enter' | 'leave'), and unmount the component after timeout.

const [onOff, setOnOff] = useState(true)
const {stage, shouldMount} = useTransition(onOff, 300) // (state, timeout)

return <div>
  <button onClick={()=>setOnOff(!onOff)}>toggle</button>
  {shouldMount && (
    <p style={{
      transition: '.3s',
      opacity: stage === 'enter' ? 1 : 0
    }}>
      Hey guys, I'm fading
    </p>
  )}
</div>

useSwitchTransition

This hook transforms when the state changes.

const [count, setCount] = useState(0)
const transition = useSwitchTransition(count, 300, 'default') // (state, timeout, mode)

return <div>
  <button onClick={()=>setCount(count+1)}>add</button>
  {transition((state, stage)=>(
    <p style={{
      transition: '.3s',
      opacity: stage === 'enter' ? 1 : 0,
      transform: {
        from: 'translateX(-100%)',
        enter: 'translateX(0%)',
        leave: 'translateX(100%)',
      }[stage]
    }}>{state}</p>
  ))}
</div>

Transition

If you prefer FaCC pattern usage, there it is!

const [onOff, setOnOff] = useState(true)

return <div>
  <button onClick={()=>setOnOff(!onOff)}>toggle</button>
  <Transition state={onOff} timeout={300}>
    {(stage, shouldMount)=>shouldMount &&(
      <p style={{
        transition: '.3s',
        opacity: stage === 'enter' ? 1 : 0
      }}>
        Hey guys, I'm fading
      </p>
    )}
  </Transition>
</div>

SwitchTransition

FaCC pattern version of useSwitchTransition

  <SwitchTransition state={count} timeout={300} mode='default'>
    {(state, stage) => (
      <h1
        style={{
          transition: '.3s',
          opacity: stage === 'enter' ? 1 : 0,
          transform: {
            from: 'translateX(-100%) scale(1.2)',
            enter: 'translateX(0)',
            leave: 'translateX(100%) scale(0)'
          }[stage]
        }}>
        {state} {stage} hello
      </h1>
    )}
  </SwitchTransition>

API Reference

useTransition(state, timeout)

  const {stage, shouldMount} = useTransition(onOff, 300)
Parameters Type Description
state boolean Required. Your boolean state, which controls animation in and out
timeout number Required. How long before the animation ends and unmounts


Returns Type Description
stage Stage: from \ enter \ leave Use three different stage to perform your animation
shouldMount boolean Whether the component should be mounted

useSwitchTransition(state, timeout, mode)

  const transition = useSwitchTransition(onOff, 300, 'default')
Parameters Type Description
state any Required. Your state, which triggers animation
timeout number Required. How long before the animation ends and unmounts
mode default \ out-in \ in-out Optional. Default to default mode

Transition

  <Transition state={onOff} timeout={300}>
    {(stage, shouldMount) => shouldMount && <div style={{...}}>hello</div>}
  </Transition>
Props Type Description
state boolean Required. Your boolean state, which controls animation in and out
timeout number Required. How long before the animation ends and unmounts
children (stage: Stage, shouldMount: boolean)=>React.ReactNode Required. FaCC pattern.

SwitchTransition

  <SwitchTransition state={count} timeout={300}>
    {(state, stage) => <div style={{...}}>{state} hello</div>}
  </SwitchTransition>
Props Type Description
state any Required. Your boolean state, which controls animation in and out
timeout number Required. How long before the animation ends and unmounts
mode default \ out-in \ in-out Optional. Default to default mode
children (state: any, stage: Stage)=>React.ReactNode Required. FaCC pattern.

ListTransition

  <ListTransition list={list} timeout={300}>
    {(item, stage)=><h1 style={...}>{item}</h1>}
  </ListTransition>
Props Type Description
list Array<any> Required. Your array state
timeout number Required. How long before the animation ends and unmounts
children (item: any, stage: Stage)=>React.ReactNode Required. FaCC pattern.

Also see these amazing hooks

Repo Intro
🧻 infinite-scroll-hook Scroll down to load more never been so easy!
☄️ transition-hook An extremely light-weight react transition animation hook

License

MIT

changelog (log de mudanças)

1.5.2 (2022-03-17)

Bug Fixes

1.5.1 (2022-02-18)

Docs

Refactors

  • config files, add qhlab eslint plugin (f204db4)

Chores

1.5.0 (2021-12-30)

Features

1.4.0 (2021-12-30)

Features

  • finished useListTransition(useTransitionGroup) (1289cff)
  • init useTransitionGroup (not finished) (77da14d)
  • unfinished useTransitionGroup (d2fb662)

1.3.3 (2021-12-24)

Chores

Docs

  • update readme, add radio-transition example (d358de3)

1.3.2 (2021-12-23)

Docs

  • add painter gif example (1698fce)

1.3.1 (2021-12-23)

Docs

  • add ripple-effect gif example (eb707d6)

1.3.0 (2021-12-23)

Features

  • add SwitchTransition, update docs (18b08e9)

Docs

1.2.1 (2021-12-22)

Docs

  • update readme, add useSwitchTransition doc, add more examples (702d098)

1.2.0 (2021-12-22)

Features

  • add useSwitchTransition (262e720), closes #3 #1
  • refactor folder structure, add setAnimationFrameTimeout (6b2fda1)
  • useTransition replace timeout with animationFrameTimeout (c59c662)

Chores

  • change commitlint rules (d10fa20)

1.1.6 (2021-12-17)

Docs

1.1.5 (2021-12-17)

Docs

1.1.4 (2021-12-17)

Docs

1.1.3 (2021-12-17)

Docs

1.1.2 (2021-12-17)

Bug Fixes

1.1.1 (2021-12-16)

Docs

  • update readme (ebe52b1)
  • update readme, add table of contents (10b6168)

Chores

  • add keywords in package.json (300eb40)

1.1.0 (2021-12-16)

Features

  • almost finished useTransition and Transition (a540689)

Chores

Docs

1.0.0 (2021-12-16)

Features

  • add semantic-release, complete config (3f97686)
  • init project (6816b98)