mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	* Footer: Single footer implementation for both react & angular pages * Export type * Updates * Use footer links in help menu * Updates & Fixes * Updated snapshot * updated snapshot
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| // Libraries
 | |
| import React, { Component } from 'react';
 | |
| import { getTitleFromNavModel } from 'app/core/selectors/navModel';
 | |
| 
 | |
| // Components
 | |
| import PageHeader from '../PageHeader/PageHeader';
 | |
| import { Footer } from '../Footer/Footer';
 | |
| import PageContents from './PageContents';
 | |
| import { CustomScrollbar } from '@grafana/ui';
 | |
| import { NavModel } from '@grafana/data';
 | |
| import { isEqual } from 'lodash';
 | |
| 
 | |
| interface Props {
 | |
|   children: JSX.Element[] | JSX.Element;
 | |
|   navModel: NavModel;
 | |
| }
 | |
| 
 | |
| class Page extends Component<Props> {
 | |
|   static Header = PageHeader;
 | |
|   static Contents = PageContents;
 | |
| 
 | |
|   componentDidMount() {
 | |
|     this.updateTitle();
 | |
|   }
 | |
| 
 | |
|   componentDidUpdate(prevProps: Props) {
 | |
|     if (!isEqual(prevProps.navModel, this.props.navModel)) {
 | |
|       this.updateTitle();
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   updateTitle = () => {
 | |
|     const title = this.getPageTitle;
 | |
|     document.title = title ? title + ' - Grafana' : 'Grafana';
 | |
|   };
 | |
| 
 | |
|   get getPageTitle() {
 | |
|     const { navModel } = this.props;
 | |
|     if (navModel) {
 | |
|       return getTitleFromNavModel(navModel) || undefined;
 | |
|     }
 | |
|     return undefined;
 | |
|   }
 | |
| 
 | |
|   render() {
 | |
|     const { navModel } = this.props;
 | |
|     return (
 | |
|       <div className="page-scrollbar-wrapper">
 | |
|         <CustomScrollbar autoHeightMin={'100%'} className="custom-scrollbar--page">
 | |
|           <div className="page-scrollbar-content">
 | |
|             <PageHeader model={navModel} />
 | |
|             {this.props.children}
 | |
|             <Footer />
 | |
|           </div>
 | |
|         </CustomScrollbar>
 | |
|       </div>
 | |
|     );
 | |
|   }
 | |
| }
 | |
| 
 | |
| export default Page;
 |