@absolutejs/absolute 0.2.2 → 0.2.4

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 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
- `,`hydrateRoot(document, <${p} />);`].join(`
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};
2
+ var It=60,h=1000,y=60000,Nt=60,ft=24,mt=86400000,d=2,B=3000;import{rm as k,mkdir as w,writeFile as ot}from"fs/promises";import{join as n,basename as rt}from"path";import{cwd as nt,exit as st}from"process";var{$:C,build:et,Glob:A}=globalThis.Bun;import{readFile as X,writeFile as Z}from"fs/promises";var{Glob:tt}=globalThis.Bun;var H=async(r,s)=>{let e=new tt("*.html"),o=[];for await(let a of e.scan({cwd:s,absolute:!0}))o.push(a);for(let a of o){let i=await X(a,"utf8");for(let[u,l]of Object.entries(r)){let I=u.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),p=new RegExp(`(<script[^>]+src=["'])(/?(?:.*\\/)?${I})(?:\\.[^."'/]+)?(\\.js)(["'][^>]*>)`,"g");i=i.replace(p,(c,f,m,M,x)=>{return`${f}${l}${x}`})}await Z(a,i,"utf8")}};var yt=async({buildDir:r="build",assetsDir:s,reactIndexDir:e,javascriptDir:o,typeScriptDir:a,reactPagesDir:i,htmlDir:u,htmxDir:l})=>{let I=performance.now();console.log("Build Config",{buildDir:r,assetsDir:s,reactIndexDir:e,javascriptDir:o,typeScriptDir:a,reactPagesDir:i,htmlDir:u,htmxDir:l});let p=nt(),c=n(p,r),f=s&&n(p,s),m=e&&n(p,e),M=o&&n(p,o),x=a&&n(p,a),D=i&&n(p,i),E=u&&n(p,u),b=l&&n(p,l);await k(c,{force:!0,recursive:!0}),await w(c),D&&m&&await it(D,m);let q=new A("*.{tsx,jsx}"),T=[];for await(let t of q.scan({absolute:!0,cwd:m}))T.push(t);let z=new A("*.js"),R=[];for await(let t of z.scan({absolute:!0,cwd:M}))R.push(t);let J=new A("*.ts"),U=[];for await(let t of J.scan({absolute:!0,cwd:x}))U.push(t);let v=T.concat(R).concat(U);if(v.length===0)return console.warn("No entry points found, skipping build"),null;let{logs:K,outputs:Q}=await et({entrypoints:v,format:"esm",naming:"[dir]/[name].[hash].[ext]",outdir:c,target:"bun"}).catch((t)=>{console.error("Build failed:",t),st(1)});if(K.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} ${c}`,E)await w(n(c,"html")),await C`cp -R ${E} ${n(c)}`;if(b)await w(n(c,"htmx")),await C`cp -R ${b} ${n(c)}`;let P=Q.reduce((t,j)=>{let _=j.path;if(_.startsWith(c))_=_.slice(c.length);_=_.replace(/^\/+/,"");let g=_.split("/").pop();if(!g)return t;let O=`.${j.hash}.`;if(!g.includes(O))throw new Error(`Expected hash delimiter ${O} in ${g}`);let[V]=g.split(O);return t[V]="/"+_,t},{});E&&await H(P,E);let N=performance.now()-I,S;if(N<h)S=`${N.toFixed(d)}ms`;else if(N<y)S=`${(N/h).toFixed(d)}s`;else S=`${(N/y).toFixed(d)}m`;return console.log(`Build completed in ${S}`),P},it=async(r,s)=>{await k(s,{force:!0,recursive:!0}),await w(s);let e=new A("*.*"),o=[];for await(let i of e.scan({cwd:r}))o.push(i);let a=o.map(async(i)=>{let u=rt(i),[l]=u.split("."),I=["import { hydrateRoot } from 'react-dom/client';",`import { ${l} } from '../pages/${l}';
3
+ `,`hydrateRoot(document, <${l} />);`].join(`
4
+ `);return ot(n(s,`${l}Index.tsx`),I)});await Promise.all(a)};import{createElement as ct}from"react";import{renderToReadableStream as at}from"react-dom/server.browser";var bt=async(r,s)=>{let e=ct(r),o=await at(e,{bootstrapModules:[s]});return new Response(o,{headers:{"Content-Type":"text/html"}})},Tt=(r)=>Bun.file(r);import{argv as pt}from"process";var{env:G}=globalThis.Bun;import lt from"os";var F=()=>{let r=lt.networkInterfaces(),e=Object.values(r).flat().filter((o)=>o!==void 0).find((o)=>o.family==="IPv4"&&!o.internal);if(e)return e.address;return console.warn("No IP address found, falling back to localhost"),"localhost"};var L=G.HOST??"localhost",$=G.PORT??B,Y,ut=pt,W=ut.includes("--host");if(W)Y=F(),L="0.0.0.0";var Yt=(r)=>r.listen({hostname:L,port:$},()=>{if(W)console.log(`Server started on http://localhost:${$}`),console.log(`Server started on network: http://${Y}:${$}`);else console.log(`Server started on http://${L}:${$}`)});export{H as updateScriptTags,Yt as networkingPlugin,bt as handleReactPageRequest,Tt as handleHTMLPageRequest,F as getLocalIPAddress,yt as build,d as TIME_PRECISION,It as SECONDS_IN_A_MINUTE,Nt as MINUTES_IN_AN_HOUR,h as MILLISECONDS_IN_A_SECOND,y as MILLISECONDS_IN_A_MINUTE,mt as MILLISECONDS_IN_A_DAY,ft as HOURS_IN_A_DAY,B as DEFAULT_PORT};
@@ -1 +1,2 @@
1
+ export * from "./networkingPlugin";
1
2
  export * from "./pageRouterPlugin";
@@ -1,6 +1 @@
1
1
  export declare const getLocalIPAddress: () => string;
2
- export declare const getNetworkSettings: () => {
3
- host: string;
4
- port: string | number;
5
- listenCallback: () => void;
6
- };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@absolutejs/absolute",
3
- "version": "0.2.2",
3
+ "version": "0.2.4",
4
4
  "description": "A fullstack meta-framework for building web applications with TypeScript",
5
5
  "repository": {
6
6
  "type": "git",
@@ -1 +1,2 @@
1
+ export * from "./networkingPlugin";
1
2
  export * from "./pageRouterPlugin";
@@ -1,6 +1,4 @@
1
1
  import os from "os";
2
- import { argv, env } from "bun";
3
- import { DEFAULT_PORT } from "../constants";
4
2
 
5
3
  export const getLocalIPAddress = () => {
6
4
  const interfaces = os.networkInterfaces();
@@ -19,28 +17,3 @@ export const getLocalIPAddress = () => {
19
17
 
20
18
  return "localhost"; // Fallback to localhost if no IP found
21
19
  };
22
-
23
- export const getNetworkSettings = () => {
24
- let host = env.HOST ?? "localhost";
25
- const port = env.PORT ?? DEFAULT_PORT;
26
- let localIP: string | undefined;
27
-
28
- const args = argv;
29
- const hostFlag = args.includes("--host");
30
-
31
- if (hostFlag) {
32
- localIP = getLocalIPAddress();
33
- host = "0.0.0.0";
34
- }
35
-
36
- const listenCallback = () => {
37
- if (hostFlag) {
38
- console.log(`Server started on http://localhost:${port}`);
39
- console.log(`Server started on network: http://${localIP}:${port}`);
40
- } else {
41
- console.log(`Server started on http://${host}:${port}`);
42
- }
43
- };
44
-
45
- return { host, port, listenCallback };
46
- };