82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| import React from "react"
 | |
| import loader from "./loader"
 | |
| import shallowCompare from "shallow-compare"
 | |
| 
 | |
| class EnsureResources extends React.Component {
 | |
|   constructor(props) {
 | |
|     super()
 | |
|     const { location, pageResources } = props
 | |
|     this.state = {
 | |
|       location: { ...location },
 | |
|       pageResources: pageResources || loader.loadPageSync(location.pathname),
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   static getDerivedStateFromProps({ location }, prevState) {
 | |
|     if (prevState.location.href !== location.href) {
 | |
|       const pageResources = loader.loadPageSync(location.pathname)
 | |
|       return {
 | |
|         pageResources,
 | |
|         location: { ...location },
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     return {
 | |
|       location: { ...location },
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   loadResources(rawPath) {
 | |
|     loader.loadPage(rawPath).then(pageResources => {
 | |
|       if (pageResources && pageResources.status !== `error`) {
 | |
|         this.setState({
 | |
|           location: { ...window.location },
 | |
|           pageResources,
 | |
|         })
 | |
|       } else {
 | |
|         window.history.replaceState({}, ``, location.href)
 | |
|         window.location = rawPath
 | |
|       }
 | |
|     })
 | |
|   }
 | |
| 
 | |
|   shouldComponentUpdate(nextProps, nextState) {
 | |
|     // Always return false if we're missing resources.
 | |
|     if (!nextState.pageResources) {
 | |
|       this.loadResources(nextProps.location.pathname)
 | |
|       return false
 | |
|     }
 | |
| 
 | |
|     // Check if the component or json have changed.
 | |
|     if (this.state.pageResources !== nextState.pageResources) {
 | |
|       return true
 | |
|     }
 | |
|     if (
 | |
|       this.state.pageResources.component !== nextState.pageResources.component
 | |
|     ) {
 | |
|       return true
 | |
|     }
 | |
| 
 | |
|     if (this.state.pageResources.json !== nextState.pageResources.json) {
 | |
|       return true
 | |
|     }
 | |
|     // Check if location has changed on a page using internal routing
 | |
|     // via matchPath configuration.
 | |
|     if (
 | |
|       this.state.location.key !== nextState.location.key &&
 | |
|       nextState.pageResources.page &&
 | |
|       (nextState.pageResources.page.matchPath ||
 | |
|         nextState.pageResources.page.path)
 | |
|     ) {
 | |
|       return true
 | |
|     }
 | |
|     return shallowCompare(this, nextProps, nextState)
 | |
|   }
 | |
| 
 | |
|   render() {
 | |
|     return this.props.children(this.state)
 | |
|   }
 | |
| }
 | |
| 
 | |
| export default EnsureResources
 |