UNPKG

4.45 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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
10
11function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
12
13function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
14
15function _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; }
16
17var _react = require('react');
18
19var _react2 = _interopRequireDefault(_react);
20
21var _reactDom = require('react-dom');
22
23var _reactDom2 = _interopRequireDefault(_reactDom);
24
25var _classnames = require('classnames');
26
27var _classnames2 = _interopRequireDefault(_classnames);
28
29var _reactTappable = require('react-tappable');
30
31var _reactTappable2 = _interopRequireDefault(_reactTappable);
32
33var Tab = (function (_React$Component) {
34 _inherits(Tab, _React$Component);
35
36 function Tab(props) {
37 _classCallCheck(this, Tab);
38
39 _get(Object.getPrototypeOf(Tab.prototype), 'constructor', this).call(this, props);
40 this.handleTabDeleteButton = this.handleTabDeleteButton.bind(this);
41 this.clickTab = this.clickTab.bind(this);
42 }
43
44 _createClass(Tab, [{
45 key: 'handleTabDeleteButton',
46 value: function handleTabDeleteButton(e) {
47 e.stopPropagation(); //prevent trigger clickTab function
48 this.props.handleTabDeleteButton(this.props.tabKey);
49 }
50 }, {
51 key: 'clickTab',
52 value: function clickTab() {
53 this.props.handleTabClick(this.props.tabKey);
54 }
55 }, {
56 key: 'render',
57 value: function render() {
58 var tabClass = undefined,
59 closeButtonStyle = undefined;
60 var _props = this.props;
61 var connectDragSource = _props.connectDragSource;
62 var connectDropTarget = _props.connectDropTarget;
63
64 if (this.props.status === 'active') {
65 tabClass = (0, _classnames2['default'])(this.props.style + 'tab', 'active');
66 } else {
67 tabClass = (0, _classnames2['default'])(this.props.style + 'tab');
68 }
69
70 // only show the delete button when it's active
71 if (this.props.tabDeleteButton && this.props.status === "active") {
72 closeButtonStyle = { display: 'inline-block' };
73 } else {
74 closeButtonStyle = { display: 'none' };
75 }
76
77 return _react2['default'].createElement(
78 'div',
79 { className: tabClass, onClick: this.clickTab },
80 this.props.title,
81 _react2['default'].createElement(
82 'div',
83 { className: 'tabtab__folder__circCont', style: closeButtonStyle },
84 _react2['default'].createElement('div', { className: 'tabtab__folder__circle', onClick: this.handleTabDeleteButton })
85 )
86 );
87 }
88 }]);
89
90 return Tab;
91})(_react2['default'].Component);
92
93exports['default'] = Tab;
94module.exports = exports['default'];
\No newline at end of file