127 lines
3.3 KiB
TypeScript
Raw Normal View History

2021-02-21 17:38:59 +01:00
import cheerio from "cheerio";
import {
replaceImportFromStaticInJsCode,
generateCssCodeToDefineGlobals
} from "../replaceImportFromStatic";
import fs from "fs";
import { join as pathJoin } from "path";
import { objectKeys } from "evt/tools/typeSafety/objectKeys";
2021-02-21 17:38:59 +01:00
export function generateFtlFilesCodeFactory(
params: {
ftlValuesGlobalName: string;
cssGlobalsToDefine: Record<string, string>;
indexHtmlCode: string;
}
) {
const { ftlValuesGlobalName, cssGlobalsToDefine, indexHtmlCode } = params;
const $ = cheerio.load(indexHtmlCode);
$("script:not([src])").each((...[, element]) => {
const { fixedJsCode } = replaceImportFromStaticInJsCode({
ftlValuesGlobalName,
"jsCode": $(element).html()!
});
2021-02-21 18:05:26 +01:00
$(element).text(fixedJsCode);
2021-02-21 17:38:59 +01:00
});
([
["link", "href"],
["script", "src"],
] as const).forEach(([selector, attrName]) =>
$(selector).each((...[, element]) => {
const href = $(element).attr(attrName);
if (!href?.startsWith("/")) {
return;
}
2021-03-02 01:05:15 +01:00
$(element).attr(attrName, "${url.resourcesPath}/build" + href);
2021-02-21 17:38:59 +01:00
})
);
//FTL is no valid html, we can't insert with cheerio, we put placeholder for injecting later.
const ftlPlaceholders = {
'{ "x": "xIdLqMeOed9sdLdIdOxdK0d" }':
fs.readFileSync(pathJoin(__dirname, "ftl2js.ftl"))
.toString("utf8")
.match(/^<script>const _=((?:.|\n)+)<\/script>[\n]?$/)![1],
'<!-- xIdLqMeOedErIdLsPdNdI9dSlxI -->':
[
'<#if scripts??>',
' <#list scripts as script>',
' <script src="${script}" type="text/javascript"></script>',
' </#list>',
'</#if>',
].join("\n")
};
2021-02-21 17:38:59 +01:00
$("head").prepend(
[
2021-02-23 09:50:24 +01:00
...(Object.keys(cssGlobalsToDefine).length === 0 ? [] : [
'',
'<style>',
generateCssCodeToDefineGlobals(
{ cssGlobalsToDefine }
).cssCodeToPrependInHead,
'</style>',
''
]),
2021-02-21 17:38:59 +01:00
'<script>',
' Object.assign(',
` window.${ftlValuesGlobalName},`,
` ${objectKeys(ftlPlaceholders)[0]}`,
2021-02-23 09:50:24 +01:00
' );',
2021-02-21 17:38:59 +01:00
'</script>',
'',
objectKeys(ftlPlaceholders)[1],
2021-02-21 17:38:59 +01:00
''
].join("\n"),
);
const partiallyFixedIndexHtmlCode = $.html();
function generateFtlFilesCode(
params: {
pageBasename: "login.ftl" | "register.ftl"
}
): { ftlCode: string; } {
const { pageBasename } = params;
const $ = cheerio.load(partiallyFixedIndexHtmlCode);
$("head").prepend(
[
'',
'<script>',
2021-02-21 18:05:26 +01:00
` window.${ftlValuesGlobalName} = { "pageBasename": "${pageBasename}" };`,
2021-02-21 17:38:59 +01:00
'</script>',
''
].join("\n")
2021-02-21 17:38:59 +01:00
);
let ftlCode = $.html();
objectKeys(ftlPlaceholders)
.forEach(id => ftlCode = ftlCode.replace(id, ftlPlaceholders[id]));
return { ftlCode };
2021-02-21 17:38:59 +01:00
}
return { generateFtlFilesCode };
}