@esportsplus/routing 0.0.27 → 0.0.29

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.
@@ -5,43 +5,13 @@ declare const _default: <T>(instance?: Router<T> | undefined) => {
5
5
  back: typeof back;
6
6
  forward: typeof forward;
7
7
  match: (subdomain?: string) => {
8
- data: {
9
- [x: string]: unknown;
10
- [x: number]: unknown;
11
- [x: symbol]: unknown;
12
- parameters?: Record<PropertyKey, unknown> | undefined;
13
- route?: import("./router/route").Route<T> | undefined;
14
- };
15
- href: string;
16
- hostname: string;
17
- method: string;
18
- origin: string;
19
- path: string;
20
- port: string;
21
- protocol: string;
22
- query: {
23
- [x: string]: unknown;
24
- };
25
- subdomain?: string | undefined;
26
- dispose: () => void;
27
- reset: () => void;
28
- nodes: {
29
- data: import("@esportsplus/reactivity/build/signal").default<Record<PropertyKey, unknown> & {
30
- parameters?: Record<PropertyKey, unknown> | undefined;
31
- route?: import("./router/route").Route<T> | undefined;
32
- }>;
33
- href: import("@esportsplus/reactivity/build/signal").default<string>;
34
- hostname: import("@esportsplus/reactivity/build/signal").default<string>;
35
- method: import("@esportsplus/reactivity/build/signal").default<string>;
36
- origin: import("@esportsplus/reactivity/build/signal").default<string>;
37
- path: import("@esportsplus/reactivity/build/signal").default<string>;
38
- port: import("@esportsplus/reactivity/build/signal").default<string>;
39
- protocol: import("@esportsplus/reactivity/build/signal").default<string>;
40
- query: import("@esportsplus/reactivity/build/signal").default<Record<string, unknown>>;
41
- subdomain?: import("@esportsplus/reactivity/build/signal").default<string> | import("@esportsplus/reactivity/build/signal").default<undefined> | undefined;
42
- };
8
+ parameters?: Record<PropertyKey, unknown> | undefined;
9
+ route?: import("./router/route").Route<T> | undefined;
43
10
  };
44
- middleware: (...middleware: Middleware<T>[]) => () => T | Promise<T>;
11
+ middleware: (...middleware: Middleware<T>[]) => ({ parameters, route }: {
12
+ parameters?: Record<PropertyKey, unknown> | undefined;
13
+ route?: import("./router/route").Route<T> | undefined;
14
+ }) => T;
45
15
  redirect: (path: string, values?: unknown[]) => void;
46
16
  router: Router<T>;
47
17
  uri: (path: string, values?: unknown[]) => string;
package/build/browser.js CHANGED
@@ -63,17 +63,18 @@ export default (instance) => {
63
63
  match = '';
64
64
  }
65
65
  }
66
- let { parameters, route } = router.match(state.method, state.path, match);
67
- state.data.parameters = parameters;
68
- state.data.route = route;
69
- return state;
66
+ return router.match(state.method, state.path, match);
70
67
  },
71
68
  middleware: (...middleware) => {
72
69
  let instance = pipeline(...middleware);
73
- return () => instance(state);
70
+ return ({ parameters, route }) => {
71
+ state.data.parameters = parameters;
72
+ state.data.route = route;
73
+ return instance(state);
74
+ };
74
75
  },
75
76
  redirect: (path, values = []) => {
76
- if (path.startsWith('https://') || path.startsWith('http://')) {
77
+ if (path.indexOf('://') !== -1) {
77
78
  return window.location.replace(path);
78
79
  }
79
80
  window.location.hash = normalize(router.uri(path, values));
@@ -1,11 +1,11 @@
1
- import { Middleware, Request, Responder } from '../types';
1
+ import { Middleware, Next, Request } from '../types';
2
2
  declare class Route<T> {
3
3
  middleware: Middleware<T>[] | null;
4
4
  name: string | null;
5
5
  path: string | null;
6
- responder: Responder<T>;
6
+ responder: Next<T>;
7
7
  subdomain: string | null;
8
- constructor(responder: Responder<T>);
9
- get dispatch(): (request: Request<T>) => T | Promise<T>;
8
+ constructor(responder: Next<T>);
9
+ get dispatch(): (request: Request<T>) => T;
10
10
  }
11
11
  export { Route };
package/build/types.d.ts CHANGED
@@ -1,12 +1,12 @@
1
1
  import { Next as N, Stage } from '@esportsplus/pipeline';
2
2
  import { Route, Router } from './router';
3
- type Middleware<T> = Stage<Request<T>, Response<T>>;
4
- type Next<T> = N<Request<T>, Response<T>>;
3
+ type Middleware<T> = Stage<Request<T>, T>;
4
+ type Next<T> = N<Request<T>, T>;
5
5
  type Options<T> = {
6
6
  middleware?: Middleware<T>[];
7
7
  name?: string;
8
8
  path?: string;
9
- responder: Responder<T>;
9
+ responder: Next<T>;
10
10
  subdomain?: string;
11
11
  };
12
12
  type Request<T> = {
@@ -21,6 +21,4 @@ type Request<T> = {
21
21
  query: Record<string, unknown>;
22
22
  subdomain?: string;
23
23
  };
24
- type Responder<T> = (request: Request<T>) => Response<T>;
25
- type Response<T> = Promise<T> | T;
26
- export { Middleware, Next, Options, Request, Responder, Route, Router };
24
+ export { Middleware, Next, Options, Request, Route, Router };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "author": "ICJR",
3
3
  "dependencies": {
4
- "@esportsplus/pipeline": "^0.0.1",
4
+ "@esportsplus/pipeline": "^0.0.5",
5
5
  "@esportsplus/reactivity": "^0.1.2"
6
6
  },
7
7
  "devDependencies": {
@@ -17,5 +17,5 @@
17
17
  "prepublishOnly": "npm run build"
18
18
  },
19
19
  "types": "./build/index.d.ts",
20
- "version": "0.0.27"
20
+ "version": "0.0.29"
21
21
  }
package/src/browser.ts CHANGED
@@ -89,20 +89,20 @@ export default <T>(instance?: Router<T>) => {
89
89
  }
90
90
  }
91
91
 
92
- let { parameters, route } = router.match(state.method, state.path, match);
93
-
94
- state.data.parameters = parameters;
95
- state.data.route = route;
96
-
97
- return state;
92
+ return router.match(state.method, state.path, match);
98
93
  },
99
94
  middleware: (...middleware: Middleware<T>[]) => {
100
95
  let instance = pipeline(...middleware);
101
96
 
102
- return () => instance(state);
97
+ return ({ parameters, route }: ReturnType<typeof router.match>) => {
98
+ state.data.parameters = parameters;
99
+ state.data.route = route;
100
+
101
+ return instance(state);
102
+ };
103
103
  },
104
104
  redirect: (path: string, values: unknown[] = []) => {
105
- if (path.startsWith('https://') || path.startsWith('http://')) {
105
+ if (path.indexOf('://') !== -1) {
106
106
  return window.location.replace(path);
107
107
  }
108
108
 
@@ -1,4 +1,4 @@
1
- import { Middleware, Request, Responder } from '~/types';
1
+ import { Middleware, Next, Request } from '~/types';
2
2
  import pipeline from '@esportsplus/pipeline';
3
3
 
4
4
 
@@ -6,11 +6,11 @@ class Route<T> {
6
6
  middleware: Middleware<T>[] | null = null;
7
7
  name: string | null = null;
8
8
  path: string | null = null;
9
- responder: Responder<T>;
9
+ responder: Next<T>;
10
10
  subdomain: string | null = null;
11
11
 
12
12
 
13
- constructor(responder: Responder<T>) {
13
+ constructor(responder: Next<T>) {
14
14
  this.responder = responder;
15
15
  }
16
16
 
@@ -20,7 +20,7 @@ class Route<T> {
20
20
  return (request: Request<T>) => this.responder(request);
21
21
  }
22
22
 
23
- return pipeline(...this.middleware, (request: Request<T>) => this.responder(request));
23
+ return pipeline(...this.middleware, (request) => this.responder(request));
24
24
  }
25
25
  }
26
26
 
package/src/types.ts CHANGED
@@ -2,15 +2,15 @@ import { Next as N, Stage } from '@esportsplus/pipeline';
2
2
  import { Route, Router } from './router';
3
3
 
4
4
 
5
- type Middleware<T> = Stage<Request<T>, Response<T>>;
5
+ type Middleware<T> = Stage<Request<T>, T>;
6
6
 
7
- type Next<T> = N<Request<T>, Response<T>>;
7
+ type Next<T> = N<Request<T>, T>;
8
8
 
9
9
  type Options<T> = {
10
10
  middleware?: Middleware<T>[];
11
11
  name?: string;
12
12
  path?: string;
13
- responder: Responder<T>;
13
+ responder: Next<T>;
14
14
  subdomain?: string;
15
15
  };
16
16
 
@@ -27,9 +27,5 @@ type Request<T> = {
27
27
  subdomain?: string;
28
28
  };
29
29
 
30
- type Responder<T> = (request: Request<T>) => Response<T>;
31
30
 
32
- type Response<T> = Promise<T> | T;
33
-
34
-
35
- export { Middleware, Next, Options, Request, Responder, Route, Router };
31
+ export { Middleware, Next, Options, Request, Route, Router };