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.
|
2020-02-08 11:11:04 +00:00
|
|
|
function assetsToHeaders(pluginAssets, options = null) {
|
|
|
|
options = Object.assign({}, { asHtml: false }, options);
|
|
|
|
|
|
|
|
const headers = {};
|
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;
|
2020-01-30 21:05:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = assetsToHeaders;
|