A collection of hooks to measure things in React
npm i react-use-size
// or
yarn add react-use-size
import { useWindowSize } from "react-use-size";
const YourComponent = () => {
  const { height, width } = useWindowSize();
  return (
    <React.Fragment>
      <p>Height: {height}</p>
      <p>Width: {width}</p>
    </React.Fragment>
  );
};import { useComponentSize } from "react-use-size";
const YourComponent = () => {
  const { ref, height, width } = useComponentSize();
  return (
    <React.Fragment>
      <div ref={ref}>
        Component
        <p>Height: {height}</p>
        <p>Width: {width}</p>
      </div>
    </React.Fragment>
  );
};import { useBreakpoint } from "react-use-size";
const YourComponent = () => {
  const isSmall = useBreakpoint(640);
  if (isSmall) {
    return <SmallComponent />
  } else {
    return <DefaultComponent />
  }
};import { useBreakpoints } from "react-use-size";
const YourComponent = () => {
  const [isSmall, isMedium] = useBreakpoints([640, 1024]);
  if (isSmall) {
    return <SmallComponent />
  } else if(isMedium) {
    return <MediumComponent />
  } else {
    return <DefaultComponent />
  }
};This repo enforce commit style so the release process is automatic. Commits must look like:
SUBJECT: message starting with a lowercase
where SUBJECT is one of:
- build
- ci
- chore
- docs
- feat
- fix
- perf
- refactor
- revert
- style
- test
A commit including BREAKING CHANGE: in the body will create a new major release.
More details about the conventions are available here and here.
Please open an issue or submit a PR, we will be more than happy to help