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 🙏

© 2025 – Pkg Stats / Ryan Hefner

r-layout

v0.7.0

Published

Layout made simple. Screw CSS!

Downloads

2

Readme

RLayout

A react component for simple layout. Screw CSS!

Motivation

Creating nice layouts in CSS has always been a pain for me. How many times have I desperately googled how to center a div? How to align divs horizontally? How to mix fixed sizes in pixels with dynamic sized divs?
This project tries to make this much easier, while at the same time stay very flexible.

Examples

Demo 1 / Src
More demos / Src

Install

npm install r-layout --save

How it works

Check out the examples!

Require the needed modules (only pick the ones you need):

var {Layout, resizeMixin, Spacer, Center, CenterHorizontal, CenterVertical} = require('r-layout');

The base component is the <Layout/> component.

Simple helper components are available, such as: <Spacer/>, <Center/>, <CenterHorizontal/> and <CenterVertical/>

There is a resizeMixin available which automatically updates the layout on page resize. Use it only on the root element.

Concepts

The most important concept is the size property. You can use it on all child components inside a <Layout> component.
Based on this property, the parent will then figure out how big to render the child and pass this information along to the child.
You can use the size property on all children, including <div>s, although I strongly disencourage using <div>s at all as <Layout> is the better <div>.

A child inside a Layout will always fill one dimension completely, leaving the other dimension open for configuration using the size property. Which dimension is controllable is determined by the parent Layout with the orientation property.

Complete Example:
"use strict";

var React = require('react/addons'),
    {Layout, resizeMixin} = require('r-layout');

var color = c => ({ backgroundColor: c});

var App = React.createClass({
    render() {
        return (
            /*{...this.props} makes sure that the <App> component behaves just like a Layout component.*/
            <Layout {...this.props} orientation="horizontal" style={{outline: "1px #000 solid"}}>
                <Layout size="weight 2" style={color("#D6E6FF")}>
                    I’m on the left, 2/7 of the remaining space wide.
                </Layout>
                <Layout size="weight 5" style={color("lightBlue")}>
                    I’m in the center, taking 5/7 of the remaining space. 
                </Layout>
                <Layout size="60px" style={color("#4EC8CF")}>
                    I’m on the right, 60px wide.
                </Layout>
            </Layout>
        );
    }
});

var Root = React.createClass({
    mixins: [resizeMixin],
    render() {
        return (
            /* The root instance needs a fixes height and width */
            <Layout calculatedWidth={window.innerWidth} calculatedHeight={window.innerHeight}>
                <Layout style={color("#FFEFD6")}>
                    Header, fills the remaining space.
                </Layout>
                {/* Notice that we can control the size of the <App> component just the same as any other Layout */}
                <App size="0.7 ofParent"/>
                <Layout size="50px" style={color("#FFEFD6")}>
                    Footer, fixed height of 50px.
                </Layout>
            </Layout>
        );
    }
});

React.render(<Root />, document.querySelector('body'));

See it in action! Demo / Src

API

Layout

The most important component. Everything else is composed out of <Layout/> components.

Example:
<Layout size="0.1 ofParent">
    Top bar
</Layout>
<Layout orientation="horizontal">
    <Layout size="weight 1">
        Side bar
    </Layout>
    <Layout size="weight 5">
        Content
    </Layout>
</Layout>
<Layout size="50px">
    Footer
</Layout>
    
Attributes:

size: Determines the size of this Layout. Available values:

  • "42px": Size in pixel
  • "0.42 ofParent": 42% of the parent size
  • "weight 4.2": A Layout with a size in weight will fill the remaining space, divided based on the weight value. E.g. two Layouts with "weight 1" / "weight 3" will take 0.25 / 0.75 of the remaining space.
  • "matchChild": Tries to match it's size to that of it's child. Note: Only one child is supported. The child needs to be an element with a size property of "__px" or an element whose size can be immediately determined by rendering it. This can be used to make something exactly the size of it's containing text, or the size of an image.

=> Default: "weight 1"

orientation: Determines how the children are laid out.

  • Either "vertical" or "horizontal".

=> Default: "vertical"

calculatedWidth: Only the root Layout must specify this value.
For the top element use: window.innerWidth.
Everywhere else just pass along the parent values: {...this.props}.
If you need more control you can also directly pass along these values: this.props.calculatedWidth

calculatedHeight: Same as above, replace Width with Height.

absolute: Indicate that this element doesn't takes any space up for others. The element will be positioned exactly like it's parent. Good when things need to be over something else.

free: Similar to absolute, this element won't claim any space. However, it will be positioned like the view port. (This is basically the same as position: fixed;)

dontRender: Indicate that this Layout shouldn't render anything. Used for spacers.

break: Opens the debugger when this Layout is rendered

debug: Displays weird random background colors

These are used internally: calculatedLeft, calculatedTop, children

Spacer

Creates an empty space, same as:

<Layout dontRender />
example:
<Spacer size="weight 2"/>
attributes:

Same as Layout. (Except children)

Center

Centers it's children.

example:
<Center contentHeight="weight 3" horizontalSpacer="50px">
    I'm 3/5 high and (parentSize - 2*50px) wide!
</Center>
```
##### attributes:

Same as Layout plus: 

**contentHeight:** The height of the content. `"Weight x"` will behave as if there were two Spacers around.

=> *Default:* `"weight 1"`

**contentWidth:** Same as above

**verticalSpacer:** The size of the spacers left and right.

=> *Default:* "weight 1"

**horizontalSpacer:** Same as above

**containerProps:** properties you want to pass down to the container object that will surround the children.
    A use might be styling the container with: `containerProps={{style: {color: "red"}}}`


### CenterVertical

Centers it's children vertically

##### example:
````Html
<CenterVertical contentSize="weight 8">
    I'm 8/10 high!
</CenterVertical>
```

##### attributes:

Same as Layout plus: 

**contentSize:** The size of the content. `"weight x"` will behave as if there were two Spacers around.

=> *Default:* `"weight 1"`

**spacerSize:** The size of the spacers around.

=> *Default:* `"weight 1"`

**containerProps:** properties you want to pass down to the container object that will surround the children.
    A use might be styling the container with: `containerProps={{style: {color: "red"}}}`


### CenterHorizontal

Centers it's children horizontally

##### example:
````Html
<CenterHorizontal spacerSize="0.2 ofParent">
    I'm 0.6 of my parent wide!
</CenterHorizontal>
```

##### attributes:

Same as Layout plus: 

**contentSize:** The size of the content. `"weight x"` will behave as if there were two Spacers around.

=> *Default:* `"weight 1"`

**spacerSize:** The size of the spacers around.

=> *Default:* `"weight 1"`

**containerProps:** properties you want to pass down to the container object that will surround the children.
    A use might be styling the container with: `containerProps={{style: {color: "red"}}}`

---
## Develop

First time, run:  
`npm install`  
After that, Just run:  
`grunt dev`

---
## Also try this
[r-animation](https://github.com/Zinggi/RAnimation) - An animation library.

---
## License

[MIT](LICENSE)