mirror of
				https://github.com/phuoc-ng/csslayout.git
				synced 2025-10-23 10:46:13 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React from 'react';
 | |
| import loadable from '@loadable/component';
 | |
| 
 | |
| import './spinner.css';
 | |
| 
 | |
| const slug = item => item.toLowerCase().split(' ').join('-');
 | |
| 
 | |
| // In order to create a link to another page that is dynamically loaded (via <Link to="...">),
 | |
| // the page chunks have to be loadable by @loadable.
 | |
| // We have to add a magic comment /* #__LOADABLE__ */ here
 | |
| // and the following plugin to Babel's settings (.babelrc):
 | |
| //  {
 | |
| //      "plugins": ["@loadable/babel-plugin"],
 | |
| //  }
 | |
| const loadDetails = /* #__LOADABLE__ */ (props) => import(`../patterns/${slug(props.pattern)}/Details`)
 | |
| 
 | |
| const DetailsLoader = loadable(loadDetails, {
 | |
|     fallback: (
 | |
|         <div className="w100 h-100 flex items-center justify-center">
 | |
|             <svg className="spinner" width="64px" height="64px" viewBox="0 0 32 32">
 | |
|                 <circle
 | |
|                     cx="16"
 | |
|                     cy="16"
 | |
|                     fill="none"
 | |
|                     r="12"
 | |
|                     stroke="rgba(0, 0, 0, 0.4)"
 | |
|                     strokeDasharray={Math.PI * 2 * 9}
 | |
|                     strokeLinecap="round"
 | |
|                     strokeWidth="4"
 | |
|                 />
 | |
|             </svg>
 | |
|         </div>
 | |
|     )
 | |
| });
 | |
| 
 | |
| export default DetailsLoader;
 |