mirror of
https://github.com/phuoc-ng/csslayout.git
synced 2025-10-24 19:26:26 +02:00
30 lines
829 B
TypeScript
30 lines
829 B
TypeScript
/**
|
|
* A collection of popular layouts and patterns made with CSS (https://csslayout.io)
|
|
* (c) 2019 - 2020 Nguyen Huu Phuoc <https://twitter.com/nghuuphuoc>
|
|
*/
|
|
|
|
import React from 'react';
|
|
|
|
import Pattern from '../constants/Pattern';
|
|
import DetailsLoader from '../loaders/DetailsLoader';
|
|
|
|
interface PatternPageProps {
|
|
pattern: string;
|
|
}
|
|
|
|
const capitalizeFirstLetter = (s: string) => `${s.charAt(0).toUpperCase()}${s.slice(1)}`;
|
|
|
|
const PatternPage: React.FC<PatternPageProps> = ({ pattern }) => {
|
|
const name = pattern.split('-').map((s) => capitalizeFirstLetter(s)).join('');
|
|
const patterns = Object.keys(Pattern);
|
|
|
|
return (
|
|
patterns.indexOf(name) === -1
|
|
// TODO: Render 404
|
|
? <div>404</div>
|
|
: <DetailsLoader pattern={pattern} />
|
|
);
|
|
};
|
|
|
|
export default PatternPage;
|