2018-01-30 11:53:12 -05:00
|
|
|
const classNames = require('classnames');
|
|
|
|
const defaults = require('lodash.defaults');
|
|
|
|
const PropTypes = require('prop-types');
|
|
|
|
const React = require('react');
|
2018-03-08 10:04:58 -05:00
|
|
|
const Slider = require('react-slick').default;
|
2015-12-21 13:30:22 -05:00
|
|
|
|
2018-01-30 11:53:12 -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');
|
2016-02-19 15:11:23 -05:00
|
|
|
require('./nestedcarousel.scss');
|
2015-12-21 13:30:22 -05:00
|
|
|
|
2016-02-19 15:11:23 -05:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
/*
|
2016-02-19 15:11:23 -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.
|
2018-01-30 11:53:12 -05:00
|
|
|
*/
|
|
|
|
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
|
|
|
|
2018-01-30 11:53:12 -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
|
|
|
}
|
2018-01-30 11:53:12 -05:00
|
|
|
stages.push(
|
|
|
|
<div key={`outer_${i}`}>
|
|
|
|
<h3>{props.items[i].title}</h3>
|
|
|
|
{thumbnails}
|
|
|
|
</div>
|
2015-12-21 13:30:22 -05:00
|
|
|
);
|
|
|
|
}
|
2018-01-30 11:53:12 -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
|
|
|
|
2016-02-19 15:11:23 -05:00
|
|
|
module.exports = NestedCarousel;
|