Added link=“prefetch” tags

This commit is contained in:
Jori Lallo
2018-01-21 22:24:10 -08:00
parent fa1b6f9b4f
commit bc403faa8e
6 changed files with 83 additions and 24 deletions

View File

@@ -0,0 +1,33 @@
// @flow
import React from 'react';
import webpackConfig from '../../webpack.config';
const PUBLIC_PATH = webpackConfig.output.publicPath;
const prefetchTags = [
<link rel="dns-prefetch" href={process.env.AWS_S3_UPLOAD_BUCKET_URL} />,
];
if (process.env.NODE_ENV === 'production') {
try {
const manifest = require('../../dist/manifest.json');
Object.values(manifest).forEach(filename => {
if (typeof filename !== 'string') return;
if (filename.endsWith('.js')) {
prefetchTags.push(
<link rel="prefetch" href={`${PUBLIC_PATH}${filename}`} as="script" />
);
} else if (filename.endsWith('.css')) {
prefetchTags.push(
<link rel="prefetch" href={`${PUBLIC_PATH}${filename}`} as="style" />
);
}
});
} catch (_e) {
console.warn(
'Warning: Unable to load dist/manifest.json. Please `yarn build` before starting production server'
);
}
}
export default prefetchTags;