- Book 7: A merry go round 😄
Slowly things are coming together
I'll reuse the crop-css-pattern for centering the picture-container and put another container in there that adheres to the pack-css-pattern
import React from 'react';
import { Picture } from '.';
import styles from './Carousel.module.sass';
export interface IProps {
currentStart: number;
data: string[];
}
interface IState {
}
export class Component extends React.Component<IProps, IState> {
public imgCount = 5;
public render(): React.ReactNode {
const { data, currentStart } = this.props;
console.log(data);
return (
<article aria-label="gallery" className={`${styles.container_outer} o-crop`}>
<section className={`${styles.container_inner} o-crop__content 0-crop__content--center o-pack`}>
{data.filter((d, i) => (i >= currentStart && i < this.imgCount + currentStart)).map((imgUrl, i) => {
console.log(imgUrl);
return (
<Picture.Component
imgUrl={imgUrl}
picNr={i}
key={`pic_nr${i}`}
className="o-pack__item"
/>
);
})}
</section>
</article>
);
}
}
We still need to style as to fit the imgs that are as of now predefined to 128px width and dynamic height ... into the viewports width. components/Carousel.module.sass
.container_outer
overflow: hidden;
height: 200px;
.container_inner
height: 150px;
&> article:nth-child(1,5)
transform: scale(33%)
&> article:nth-child(2,4)
transform: scale(66%)