xplorajs 0.1.9 → 0.3.0
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/cli.d.ts +2 -0
- package/dist/cli.js +4 -4
- package/dist/cli.js.map +1 -1
- package/dist/commands/build.d.ts +1 -0
- package/dist/commands/build.js +9 -12
- package/dist/commands/build.js.map +1 -1
- package/dist/commands/dev.d.ts +1 -0
- package/dist/commands/dev.js +12 -20
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/start.d.ts +1 -0
- package/dist/commands/start.js +2 -7
- package/dist/commands/start.js.map +1 -1
- package/dist/config.d.ts +18 -0
- package/dist/config.js +1 -4
- package/dist/config.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/package.json +7 -5
- package/dist/app/page.js +0 -7
- package/dist/assets/react-refresh.js +0 -338
- package/dist/assets/style.css +0 -230
- package/dist/dev.js +0 -21
- package/dist/node_modules/react-refresh/runtime.js +0 -7
- package/dist/pages/index.js +0 -7
- package/dist/server.js +0 -391
package/dist/cli.d.ts
ADDED
package/dist/cli.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { Command } from "commander";
|
|
3
|
+
import { build } from "./commands/build";
|
|
4
|
+
import { dev } from "./commands/dev";
|
|
5
|
+
import { start } from "./commands/start";
|
|
6
6
|
const program = new Command();
|
|
7
7
|
program.name("xplorajs").description("Xplora.js CLI tool").version("0.0.0");
|
|
8
8
|
program.command("dev").description("Start development server").action(dev);
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli.ts"],"sourcesContent":["#!/usr/bin/env node\
|
|
1
|
+
{"version":3,"sources":["../src/cli.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from \"commander\";\nimport { build } from \"./commands/build\";\nimport { dev } from \"./commands/dev\";\nimport { start } from \"./commands/start\";\n\nconst program = new Command();\n\nprogram.name(\"xplorajs\").description(\"Xplora.js CLI tool\").version(\"0.0.0\");\n\nprogram.command(\"dev\").description(\"Start development server\").action(dev);\n\nprogram.command(\"build\").description(\"Build for production\").action(build);\n\nprogram.command(\"start\").description(\"Start production server\").action(start);\n\nprogram.parse();\n"],"names":["Command","build","dev","start","program","name","description","version","command","action","parse"],"mappings":";AACA,SAASA,OAAO,QAAQ,YAAY;AACpC,SAASC,KAAK,QAAQ,mBAAmB;AACzC,SAASC,GAAG,QAAQ,iBAAiB;AACrC,SAASC,KAAK,QAAQ,mBAAmB;AAEzC,MAAMC,UAAU,IAAIJ;AAEpBI,QAAQC,IAAI,CAAC,YAAYC,WAAW,CAAC,sBAAsBC,OAAO,CAAC;AAEnEH,QAAQI,OAAO,CAAC,OAAOF,WAAW,CAAC,4BAA4BG,MAAM,CAACP;AAEtEE,QAAQI,OAAO,CAAC,SAASF,WAAW,CAAC,wBAAwBG,MAAM,CAACR;AAEpEG,QAAQI,OAAO,CAAC,SAASF,WAAW,CAAC,2BAA2BG,MAAM,CAACN;AAEvEC,QAAQM,KAAK"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function build(): Promise<void>;
|
package/dist/commands/build.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { mkdir, writeFile } from "node:fs/promises";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { glob } from "fast-glob";
|
|
4
|
+
import React from "react";
|
|
5
|
+
import { generateStaticPage } from "xplorajs-react";
|
|
6
6
|
function convertToRoute(filePath) {
|
|
7
7
|
const relativePath = filePath.replace("src/app/", "");
|
|
8
8
|
const path = relativePath.replace(/\.tsx$/, "").replace(/\/page$/, "").replace(/\[([^\]]+)\]/g, ":$1");
|
|
@@ -16,9 +16,9 @@ function convertToRoute(filePath) {
|
|
|
16
16
|
}
|
|
17
17
|
async function processPage(page, route) {
|
|
18
18
|
try {
|
|
19
|
-
const
|
|
20
|
-
const PageComponent =
|
|
21
|
-
const getStaticProps =
|
|
19
|
+
const module = await import(join(process.cwd(), page));
|
|
20
|
+
const PageComponent = module.default;
|
|
21
|
+
const getStaticProps = module.getStaticProps;
|
|
22
22
|
let props = {};
|
|
23
23
|
if (getStaticProps) {
|
|
24
24
|
const result = await getStaticProps();
|
|
@@ -35,7 +35,7 @@ async function processPage(page, route) {
|
|
|
35
35
|
console.error(`Error processing ${page}:`, error);
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
async function build() {
|
|
38
|
+
export async function build() {
|
|
39
39
|
console.log("Building application...");
|
|
40
40
|
await mkdir(join(process.cwd(), "dist"), {
|
|
41
41
|
recursive: true
|
|
@@ -59,8 +59,5 @@ async function build() {
|
|
|
59
59
|
console.log("Build completed!");
|
|
60
60
|
console.log("Routes:", routes.map((r)=>r.path).join("\n"));
|
|
61
61
|
}
|
|
62
|
-
module.exports = {
|
|
63
|
-
build
|
|
64
|
-
};
|
|
65
62
|
|
|
66
63
|
//# sourceMappingURL=build.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/commands/build.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../src/commands/build.ts"],"sourcesContent":["import { mkdir, writeFile } from \"node:fs/promises\";\nimport { join } from \"node:path\";\nimport { glob } from \"fast-glob\";\nimport React from \"react\";\nimport { generateStaticPage } from \"xplorajs-react\";\n\ninterface Route {\n path: string;\n file: string;\n isDynamic: boolean;\n params: string[];\n}\n\nfunction convertToRoute(filePath: string): Route {\n const relativePath = filePath.replace(\"src/app/\", \"\");\n const path = relativePath\n .replace(/\\.tsx$/, \"\")\n .replace(/\\/page$/, \"\")\n .replace(/\\[([^\\]]+)\\]/g, \":$1\");\n\n const params = (relativePath.match(/\\[([^\\]]+)\\]/g) || []).map((param) =>\n param.slice(1, -1),\n );\n\n return {\n path: path === \"page\" ? \"/\" : `/${path}`,\n file: filePath,\n isDynamic: params.length > 0,\n params,\n };\n}\n\nasync function processPage(page: string, route: Route) {\n try {\n const module = await import(join(process.cwd(), page));\n const PageComponent = module.default;\n\n const getStaticProps = module.getStaticProps;\n let props = {};\n\n if (getStaticProps) {\n const result = await getStaticProps();\n props = result.props;\n }\n\n const outputPath = join(process.cwd(), \"dist\", route.path, \"index.html\");\n await generateStaticPage({\n component: React.createElement(PageComponent, props),\n outputPath,\n props,\n });\n\n console.log(`Generated ${outputPath}`);\n } catch (error) {\n console.error(`Error processing ${page}:`, error);\n }\n}\n\nexport async function build() {\n console.log(\"Building application...\");\n\n await mkdir(join(process.cwd(), \"dist\"), { recursive: true });\n\n const pages = await glob(\"src/app/**/*.tsx\", {\n ignore: [\"**/node_modules/**\"],\n });\n\n const routes: Route[] = [];\n\n for (const page of pages) {\n const route = convertToRoute(page);\n routes.push(route);\n await processPage(page, route);\n }\n\n const routesConfig = {\n routes,\n generatedAt: new Date().toISOString(),\n };\n\n await writeFile(\n join(process.cwd(), \".xplora\", \"routes.json\"),\n JSON.stringify(routesConfig, null, 2),\n );\n\n console.log(\"Build completed!\");\n console.log(\"Routes:\", routes.map((r) => r.path).join(\"\\n\"));\n}\n"],"names":["mkdir","writeFile","join","glob","React","generateStaticPage","convertToRoute","filePath","relativePath","replace","path","params","match","map","param","slice","file","isDynamic","length","processPage","page","route","module","process","cwd","PageComponent","default","getStaticProps","props","result","outputPath","component","createElement","console","log","error","build","recursive","pages","ignore","routes","push","routesConfig","generatedAt","Date","toISOString","JSON","stringify","r"],"mappings":"AAAA,SAASA,KAAK,EAAEC,SAAS,QAAQ,mBAAmB;AACpD,SAASC,IAAI,QAAQ,YAAY;AACjC,SAASC,IAAI,QAAQ,YAAY;AACjC,OAAOC,WAAW,QAAQ;AAC1B,SAASC,kBAAkB,QAAQ,iBAAiB;AASpD,SAASC,eAAeC,QAAgB;IACtC,MAAMC,eAAeD,SAASE,OAAO,CAAC,YAAY;IAClD,MAAMC,OAAOF,aACVC,OAAO,CAAC,UAAU,IAClBA,OAAO,CAAC,WAAW,IACnBA,OAAO,CAAC,iBAAiB;IAE5B,MAAME,SAAS,AAACH,CAAAA,aAAaI,KAAK,CAAC,oBAAoB,EAAE,AAAD,EAAGC,GAAG,CAAC,CAACC,QAC9DA,MAAMC,KAAK,CAAC,GAAG,CAAC;IAGlB,OAAO;QACLL,MAAMA,SAAS,SAAS,MAAM,CAAC,CAAC,EAAEA,MAAM;QACxCM,MAAMT;QACNU,WAAWN,OAAOO,MAAM,GAAG;QAC3BP;IACF;AACF;AAEA,eAAeQ,YAAYC,IAAY,EAAEC,KAAY;IACnD,IAAI;QACF,MAAMC,SAAS,MAAM,MAAM,CAACpB,KAAKqB,QAAQC,GAAG,IAAIJ;QAChD,MAAMK,gBAAgBH,OAAOI,OAAO;QAEpC,MAAMC,iBAAiBL,OAAOK,cAAc;QAC5C,IAAIC,QAAQ,CAAC;QAEb,IAAID,gBAAgB;YAClB,MAAME,SAAS,MAAMF;YACrBC,QAAQC,OAAOD,KAAK;QACtB;QAEA,MAAME,aAAa5B,KAAKqB,QAAQC,GAAG,IAAI,QAAQH,MAAMX,IAAI,EAAE;QAC3D,MAAML,mBAAmB;YACvB0B,WAAW3B,MAAM4B,aAAa,CAACP,eAAeG;YAC9CE;YACAF;QACF;QAEAK,QAAQC,GAAG,CAAC,CAAC,UAAU,EAAEJ,YAAY;IACvC,EAAE,OAAOK,OAAO;QACdF,QAAQE,KAAK,CAAC,CAAC,iBAAiB,EAAEf,KAAK,CAAC,CAAC,EAAEe;IAC7C;AACF;AAEA,OAAO,eAAeC;IACpBH,QAAQC,GAAG,CAAC;IAEZ,MAAMlC,MAAME,KAAKqB,QAAQC,GAAG,IAAI,SAAS;QAAEa,WAAW;IAAK;IAE3D,MAAMC,QAAQ,MAAMnC,KAAK,oBAAoB;QAC3CoC,QAAQ;YAAC;SAAqB;IAChC;IAEA,MAAMC,SAAkB,EAAE;IAE1B,KAAK,MAAMpB,QAAQkB,MAAO;QACxB,MAAMjB,QAAQf,eAAec;QAC7BoB,OAAOC,IAAI,CAACpB;QACZ,MAAMF,YAAYC,MAAMC;IAC1B;IAEA,MAAMqB,eAAe;QACnBF;QACAG,aAAa,IAAIC,OAAOC,WAAW;IACrC;IAEA,MAAM5C,UACJC,KAAKqB,QAAQC,GAAG,IAAI,WAAW,gBAC/BsB,KAAKC,SAAS,CAACL,cAAc,MAAM;IAGrCT,QAAQC,GAAG,CAAC;IACZD,QAAQC,GAAG,CAAC,WAAWM,OAAO3B,GAAG,CAAC,CAACmC,IAAMA,EAAEtC,IAAI,EAAER,IAAI,CAAC;AACxD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function dev(): Promise<void>;
|
package/dist/commands/dev.js
CHANGED
|
@@ -1,20 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
const { build } = require("./build");
|
|
1
|
+
import { readFileSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { serve } from "bun";
|
|
4
|
+
import { watch } from "chokidar";
|
|
5
|
+
import React from "react";
|
|
6
|
+
import { WebSocketServer } from "ws";
|
|
7
|
+
import { renderToStream } from "xplorajs-react";
|
|
8
|
+
import { build } from "./build";
|
|
10
9
|
const pages = new Map();
|
|
11
10
|
async function loadPages() {
|
|
12
11
|
pages.clear();
|
|
13
12
|
const routes = await loadRoutes();
|
|
14
13
|
for (const route of routes){
|
|
15
14
|
const abs = join(process.cwd(), route.file);
|
|
16
|
-
delete require
|
|
17
|
-
pages.set(route.path,
|
|
15
|
+
delete import.meta.require?.cache?.[abs];
|
|
16
|
+
pages.set(route.path, (await import(abs)).default);
|
|
18
17
|
}
|
|
19
18
|
}
|
|
20
19
|
async function loadRoutes() {
|
|
@@ -26,7 +25,7 @@ async function loadRoutes() {
|
|
|
26
25
|
return [];
|
|
27
26
|
}
|
|
28
27
|
}
|
|
29
|
-
async function dev() {
|
|
28
|
+
export async function dev() {
|
|
30
29
|
console.log("Starting development server...");
|
|
31
30
|
const wss = new WebSocketServer({
|
|
32
31
|
port: 3001
|
|
@@ -51,12 +50,8 @@ async function dev() {
|
|
|
51
50
|
});
|
|
52
51
|
await build();
|
|
53
52
|
await loadPages();
|
|
54
|
-
const config = {
|
|
55
|
-
port: 3000,
|
|
56
|
-
hmr: true
|
|
57
|
-
};
|
|
58
53
|
serve({
|
|
59
|
-
port:
|
|
54
|
+
port: 3000,
|
|
60
55
|
development: true,
|
|
61
56
|
async fetch (req) {
|
|
62
57
|
const url = new URL(req.url);
|
|
@@ -127,8 +122,5 @@ async function dev() {
|
|
|
127
122
|
});
|
|
128
123
|
console.log("Development server running at http://localhost:3000");
|
|
129
124
|
}
|
|
130
|
-
module.exports = {
|
|
131
|
-
dev
|
|
132
|
-
};
|
|
133
125
|
|
|
134
126
|
//# sourceMappingURL=dev.js.map
|
package/dist/commands/dev.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/commands/dev.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../src/commands/dev.ts"],"sourcesContent":["import { readFileSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport { serve } from \"bun\";\nimport { watch } from \"chokidar\";\nimport React from \"react\";\nimport type { ComponentType } from \"react\";\nimport { WebSocketServer } from \"ws\";\nimport { renderToStream } from \"xplorajs-react\";\nimport { build } from \"./build\";\n\n// biome-ignore lint/suspicious/noExplicitAny: <intended>\nconst pages = new Map<string, ComponentType<Record<string, any>>>();\n\nasync function loadPages() {\n pages.clear();\n const routes = await loadRoutes();\n\n for (const route of routes) {\n const abs = join(process.cwd(), route.file);\n delete import.meta.require?.cache?.[abs];\n pages.set(\n route.path,\n // biome-ignore lint/suspicious/noExplicitAny: <intended>\n (await import(abs)).default as ComponentType<Record<string, any>>,\n );\n }\n}\n\nasync function loadRoutes() {\n try {\n const routesPath = join(process.cwd(), \".xplora\", \"routes.json\");\n const routesContent = readFileSync(routesPath, \"utf-8\");\n return JSON.parse(routesContent).routes;\n } catch {\n return [];\n }\n}\n\nexport async function dev() {\n console.log(\"Starting development server...\");\n\n const wss = new WebSocketServer({ port: 3001 });\n\n const watcher = watch([\"src/**/*\"], {\n ignored: /(^|[\\/\\\\])\\../,\n persistent: true,\n });\n\n watcher.on(\"change\", async (path: string) => {\n console.log(`File ${path} has been changed`);\n await build();\n await loadPages();\n\n for (const client of wss.clients) {\n if (client.readyState === WebSocket.OPEN) {\n client.send(JSON.stringify({ type: \"reload\" }));\n }\n }\n });\n\n await build();\n await loadPages();\n\n serve({\n port: 3000,\n development: true,\n async fetch(req: Request) {\n const url = new URL(req.url);\n const path = url.pathname;\n\n if (path === \"/\") {\n return new Response(\"Hello from XploraJS!\");\n }\n\n if (path.startsWith(\"/assets/\")) {\n const f = Bun.file(join(process.cwd(), \"dist\", path));\n if (await f.exists()) return new Response(f);\n }\n\n const Page = pages.get(path);\n if (!Page) return new Response(\"Not Found\", { status: 404 });\n\n const stream = await renderToStream(React.createElement(Page));\n\n const head = `<!DOCTYPE html><html><head>\n\t\t\t\t<meta charset=\"utf-8\"/>\n\t\t\t\t<link rel=\"stylesheet\" href=\"/assets/style.css\"/>\n\t\t\t\t<script>window.process={env:{NODE_ENV:\"development\"}};</script>\n\t\t\t\t</head><body><div id=\"root\">`;\n\n const foot = `</div>\n\t\t\t\t<script type=\"module\">\n\t\t\t\t\timport * as RefreshRuntime from \"https://esm.sh/react-refresh@0.17.0/runtime\";\n\t\t\t\t\tif (window.process?.env?.NODE_ENV === \"development\") {\n\t\t\t\t\t\tconsole.log(\"Fast refresh runtime loaded in development mode\");\n\t\t\t\t\t}\n\t\t\t\t\tRefreshRuntime.injectIntoGlobalHook(window);\n\t\t\t\t\twindow.$RefreshReg$=()=>{};\n\t\t\t\t\twindow.$RefreshSig$=()=>t=>t;\n\t\t\t\t</script>\n\t\t\t\t<script>\n\t\t\t\t\tconst ws=new WebSocket(\"ws://localhost:3001\");\n\t\t\t\t\tws.onmessage=async e=>{\n\t\t\t\t\t\tif(e.data===\"css\"){\n\t\t\t\t\t\t\tdocument.querySelectorAll('link[rel=\"stylesheet\"]').forEach(l=>l.href=\"/assets/style.css?v=\"+Date.now());\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(e.data===\"reload\"){\n\t\t\t\t\t\t\tconsole.log(\"Reloading...\");\n\t\t\t\t\t\t\tlocation.reload();\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t</script>\n\t\t\t</body></html>`;\n\n return new Response(\n new ReadableStream({\n start(ctrl) {\n ctrl.enqueue(new TextEncoder().encode(head));\n if (typeof stream === \"string\") {\n ctrl.enqueue(new TextEncoder().encode(stream));\n } else {\n stream.pipeTo(\n new WritableStream({\n write(c) {\n ctrl.enqueue(c);\n },\n close() {\n ctrl.enqueue(new TextEncoder().encode(foot));\n ctrl.close();\n },\n }),\n );\n }\n },\n }),\n { headers: { \"Content-Type\": \"text/html; charset=utf-8\" } },\n );\n },\n });\n\n console.log(\"Development server running at http://localhost:3000\");\n}\n"],"names":["readFileSync","join","serve","watch","React","WebSocketServer","renderToStream","build","pages","Map","loadPages","clear","routes","loadRoutes","route","abs","process","cwd","file","require","cache","set","path","default","routesPath","routesContent","JSON","parse","dev","console","log","wss","port","watcher","ignored","persistent","on","client","clients","readyState","WebSocket","OPEN","send","stringify","type","development","fetch","req","url","URL","pathname","Response","startsWith","f","Bun","exists","Page","get","status","stream","createElement","head","foot","ReadableStream","start","ctrl","enqueue","TextEncoder","encode","pipeTo","WritableStream","write","c","close","headers"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function start(): Promise<void>;
|
package/dist/commands/start.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
const { join } = require("node:path");
|
|
4
|
-
async function start() {
|
|
1
|
+
import { serve } from "bun";
|
|
2
|
+
export async function start() {
|
|
5
3
|
console.log("Starting production server...");
|
|
6
4
|
const config = {
|
|
7
5
|
port: 3000
|
|
@@ -21,8 +19,5 @@ async function start() {
|
|
|
21
19
|
});
|
|
22
20
|
console.log("Production server running at http://localhost:3000");
|
|
23
21
|
}
|
|
24
|
-
module.exports = {
|
|
25
|
-
start
|
|
26
|
-
};
|
|
27
22
|
|
|
28
23
|
//# sourceMappingURL=start.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/commands/start.ts"],"sourcesContent":["
|
|
1
|
+
{"version":3,"sources":["../../src/commands/start.ts"],"sourcesContent":["import { serve } from \"bun\";\n\nexport async function start() {\n console.log(\"Starting production server...\");\n\n const config = {\n port: 3000,\n };\n\n serve({\n port: config.port,\n async fetch(req: Request) {\n const url = new URL(req.url);\n const path = url.pathname;\n\n if (path === \"/\") {\n return new Response(\"Hello from XploraJS!\");\n }\n\n return new Response(\"Not found\", { status: 404 });\n },\n });\n\n console.log(\"Production server running at http://localhost:3000\");\n}\n"],"names":["serve","start","console","log","config","port","fetch","req","url","URL","path","pathname","Response","status"],"mappings":"AAAA,SAASA,KAAK,QAAQ,MAAM;AAE5B,OAAO,eAAeC;IACpBC,QAAQC,GAAG,CAAC;IAEZ,MAAMC,SAAS;QACbC,MAAM;IACR;IAEAL,MAAM;QACJK,MAAMD,OAAOC,IAAI;QACjB,MAAMC,OAAMC,GAAY;YACtB,MAAMC,MAAM,IAAIC,IAAIF,IAAIC,GAAG;YAC3B,MAAME,OAAOF,IAAIG,QAAQ;YAEzB,IAAID,SAAS,KAAK;gBAChB,OAAO,IAAIE,SAAS;YACtB;YAEA,OAAO,IAAIA,SAAS,aAAa;gBAAEC,QAAQ;YAAI;QACjD;IACF;IAEAX,QAAQC,GAAG,CAAC;AACd"}
|
package/dist/config.d.ts
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
interface XploraConfig {
|
|
2
|
+
dev?: {
|
|
3
|
+
port?: number;
|
|
4
|
+
hmr?: boolean;
|
|
5
|
+
};
|
|
6
|
+
static?: {
|
|
7
|
+
outputDir?: string;
|
|
8
|
+
revalidate?: number;
|
|
9
|
+
fallback?: boolean;
|
|
10
|
+
};
|
|
11
|
+
build?: {
|
|
12
|
+
minify?: boolean;
|
|
13
|
+
sourcemap?: boolean;
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
declare function defineConfig(config: XploraConfig): XploraConfig;
|
|
17
|
+
export type { XploraConfig };
|
|
18
|
+
export { defineConfig };
|
package/dist/config.js
CHANGED
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/config.ts"],"sourcesContent":["interface XploraConfig {\n
|
|
1
|
+
{"version":3,"sources":["../src/config.ts"],"sourcesContent":["interface XploraConfig {\n dev?: {\n port?: number;\n hmr?: boolean;\n };\n static?: {\n outputDir?: string;\n revalidate?: number;\n fallback?: boolean;\n };\n build?: {\n minify?: boolean;\n sourcemap?: boolean;\n };\n}\n\nfunction defineConfig(config: XploraConfig): XploraConfig {\n return {\n dev: {\n port: 3000,\n hmr: true,\n ...config.dev,\n },\n static: {\n outputDir: \"./dist\",\n revalidate: 3600,\n fallback: false,\n ...config.static,\n },\n build: {\n minify: true,\n sourcemap: true,\n ...config.build,\n },\n };\n}\n\nexport type { XploraConfig };\nexport { defineConfig };\n"],"names":["defineConfig","config","dev","port","hmr","static","outputDir","revalidate","fallback","build","minify","sourcemap"],"mappings":"AAgBA,SAASA,aAAaC,MAAoB;IACxC,OAAO;QACLC,KAAK;YACHC,MAAM;YACNC,KAAK;YACL,GAAGH,OAAOC,GAAG;QACf;QACAG,QAAQ;YACNC,WAAW;YACXC,YAAY;YACZC,UAAU;YACV,GAAGP,OAAOI,MAAM;QAClB;QACAI,OAAO;YACLC,QAAQ;YACRC,WAAW;YACX,GAAGV,OAAOQ,KAAK;QACjB;IACF;AACF;AAGA,SAAST,YAAY,GAAG"}
|
package/dist/index.d.ts
ADDED
package/dist/index.js
CHANGED
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["const { XploraConfig, defineConfig } = require(\"./config\");\n\nmodule.exports = {\n\tXploraConfig,\n\tdefineConfig,\n};\n"],"names":["XploraConfig","defineConfig","require","module","exports"],"mappings":"AAAA,MAAM,EAAEA,YAAY,EAAEC,YAAY,EAAE,GAAGC,QAAQ;AAE/CC,OAAOC,OAAO,GAAG;IAChBJ;IACAC;AACD"}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["const { XploraConfig, defineConfig } = require(\"./config\");\n\nmodule.exports = {\n\tXploraConfig,\n\tdefineConfig,\n};\nexport { defineConfig };\n\n"],"names":["XploraConfig","defineConfig","require","module","exports"],"mappings":"AAAA,MAAM,EAAEA,YAAY,EAAEC,YAAY,EAAE,GAAGC,QAAQ;AAE/CC,OAAOC,OAAO,GAAG;IAChBJ;IACAC;AACD;AACA,SAASA,YAAY,GAAG"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "xplorajs",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"types": "dist/index.d.ts",
|
|
6
6
|
"bin": {
|
|
@@ -12,17 +12,17 @@
|
|
|
12
12
|
],
|
|
13
13
|
"scripts": {
|
|
14
14
|
"dev": "bun run build --watch",
|
|
15
|
-
"build": "swc src -d dist --config-file .swcrc",
|
|
15
|
+
"build": "swc src -d dist --config-file .swcrc && tsc --emitDeclarationOnly",
|
|
16
16
|
"prepublishOnly": "bun run build"
|
|
17
17
|
},
|
|
18
18
|
"dependencies": {
|
|
19
19
|
"@swc/cli": "^0.1.65",
|
|
20
20
|
"@swc/core": "^1.11.24",
|
|
21
21
|
"chokidar": "^3.6.0",
|
|
22
|
-
"commander": "^11.
|
|
22
|
+
"commander": "^11.1.0",
|
|
23
23
|
"fast-glob": "^3.3.3",
|
|
24
24
|
"ws": "^8.18.2",
|
|
25
|
-
"xplorajs-react": "
|
|
25
|
+
"xplorajs-react": "^0.2.0"
|
|
26
26
|
},
|
|
27
27
|
"devDependencies": {
|
|
28
28
|
"@types/bun": "^1.2.13",
|
|
@@ -31,7 +31,9 @@
|
|
|
31
31
|
},
|
|
32
32
|
"peerDependencies": {
|
|
33
33
|
"react": "^19.1.0",
|
|
34
|
-
"react-dom": "^19.1.0"
|
|
34
|
+
"react-dom": "^19.1.0",
|
|
35
|
+
"@types/react": "^19.1.4",
|
|
36
|
+
"@types/react-dom": "^19.1.5"
|
|
35
37
|
},
|
|
36
38
|
"publishConfig": {
|
|
37
39
|
"access": "public"
|
package/dist/app/page.js
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
export default function Home() {
|
|
2
|
-
return /*#__PURE__*/ React.createElement("section", {
|
|
3
|
-
className: "flex h-screen items-center justify-center bg-gray-100"
|
|
4
|
-
}, /*#__PURE__*/ React.createElement("h1", {
|
|
5
|
-
className: "text-4xl font-bold text-teal-600"
|
|
6
|
-
}, "XploraJS \uD83D\uDE80"));
|
|
7
|
-
}
|