@absolutejs/absolute 0.1.27 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
1
  // @bun
2
- var pt=60,g=1000,y=60000,ut=60,_t=24,Nt=86400000,d=2,h=3000;import{rm as v,mkdir as x,writeFile as X}from"fs/promises";import{join as e,basename as Z}from"path";import{cwd as F,exit as tt}from"process";var{$:C,build:ot,Glob:A}=globalThis.Bun;import{readFile as K,writeFile as Q}from"fs/promises";var{Glob:V}=globalThis.Bun;var H=async(r,o)=>{let s=new V("*.html"),n=[];for await(let i of s.scan({cwd:o,absolute:!0}))n.push(i);for(let i of n){let c=await K(i,"utf8");for(let[_,p]of Object.entries(r)){let l=_.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),u=new RegExp(`(<script[^>]+src=["'])(/?(?:.*\\/)?${l})(?:\\.[^."'/]+)?(\\.js)(["'][^>]*>)`,"g");c=c.replace(u,(a,f,m,M,O)=>{return`${f}${p}${O}`})}await Q(i,c,"utf8")}};var G=async({buildDir:r="build",assetsDir:o,reactIndexDir:s,javascriptDir:n,typeScriptDir:i,reactPagesDir:c,htmlDir:_,htmxDir:p})=>{let l=performance.now();console.log("Build Config",{buildDir:r,assetsDir:o,reactIndexDir:s,javascriptDir:n,typeScriptDir:i,reactPagesDir:c,htmlDir:_,htmxDir:p});let u=F(),a=e(u,r),f=o&&e(u,o),m=s&&e(u,s),M=n&&e(u,n),O=i&&e(u,i),b=c&&e(u,c),E=_&&e(u,_),D=p&&e(u,p);await v(a,{force:!0,recursive:!0}),await x(a),b&&m&&await nt(b,m);let k=new A("*.{tsx,jsx}"),L=[];for await(let t of k.scan({absolute:!0,cwd:m}))L.push(t);let P=new A("*.js"),U=[];for await(let t of P.scan({absolute:!0,cwd:M}))U.push(t);let W=new A("*.ts"),R=[];for await(let t of W.scan({absolute:!0,cwd:O}))R.push(t);let T=L.concat(U).concat(R);if(T.length===0)return console.warn("No entry points found, skipping build"),null;let{logs:q,outputs:z}=await ot({entrypoints:T,format:"esm",naming:"[dir]/[name].[hash].[ext]",outdir:a}).catch((t)=>{console.error("Build failed:",t),tt(1)});if(q.forEach((t)=>{if(t.level==="error")console.error(t);else if(t.level==="warning")console.warn(t);else if(t.level==="info"||t.level==="debug")console.info(t)}),f&&await C`cp -R ${f} ${a}`,E)await x(e(a,"html")),await C`cp -R ${E} ${e(a)}`;if(D)await x(e(a,"htmx")),await C`cp -R ${D} ${e(a)}`;let j=z.reduce((t,B)=>{let N=B.path;if(N.startsWith(a))N=N.slice(a.length);N=N.replace(/^\/+/,"");let w=N.split("/").pop();if(!w)return t;let $=`.${B.hash}.`;if(!w.includes($))throw new Error(`Expected hash delimiter ${$} in ${w}`);let[J]=w.split($);return t[J]="/"+N,t},{});E&&await H(j,E);let I=performance.now()-l,S;if(I<g)S=`${I.toFixed(d)}ms`;else if(I<y)S=`${(I/g).toFixed(d)}s`;else S=`${(I/y).toFixed(d)}m`;return console.log(`Build completed in ${S}`),j},nt=async(r,o)=>{await v(o,{force:!0,recursive:!0}),await x(o);let s=new A("*.*"),n=[];for await(let c of s.scan({cwd:r}))n.push(c);let i=n.map(async(c)=>{let _=Z(c),[p]=_.split("."),l=["import { hydrateRoot } from 'react-dom/client';",`import { ${p} } from '../pages/${p}';
2
+ var at=60,$=1000,y=60000,pt=60,_t=24,ut=86400000,d=2,h=3000;import{rm as v,mkdir as x,writeFile as V}from"fs/promises";import{join as e,basename as X}from"path";import{cwd as Z,exit as F}from"process";var{$:C,build:tt,Glob:A}=globalThis.Bun;import{readFile as J,writeFile as K}from"fs/promises";var{Glob:Q}=globalThis.Bun;var H=async(r,o)=>{let s=new Q("*.html"),n=[];for await(let i of s.scan({cwd:o,absolute:!0}))n.push(i);for(let i of n){let c=await J(i,"utf8");for(let[u,p]of Object.entries(r)){let l=u.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),_=new RegExp(`(<script[^>]+src=["'])(/?(?:.*\\/)?${l})(?:\\.[^."'/]+)?(\\.js)(["'][^>]*>)`,"g");c=c.replace(_,(a,E,f,M,g)=>{return`${E}${p}${g}`})}await K(i,c,"utf8")}};var At=async({buildDir:r="build",assetsDir:o,reactIndexDir:s,javascriptDir:n,typeScriptDir:i,reactPagesDir:c,htmlDir:u,htmxDir:p})=>{let l=performance.now();console.log("Build Config",{buildDir:r,assetsDir:o,reactIndexDir:s,javascriptDir:n,typeScriptDir:i,reactPagesDir:c,htmlDir:u,htmxDir:p});let _=Z(),a=e(_,r),E=o&&e(_,o),f=s&&e(_,s),M=n&&e(_,n),g=i&&e(_,i),b=c&&e(_,c),S=u&&e(_,u),D=p&&e(_,p);await v(a,{force:!0,recursive:!0}),await x(a),b&&f&&await ot(b,f);let Y=new A("*.{tsx,jsx}"),L=[];for await(let t of Y.scan({absolute:!0,cwd:f}))L.push(t);let k=new A("*.js"),U=[];for await(let t of k.scan({absolute:!0,cwd:M}))U.push(t);let P=new A("*.ts"),R=[];for await(let t of P.scan({absolute:!0,cwd:g}))R.push(t);let T=L.concat(U).concat(R);if(T.length===0)return console.warn("No entry points found, skipping build"),null;let{logs:W,outputs:q}=await tt({entrypoints:T,format:"esm",naming:"[dir]/[name].[hash].[ext]",outdir:a,target:"bun"}).catch((t)=>{console.error("Build failed:",t),F(1)});if(W.forEach((t)=>{if(t.level==="error")console.error(t);else if(t.level==="warning")console.warn(t);else if(t.level==="info"||t.level==="debug")console.info(t)}),E&&await C`cp -R ${E} ${a}`,S)await x(e(a,"html")),await C`cp -R ${S} ${e(a)}`;if(D)await x(e(a,"htmx")),await C`cp -R ${D} ${e(a)}`;let j=q.reduce((t,B)=>{let N=B.path;if(N.startsWith(a))N=N.slice(a.length);N=N.replace(/^\/+/,"");let w=N.split("/").pop();if(!w)return t;let O=`.${B.hash}.`;if(!w.includes(O))throw new Error(`Expected hash delimiter ${O} in ${w}`);let[z]=w.split(O);return t[z]="/"+N,t},{});S&&await H(j,S);let I=performance.now()-l,m;if(I<$)m=`${I.toFixed(d)}ms`;else if(I<y)m=`${(I/$).toFixed(d)}s`;else m=`${(I/y).toFixed(d)}m`;return console.log(`Build completed in ${m}`),j},ot=async(r,o)=>{await v(o,{force:!0,recursive:!0}),await x(o);let s=new A("*.*"),n=[];for await(let c of s.scan({cwd:r}))n.push(c);let i=n.map(async(c)=>{let u=X(c),[p]=u.split("."),l=["import { hydrateRoot } from 'react-dom/client';",`import { ${p} } from '../pages/${p}';
3
3
  `,`hydrateRoot(document, <${p} />);`].join(`
4
- `);return X(e(o,`${p}Index.tsx`),l)});await Promise.all(i)};import{createElement as rt}from"react";import{renderToReadableStream as st}from"react-dom/server.browser";var Ct=async(r,o)=>{let s=rt(r),n=await st(s,{bootstrapModules:[o]});return new Response(n,{headers:{"Content-Type":"text/html"}})},Mt=(r)=>Bun.file(r);var Tt=await G({});import it from"os";var{argv:et,env:Y}=globalThis.Bun;var ct=()=>{let r=it.networkInterfaces(),s=Object.values(r).flat().filter((n)=>n!==void 0).find((n)=>n.family==="IPv4"&&!n.internal);if(s)return s.address;return console.warn("No IP address found, falling back to localhost"),"localhost"},vt=()=>{let r=Y.HOST??"localhost",o=Y.PORT??h,s,i=et.includes("--host");if(i)s=ct(),r="0.0.0.0";return{host:r,port:o,listenCallback:()=>{if(i)console.log(`Server started on http://localhost:${o}`),console.log(`Server started on network: http://${s}:${o}`);else console.log(`Server started on http://${r}:${o}`)}}};export{H as updateScriptTags,Ct as handleReactPageRequest,Mt as handleHTMLPageRequest,vt as getNetworkSettings,ct as getLocalIPAddress,G as build,d as TIME_PRECISION,pt as SECONDS_IN_A_MINUTE,ut as MINUTES_IN_AN_HOUR,g as MILLISECONDS_IN_A_SECOND,y as MILLISECONDS_IN_A_MINUTE,Nt as MILLISECONDS_IN_A_DAY,_t as HOURS_IN_A_DAY,h as DEFAULT_PORT};
4
+ `);return V(e(o,`${p}Index.tsx`),l)});await Promise.all(i)};import{createElement as nt}from"react";import{renderToReadableStream as rt}from"react-dom/server.browser";var Ct=async(r,o)=>{let s=nt(r),n=await rt(s,{bootstrapModules:[o]});return new Response(n,{headers:{"Content-Type":"text/html"}})},Mt=(r)=>Bun.file(r);import st from"os";var{argv:it,env:G}=globalThis.Bun;var et=()=>{let r=st.networkInterfaces(),s=Object.values(r).flat().filter((n)=>n!==void 0).find((n)=>n.family==="IPv4"&&!n.internal);if(s)return s.address;return console.warn("No IP address found, falling back to localhost"),"localhost"},ht=()=>{let r=G.HOST??"localhost",o=G.PORT??h,s,i=it.includes("--host");if(i)s=et(),r="0.0.0.0";return{host:r,port:o,listenCallback:()=>{if(i)console.log(`Server started on http://localhost:${o}`),console.log(`Server started on network: http://${s}:${o}`);else console.log(`Server started on http://${r}:${o}`)}}};export{H as updateScriptTags,Ct as handleReactPageRequest,Mt as handleHTMLPageRequest,ht as getNetworkSettings,et as getLocalIPAddress,At as build,d as TIME_PRECISION,at as SECONDS_IN_A_MINUTE,pt as MINUTES_IN_AN_HOUR,$ as MILLISECONDS_IN_A_SECOND,y as MILLISECONDS_IN_A_MINUTE,ut as MILLISECONDS_IN_A_DAY,_t as HOURS_IN_A_DAY,h as DEFAULT_PORT};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@absolutejs/absolute",
3
- "version": "0.1.27",
3
+ "version": "0.2.1",
4
4
  "description": "A fullstack meta-framework for building web applications with TypeScript",
5
5
  "repository": {
6
6
  "type": "git",
package/src/core/build.ts CHANGED
@@ -106,7 +106,8 @@ export const build = async ({
106
106
  entrypoints: entryPaths,
107
107
  format: "esm",
108
108
  naming: `[dir]/[name].[hash].[ext]`,
109
- outdir: buildDirAbsolute
109
+ outdir: buildDirAbsolute,
110
+ target: "bun"
110
111
  }).catch((error) => {
111
112
  console.error("Build failed:", error);
112
113
  exit(1);
@@ -1,3 +1,3 @@
1
1
  import { build } from "../core/build";
2
2
 
3
- const manifest = await build({});
3
+ // const manifest = await build({});