@beisen/ethos
Version:
beisencloud pc react components
89 lines (62 loc) • 2.55 kB
JavaScript
;
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 _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _panel = require('./panel.js');
var _panel2 = _interopRequireDefault(_panel);
require('./accordion.scss');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var Accordion = function (_Component) {
(0, _inherits3.default)(Accordion, _Component);
function Accordion(props) {
(0, _classCallCheck3.default)(this, Accordion);
var _this = (0, _possibleConstructorReturn3.default)(this, (Accordion.__proto__ || (0, _getPrototypeOf2.default)(Accordion)).call(this, props));
_this.state = props;
_this.handleClick = _this.handleClick.bind(_this);
return _this;
}
(0, _createClass3.default)(Accordion, [{
key: 'componentWillMount',
value: function componentWillMount() {
// let propsChildren = this.props.children;
// propsChildren.map((item,index)=>{item.active = false});
// propsChildren[this.props.showIndex-1].active = true;
// this.setState({children:propsChildren});
}
}, {
key: 'handleClick',
value: function handleClick(index) {
this.setState({ showIndex: index });
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var hidden = this.props.hidden;
var paneList = this.props.children.map(function (item, index) {
return _react2.default.createElement(_panel2.default, { key: index, showIndex: _this2.state.showIndex, item: item, index: index, handleClick: _this2.handleClick });
});
if (!hidden) {
return _react2.default.createElement('div', null);
} else {
return _react2.default.createElement(
'div',
{ className: 'panel-container' },
paneList
);
}
}
}]);
return Accordion;
}(_react.Component);
module.exports = Accordion;