A React higher-order component that pass media queries props to components
$ npm install react-mediaquery-props --save
A React higher-order components, HOC, is a function that receive a React Component and return a enhance version.
This module enhance components with prop mq
object. Each key is a matchMedia listener
name and value is a flag that reflect actual media query state. See Bootstrap 4 media queries included.
On function call create a new Component and pass prop ´md´ with all registered media query listeners
mediaQuery(Component, { mediaqueries })
import React from 'react';
import mediaQuery from 'react-mediaquery-props';
//Bootstrap 4 greater than 'medium' and 'extra small' media queries
import { mdUp, xs } from 'react-mediaquery-props/lib/bootstrap4-media-query.js';
const Navbar = mediaQuery(class Navbar extends React.Component {
render() {
const mdUp = this.props.mq.mdUp
? { id: 'header-nav', div: '', ul: 'pull-right' } // medium Up
: { id: 'mobile-nav', div: 'collapse neal-mobile-nav', ul: '' };
const mobileNav = this.props.mq.xs ? '☰' : '';
return (
<header className="neal-navbar-wrapper">
<nav className="navbar-toggler"}>
<div className="container">
<button className="navbar-toggler hidden-md-up" type="button" data-toggle="collapse"
data-target="#mobile-nav">
{mobileNav}
</button>
<a className="navbar-brand hidden-sm-down" href="/">{this.props.brand}</a>
<div className={`navbar-toggleable-sm ${mdUp.div}`} id={mdUp.id}>
<ul className={`nav navbar-nav ${mdUp.ul}`}>
{this.props.children}
</ul>
</div>
</div>
</nav>
</header>
);
}
}, { mdUp, xs });
- Bootstrap 4 src
- Media queries definitions for other projects than already included
- Documentation improvement
- Feel free to send any PR
This module use matchMedia API. For IE < 10, user must provide a matchMedia
polyfill, Ex:
MIT