JSPM

@rocket.chat/fuselage-hooks

0.2.0-alpha.8
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 2278
  • Score
    100M100P100Q129814F
  • License MIT

React Hooks for Fuselage, Rocket.Chat's design system

Package Exports

  • @rocket.chat/fuselage-hooks

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@rocket.chat/fuselage-hooks) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Welcome to @rocket.chat/fuselage-hooks 👋

Documentation Maintenance License: MIT Twitter: RocketChat

React Hooks for Fuselage, Rocket.Chat's design system

🏠 Homepage

Install

yarn add @rocket.chat/fuselage-hooks

Run tests

yarn test

API Reference

Table of Contents

useClassName

Hook to generate a BEM-compatible className value for a component.

Parameters

  • componentClassName string the style class which identifies the component
  • modifiers Object the modifiers applied to the style class (optional, default {})
  • classNames ...string the additional style classes appended to the className

Returns string a BEM-compatible className in the format (<block>|<block>__<element>) [...(<block>--<modifier>|<block>__<element>--<modifier>)] [...classNames]

useDebouncedUpdates

Hook to debounce the state updater function returned by hooks like useState() and useReducer().

Parameters

  • pair [any, function] the state and updater pair which will be debounced
    • pair.0 any the state value
    • pair.1 function the state updater function
  • delay number the number of milliseconds to delay the updater

Returns [any, function] a state value and debounced updater pair

useDebouncedReducer

Hook to create a reduced state with a debounced dispatch() function.

Parameters

  • reducer function the reducer function
  • initializerArg any the initial state value or the argument passed to the initial state generator function
  • initializer function the initial state generator function
  • delay number the number of milliseconds to delay the updater

Returns [any, function] a state and debounced dispatch() function

useDebouncedState

Hook to create a state with a debounced setter function.

Parameters

  • initialValue (any | function) the initial state value or the initial state generator function
  • delay number the number of milliseconds to delay the updater

Returns [any, function] a state and debounced setter function

useDebouncedCallback

Hook to memoize a debounced version of a callback.

Parameters

  • callback function the callback to debounce
  • delay number the number of milliseconds to delay
  • deps (Array<any> | undefined) the hook dependencies

Returns function a memoized and debounced callback

useExclusiveBooleanProps

Hook for asserting mutually exclusive boolean props. Useful for components that use boolean props to choose styling variants.

Parameters

  • props Object the mutually exclusive boolean props

  • Throws Error if two or more booleans props are set as true

useMediaQuery

Hook to listen to a media query.

Parameters

  • query string? the CSS3 media query expression

Returns bool true if the media query matches; false is it does not match or the query is not defined

useMergedRefs

Hook to merge refs and callbacks refs into a single callback ref. Useful when your component need a internal ref while receiving a forwared ref.

Parameters

  • refs ...(Object | function) the refs and callback refs that should be merged

Returns function a merged callback ref

useToggle

Hook to create a toggleable boolean state.

Parameters

  • initialValue (any | function) the initial value or the initial state generator function

Returns [any, function] a state boolean value and a state toggler function

Author

👤 Rocket.Chat

🤝 Contributing

Contributions, issues and feature requests are welcome!

Feel free to check issues page.

Show your support

Give a ⭐️ if this project helped you!


This README was generated with ❤️ by readme-md-generator