Compare commits

..

2 Commits

Author SHA1 Message Date
3a3fdcf5e2 patch caching 2023-07-01 10:53:10 -04:00
d6a9a269a7 apply import maps 2023-07-01 10:43:29 -04:00
2 changed files with 67 additions and 13 deletions

View File

@ -1,6 +1,9 @@
import * as Util from "@able/";
import * as React from "react";
import {createElement} from "react/client";
import('https://esm.sh/react').then((module) => { import('react').then((module) => {
console.log(module); console.log(module);
}); });

View File

@ -57,12 +57,11 @@ let Configuration:Configuration =
Spoof: "/@able", Spoof: "/@able",
async Serve(inReq, inURL, inExt, inMap, inConfig) async Serve(inReq, inURL, inExt, inMap, inConfig)
{ {
if(inReq.headers.get("user-agent")?.startsWith("Deno")) if( inReq.headers.get("user-agent")?.startsWith("Deno") || inURL.searchParams.get("deno") )
{ {
const file = await fetch(inConfig.Proxy + inURL.pathname); const file = await fetch(inConfig.Proxy + inURL.pathname);
const text = await file.text(); const text = await file.text();
return new Response(Transpile.Patch(text, "deno-"+inURL.pathname, inMap), {headers:{"content-type":"application/javascript"}} );
return new Response(Transpile.Patch(text), {headers:{"content-type":"application/javascript"}} );
} }
}, },
Remap: (inImports, inConfig)=> Remap: (inImports, inConfig)=>
@ -139,24 +138,76 @@ export const Transpile =
ImportMapReload(); ImportMapReload();
return size; return size;
}, },
Patch(inText) /**
* Converts dynamic module imports in to static, also can resolve paths with an import map
*/
Patch(inText:string, inKey:string|false = false, inMap?:DenoConfig)
{ {
const regex = /(?<![\w.])import\(([^)]+)(?!import\b)\)/g;
const staticImports = [];
let match; if(inKey)
{
const check = this.Cache.get(inKey);
if(check)
{
return check;
}
}
const remap = inMap ? (inPath:string)=>
{
const match = inMap.imports[inPath];
if(match)
{
return match;
}
else if(inPath.includes("/"))
{
let bestKey = "";
let bestLength = 0;
Object.keys(inMap.imports).forEach((key, i, arr)=>
{
if(key.endsWith("/") && inPath.startsWith(key) && key.length > bestLength)
{
bestKey = key;
bestLength = bestLength;
}
});
if(bestKey)
{
return inMap.imports[bestKey]+inPath.substring(bestKey.length);
}
}
return inPath;
}
: (inPath:string)=>inPath;
let match, regex;
let convertedBody = inText; let convertedBody = inText;
// remap static imports
regex = /from\s+(['"`])(.*?)\1/g;
while ((match = regex.exec(inText)))
{
const importStatement = match[0];
const importPath = match[2];
convertedBody = convertedBody.replace(importStatement, `from "${remap(importPath)}"`);
}
// convert dynamic imports into static (to work around deno deploy)
const staticImports = [];
regex = /(?<![\w.])import\(([^)]+)(?!import\b)\)/g;
while ((match = regex.exec(inText))) while ((match = regex.exec(inText)))
{ {
const importStatement = match[0]; const importStatement = match[0];
const importContent = match[1]; const importPath = remap(match[1].substring(1, match[1].length-1));
const moduleName = `_dyn_${staticImports.length}`; const moduleName:string = `_dyn_${staticImports.length}`;
staticImports.push(`import ${moduleName} from ${importContent};`); staticImports.push(`import ${moduleName} from ${importPath};`);
convertedBody = convertedBody.replace(importStatement, `Promise.resolve(${moduleName})`); convertedBody = convertedBody.replace(importStatement, `Promise.resolve(${moduleName})`);
} }
convertedBody = staticImports.join("\n") + convertedBody;
return staticImports.join("\n") + convertedBody; inKey && this.Cache.set(inKey, convertedBody);
return convertedBody;
}, },
Fetch: async function(inPath:string, inKey:string, inCheckCache=true) Fetch: async function(inPath:string, inKey:string, inCheckCache=true)
{ {