react-framestack
v0.1.0
Published
Conditionally render frames based on stack index
Downloads
2
Maintainers
Readme
React-Framestack
yarn add react-framestack
Components
Stack
<Stack>{/* ... */}<Stack>
Props
stack
name for the stack; frames subscribe to a stackstartAt
initial index
Provides Context (subscribe through Frame)
index
selected framedispatch
trigger action (like Redux)dispatch("goForward")
dispatch("goForward")
dispatch("jumpTo", index)
Frame
<Frame frame={0} exact={true} stack='slides'>{dispatch => <h1>One</h1>}<Frame>
Props
frame
hide unless frame matches indexexact
(defaults to true) if false, show if index is>=
frame instead of===
stack
(defaults to 'slides') stack to subscribe tochildren
function that takesdispatch
as an argument
Example: Building a Slideshow (Codepen)
import { Stack, Frame } from 'react-framestack'
const lorem = `Lorem ipsum dolor sit amet`;
const NavButton = ({ navigate, children, ...props }) => {
const handleClick = e => {
e.preventDefault();
e.stopPropagation();
navigate();
};
return (
<span {...props} onClick={handleClick}>
{children}
</span>
);
};
const Slide = ({ next, prev, children }) => (
<div className="slide" onClick={next}>
{children}
<NavButton
style={{ position: "absolute", bottom: "1em", left: "1em" }}
navigate={prev}
>
←
</NavButton>
<NavButton
style={{ position: "absolute", bottom: "1em", right: "1em" }}
navigate={next}
>
→
</NavButton>
</div>
);
const Title = ({ children }) => <h1>{children}</h1>;
const Body = ({ color = "black", children }) => (
<p style={{ color: color }}>{children}</p>
);
// Helper to simplify events
const createSlide = Component => dispatch => {
const next = () => dispatch("goForward");
const prev = () => dispatch("goBack");
return (
<Slide next={next} prev={prev}>
<Component />
</Slide>
);
};
const SlideOne = createSlide(() => (
<div>
<Title>Slide One</Title>
<Body>{lorem}</Body>
</div>
));
const SlideTwo = createSlide(() => (
<div>
<Title>Slide Two</Title>
<Body color="red">{lorem}</Body>
</div>
));
const End = dispatch => (
<div className="slide" style={{ background: "black" }}>
<p>
<a href="#" onClick={() => dispatch("jumpTo", 0)}>
Restart
</a>
</p>
</div>
);
const SlideShow = () => (
<Stack stack="slides">
{[SlideOne, SlideTwo, End].map((slide, i) => (
<Frame frame={i} stack="slides" key={slide.name}>
{slide}
</Frame>
))}
</Stack>
);