UNPKG

5.4 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
8
9var _style = require('./style.css');
10
11var _style2 = _interopRequireDefault(_style);
12
13var _tableItem = require('../table-item');
14
15var _tableItem2 = _interopRequireDefault(_tableItem);
16
17var _tableHeader = require('../table-header');
18
19var _tableHeader2 = _interopRequireDefault(_tableHeader);
20
21var _navigationColumn = require('./navigation-column');
22
23var _navigationColumn2 = _interopRequireDefault(_navigationColumn);
24
25var _react = require('react');
26
27var _react2 = _interopRequireDefault(_react);
28
29function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
30
31function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
32
33function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
34
35function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
36
37var Foot = function (_Component) {
38 _inherits(Foot, _Component);
39
40 function Foot() {
41 var _ref;
42
43 var _temp, _this, _ret;
44
45 _classCallCheck(this, Foot);
46
47 for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
48 args[_key] = arguments[_key];
49 }
50
51 return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Foot.__proto__ || Object.getPrototypeOf(Foot)).call.apply(_ref, [this].concat(args))), _this), _this.step = function () {
52 var top = _this.refs.component.getBoundingClientRect().top;
53 var offset = top > 0 ? 0 : Math.abs(top);
54 _this.refs.header.refs.component.style.transform = 'translateY(' + offset + 'px)';
55 _this.refs.navigation.refs.header.style.transform = 'translateY(' + offset + 'px)';
56 _this.requestId = requestAnimationFrame(_this.step);
57 }, _temp), _possibleConstructorReturn(_this, _ret);
58 }
59
60 /**
61 * Define the proptypes of the component.
62 *
63 * @type {Object}
64 */
65
66
67 _createClass(Foot, [{
68 key: 'componentDidMount',
69
70
71 /**
72 * Invoked when the component is mounted.
73 *
74 * @return {void}
75 */
76 value: function componentDidMount() {
77 this.requestId = requestAnimationFrame(this.step);
78 }
79
80 /**
81 * Invoked when the component will unmount.
82 *
83 * @return {void}
84 */
85
86 }, {
87 key: 'componentWillUnmount',
88 value: function componentWillUnmount() {
89 cancelAnimationFrame(this.requestId);
90 }
91
92 /**
93 * Move the header according to the scroll position.
94 *
95 * @return {void}
96 */
97
98 }, {
99 key: 'render',
100
101
102 /**
103 * Render the component.
104 *
105 * @return {ReactElement}
106 */
107 value: function render() {
108 return _react2.default.createElement(
109 'tfoot',
110 { ref: 'component', className: _style2.default.foot },
111 _react2.default.createElement(_navigationColumn2.default, {
112 ref: 'navigation',
113 direction: 'right',
114 entries: this.props.entries,
115 visible: this.props.showNavigation
116 }),
117 _react2.default.createElement(
118 'tr',
119 { className: [_style2.default.column, _style2.default.foot_column].join(' ') },
120 _react2.default.createElement(
121 _tableHeader2.default,
122 {
123 id: 'place',
124 ref: 'header',
125 className: _style2.default.foot_header,
126 onClick: this.props.onHeaderClick,
127 active: this.props.sortBy === 'place',
128 orderBy: this.props.orderByDesc ? 'DESC' : 'ASC'
129 },
130 'Place'
131 ),
132 this.props.entries.map(function (entry) {
133 return _react2.default.createElement(
134 _tableItem2.default,
135 { key: entry.place, className: _style2.default.foot_item, align: 'right' },
136 entry.place
137 );
138 })
139 )
140 );
141 }
142 }]);
143
144 return Foot;
145}(_react.Component);
146
147Foot.propTypes = {
148 sortBy: _react.PropTypes.string.isRequired,
149 entries: _react.PropTypes.array.isRequired,
150 orderByDesc: _react.PropTypes.bool.isRequired,
151 onHeaderClick: _react.PropTypes.func.isRequired,
152 showNavigation: _react.PropTypes.bool.isRequired
153};
154exports.default = Foot;
\No newline at end of file