UNPKG

5.55 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 _country = require('../country');
18
19var _country2 = _interopRequireDefault(_country);
20
21var _tableHeader = require('../table-header');
22
23var _tableHeader2 = _interopRequireDefault(_tableHeader);
24
25var _navigationColumn = require('./navigation-column');
26
27var _navigationColumn2 = _interopRequireDefault(_navigationColumn);
28
29var _react = require('react');
30
31var _react2 = _interopRequireDefault(_react);
32
33function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
34
35function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
36
37function _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; }
38
39function _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; }
40
41var Head = function (_Component) {
42 _inherits(Head, _Component);
43
44 function Head() {
45 var _ref;
46
47 var _temp, _this, _ret;
48
49 _classCallCheck(this, Head);
50
51 for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
52 args[_key] = arguments[_key];
53 }
54
55 return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = Head.__proto__ || Object.getPrototypeOf(Head)).call.apply(_ref, [this].concat(args))), _this), _this.step = function () {
56 var top = _this.refs.component.getBoundingClientRect().top;
57 var offset = top > 0 ? 0 : Math.abs(top);
58 _this.refs.header.refs.component.style.transform = 'translateY(' + offset + 'px)';
59 _this.refs.navigation.refs.header.style.transform = 'translateY(' + offset + 'px)';
60 _this.requestId = requestAnimationFrame(_this.step);
61 }, _temp), _possibleConstructorReturn(_this, _ret);
62 }
63
64 /**
65 * Define the proptypes of the component.
66 *
67 * @type {Object}
68 */
69
70
71 _createClass(Head, [{
72 key: 'componentDidMount',
73
74
75 /**
76 * Invoked when the component is mounted.
77 *
78 * @return {void}
79 */
80 value: function componentDidMount() {
81 this.requestId = requestAnimationFrame(this.step);
82 }
83
84 /**
85 * Invoked when the component will unmount.
86 *
87 * @return {void}
88 */
89
90 }, {
91 key: 'componentWillUnmount',
92 value: function componentWillUnmount() {
93 cancelAnimationFrame(this.requestId);
94 }
95
96 /**
97 * Move the header according to the scroll position.
98 *
99 * @return {void}
100 */
101
102 }, {
103 key: 'render',
104
105
106 /**
107 * Render the component.
108 *
109 * @return {ReactElement}
110 */
111 value: function render() {
112 return _react2.default.createElement(
113 'thead',
114 { ref: 'component', className: _style2.default.head },
115 _react2.default.createElement(
116 'tr',
117 { className: [_style2.default.column, _style2.default.head_column].join(' ') },
118 _react2.default.createElement(
119 _tableHeader2.default,
120 {
121 id: 'label',
122 ref: 'header',
123 className: _style2.default.head_header,
124 onClick: this.props.onHeaderClick,
125 active: this.props.sortBy === 'label',
126 orderBy: this.props.orderByDesc ? 'DESC' : 'ASC'
127 },
128 'Points from'
129 ),
130 this.props.entries.map(function (entry) {
131 return _react2.default.createElement(
132 _tableItem2.default,
133 { key: entry.code, className: _style2.default.head_item },
134 _react2.default.createElement(_country2.default, { label: entry.label, code: entry.code })
135 );
136 })
137 ),
138 _react2.default.createElement(_navigationColumn2.default, {
139 ref: 'navigation',
140 direction: 'left',
141 entries: this.props.entries,
142 visible: this.props.showNavigation
143 })
144 );
145 }
146 }]);
147
148 return Head;
149}(_react.Component);
150
151Head.propTypes = {
152 sortBy: _react.PropTypes.string.isRequired,
153 entries: _react.PropTypes.array.isRequired,
154 orderByDesc: _react.PropTypes.bool.isRequired,
155 onHeaderClick: _react.PropTypes.func.isRequired,
156 showNavigation: _react.PropTypes.bool.isRequired
157};
158exports.default = Head;
\No newline at end of file