2024-01-18 03:20:10 -08:00
|
|
|
import { RenderResultPluginAsset } from './types';
|
|
|
|
|
|
|
|
interface Options {
|
|
|
|
asHtml: boolean;
|
|
|
|
}
|
|
|
|
|
2020-01-30 21:05:23 +00:00
|
|
|
// Utility function to convert the plugin assets to a list of LINK or SCRIPT tags
|
|
|
|
// that can be included in the HEAD tag.
|
2024-01-18 03:20:10 -08:00
|
|
|
const assetsToHeaders = (pluginAssets: RenderResultPluginAsset[], options: Options|null = null) => {
|
2023-06-01 12:02:36 +01:00
|
|
|
options = { asHtml: false, ...options };
|
2020-02-08 11:11:04 +00:00
|
|
|
|
2024-01-18 03:20:10 -08:00
|
|
|
const headers: Record<string, string> = {};
|
2020-01-30 21:05:23 +00:00
|
|
|
for (let i = 0; i < pluginAssets.length; i++) {
|
|
|
|
const asset = pluginAssets[i];
|
|
|
|
if (asset.mime === 'text/css') {
|
2020-02-08 11:11:04 +00:00
|
|
|
headers[asset.name] = `<link rel="stylesheet" href="pluginAssets/${asset.name}">`;
|
2020-01-30 21:05:23 +00:00
|
|
|
} else if (asset.mime === 'application/javascript') {
|
|
|
|
// NOT TESTED!!
|
2020-02-08 11:11:04 +00:00
|
|
|
headers[asset.name] = `<script type="application/javascript" src="pluginAssets/${asset.name}"></script>`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (options.asHtml) {
|
2020-03-13 23:46:14 +00:00
|
|
|
const output = [];
|
|
|
|
for (const name in headers) {
|
2020-02-08 11:11:04 +00:00
|
|
|
output.push(headers[name]);
|
2020-01-30 21:05:23 +00:00
|
|
|
}
|
2020-02-08 11:11:04 +00:00
|
|
|
return output.join('');
|
2020-01-30 21:05:23 +00:00
|
|
|
}
|
|
|
|
|
2020-02-08 11:11:04 +00:00
|
|
|
return headers;
|
2024-01-18 03:20:10 -08:00
|
|
|
};
|
2020-01-30 21:05:23 +00:00
|
|
|
|
2024-01-18 03:20:10 -08:00
|
|
|
export default assetsToHeaders;
|