scratch-www/src/components/nestedcarousel/nestedcarousel.jsx

85 lines
2.4 KiB
React
Raw Normal View History

const classNames = require('classnames');
const defaults = require('lodash.defaults');
const PropTypes = require('prop-types');
const React = require('react');
const Slider = require('react-slick').default;
2015-12-21 13:30:22 -05:00
const Thumbnail = require('../thumbnail/thumbnail.jsx');
2015-12-21 13:30:22 -05:00
require('slick-carousel/slick/slick.scss');
require('slick-carousel/slick/slick-theme.scss');
require('./nestedcarousel.scss');
2015-12-21 13:30:22 -05:00
/*
NestedCarousel is used to show a carousel, where each slide is composed of a few
thumbnails (for example, to show step-by-syep tips, where each stage has a few steps).
It creates the thumbnails without links.
Each slide has a title, and then a list of thumbnails, that will be shown together.
*/
const NestedCarousel = props => {
defaults(props.settings, {
dots: true,
infinite: false,
lazyLoad: true,
slidesToShow: 1,
slidesToScroll: 1,
variableWidth: false
});
2015-12-21 13:30:22 -05:00
const arrows = props.items.length > props.settings.slidesToShow;
const stages = [];
for (let i = 0; i < props.items.length; i++) {
const items = props.items[i].thumbnails;
const thumbnails = [];
for (let j = 0; j < items.length; j++) {
const item = items[j];
thumbnails.push(
<Thumbnail
key={`inner_${i}_${j}`}
linkTitle={false}
src={item.thumbnailUrl}
title={item.title}
/>
);
2018-01-30 09:54:45 -05:00
}
stages.push(
<div key={`outer_${i}`}>
<h3>{props.items[i].title}</h3>
{thumbnails}
</div>
2015-12-21 13:30:22 -05:00
);
}
return (
<Slider
arrows={arrows}
className={classNames('nestedcarousel', 'carousel', props.className)}
{...props.settings}
>
{stages}
</Slider>
);
};
NestedCarousel.propTypes = {
className: PropTypes.string,
items: PropTypes.arrayOf(PropTypes.object),
settings: PropTypes.shape({
dots: PropTypes.bool,
infinite: PropTypes.bool,
lazyLoad: PropTypes.bool,
slidesToShow: PropTypes.number,
slidesToScroll: PropTypes.number,
variableWidth: PropTypes.bool
})
};
NestedCarousel.defaultProps = {
settings: {},
items: require('./nestedcarousel.json')
};
2015-12-21 13:30:22 -05:00
module.exports = NestedCarousel;