1.1.0 • Published 3 years ago

@pmwcs/elevation v1.1.0

Weekly downloads
5
License
MIT
Repository
github
Last release
3 years ago

Elevation

Elevation is the relative distance between two surfaces along the z-axis.

<>
  {Array(25)
    .fill(undefined)
    .map((val, i) => (
      <Elevation z={i} key={i}>
        {i}dp
      </Elevation>
    ))}
</>
function Example() {
  const [elevation, setElevation] = React.useState(0);

  return (
    <Elevation
      z={elevation}
      transition
      onMouseOver={() => setElevation(24)}
      onMouseOut={() => setElevation(0)}
    >
      Hover Me {elevation}dp
    </Elevation>
  );
}

Wrapping Children

You can avoid adding extra DOM nodes by using the wrap prop on elevation. This will apply the classes directly to the child component. Additionally, Elevation is simply a className, so you can achieve the same effect by adding className="mdc-elevation--z15".

<Elevation z={21} wrap>
  <span>Wrapped!</span>
</Elevation>

Elevation

The Elevation Component

Props

NameTypeDescription
transitionundefined \| false \| trueAllows for smooth transitions between elevations when the z value changes.
wrapundefined \| false \| trueAllows the elevation classes to be merged onto the child component instead of creating an new DOM node.
znumber \| stringA number from 0 - 24 for different levels of elevation