mirror of
				https://github.com/phuoc-ng/csslayout.git
				synced 2025-10-26 11:16:11 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			153 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			153 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			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 { Helmet } from 'react-helmet';
 | |
| 
 | |
| import './nested-dropdowns.css';
 | |
| 
 | |
| import RelatedPatterns from '../../components/RelatedPatterns';
 | |
| import Pattern from '../../constants/Pattern';
 | |
| import DetailsLayout from '../../layouts/DetailsLayout';
 | |
| import BrowserFrame from '../../placeholders/BrowserFrame';
 | |
| 
 | |
| const Details: React.FC<{}> = () => {
 | |
|     return (
 | |
|         <DetailsLayout pattern={Pattern.NestedDropdowns}>
 | |
|             <Helmet>
 | |
|                 <meta name="description" content="Create nested dropdown menu with CSS" />
 | |
|                 <meta name="keywords" content="css dropdown menu, css multi-level dropdown menu, css nested dropdown menu" />
 | |
|             </Helmet>
 | |
|             <div className='p-8 pb-20'>
 | |
|                 <div style={{ lineHeight: 1.5, marginBottom: '16px' }}>
 | |
|                     Hover on the Patterns → Navigation to see the sub dropdowns.
 | |
|                 </div>
 | |
|                 <BrowserFrame
 | |
| html={`
 | |
| <ul class="container">
 | |
|     <li>Home</li>
 | |
|     <li>
 | |
|         <div>Patterns</div>
 | |
|         <!-- First level sub dropdown -->
 | |
|         <ul>
 | |
|             <li>Layout</li>
 | |
|             <li>Input</li>
 | |
|             <li>
 | |
|                 <div>Navigation</div>
 | |
|                 <!-- Second level sub dropdown -->
 | |
|                 <ul>
 | |
|                     <li>Breadcrumb</li>
 | |
|                     <li>Dropdown</li>
 | |
|                     <li>Menu</li>
 | |
|                     <li>Nested dropdown</li>
 | |
|                 </ul>
 | |
|             </li>
 | |
|             <li>Display</li>
 | |
|             <li>Feedback</li>
 | |
|         </ul>
 | |
|     </li>
 | |
|     <li>Products</li>
 | |
|     <li>About</li>
 | |
| </ul>
 | |
| `}
 | |
| css={`
 | |
| .container {
 | |
|     /* Border */
 | |
|     border: 1px solid rgba(0, 0, 0, 0.3);
 | |
|     display: flex;
 | |
| 
 | |
|     /* Reset list styles */
 | |
|     list-style-type: none;
 | |
|     margin: 0;
 | |
|     padding: 0;
 | |
| }
 | |
| 
 | |
| .container li {
 | |
|     /* Spacing */
 | |
|     padding: 8px;
 | |
| 
 | |
|     /* Used to position the sub dropdown */
 | |
|     position: relative;
 | |
| }
 | |
| 
 | |
| /* The sub dropdown */
 | |
| .container ul {
 | |
|     /* Border */
 | |
|     border: 1px solid rgba(0, 0, 0, 0.3);
 | |
| 
 | |
|     /* Hidden by default */
 | |
|     display: none;
 | |
| 
 | |
|     /* Absolute position */
 | |
|     left: 0;
 | |
|     position: absolute;
 | |
|     top: 100%;
 | |
| 
 | |
|     /* Reset styles */
 | |
|     list-style-type: none;
 | |
|     margin: 0;
 | |
|     padding: 0;
 | |
| 
 | |
|     /* Width */
 | |
|     width: 200px;
 | |
| }
 | |
| 
 | |
| /* The second level sub dropdown */
 | |
| .container ul ul {
 | |
|     left: 100%;
 | |
|     position: absolute;
 | |
|     top: 0;
 | |
| }
 | |
| 
 | |
| /* Change background color of list item when being hovered */
 | |
| .container li:hover {
 | |
|     background-color: rgba(0, 0, 0, 0.1);
 | |
| }
 | |
| 
 | |
| /* Show the direct sub dropdown when hovering the list item */
 | |
| .container li:hover > ul {
 | |
|     display: block;
 | |
| }
 | |
| `}
 | |
|                 >
 | |
|                     <div
 | |
|                         style={{
 | |
|                             padding: '8px',
 | |
|                         }}
 | |
|                     >
 | |
|                         <ul className="p-nested-dropdowns">
 | |
|                             <li>Home</li>
 | |
|                             <li>
 | |
|                                 <div>Patterns</div>
 | |
|                                 <ul>
 | |
|                                     <li>Layout</li>
 | |
|                                     <li>Input</li>
 | |
|                                     <li>
 | |
|                                         <div>Navigation</div>
 | |
|                                         <ul>
 | |
|                                             <li>Breadcrumb</li>
 | |
|                                             <li>Dropdown</li>
 | |
|                                             <li>Menu</li>
 | |
|                                             <li>Nested dropdown</li>
 | |
|                                         </ul>
 | |
|                                     </li>
 | |
|                                     <li>Display</li>
 | |
|                                     <li>Feedback</li>
 | |
|                                 </ul>
 | |
|                             </li>
 | |
|                             <li>Products</li>
 | |
|                             <li>About</li>
 | |
|                         </ul>
 | |
|                     </div>
 | |
|                 </BrowserFrame>
 | |
|             </div>
 | |
| 
 | |
|             <RelatedPatterns patterns={[Pattern.Dropdown, Pattern.Menu]} />
 | |
|         </DetailsLayout>
 | |
|     );
 | |
| };
 | |
| 
 | |
| export default Details;
 |