-
Notifications
You must be signed in to change notification settings - Fork 182
/
Copy pathReveal.js
56 lines (48 loc) · 1.59 KB
/
Reveal.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/*
* Reveal React Component
*
* Copyright © Roman Nosov 2017
*
* This source code is licensed under the MIT license found in the
* LICENSE.txt file in the root directory of this source tree.
*/
import { bool, string, number, object, oneOf, oneOfType } from 'prop-types';
import { defaults } from './lib/globals';
import wrap from './lib/wrap';
import Fade from './in-and-out/Fade';
const
propTypes = {
in: object,
out: oneOfType([object, oneOf([ false ]) ]),
effect: string,
effectOut: string,
duration: number,
timeout: number,
delay: number,
count: number,
forever: bool,
durationOut: number,
delayOut: number,
countOut: number,
foreverOut: bool,
},
defaultProps = {
...defaults,
durationOut: defaults.duration ,
delayOut: defaults.delay,
countOut: defaults.count,
foreverOut: defaults.forever,
inEffect: Fade(defaults),
outEffect: Fade({ out: true, ...defaults }),
};
function Reveal({ children, timeout, duration, delay, count, forever, durationOut, delayOut, countOut, foreverOut, effect, effectOut, inEffect, outEffect, ...props}) {
function factory(reverse) {
return reverse
? effectOut ? { duration: durationOut, delay: delayOut, count: countOut, forever: foreverOut, className: effectOut, style: {} } : outEffect
: effect ? { duration: timeout === undefined ? duration : timeout, delay, count, forever, className: effect, style: {} } : inEffect;
}
return wrap(props, factory(false), factory(true), children);
}
Reveal.propTypes = propTypes;
Reveal.defaultProps = defaultProps;
export default Reveal;