@hyeonqyu/typed-router-core 0.1.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/index.d.mts +47 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.js +44 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +42 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +60 -0
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
type Paths<TObject, TSplitter extends string, TPrev extends string = ''> = TSplitter | {
|
|
5
|
+
[K in keyof TObject & string]: TObject[K] extends object ? `${TSplitter}${TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`}` | Paths<TObject[K], TSplitter, TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`> : `${TSplitter}${TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`}`;
|
|
6
|
+
}[keyof TObject & string];
|
|
7
|
+
type PathValue<T, P extends string, S extends string> = P extends S ? T : P extends `${S}${infer Rest}` ? Rest extends `${infer K}${S}${infer R}` ? K extends keyof T ? PathValue<T[K], `${S}${R}`, S> : never : Rest extends keyof T ? T[Rest] : never : never;
|
|
8
|
+
|
|
9
|
+
type BaseMetadata = NonNullable<unknown>;
|
|
10
|
+
type RouteNode<TMetadata extends BaseMetadata, TContext> = {
|
|
11
|
+
_metadata: RouteNodeMetadata<TMetadata, TContext>;
|
|
12
|
+
};
|
|
13
|
+
type RouteNodeMetadata<TMetadata extends BaseMetadata, TContext> = {
|
|
14
|
+
title?: string;
|
|
15
|
+
label?: string;
|
|
16
|
+
description?: string;
|
|
17
|
+
href?: (context: TContext) => string;
|
|
18
|
+
accessible?: (context: TContext) => boolean;
|
|
19
|
+
} & TMetadata;
|
|
20
|
+
type PartialRouteTree<TMetadata extends BaseMetadata, TContext> = {
|
|
21
|
+
[key: string]: RouteNode<TMetadata, TContext> | PartialRouteTree<TMetadata, TContext>;
|
|
22
|
+
};
|
|
23
|
+
type ExtractChildRoutes<TMetadata extends BaseMetadata, TContext, TSubRouteTree, TRouteTree> = {
|
|
24
|
+
[K in '_metadata' | keyof TSubRouteTree]: K extends '_metadata' ? RouteNodeMetadata<TMetadata, TContext> : K extends keyof TSubRouteTree ? TSubRouteTree[K] extends RouteNode<TMetadata, TContext> ? TSubRouteTree[K] : TSubRouteTree[K] extends Record<string, unknown> ? ExtractChildRoutes<TMetadata, TContext, TSubRouteTree[K], TRouteTree> : never : never;
|
|
25
|
+
};
|
|
26
|
+
type RouteTree<TMetadata extends BaseMetadata, TContext, TSubRouteTree extends PartialRouteTree<TMetadata, TContext>, TRouteTree = TSubRouteTree> = {
|
|
27
|
+
[K in keyof TSubRouteTree]: TSubRouteTree[K] extends RouteNode<TMetadata, TContext> ? TSubRouteTree[K] : TSubRouteTree[K] extends Record<string, unknown> ? ExtractChildRoutes<TMetadata, TContext, TSubRouteTree[K], TRouteTree> : never;
|
|
28
|
+
};
|
|
29
|
+
type RouteTreeWithoutMetadata<T> = {
|
|
30
|
+
[K in keyof T as K extends '_metadata' ? never : K]: T[K] extends object ? RouteTreeWithoutMetadata<T[K]> : T[K];
|
|
31
|
+
};
|
|
32
|
+
type RoutePathname<TMetadata extends BaseMetadata, TContext, TRouteTree extends PartialRouteTree<TMetadata, TContext>> = Paths<RouteTreeWithoutMetadata<TRouteTree>, '/', ''>;
|
|
33
|
+
|
|
34
|
+
declare const createAppRoutes: <TMetadata extends BaseMetadata, TContext>() => <TRouteTree extends PartialRouteTree<TMetadata, TContext>>(appRoutes: TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>) => {
|
|
35
|
+
AppRoutesProvider: ({ children }: {
|
|
36
|
+
children: ReactNode;
|
|
37
|
+
}) => react_jsx_runtime.JSX.Element;
|
|
38
|
+
useAppRoutes: () => TRouteTree & RouteTree<TMetadata, TContext, TRouteTree, TRouteTree>;
|
|
39
|
+
useCurrentRouteNode: <TPath extends RoutePathname<TMetadata, TContext, TRouteTree>>(pathname: TPath) => PathValue<TRouteTree, TPath, "/">;
|
|
40
|
+
_types: {
|
|
41
|
+
AppRoutesMetadata: TMetadata;
|
|
42
|
+
AppRoutesContext: TContext;
|
|
43
|
+
AppRoutesPathname: RoutePathname<TMetadata, TContext, TRouteTree>;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { type BaseMetadata, type PartialRouteTree, type RouteNode, type RouteNodeMetadata, type RoutePathname, type RouteTree, createAppRoutes };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
+
import { ReactNode } from 'react';
|
|
3
|
+
|
|
4
|
+
type Paths<TObject, TSplitter extends string, TPrev extends string = ''> = TSplitter | {
|
|
5
|
+
[K in keyof TObject & string]: TObject[K] extends object ? `${TSplitter}${TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`}` | Paths<TObject[K], TSplitter, TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`> : `${TSplitter}${TPrev extends '' ? K : `${TPrev}${TSplitter}${K}`}`;
|
|
6
|
+
}[keyof TObject & string];
|
|
7
|
+
type PathValue<T, P extends string, S extends string> = P extends S ? T : P extends `${S}${infer Rest}` ? Rest extends `${infer K}${S}${infer R}` ? K extends keyof T ? PathValue<T[K], `${S}${R}`, S> : never : Rest extends keyof T ? T[Rest] : never : never;
|
|
8
|
+
|
|
9
|
+
type BaseMetadata = NonNullable<unknown>;
|
|
10
|
+
type RouteNode<TMetadata extends BaseMetadata, TContext> = {
|
|
11
|
+
_metadata: RouteNodeMetadata<TMetadata, TContext>;
|
|
12
|
+
};
|
|
13
|
+
type RouteNodeMetadata<TMetadata extends BaseMetadata, TContext> = {
|
|
14
|
+
title?: string;
|
|
15
|
+
label?: string;
|
|
16
|
+
description?: string;
|
|
17
|
+
href?: (context: TContext) => string;
|
|
18
|
+
accessible?: (context: TContext) => boolean;
|
|
19
|
+
} & TMetadata;
|
|
20
|
+
type PartialRouteTree<TMetadata extends BaseMetadata, TContext> = {
|
|
21
|
+
[key: string]: RouteNode<TMetadata, TContext> | PartialRouteTree<TMetadata, TContext>;
|
|
22
|
+
};
|
|
23
|
+
type ExtractChildRoutes<TMetadata extends BaseMetadata, TContext, TSubRouteTree, TRouteTree> = {
|
|
24
|
+
[K in '_metadata' | keyof TSubRouteTree]: K extends '_metadata' ? RouteNodeMetadata<TMetadata, TContext> : K extends keyof TSubRouteTree ? TSubRouteTree[K] extends RouteNode<TMetadata, TContext> ? TSubRouteTree[K] : TSubRouteTree[K] extends Record<string, unknown> ? ExtractChildRoutes<TMetadata, TContext, TSubRouteTree[K], TRouteTree> : never : never;
|
|
25
|
+
};
|
|
26
|
+
type RouteTree<TMetadata extends BaseMetadata, TContext, TSubRouteTree extends PartialRouteTree<TMetadata, TContext>, TRouteTree = TSubRouteTree> = {
|
|
27
|
+
[K in keyof TSubRouteTree]: TSubRouteTree[K] extends RouteNode<TMetadata, TContext> ? TSubRouteTree[K] : TSubRouteTree[K] extends Record<string, unknown> ? ExtractChildRoutes<TMetadata, TContext, TSubRouteTree[K], TRouteTree> : never;
|
|
28
|
+
};
|
|
29
|
+
type RouteTreeWithoutMetadata<T> = {
|
|
30
|
+
[K in keyof T as K extends '_metadata' ? never : K]: T[K] extends object ? RouteTreeWithoutMetadata<T[K]> : T[K];
|
|
31
|
+
};
|
|
32
|
+
type RoutePathname<TMetadata extends BaseMetadata, TContext, TRouteTree extends PartialRouteTree<TMetadata, TContext>> = Paths<RouteTreeWithoutMetadata<TRouteTree>, '/', ''>;
|
|
33
|
+
|
|
34
|
+
declare const createAppRoutes: <TMetadata extends BaseMetadata, TContext>() => <TRouteTree extends PartialRouteTree<TMetadata, TContext>>(appRoutes: TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>) => {
|
|
35
|
+
AppRoutesProvider: ({ children }: {
|
|
36
|
+
children: ReactNode;
|
|
37
|
+
}) => react_jsx_runtime.JSX.Element;
|
|
38
|
+
useAppRoutes: () => TRouteTree & RouteTree<TMetadata, TContext, TRouteTree, TRouteTree>;
|
|
39
|
+
useCurrentRouteNode: <TPath extends RoutePathname<TMetadata, TContext, TRouteTree>>(pathname: TPath) => PathValue<TRouteTree, TPath, "/">;
|
|
40
|
+
_types: {
|
|
41
|
+
AppRoutesMetadata: TMetadata;
|
|
42
|
+
AppRoutesContext: TContext;
|
|
43
|
+
AppRoutesPathname: RoutePathname<TMetadata, TContext, TRouteTree>;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { type BaseMetadata, type PartialRouteTree, type RouteNode, type RouteNodeMetadata, type RoutePathname, type RouteTree, createAppRoutes };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('react');
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
|
|
6
|
+
// src/routes.utils.tsx
|
|
7
|
+
|
|
8
|
+
// src/object.utils.ts
|
|
9
|
+
var getSafely = (splitter, obj, path) => {
|
|
10
|
+
if (path === "" || path === splitter) return obj;
|
|
11
|
+
const keys = path.split(splitter);
|
|
12
|
+
let value = obj;
|
|
13
|
+
for (const key of keys) {
|
|
14
|
+
if (typeof value === "object" && value !== null && key in value) {
|
|
15
|
+
value = value[key];
|
|
16
|
+
} else {
|
|
17
|
+
return void 0;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return value;
|
|
21
|
+
};
|
|
22
|
+
var createAppRoutes = () => (appRoutes) => {
|
|
23
|
+
const Context = react.createContext(appRoutes);
|
|
24
|
+
const useAppRoutes = () => {
|
|
25
|
+
return react.useContext(Context);
|
|
26
|
+
};
|
|
27
|
+
const useCurrentRouteNode = (pathname) => {
|
|
28
|
+
const routes = react.useContext(Context);
|
|
29
|
+
return getSafely("/", routes, pathname);
|
|
30
|
+
};
|
|
31
|
+
const AppRoutesProvider = ({ children }) => {
|
|
32
|
+
return /* @__PURE__ */ jsxRuntime.jsx(Context.Provider, { value: appRoutes, children });
|
|
33
|
+
};
|
|
34
|
+
return {
|
|
35
|
+
AppRoutesProvider,
|
|
36
|
+
useAppRoutes,
|
|
37
|
+
useCurrentRouteNode,
|
|
38
|
+
_types: {}
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
exports.createAppRoutes = createAppRoutes;
|
|
43
|
+
//# sourceMappingURL=index.js.map
|
|
44
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/object.utils.ts","../src/routes.utils.tsx"],"names":["createContext","useContext"],"mappings":";;;;;;;;AAEO,IAAM,SAAA,GAAY,CACvB,QAAA,EACA,GAAA,EACA,IAAA,KACyC;AACzC,EAAA,IAAI,IAAA,KAAS,EAAA,IAAM,IAAA,KAAS,QAAA,EAAU,OAAO,GAAA;AAE7C,EAAA,MAAM,IAAA,GAAQ,IAAA,CAAgB,KAAA,CAAM,QAAQ,CAAA;AAC5C,EAAA,IAAI,KAAA,GAAiB,GAAA;AAErB,EAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,IAAA,IAAI,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,EAAO;AAC/D,MAAA,KAAA,GAAS,MAAkC,GAAG,CAAA;AAAA,IAChD,CAAA,MAAO;AACL,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT,CAAA;AChBO,IAAM,eAAA,GACX,MACA,CAA2D,SAAA,KAAuE;AAChI,EAAA,MAAM,OAAA,GAAUA,oBAAuE,SAAS,CAAA;AAEhG,EAAA,MAAM,eAAe,MAAM;AACzB,IAAA,OAAOC,iBAAW,OAAO,CAAA;AAAA,EAC3B,CAAA;AAEA,EAAA,MAAM,mBAAA,GAAsB,CAA+D,QAAA,KAAoB;AAC7G,IAAA,MAAM,MAAA,GAASA,iBAAW,OAAO,CAAA;AACjC,IAAA,OAAO,SAAA,CAAU,GAAA,EAAK,MAAA,EAAQ,QAAQ,CAAA;AAAA,EACxC,CAAA;AAEA,EAAA,MAAM,iBAAA,GAAoB,CAAC,EAAE,QAAA,EAAS,KAA+B;AACnE,IAAA,sCAAQ,OAAA,CAAQ,QAAA,EAAR,EAAiB,KAAA,EAAO,WAAY,QAAA,EAAS,CAAA;AAAA,EACvD,CAAA;AAEA,EAAA,OAAO;AAAA,IACL,iBAAA;AAAA,IACA,YAAA;AAAA,IACA,mBAAA;AAAA,IACA,QAAQ;AAAC,GAKX;AACF","file":"index.js","sourcesContent":["import { Paths, PathValue } from './path.types';\n\nexport const getSafely = <TObject, TSplitter extends string, TPath extends string & Paths<TObject, TSplitter>>(\n splitter: TSplitter,\n obj: TObject,\n path: TPath,\n): PathValue<TObject, TPath, TSplitter> => {\n if (path === '' || path === splitter) return obj as PathValue<TObject, TPath, TSplitter>;\n\n const keys = (path as string).split(splitter);\n let value: unknown = obj;\n\n for (const key of keys) {\n if (typeof value === 'object' && value !== null && key in value) {\n value = (value as Record<string, unknown>)[key];\n } else {\n return undefined as PathValue<TObject, TPath, TSplitter>;\n }\n }\n\n return value as PathValue<TObject, TPath, TSplitter>;\n};\n","import { createContext, ReactNode, useContext } from 'react';\nimport { getSafely } from './object.utils';\nimport { PathValue } from './path.types';\nimport { BaseMetadata, PartialRouteTree, RoutePathname, RouteTree } from './routes.types';\n\nexport const createAppRoutes =\n <TMetadata extends BaseMetadata, TContext>() =>\n <TRouteTree extends PartialRouteTree<TMetadata, TContext>>(appRoutes: TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>) => {\n const Context = createContext<TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>>(appRoutes);\n\n const useAppRoutes = () => {\n return useContext(Context);\n };\n\n const useCurrentRouteNode = <TPath extends RoutePathname<TMetadata, TContext, TRouteTree>>(pathname: TPath) => {\n const routes = useContext(Context);\n return getSafely('/', routes, pathname) as PathValue<TRouteTree, TPath, '/'>;\n };\n\n const AppRoutesProvider = ({ children }: { children: ReactNode }) => {\n return <Context.Provider value={appRoutes}>{children}</Context.Provider>;\n };\n\n return {\n AppRoutesProvider,\n useAppRoutes,\n useCurrentRouteNode,\n _types: {} as {\n AppRoutesMetadata: TMetadata;\n AppRoutesContext: TContext;\n AppRoutesPathname: RoutePathname<TMetadata, TContext, TRouteTree>;\n },\n };\n };\n"]}
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
|
+
import { jsx } from 'react/jsx-runtime';
|
|
3
|
+
|
|
4
|
+
// src/routes.utils.tsx
|
|
5
|
+
|
|
6
|
+
// src/object.utils.ts
|
|
7
|
+
var getSafely = (splitter, obj, path) => {
|
|
8
|
+
if (path === "" || path === splitter) return obj;
|
|
9
|
+
const keys = path.split(splitter);
|
|
10
|
+
let value = obj;
|
|
11
|
+
for (const key of keys) {
|
|
12
|
+
if (typeof value === "object" && value !== null && key in value) {
|
|
13
|
+
value = value[key];
|
|
14
|
+
} else {
|
|
15
|
+
return void 0;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return value;
|
|
19
|
+
};
|
|
20
|
+
var createAppRoutes = () => (appRoutes) => {
|
|
21
|
+
const Context = createContext(appRoutes);
|
|
22
|
+
const useAppRoutes = () => {
|
|
23
|
+
return useContext(Context);
|
|
24
|
+
};
|
|
25
|
+
const useCurrentRouteNode = (pathname) => {
|
|
26
|
+
const routes = useContext(Context);
|
|
27
|
+
return getSafely("/", routes, pathname);
|
|
28
|
+
};
|
|
29
|
+
const AppRoutesProvider = ({ children }) => {
|
|
30
|
+
return /* @__PURE__ */ jsx(Context.Provider, { value: appRoutes, children });
|
|
31
|
+
};
|
|
32
|
+
return {
|
|
33
|
+
AppRoutesProvider,
|
|
34
|
+
useAppRoutes,
|
|
35
|
+
useCurrentRouteNode,
|
|
36
|
+
_types: {}
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export { createAppRoutes };
|
|
41
|
+
//# sourceMappingURL=index.mjs.map
|
|
42
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/object.utils.ts","../src/routes.utils.tsx"],"names":[],"mappings":";;;;;;AAEO,IAAM,SAAA,GAAY,CACvB,QAAA,EACA,GAAA,EACA,IAAA,KACyC;AACzC,EAAA,IAAI,IAAA,KAAS,EAAA,IAAM,IAAA,KAAS,QAAA,EAAU,OAAO,GAAA;AAE7C,EAAA,MAAM,IAAA,GAAQ,IAAA,CAAgB,KAAA,CAAM,QAAQ,CAAA;AAC5C,EAAA,IAAI,KAAA,GAAiB,GAAA;AAErB,EAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,IAAA,IAAI,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,EAAO;AAC/D,MAAA,KAAA,GAAS,MAAkC,GAAG,CAAA;AAAA,IAChD,CAAA,MAAO;AACL,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT,CAAA;AChBO,IAAM,eAAA,GACX,MACA,CAA2D,SAAA,KAAuE;AAChI,EAAA,MAAM,OAAA,GAAU,cAAuE,SAAS,CAAA;AAEhG,EAAA,MAAM,eAAe,MAAM;AACzB,IAAA,OAAO,WAAW,OAAO,CAAA;AAAA,EAC3B,CAAA;AAEA,EAAA,MAAM,mBAAA,GAAsB,CAA+D,QAAA,KAAoB;AAC7G,IAAA,MAAM,MAAA,GAAS,WAAW,OAAO,CAAA;AACjC,IAAA,OAAO,SAAA,CAAU,GAAA,EAAK,MAAA,EAAQ,QAAQ,CAAA;AAAA,EACxC,CAAA;AAEA,EAAA,MAAM,iBAAA,GAAoB,CAAC,EAAE,QAAA,EAAS,KAA+B;AACnE,IAAA,2BAAQ,OAAA,CAAQ,QAAA,EAAR,EAAiB,KAAA,EAAO,WAAY,QAAA,EAAS,CAAA;AAAA,EACvD,CAAA;AAEA,EAAA,OAAO;AAAA,IACL,iBAAA;AAAA,IACA,YAAA;AAAA,IACA,mBAAA;AAAA,IACA,QAAQ;AAAC,GAKX;AACF","file":"index.mjs","sourcesContent":["import { Paths, PathValue } from './path.types';\n\nexport const getSafely = <TObject, TSplitter extends string, TPath extends string & Paths<TObject, TSplitter>>(\n splitter: TSplitter,\n obj: TObject,\n path: TPath,\n): PathValue<TObject, TPath, TSplitter> => {\n if (path === '' || path === splitter) return obj as PathValue<TObject, TPath, TSplitter>;\n\n const keys = (path as string).split(splitter);\n let value: unknown = obj;\n\n for (const key of keys) {\n if (typeof value === 'object' && value !== null && key in value) {\n value = (value as Record<string, unknown>)[key];\n } else {\n return undefined as PathValue<TObject, TPath, TSplitter>;\n }\n }\n\n return value as PathValue<TObject, TPath, TSplitter>;\n};\n","import { createContext, ReactNode, useContext } from 'react';\nimport { getSafely } from './object.utils';\nimport { PathValue } from './path.types';\nimport { BaseMetadata, PartialRouteTree, RoutePathname, RouteTree } from './routes.types';\n\nexport const createAppRoutes =\n <TMetadata extends BaseMetadata, TContext>() =>\n <TRouteTree extends PartialRouteTree<TMetadata, TContext>>(appRoutes: TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>) => {\n const Context = createContext<TRouteTree & RouteTree<TMetadata, TContext, TRouteTree>>(appRoutes);\n\n const useAppRoutes = () => {\n return useContext(Context);\n };\n\n const useCurrentRouteNode = <TPath extends RoutePathname<TMetadata, TContext, TRouteTree>>(pathname: TPath) => {\n const routes = useContext(Context);\n return getSafely('/', routes, pathname) as PathValue<TRouteTree, TPath, '/'>;\n };\n\n const AppRoutesProvider = ({ children }: { children: ReactNode }) => {\n return <Context.Provider value={appRoutes}>{children}</Context.Provider>;\n };\n\n return {\n AppRoutesProvider,\n useAppRoutes,\n useCurrentRouteNode,\n _types: {} as {\n AppRoutesMetadata: TMetadata;\n AppRoutesContext: TContext;\n AppRoutesPathname: RoutePathname<TMetadata, TContext, TRouteTree>;\n },\n };\n };\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@hyeonqyu/typed-router-core",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Core types and utilities for typed-react-router",
|
|
5
|
+
"author": "hyeonQyu <dhk0561@naver.com>",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"repository": {
|
|
8
|
+
"type": "git",
|
|
9
|
+
"url": "https://github.com/hyeonQyu/typed-react-router.git"
|
|
10
|
+
},
|
|
11
|
+
"homepage": "https://github.com/hyeonQyu/typed-react-router#readme",
|
|
12
|
+
"bugs": {
|
|
13
|
+
"url": "https://github.com/hyeonQyu/typed-react-router/issues"
|
|
14
|
+
},
|
|
15
|
+
"keywords": [
|
|
16
|
+
"react",
|
|
17
|
+
"routing",
|
|
18
|
+
"typescript",
|
|
19
|
+
"type-safe",
|
|
20
|
+
"information-architecture"
|
|
21
|
+
],
|
|
22
|
+
"main": "./dist/index.js",
|
|
23
|
+
"module": "./dist/index.mjs",
|
|
24
|
+
"types": "./dist/index.d.ts",
|
|
25
|
+
"exports": {
|
|
26
|
+
".": {
|
|
27
|
+
"types": "./dist/index.d.ts",
|
|
28
|
+
"import": "./dist/index.mjs",
|
|
29
|
+
"require": "./dist/index.js"
|
|
30
|
+
},
|
|
31
|
+
"./package.json": "./package.json"
|
|
32
|
+
},
|
|
33
|
+
"sideEffects": false,
|
|
34
|
+
"files": [
|
|
35
|
+
"dist",
|
|
36
|
+
"README.md",
|
|
37
|
+
"LICENSE"
|
|
38
|
+
],
|
|
39
|
+
"scripts": {
|
|
40
|
+
"build": "tsup",
|
|
41
|
+
"dev": "tsup --watch",
|
|
42
|
+
"lint": "eslint . --ext .ts,.tsx",
|
|
43
|
+
"lint:fix": "eslint . --ext .ts,.tsx --fix",
|
|
44
|
+
"type": "tsc --noEmit"
|
|
45
|
+
},
|
|
46
|
+
"peerDependencies": {
|
|
47
|
+
"react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0"
|
|
48
|
+
},
|
|
49
|
+
"devDependencies": {
|
|
50
|
+
"@types/react": "^19.2.5",
|
|
51
|
+
"react": "^19.2.0",
|
|
52
|
+
"typescript": "^5.9.3"
|
|
53
|
+
},
|
|
54
|
+
"engines": {
|
|
55
|
+
"node": ">=18.0.0"
|
|
56
|
+
},
|
|
57
|
+
"publishConfig": {
|
|
58
|
+
"access": "public"
|
|
59
|
+
}
|
|
60
|
+
}
|