@esportsplus/routing 0.0.24 → 0.0.25

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.
@@ -1,14 +1,50 @@
1
- import { Middleware, Response, Router } from './types';
1
+ import { Middleware, Router } from './types';
2
2
  declare function back(): void;
3
3
  declare function forward(): void;
4
4
  declare const _default: <T>(instance?: Router<T> | undefined) => {
5
5
  back: typeof back;
6
6
  forward: typeof forward;
7
- middleware: (...middleware: Middleware<T>[]) => () => Response<T>;
8
- redirect: (path: string, { state, values }: {
9
- state?: Record<PropertyKey, unknown> | undefined;
10
- values?: unknown[] | undefined;
11
- }) => void;
7
+ middleware: (...middleware: Middleware<T>[]) => {
8
+ pipeline: () => T;
9
+ request: {
10
+ data: {
11
+ [x: string]: unknown;
12
+ [x: number]: unknown;
13
+ [x: symbol]: unknown;
14
+ parameters?: Record<PropertyKey, unknown> | undefined;
15
+ route?: import("./router/route").Route<T> | undefined;
16
+ };
17
+ href: string;
18
+ hostname: string;
19
+ method: string;
20
+ origin: string;
21
+ path: string;
22
+ port: string;
23
+ protocol: string;
24
+ query: {
25
+ [x: string]: unknown;
26
+ };
27
+ subdomain?: string | undefined;
28
+ dispose: () => void;
29
+ reset: () => void;
30
+ nodes: {
31
+ data: import("@esportsplus/reactivity/build/signal").default<Record<PropertyKey, unknown> & {
32
+ parameters?: Record<PropertyKey, unknown> | undefined;
33
+ route?: import("./router/route").Route<T> | undefined;
34
+ }>;
35
+ href: import("@esportsplus/reactivity/build/signal").default<string>;
36
+ hostname: import("@esportsplus/reactivity/build/signal").default<string>;
37
+ method: import("@esportsplus/reactivity/build/signal").default<string>;
38
+ origin: import("@esportsplus/reactivity/build/signal").default<string>;
39
+ path: import("@esportsplus/reactivity/build/signal").default<string>;
40
+ port: import("@esportsplus/reactivity/build/signal").default<string>;
41
+ protocol: import("@esportsplus/reactivity/build/signal").default<string>;
42
+ query: import("@esportsplus/reactivity/build/signal").default<Record<string, unknown>>;
43
+ subdomain?: import("@esportsplus/reactivity/build/signal").default<string> | import("@esportsplus/reactivity/build/signal").default<undefined> | undefined;
44
+ };
45
+ };
46
+ };
47
+ redirect: (path: string, values?: unknown[]) => void;
12
48
  router: Router<T>;
13
49
  uri: (path: string, values?: unknown[]) => string;
14
50
  };
package/build/browser.js CHANGED
@@ -18,7 +18,7 @@ function onpopstate() {
18
18
  let values = request();
19
19
  for (let i = 0, n = cache.length; i < n; i++) {
20
20
  let state = cache[i];
21
- for (let key in state) {
21
+ for (let key in values) {
22
22
  state[key] = values[key];
23
23
  }
24
24
  }
@@ -42,24 +42,27 @@ export default (instance) => {
42
42
  cache.push(state);
43
43
  if (!registered) {
44
44
  registered = true;
45
- window.addEventListener('popstate', onpopstate);
45
+ window.addEventListener('hashchange', onpopstate);
46
46
  }
47
47
  return {
48
48
  back,
49
49
  forward,
50
50
  middleware: (...middleware) => {
51
51
  let instance = pipeline(...middleware);
52
- return () => instance(state);
52
+ return {
53
+ pipeline: () => instance(state),
54
+ request: state
55
+ };
53
56
  },
54
- redirect: (path, { state, values }) => {
57
+ redirect: (path, values = []) => {
55
58
  if (path.startsWith('https://') || path.startsWith('http://')) {
56
59
  return window.location.replace(path);
57
60
  }
58
- window.history.pushState((state || {}), '', normalize(router.uri(path, values || [])));
61
+ window.location.hash = normalize(router.uri(path, values));
59
62
  },
60
63
  router,
61
64
  uri: (path, values = []) => {
62
- return normalize(router.uri(path, values || []));
65
+ return normalize(router.uri(path, values));
63
66
  }
64
67
  };
65
68
  };
package/build/types.d.ts CHANGED
@@ -22,5 +22,5 @@ type Request<T> = {
22
22
  subdomain?: string;
23
23
  };
24
24
  type Responder<T> = (request: Request<T>) => Response<T>;
25
- type Response<T> = Promise<T> | T;
25
+ type Response<T> = T;
26
26
  export { Middleware, Next, Options, Request, Responder, Response, Route, Router };
package/package.json CHANGED
@@ -17,5 +17,5 @@
17
17
  "prepublishOnly": "npm run build"
18
18
  },
19
19
  "types": "./build/index.d.ts",
20
- "version": "0.0.24"
20
+ "version": "0.0.25"
21
21
  }
package/src/browser.ts CHANGED
@@ -30,7 +30,7 @@ function onpopstate() {
30
30
  for (let i = 0, n = cache.length; i < n; i++) {
31
31
  let state = cache[i];
32
32
 
33
- for (let key in state) {
33
+ for (let key in values) {
34
34
  // @ts-ignore
35
35
  state[key] = values[key];
36
36
  }
@@ -63,7 +63,7 @@ export default <T>(instance?: Router<T>) => {
63
63
 
64
64
  if (!registered) {
65
65
  registered = true;
66
- window.addEventListener('popstate', onpopstate);
66
+ window.addEventListener('hashchange', onpopstate);
67
67
  }
68
68
 
69
69
  return {
@@ -72,18 +72,21 @@ export default <T>(instance?: Router<T>) => {
72
72
  middleware: (...middleware: Middleware<T>[]) => {
73
73
  let instance = pipeline<Request<T>, Response<T>>(...middleware);
74
74
 
75
- return () => instance(state);
75
+ return {
76
+ pipeline: () => instance(state),
77
+ request: state
78
+ };
76
79
  },
77
- redirect: (path: string, { state, values }: { state?: Record<PropertyKey, unknown>; values?: unknown[] }) => {
80
+ redirect: (path: string, values: unknown[] = []) => {
78
81
  if (path.startsWith('https://') || path.startsWith('http://')) {
79
82
  return window.location.replace(path);
80
83
  }
81
84
 
82
- window.history.pushState( (state || {}), '', normalize(router.uri(path, values || [])) );
85
+ window.location.hash = normalize( router.uri(path, values) );
83
86
  },
84
87
  router,
85
88
  uri: (path: string, values: unknown[] = []) => {
86
- return normalize( router.uri(path, values || []) );
89
+ return normalize( router.uri(path, values) );
87
90
  }
88
91
  };
89
92
  };
package/src/types.ts CHANGED
@@ -29,7 +29,7 @@ type Request<T> = {
29
29
 
30
30
  type Responder<T> = (request: Request<T>) => Response<T>;
31
31
 
32
- type Response<T> = Promise<T> | T;
32
+ type Response<T> = T;
33
33
 
34
34
 
35
35
  export { Middleware, Next, Options, Request, Responder, Response, Route, Router };