react-stack-grid-compat
v1.0.0-beta.1
Published
react-stack-grid, but compatible with React 0.14
Downloads
3
Maintainers
Readme
react-stack-grid-compat
Pinterest like layout components for React.js.
Live Demo
https://tsuyoshiwada.github.io/react-stack-grid/
Install
You can install the react-stack-grid-compat from npm.
$ npm install react-stack-grid-compat
Quick Example
Following code is simplest usage.
import React, { Component } from "react";
import StackGrid from "react-stack-grid-compat";
class MyComponent extends Component {
render() {
return (
<StackGrid
columnWidth={150}
>
<div key="key1">Item 1</div>
<div key="key2">Item 2</div>
<div key="key3">Item 3</div>
</StackGrid>
);
}
}
width of parent is managed by react-sizeme.
Props
You can set the following properties.
| Property | Type | Default | Description |
|:----------------------|:------------------------------------------------------------|:---------------------------------|:----------------------------------------------------------------------------------------------------------------------------------------|
| className
| PropTypes.string
| undefined
| Specify className
of component. |
| style
| PropTypes.object
| {}
| Original style of component. Following styles are ignored. (position
, height
, transition
) |
| component
| PropTypes.string
| "div"
| See ReactTransitionGroup |
| columnWidth
| PropTypes.oneOfType([PropTypes.number, PropTypes.string])
| 150
| Specify column width as an number(px
), or percentage string. (Example "33.33%"
) |
| gutterWidth
| PropTypes.number
| 5
| Specify gutter width as an number. |
| gutterHeight
| PropTypes.number
| 5
| Specify gutter height as an number. |
| duration
| PropTypes.number
| 480
| Specify duration of animation in ms. |
| easing
| PropTypes.string
| easings.quartOut
| Specify a css valid transition-timing-function string. It can be easily specification by using easings
. |
| appearDelay
| PropTypes.number
| 30
| Specify delay of the initial animation in ms. |
| appear
| PropTypes.func
| fadeUp.appear
| See Animations section. |
| appeared
| PropTypes.func
| fadeUp.appear
| ... |
| enter
| PropTypes.func
| fadeUp.appear
| ... |
| entered
| PropTypes.func
| fadeUp.appear
| ... |
| leaved
| PropTypes.func
| fadeUp.appear
| ... |
| units
| PropTypes.func
| { length: "px", angle: "deg" }
| ... |
| monitorImagesLoaded
| PropTypes.bool
| false
| If set to true
, images reading is monitored. use imagesloaded. |
| vendorPrefix
| PropTypes.bool
| false
| If set to true
, add a vendor prefix to styles add dynamically. |
| userAgent
| PropTypes.string
| undefined
| Specify userAgent for determinig the vendor prefix. See inline-style-prefixer. |
Animations
The following function must return styles related to animation.
See ReactTransitionGroup for details.
appear
appeared
enter
entered
leaved
You can use extended syntax for transform's style. For example properties like translateX
and scale
.
See easy-css-transform-builder.
Each function is given the following arguments.
rect: { top: number; left: number; width: number; height: number; }
containerSize: { width: number; height: number; }
index: number
It is easiest to use them because you have several presets.
fade
fadeDown
fadeUp
scaleDown
scaleUp
flip
helix
It's an actual use example.
import StackGrid, { transitions } from "react-stack-grid";
const { scaleDown } = transitions;
class MyComponent extends Component {
render() {
return (
<StackGrid
...
appear={scaleDown.appear}
appeared={scaleDown.appeared}
enter={scaleDown.enter}
entered={scaleDown.entered}
leaved={scaleDown.leaved}
>
...
</StackGrid>
);
}
}
Please try actual demonstration in live demo.
Tips
Performance when using images
When true
is specified for monitorImagesLoaded
, reloading occurs when the image loading is completed.
If you know the size in advance, specify monitorImagesLoaded
as false
.
When animation is unnecessary
By default animation is enabled.
If it's not necessary, specify 0
for duration
property.
<StackGrid
...
duration={0}
>
...
</StackGrid/>
TODO
- [x] Support
%
columnWidth.
Thanks
- Layout inspired by Pinterest.
- API inspired by dantrain/react-stonecutter.
License
Released under the MIT Licence
ChangeLog
See CHANGELOG.md
Author
Development
Initialization of the project.
$ cd /your/project/dir
$ git clone https://github.com/jameswomack/react-stack-grid-compat.git
Install some dependencies.
$ npm install
Start the development and can you see demo page (access to the http://localhost:3000/
).
$ npm start
Run lint and testing.
$ npm test
Generates build file.
$ npm run build
Contribution
Thank you for your interest in react-stack-grid.js.
Bugs, feature requests and comments are more than welcome in the issues.
Before you open a PR:
Be careful to follow the code style of the project. Run npm test
after your changes and ensure you do not introduce any new errors or warnings.
All new features and changes need documentation.
Thanks!