npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

redux-mediaquery

v0.11.0

Published

Manage your responsive layout via Redux

Downloads

3,054

Readme

redux-mediaquery

👉 Watch me present this at React Europe 2016 👈

Intro

This is an ActionCreator for Redux that makes CSS mediaqueries (and more) available in the store. This allows you to declaratively make responsive layouts.

It is very small, without any dependencies, except that the reducer requires Object.assign().

Use Cases

  • Complement CSS, rendering fully different components depending on screen size instead of just showing/hiding parts of the application
  • Update measuring components when screen size changes
  • responsive images
  • flag server-side rendering

How to use

  1. npm install --save redux-mediaquery
  2. In your store creator, import the reducer and action:
import {reducer as responsive, mediaQueryTracker} from 'redux-mediaquery'
  1. Add it to the reducers:
const reducer = combineReducers({
  responsive,
  ...reducers,
})
  1. After the store is created, indicate the properties that you are interested in:
const unlisten = mediaQueryTracker({
  isPhone: "screen and (max-width: 767px)",
  isTablet: "screen and (max-width: 1024px)",
  innerWidth: true,
  innerHeight: true,
}, store.dispatch))

You can call unlisten() when you need to remove the listener it puts on window, for example when you are Note: this stores the dispatch handler. If you want it to look up the dispatch handler at runtime (e.g. because you change the store), you can dispatch mediaQueryTracker(...) as an action. In that case, do not provide the dispatch argument. This requires you to use the redux-thunk middleware.

  1. Connect components to the store and conditionally render things:
@connect(({responsive}) => ({
  isPhone: responsive.isPhone,
  innerHeight: responsive.innerHeight,
}))
class SomeComponent extends React.Component {
  render() {
    const {isPhone, innerHeight} = this.props
    return (
      <div>
        {isPhone ? (
          <h1>I'm on a phone!</h1>
        ) : (
          <p>Desktop here. My height is {innerHeight}</p>
        )}
      </div>
    )
  }
  1. sit back and relax 🏝

Pro Tip: write your media queries so false is the default, for server side rendering or in case matchMedia doesn't exist

Browser Support

For innerWidth/innerHeight, IE9 is sufficient. For the mediaqueries, this relies on matchMedia() support in the browser, and thus requires Internet Explorer 10+.

Object.assign() needs to be polyfilled if missing. (It is probably already available, through your JSX build)

Changelog

  • v0.11:
    • remove reliance on redux-thunk (backwards-compatible)
    • unlisten for hot reload etc
    • some tests
  • v0.10:
    • change the action type string to have '@@' as a prefix (@moimikey)

Ideas for future development

  • uglify build
  • stable API once more feedback from community
  • other special measurements? e.g. "is actual phone", "has touch", …
  • a collection of breakpoints/queries?
  • server side helpers for converting from user agent string to redux actions
  • demo page