This repository was archived by the owner on Nov 26, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtoggle.js
106 lines (78 loc) · 3.11 KB
/
toggle.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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
'use strict';
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _class, _temp;
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var React = require('react');
var T = require('prop-types');
var StrangeMotion = require('./index');
var _require = require('react-motion'),
TransitionMotion = _require.TransitionMotion;
// Component
module.exports = (_temp = _class = function (_StrangeMotion) {
(0, _inherits3.default)(ToggleMotion, _StrangeMotion);
function ToggleMotion(props) {
(0, _classCallCheck3.default)(this, ToggleMotion);
var _this = (0, _possibleConstructorReturn3.default)(this, (ToggleMotion.__proto__ || (0, _getPrototypeOf2.default)(ToggleMotion)).call(this, props));
_this.setRef = _this._setRef.bind(_this);
return _this;
}
(0, _createClass3.default)(ToggleMotion, [{
key: '_setRef',
value: function _setRef(refName) {
var _this2 = this;
return function (ref) {
_this2[refName] = ref;
};
}
}, {
key: 'filterChildrenForType',
value: function filterChildrenForType(children) {
var trigger = this.props.trigger;
if (trigger === true) {
return children.filter(function (child) {
return child.key === 'on';
});
} else if (trigger === false) {
return children.filter(function (child) {
return child.key === 'off';
});
}
throw new Error('ToggleMotion: Bad value for trigger: ' + trigger);
}
}, {
key: 'render',
value: function render() {
var _this3 = this;
return React.createElement(
TransitionMotion,
{
defaultStyles: this.getDefaultStyles(),
styles: this.getStyles(),
willEnter: this.willEnter,
willLeave: this.willLeave,
ref: this.setRef('reactMotion')
},
function (interpolatedStyles) {
return _this3.getChildren(interpolatedStyles);
}
);
}
}]);
return ToggleMotion;
}(StrangeMotion), _class.propTypes = {
trigger: T.bool,
animConfig: T.shape({
start: T.object,
enter: T.object,
leave: T.object.isRequired
})
}, _temp);