mirror of
https://github.com/idanoo/GoScrobble.git
synced 2024-11-24 17:35:16 +00:00
38 lines
1.2 KiB
JavaScript
38 lines
1.2 KiB
JavaScript
|
import React from 'react';
|
||
|
import PropTypes from 'prop-types';
|
||
|
import classNames from 'classnames';
|
||
|
import { mapToCssModules } from './utils';
|
||
|
|
||
|
var CarouselIndicators = function CarouselIndicators(props) {
|
||
|
var items = props.items,
|
||
|
activeIndex = props.activeIndex,
|
||
|
cssModule = props.cssModule,
|
||
|
onClickHandler = props.onClickHandler,
|
||
|
className = props.className;
|
||
|
var listClasses = mapToCssModules(classNames(className, 'carousel-indicators'), cssModule);
|
||
|
var indicators = items.map(function (item, idx) {
|
||
|
var indicatorClasses = mapToCssModules(classNames({
|
||
|
active: activeIndex === idx
|
||
|
}), cssModule);
|
||
|
return /*#__PURE__*/React.createElement("li", {
|
||
|
key: "" + (item.key || Object.values(item).join('')),
|
||
|
onClick: function onClick(e) {
|
||
|
e.preventDefault();
|
||
|
onClickHandler(idx);
|
||
|
},
|
||
|
className: indicatorClasses
|
||
|
});
|
||
|
});
|
||
|
return /*#__PURE__*/React.createElement("ol", {
|
||
|
className: listClasses
|
||
|
}, indicators);
|
||
|
};
|
||
|
|
||
|
CarouselIndicators.propTypes = {
|
||
|
items: PropTypes.array.isRequired,
|
||
|
activeIndex: PropTypes.number.isRequired,
|
||
|
cssModule: PropTypes.object,
|
||
|
onClickHandler: PropTypes.func.isRequired,
|
||
|
className: PropTypes.string
|
||
|
};
|
||
|
export default CarouselIndicators;
|