Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[1.0] optimizations around prefetching page resources #1133

Merged
merged 29 commits into from
Jun 10, 2017
Merged
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
c0ae4f9
Copy cache-dir files into site's .cache
KyleAMathews Jun 7, 2017
291b69c
Got new loader/componentrenderer working in development
KyleAMathews Jun 7, 2017
f92fdb9
Use ComponentRenderer for rendering
KyleAMathews Jun 7, 2017
f6c3112
On demand loading of async page resources working for prod builds
KyleAMathews Jun 7, 2017
d0ae0e6
Merge branch '1.0' into queue-requests
KyleAMathews Jun 7, 2017
0c8abd7
Use script loader so loading scripts don't block rendering
KyleAMathews Jun 7, 2017
69f60ae
Add gatsby-module-loader to replace bundle-loader to add ability to d…
KyleAMathews Jun 8, 2017
1f44c11
Split out loading/executing resources into functions
KyleAMathews Jun 8, 2017
f289c38
Add prefetcher
KyleAMathews Jun 8, 2017
389f7e9
changing order to see if it fixes not removing event handler
KyleAMathews Jun 8, 2017
b0f2c88
Just don't have a loader for now
KyleAMathews Jun 8, 2017
d4a841b
Updates to service worker plugin
KyleAMathews Jun 9, 2017
f2f368b
Add tests for find-page + make it work with prefixed links
KyleAMathews Jun 9, 2017
9ae6a60
Proritize links that mount first i.e. are higher on the page
KyleAMathews Jun 9, 2017
7766b77
Wait for all links to mount before fetching so resource count is correct
KyleAMathews Jun 9, 2017
ab5da7f
Add plop template for adding new example sites
KyleAMathews Jun 10, 2017
c7dd9b1
Add plugin for nprogress to auto show when page loading is delayed
KyleAMathews Jun 10, 2017
4644ea7
Don't break layout if there's no content
KyleAMathews Jun 10, 2017
aeb9a77
Log at end of build how long build took
KyleAMathews Jun 10, 2017
8162a91
Not using this package
KyleAMathews Jun 10, 2017
bbf5302
Merge remote-tracking branch 'origin/1.0' into queue-requests
KyleAMathews Jun 10, 2017
19f7c72
Remove logging + run format
KyleAMathews Jun 10, 2017
a1fd507
Add the nprogress plugin
KyleAMathews Jun 10, 2017
ce5ca59
Fix some emitter code
KyleAMathews Jun 10, 2017
ab0e3f4
Make it easy to override the default color of the nprogress bar
KyleAMathews Jun 10, 2017
33e9e8e
Fix check on variable
KyleAMathews Jun 10, 2017
c6b486a
Fix prefetching
KyleAMathews Jun 10, 2017
6cac6e1
Fix test
KyleAMathews Jun 10, 2017
fd01c58
Add nprogress plugin to list
KyleAMathews Jun 10, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Use ComponentRenderer for rendering
  • Loading branch information
KyleAMathews committed Jun 7, 2017
commit f92fdb987f9cbd47031cbaf93fabc8fe730a947a
30 changes: 24 additions & 6 deletions packages/gatsby/src/cache-dir/component-renderer.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,33 @@ import loader from "./loader"
// component will try fetching resources. If they exist,
// will just render, else will render null.
class ComponentRenderer extends React.Component {
constructor(props) {
super()
this.state = {
pageResources: loader.getResourcesForPathname(props.location.pathname),
}
}

componentWillReceiveProps(nextProps) {
if (this.props.location.pathname !== nextProps.location.pathname) {
this.setState({
pageResources: loader.getResourcesForPathname(
nextProps.location.pathname
),
})
}
}

componentDidMount() {
// listen to events.
}

render() {
console.log("rendering ComponentRenderer")
const pageResources = loader.getResourcesForPathname(
this.props.location.pathname
)
if (pageResources) {
return createElement(pageResources.component, {
if (this.state.pageResources) {
return createElement(this.state.pageResources.component, {
...this.props,
...pageResources.json,
...this.state.pageResources.json,
})
} else {
return "...loading"
Expand Down