htmx-router 0.0.2 → 0.0.3
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/bin/cli/index.js +14 -0
- package/bin/index.d.ts +2 -2
- package/bin/index.js +2 -1
- package/bin/router.d.ts +2 -2
- package/bin/router.js +20 -7
- package/bin/shared.d.ts +3 -2
- package/bin/shared.js +1 -1
- package/package.json +3 -4
package/bin/cli/index.js
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
const dynamic_1 = require("./dynamic");
|
|
5
|
+
const static_1 = require("./static");
|
|
6
|
+
const isDynamic = process.argv.includes('--dynamic');
|
|
7
|
+
const cwd = process.argv[2] || "./";
|
|
8
|
+
console.log(`Building ${isDynamic ? "dynamic" : "static"} routes`);
|
|
9
|
+
if (isDynamic) {
|
|
10
|
+
(0, dynamic_1.BuildDynamic)(cwd);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
(0, static_1.BuildStatic)(cwd);
|
|
14
|
+
}
|
package/bin/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { RouteTree } from "./router";
|
|
1
|
+
import { RouteTree, IsAllowedExt } from "./router";
|
|
2
2
|
import { ErrorResponse, Redirect, Outlet, Override, RenderArgs } from "./shared";
|
|
3
3
|
import { StyleCSS } from "./helper";
|
|
4
|
-
export { RouteTree, ErrorResponse, Redirect, Override, RenderArgs, Outlet, StyleCSS };
|
|
4
|
+
export { IsAllowedExt, RouteTree, ErrorResponse, Redirect, Override, RenderArgs, Outlet, StyleCSS };
|
package/bin/index.js
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.StyleCSS = exports.RenderArgs = exports.Override = exports.Redirect = exports.ErrorResponse = exports.RouteTree = void 0;
|
|
3
|
+
exports.StyleCSS = exports.RenderArgs = exports.Override = exports.Redirect = exports.ErrorResponse = exports.RouteTree = exports.IsAllowedExt = void 0;
|
|
4
4
|
const router_1 = require("./router");
|
|
5
5
|
Object.defineProperty(exports, "RouteTree", { enumerable: true, get: function () { return router_1.RouteTree; } });
|
|
6
|
+
Object.defineProperty(exports, "IsAllowedExt", { enumerable: true, get: function () { return router_1.IsAllowedExt; } });
|
|
6
7
|
const shared_1 = require("./shared");
|
|
7
8
|
Object.defineProperty(exports, "ErrorResponse", { enumerable: true, get: function () { return shared_1.ErrorResponse; } });
|
|
8
9
|
Object.defineProperty(exports, "Redirect", { enumerable: true, get: function () { return shared_1.Redirect; } });
|
package/bin/router.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
2
|
import type http from "node:http";
|
|
3
|
-
import { Outlet, RenderArgs, RouteModule } from "./shared";
|
|
3
|
+
import { Outlet, Override, Redirect, RenderArgs, RouteModule } from "./shared";
|
|
4
4
|
export declare function IsAllowedExt(ext: string): boolean;
|
|
5
5
|
declare class RouteLeaf {
|
|
6
6
|
module: RouteModule;
|
|
@@ -17,7 +17,7 @@ export declare class RouteTree {
|
|
|
17
17
|
constructor();
|
|
18
18
|
assignRoot(module: RouteModule): void;
|
|
19
19
|
ingest(path: string | string[], module: RouteModule, override: boolean[]): void;
|
|
20
|
-
render(req: http.IncomingMessage, res: http.ServerResponse, url: URL): Promise<string
|
|
20
|
+
render(req: http.IncomingMessage, res: http.ServerResponse, url: URL): Promise<string | Redirect | Override>;
|
|
21
21
|
private _recursiveRender;
|
|
22
22
|
}
|
|
23
23
|
export {};
|
package/bin/router.js
CHANGED
|
@@ -3,16 +3,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.RouteTree = exports.IsAllowedExt = void 0;
|
|
4
4
|
const shared_1 = require("./shared");
|
|
5
5
|
function IsAllowedExt(ext) {
|
|
6
|
+
if (ext[0] !== ".")
|
|
7
|
+
return false;
|
|
6
8
|
// js, jsx, tsx, ts
|
|
7
|
-
if (ext[
|
|
9
|
+
if (ext[2] !== "s")
|
|
8
10
|
return false;
|
|
9
|
-
if (ext[
|
|
11
|
+
if (ext[1] !== "j" && ext[1] !== "t")
|
|
10
12
|
return false;
|
|
11
|
-
if (ext.length ==
|
|
13
|
+
if (ext.length == 3)
|
|
12
14
|
return true;
|
|
13
|
-
if (ext.length !=
|
|
15
|
+
if (ext.length != 4)
|
|
14
16
|
return false;
|
|
15
|
-
if (ext[
|
|
17
|
+
if (ext[3] !== "x")
|
|
16
18
|
return false;
|
|
17
19
|
return true;
|
|
18
20
|
}
|
|
@@ -100,7 +102,7 @@ class RouteTree {
|
|
|
100
102
|
path.splice(0, 1);
|
|
101
103
|
next.ingest(path, module, override);
|
|
102
104
|
}
|
|
103
|
-
render(req, res, url) {
|
|
105
|
+
async render(req, res, url) {
|
|
104
106
|
const args = new shared_1.RenderArgs(req, res, url);
|
|
105
107
|
if (!this.default || !this.default.module.Render) {
|
|
106
108
|
return "";
|
|
@@ -109,7 +111,18 @@ class RouteTree {
|
|
|
109
111
|
if (frags.length === 1 && frags[0] === "") {
|
|
110
112
|
frags.splice(0, 1);
|
|
111
113
|
}
|
|
112
|
-
|
|
114
|
+
try {
|
|
115
|
+
const out = await this._recursiveRender(args, frags).outlet();
|
|
116
|
+
return out;
|
|
117
|
+
}
|
|
118
|
+
catch (e) {
|
|
119
|
+
if (e instanceof shared_1.Redirect)
|
|
120
|
+
return e;
|
|
121
|
+
if (e instanceof shared_1.Override)
|
|
122
|
+
return e;
|
|
123
|
+
throw new Error(`Unhandled boil up type ${typeof (e)}: ${e}`);
|
|
124
|
+
}
|
|
125
|
+
;
|
|
113
126
|
}
|
|
114
127
|
_recursiveRender(args, frags) {
|
|
115
128
|
var _a;
|
package/bin/shared.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
2
3
|
import type http from "node:http";
|
|
3
4
|
export type Outlet = () => Promise<string>;
|
|
4
5
|
export type RenderFunction = (args: RenderArgs, Outlet: Outlet) => Promise<string>;
|
|
@@ -19,8 +20,8 @@ export declare class Redirect {
|
|
|
19
20
|
run(res: http.ServerResponse): http.ServerResponse<http.IncomingMessage>;
|
|
20
21
|
}
|
|
21
22
|
export declare class Override {
|
|
22
|
-
data:
|
|
23
|
-
constructor(data:
|
|
23
|
+
data: string | Buffer | Uint8Array;
|
|
24
|
+
constructor(data: string | Buffer | Uint8Array);
|
|
24
25
|
}
|
|
25
26
|
type MetaHTML = {
|
|
26
27
|
[key: string]: string;
|
package/bin/shared.js
CHANGED
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "htmx-router",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.3",
|
|
4
4
|
"description": "A remix.js style file path router for htmX websites",
|
|
5
5
|
"main": "./bin/index.js",
|
|
6
6
|
"scripts": {
|
|
7
7
|
"build": "tsc"
|
|
8
8
|
},
|
|
9
9
|
"bin": {
|
|
10
|
-
"htmx-router": "bin/cli.js"
|
|
10
|
+
"htmx-router": "bin/cli/index.js"
|
|
11
11
|
},
|
|
12
12
|
"repository": {
|
|
13
13
|
"type": "git",
|
|
@@ -25,7 +25,6 @@
|
|
|
25
25
|
"typescript": "^5.1.6"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"csstype": "^3.1.2"
|
|
29
|
-
"import": "^0.0.6"
|
|
28
|
+
"csstype": "^3.1.2"
|
|
30
29
|
}
|
|
31
30
|
}
|