react-micro-match-media

1.0.0 • Public • Published

react-micro-match-media

zero dependencies, ~1kb render prop wrapper of window.matchMedia

Instalation

$ npm install --save react-micro-match-media

Peer dependencies

This package expect react@^16.3.0 as a peer dependency.

Usage

You just pass in the query that you want to be listening and render your components accordingly.

import React, { Component } from 'react'
import MatchMedia from 'react-micro-match-media'
 
const App = () => (
  <MatchMedia query={`(max-width: 600px)`}>
    {matches => {
      if (matches) return 'will be rendered if viewport is <= 600'
      return 'will be rendered if viewport is > 600'
    }}
  </MatchMedia>
)

Smart usage

You can also do things like:

import React, { Component } from 'react'
import MatchMedia from 'react-micro-match-media'
 
const Portrait = ({ children, ...props }) => (
  <MatchMedia {...props} query={`(orientation: portrait)`}>
    {isPortrait => (isPortrait ? children : null)}
  </MatchMedia>
)
 
const App = () => (
  <Portrait>will render only if orientation is portrait</Portrait>
)

Dependents (0)

Package Sidebar

Install

npm i react-micro-match-media

Weekly Downloads

291

Version

1.0.0

License

MIT

Unpacked Size

244 kB

Total Files

12

Last publish

Collaborators

  • schiehll