mirror of
				https://github.com/phuoc-ng/csslayout.git
				synced 2025-10-26 11:16:11 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			30 lines
		
	
	
		
			834 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			834 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * A collection of popular layouts and patterns made with CSS (https://csslayout.io)
 | |
|  * (c) 2019 - 2021 Nguyen Huu Phuoc <https://twitter.com/nghuuphuoc>
 | |
|  */
 | |
| 
 | |
| import * as 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;
 |