23 lines
1.1 KiB
JavaScript
23 lines
1.1 KiB
JavaScript
import { interopDefault } from './interop-default';
|
|
import { getLinkAndScriptTags } from './get-css-inlined-link-tags';
|
|
import { getAssetQueryString } from './get-asset-query-string';
|
|
import { encodeURIPath } from '../../shared/lib/encode-uri-path';
|
|
import { renderCssResource } from './render-css-resource';
|
|
export async function createComponentStylesAndScripts({ filePath, getComponent, injectedCSS, injectedJS, ctx }) {
|
|
const { componentMod: { createElement } } = ctx;
|
|
const { styles: entryCssFiles, scripts: jsHrefs } = getLinkAndScriptTags(filePath, injectedCSS, injectedJS);
|
|
const styles = renderCssResource(entryCssFiles, ctx);
|
|
const scripts = jsHrefs ? jsHrefs.map((href, index)=>createElement('script', {
|
|
src: `${ctx.assetPrefix}/_next/${encodeURIPath(href)}${getAssetQueryString(ctx, true)}`,
|
|
async: true,
|
|
key: `script-${index}`
|
|
})) : null;
|
|
const Comp = interopDefault(await getComponent());
|
|
return [
|
|
Comp,
|
|
styles,
|
|
scripts
|
|
];
|
|
}
|
|
|
|
//# sourceMappingURL=create-component-styles-and-scripts.js.map
|