@tanstack/router-devtools 1.20.1 → 1.20.3-alpha.1
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/README.md +3 -1
- package/dist/cjs/index.cjs +12 -3
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/index.d.cts +2 -1
- package/dist/esm/index.d.ts +2 -1
- package/dist/esm/index.js +6 -3
- package/dist/esm/index.js.map +1 -1
- package/package.json +34 -34
- package/src/index.tsx +6 -1
- package/dist/cjs/Explorer.cjs +0 -306
- package/dist/cjs/Explorer.cjs.map +0 -1
- package/dist/cjs/Explorer.d.cts +0 -46
- package/dist/cjs/devtools.cjs +0 -1181
- package/dist/cjs/devtools.cjs.map +0 -1
- package/dist/cjs/devtools.d.cts +0 -65
- package/dist/cjs/logo.cjs +0 -1012
- package/dist/cjs/logo.cjs.map +0 -1
- package/dist/cjs/logo.d.cts +0 -2
- package/dist/cjs/theme.d.cts +0 -34
- package/dist/cjs/tokens.cjs +0 -302
- package/dist/cjs/tokens.cjs.map +0 -1
- package/dist/cjs/tokens.d.cts +0 -298
- package/dist/cjs/useLocalStorage.cjs +0 -45
- package/dist/cjs/useLocalStorage.cjs.map +0 -1
- package/dist/cjs/useLocalStorage.d.cts +0 -1
- package/dist/cjs/useMediaQuery.d.cts +0 -1
- package/dist/cjs/utils.cjs +0 -82
- package/dist/cjs/utils.cjs.map +0 -1
- package/dist/cjs/utils.d.cts +0 -23
- package/dist/esm/Explorer.d.ts +0 -46
- package/dist/esm/Explorer.js +0 -289
- package/dist/esm/Explorer.js.map +0 -1
- package/dist/esm/devtools.d.ts +0 -65
- package/dist/esm/devtools.js +0 -1181
- package/dist/esm/devtools.js.map +0 -1
- package/dist/esm/logo.d.ts +0 -2
- package/dist/esm/logo.js +0 -1012
- package/dist/esm/logo.js.map +0 -1
- package/dist/esm/theme.d.ts +0 -34
- package/dist/esm/tokens.d.ts +0 -298
- package/dist/esm/tokens.js +0 -302
- package/dist/esm/tokens.js.map +0 -1
- package/dist/esm/useLocalStorage.d.ts +0 -1
- package/dist/esm/useLocalStorage.js +0 -46
- package/dist/esm/useLocalStorage.js.map +0 -1
- package/dist/esm/useMediaQuery.d.ts +0 -1
- package/dist/esm/utils.d.ts +0 -23
- package/dist/esm/utils.js +0 -82
- package/dist/esm/utils.js.map +0 -1
- package/src/Explorer.tsx +0 -357
- package/src/devtools.tsx +0 -1401
- package/src/logo.tsx +0 -817
- package/src/theme.tsx +0 -31
- package/src/tokens.ts +0 -305
- package/src/useLocalStorage.ts +0 -52
- package/src/useMediaQuery.ts +0 -39
- package/src/utils.ts +0 -183
package/README.md
CHANGED
package/dist/cjs/index.cjs
CHANGED
|
@@ -1,6 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
const reactRouterDevtools = require("@tanstack/react-router-devtools");
|
|
4
|
+
console.warn(
|
|
5
|
+
"[@tanstack/router-devtools] This package has moved to @tanstack/react-router-devtools. Please switch to the new package at your earliest convenience, as this package will be dropped in the next major version release."
|
|
6
|
+
);
|
|
7
|
+
Object.defineProperty(exports, "TanStackRouterDevtools", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: () => reactRouterDevtools.TanStackRouterDevtoolsInProd
|
|
10
|
+
});
|
|
11
|
+
Object.defineProperty(exports, "TanStackRouterDevtoolsPanel", {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: () => reactRouterDevtools.TanStackRouterDevtoolsPanelInProd
|
|
14
|
+
});
|
|
6
15
|
//# sourceMappingURL=index.cjs.map
|
package/dist/cjs/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../../src/index.tsx"],"sourcesContent":["console.warn(\n '[@tanstack/router-devtools] This package has moved to @tanstack/react-router-devtools. Please switch to the new package at your earliest convenience, as this package will be dropped in the next major version release.',\n)\n\nexport { TanStackRouterDevtoolsInProd as TanStackRouterDevtools } from '@tanstack/react-router-devtools'\nexport { TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel } from '@tanstack/react-router-devtools'\n"],"names":[],"mappings":";;;AAAA,QAAQ;AAAA,EACN;AACF;;;;;;;;;"}
|
package/dist/cjs/index.d.cts
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { TanStackRouterDevtoolsInProd as TanStackRouterDevtools } from '@tanstack/react-router-devtools';
|
|
2
|
+
export { TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel } from '@tanstack/react-router-devtools';
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { TanStackRouterDevtoolsInProd as TanStackRouterDevtools } from '@tanstack/react-router-devtools';
|
|
2
|
+
export { TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel } from '@tanstack/react-router-devtools';
|
package/dist/esm/index.js
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { TanStackRouterDevtoolsInProd, TanStackRouterDevtoolsPanelInProd } from "@tanstack/react-router-devtools";
|
|
2
|
+
console.warn(
|
|
3
|
+
"[@tanstack/router-devtools] This package has moved to @tanstack/react-router-devtools. Please switch to the new package at your earliest convenience, as this package will be dropped in the next major version release."
|
|
4
|
+
);
|
|
2
5
|
export {
|
|
3
|
-
TanStackRouterDevtools,
|
|
4
|
-
TanStackRouterDevtoolsPanel
|
|
6
|
+
TanStackRouterDevtoolsInProd as TanStackRouterDevtools,
|
|
7
|
+
TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel
|
|
5
8
|
};
|
|
6
9
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../src/index.tsx"],"sourcesContent":["console.warn(\n '[@tanstack/router-devtools] This package has moved to @tanstack/react-router-devtools. Please switch to the new package at your earliest convenience, as this package will be dropped in the next major version release.',\n)\n\nexport { TanStackRouterDevtoolsInProd as TanStackRouterDevtools } from '@tanstack/react-router-devtools'\nexport { TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel } from '@tanstack/react-router-devtools'\n"],"names":[],"mappings":";AAAA,QAAQ;AAAA,EACN;AACF;"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tanstack/router-devtools",
|
|
3
|
-
"version": "1.20.1",
|
|
4
|
-
"description": "",
|
|
3
|
+
"version": "1.20.3-alpha.1",
|
|
4
|
+
"description": "Modern and scalable routing for React applications",
|
|
5
5
|
"author": "Tanner Linsley",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"repository": {
|
|
@@ -9,15 +9,24 @@
|
|
|
9
9
|
"url": "https://github.com/TanStack/router.git",
|
|
10
10
|
"directory": "packages/router-devtools"
|
|
11
11
|
},
|
|
12
|
-
"homepage": "https://tanstack.com/router
|
|
12
|
+
"homepage": "https://tanstack.com/router",
|
|
13
13
|
"funding": {
|
|
14
14
|
"type": "github",
|
|
15
15
|
"url": "https://github.com/sponsors/tannerlinsley"
|
|
16
16
|
},
|
|
17
|
+
"keywords": [
|
|
18
|
+
"react",
|
|
19
|
+
"location",
|
|
20
|
+
"router",
|
|
21
|
+
"routing",
|
|
22
|
+
"async",
|
|
23
|
+
"async router",
|
|
24
|
+
"typescript"
|
|
25
|
+
],
|
|
17
26
|
"type": "module",
|
|
18
|
-
"types": "dist/esm/index.d.ts",
|
|
19
|
-
"main": "dist/cjs/index.cjs",
|
|
20
|
-
"module": "dist/esm/index.js",
|
|
27
|
+
"types": "./dist/esm/index.d.ts",
|
|
28
|
+
"main": "./dist/cjs/index.cjs",
|
|
29
|
+
"module": "./dist/esm/index.js",
|
|
21
30
|
"exports": {
|
|
22
31
|
".": {
|
|
23
32
|
"import": {
|
|
@@ -32,42 +41,33 @@
|
|
|
32
41
|
"./package.json": "./package.json"
|
|
33
42
|
},
|
|
34
43
|
"sideEffects": false,
|
|
35
|
-
"keywords": [
|
|
36
|
-
"react",
|
|
37
|
-
"location",
|
|
38
|
-
"router",
|
|
39
|
-
"routing",
|
|
40
|
-
"async",
|
|
41
|
-
"async router",
|
|
42
|
-
"typescript"
|
|
43
|
-
],
|
|
44
|
-
"engines": {
|
|
45
|
-
"node": ">=12"
|
|
46
|
-
},
|
|
47
44
|
"files": [
|
|
48
45
|
"dist",
|
|
49
46
|
"src"
|
|
50
47
|
],
|
|
48
|
+
"engines": {
|
|
49
|
+
"node": ">=12"
|
|
50
|
+
},
|
|
51
51
|
"dependencies": {
|
|
52
|
-
"clsx": "^2.1.
|
|
53
|
-
"
|
|
54
|
-
"
|
|
55
|
-
"@tanstack/react-router": "1.20.1"
|
|
52
|
+
"clsx": "^2.1.1",
|
|
53
|
+
"goober": "^2.1.16",
|
|
54
|
+
"@tanstack/react-router-devtools": "^1.20.3-alpha.1"
|
|
56
55
|
},
|
|
57
56
|
"devDependencies": {
|
|
58
|
-
"@vitejs/plugin-react": "^4.
|
|
59
|
-
"react": "^
|
|
60
|
-
"react-dom": "^
|
|
61
|
-
"vite": "^5.0.12"
|
|
57
|
+
"@vitejs/plugin-react": "^4.3.4",
|
|
58
|
+
"react": "^19.0.0",
|
|
59
|
+
"react-dom": "^19.0.0"
|
|
62
60
|
},
|
|
63
61
|
"peerDependencies": {
|
|
64
|
-
"
|
|
65
|
-
"react
|
|
62
|
+
"csstype": "^3.0.10",
|
|
63
|
+
"react": ">=18.0.0 || >=19.0.0",
|
|
64
|
+
"react-dom": ">=18.0.0 || >=19.0.0",
|
|
65
|
+
"@tanstack/react-router": "^1.20.3-alpha.1"
|
|
66
|
+
},
|
|
67
|
+
"peerDependenciesMeta": {
|
|
68
|
+
"csstype": {
|
|
69
|
+
"optional": true
|
|
70
|
+
}
|
|
66
71
|
},
|
|
67
|
-
"scripts": {
|
|
68
|
-
"clean": "rimraf ./dist && rimraf ./coverage",
|
|
69
|
-
"test:types": "tsc",
|
|
70
|
-
"test:build": "publint --strict",
|
|
71
|
-
"build": "vite build"
|
|
72
|
-
}
|
|
72
|
+
"scripts": {}
|
|
73
73
|
}
|
package/src/index.tsx
CHANGED
|
@@ -1 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
console.warn(
|
|
2
|
+
'[@tanstack/router-devtools] This package has moved to @tanstack/react-router-devtools. Please switch to the new package at your earliest convenience, as this package will be dropped in the next major version release.',
|
|
3
|
+
)
|
|
4
|
+
|
|
5
|
+
export { TanStackRouterDevtoolsInProd as TanStackRouterDevtools } from '@tanstack/react-router-devtools'
|
|
6
|
+
export { TanStackRouterDevtoolsPanelInProd as TanStackRouterDevtoolsPanel } from '@tanstack/react-router-devtools'
|
package/dist/cjs/Explorer.cjs
DELETED
|
@@ -1,306 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
-
const jsxRuntime = require("react/jsx-runtime");
|
|
4
|
-
const React = require("react");
|
|
5
|
-
const clsx = require("clsx");
|
|
6
|
-
const tokens = require("./tokens.cjs");
|
|
7
|
-
const utils = require("./utils.cjs");
|
|
8
|
-
const goober = require("goober");
|
|
9
|
-
function _interopNamespaceDefault(e) {
|
|
10
|
-
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
|
11
|
-
if (e) {
|
|
12
|
-
for (const k in e) {
|
|
13
|
-
if (k !== "default") {
|
|
14
|
-
const d = Object.getOwnPropertyDescriptor(e, k);
|
|
15
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
16
|
-
enumerable: true,
|
|
17
|
-
get: () => e[k]
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
n.default = e;
|
|
23
|
-
return Object.freeze(n);
|
|
24
|
-
}
|
|
25
|
-
const React__namespace = /* @__PURE__ */ _interopNamespaceDefault(React);
|
|
26
|
-
const Expander = ({ expanded, style = {} }) => /* @__PURE__ */ jsxRuntime.jsx("span", { className: getStyles().expander, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
27
|
-
"svg",
|
|
28
|
-
{
|
|
29
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
30
|
-
width: "12",
|
|
31
|
-
height: "12",
|
|
32
|
-
fill: "none",
|
|
33
|
-
viewBox: "0 0 24 24",
|
|
34
|
-
className: clsx.clsx(getStyles().expanderIcon(expanded)),
|
|
35
|
-
children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
36
|
-
"path",
|
|
37
|
-
{
|
|
38
|
-
stroke: "currentColor",
|
|
39
|
-
strokeLinecap: "round",
|
|
40
|
-
strokeLinejoin: "round",
|
|
41
|
-
strokeWidth: "2",
|
|
42
|
-
d: "M9 18l6-6-6-6"
|
|
43
|
-
}
|
|
44
|
-
)
|
|
45
|
-
}
|
|
46
|
-
) });
|
|
47
|
-
function chunkArray(array, size) {
|
|
48
|
-
if (size < 1)
|
|
49
|
-
return [];
|
|
50
|
-
let i = 0;
|
|
51
|
-
const result = [];
|
|
52
|
-
while (i < array.length) {
|
|
53
|
-
result.push(array.slice(i, i + size));
|
|
54
|
-
i = i + size;
|
|
55
|
-
}
|
|
56
|
-
return result;
|
|
57
|
-
}
|
|
58
|
-
const DefaultRenderer = ({
|
|
59
|
-
handleEntry,
|
|
60
|
-
label,
|
|
61
|
-
value,
|
|
62
|
-
subEntries = [],
|
|
63
|
-
subEntryPages = [],
|
|
64
|
-
type,
|
|
65
|
-
expanded = false,
|
|
66
|
-
toggleExpanded,
|
|
67
|
-
pageSize,
|
|
68
|
-
renderer
|
|
69
|
-
}) => {
|
|
70
|
-
const [expandedPages, setExpandedPages] = React__namespace.useState([]);
|
|
71
|
-
const [valueSnapshot, setValueSnapshot] = React__namespace.useState(void 0);
|
|
72
|
-
const refreshValueSnapshot = () => {
|
|
73
|
-
setValueSnapshot(value());
|
|
74
|
-
};
|
|
75
|
-
return /* @__PURE__ */ jsxRuntime.jsx("div", { className: getStyles().entry, children: subEntryPages.length ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
76
|
-
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
77
|
-
"button",
|
|
78
|
-
{
|
|
79
|
-
className: getStyles().expandButton,
|
|
80
|
-
onClick: () => toggleExpanded(),
|
|
81
|
-
children: [
|
|
82
|
-
/* @__PURE__ */ jsxRuntime.jsx(Expander, { expanded }),
|
|
83
|
-
label,
|
|
84
|
-
/* @__PURE__ */ jsxRuntime.jsxs("span", { className: getStyles().info, children: [
|
|
85
|
-
String(type).toLowerCase() === "iterable" ? "(Iterable) " : "",
|
|
86
|
-
subEntries.length,
|
|
87
|
-
" ",
|
|
88
|
-
subEntries.length > 1 ? `items` : `item`
|
|
89
|
-
] })
|
|
90
|
-
]
|
|
91
|
-
}
|
|
92
|
-
),
|
|
93
|
-
expanded ? subEntryPages.length === 1 ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: getStyles().subEntries, children: subEntries.map((entry, index) => handleEntry(entry)) }) : /* @__PURE__ */ jsxRuntime.jsx("div", { className: getStyles().subEntries, children: subEntryPages.map((entries, index) => {
|
|
94
|
-
return /* @__PURE__ */ jsxRuntime.jsx("div", { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: getStyles().entry, children: [
|
|
95
|
-
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
96
|
-
"button",
|
|
97
|
-
{
|
|
98
|
-
className: clsx.clsx(getStyles().labelButton, "labelButton"),
|
|
99
|
-
onClick: () => setExpandedPages(
|
|
100
|
-
(old) => old.includes(index) ? old.filter((d) => d !== index) : [...old, index]
|
|
101
|
-
),
|
|
102
|
-
children: [
|
|
103
|
-
/* @__PURE__ */ jsxRuntime.jsx(Expander, { expanded: expandedPages.includes(index) }),
|
|
104
|
-
" ",
|
|
105
|
-
"[",
|
|
106
|
-
index * pageSize,
|
|
107
|
-
" ...",
|
|
108
|
-
" ",
|
|
109
|
-
index * pageSize + pageSize - 1,
|
|
110
|
-
"]"
|
|
111
|
-
]
|
|
112
|
-
}
|
|
113
|
-
),
|
|
114
|
-
expandedPages.includes(index) ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: getStyles().subEntries, children: entries.map((entry) => handleEntry(entry)) }) : null
|
|
115
|
-
] }) }, index);
|
|
116
|
-
}) }) : null
|
|
117
|
-
] }) : type === "function" ? /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
118
|
-
Explorer,
|
|
119
|
-
{
|
|
120
|
-
renderer,
|
|
121
|
-
label: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
122
|
-
"button",
|
|
123
|
-
{
|
|
124
|
-
onClick: refreshValueSnapshot,
|
|
125
|
-
className: getStyles().refreshValueBtn,
|
|
126
|
-
children: [
|
|
127
|
-
/* @__PURE__ */ jsxRuntime.jsx("span", { children: label }),
|
|
128
|
-
" 🔄",
|
|
129
|
-
" "
|
|
130
|
-
]
|
|
131
|
-
}
|
|
132
|
-
),
|
|
133
|
-
value: valueSnapshot,
|
|
134
|
-
defaultExpanded: {}
|
|
135
|
-
}
|
|
136
|
-
) }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
137
|
-
/* @__PURE__ */ jsxRuntime.jsxs("span", { children: [
|
|
138
|
-
label,
|
|
139
|
-
":"
|
|
140
|
-
] }),
|
|
141
|
-
" ",
|
|
142
|
-
/* @__PURE__ */ jsxRuntime.jsx("span", { className: getStyles().value, children: utils.displayValue(value) })
|
|
143
|
-
] }) });
|
|
144
|
-
};
|
|
145
|
-
function isIterable(x) {
|
|
146
|
-
return Symbol.iterator in x;
|
|
147
|
-
}
|
|
148
|
-
function Explorer({
|
|
149
|
-
value,
|
|
150
|
-
defaultExpanded,
|
|
151
|
-
renderer = DefaultRenderer,
|
|
152
|
-
pageSize = 100,
|
|
153
|
-
filterSubEntries,
|
|
154
|
-
...rest
|
|
155
|
-
}) {
|
|
156
|
-
const [expanded, setExpanded] = React__namespace.useState(Boolean(defaultExpanded));
|
|
157
|
-
const toggleExpanded = React__namespace.useCallback(() => setExpanded((old) => !old), []);
|
|
158
|
-
let type = typeof value;
|
|
159
|
-
let subEntries = [];
|
|
160
|
-
const makeProperty = (sub) => {
|
|
161
|
-
const subDefaultExpanded = defaultExpanded === true ? { [sub.label]: true } : defaultExpanded == null ? void 0 : defaultExpanded[sub.label];
|
|
162
|
-
return {
|
|
163
|
-
...sub,
|
|
164
|
-
defaultExpanded: subDefaultExpanded
|
|
165
|
-
};
|
|
166
|
-
};
|
|
167
|
-
if (Array.isArray(value)) {
|
|
168
|
-
type = "array";
|
|
169
|
-
subEntries = value.map(
|
|
170
|
-
(d, i) => makeProperty({
|
|
171
|
-
label: i.toString(),
|
|
172
|
-
value: d
|
|
173
|
-
})
|
|
174
|
-
);
|
|
175
|
-
} else if (value !== null && typeof value === "object" && isIterable(value) && typeof value[Symbol.iterator] === "function") {
|
|
176
|
-
type = "Iterable";
|
|
177
|
-
subEntries = Array.from(
|
|
178
|
-
value,
|
|
179
|
-
(val, i) => makeProperty({
|
|
180
|
-
label: i.toString(),
|
|
181
|
-
value: val
|
|
182
|
-
})
|
|
183
|
-
);
|
|
184
|
-
} else if (typeof value === "object" && value !== null) {
|
|
185
|
-
type = "object";
|
|
186
|
-
subEntries = Object.entries(value).map(
|
|
187
|
-
([key, val]) => makeProperty({
|
|
188
|
-
label: key,
|
|
189
|
-
value: val
|
|
190
|
-
})
|
|
191
|
-
);
|
|
192
|
-
}
|
|
193
|
-
subEntries = filterSubEntries ? filterSubEntries(subEntries) : subEntries;
|
|
194
|
-
const subEntryPages = chunkArray(subEntries, pageSize);
|
|
195
|
-
return renderer({
|
|
196
|
-
handleEntry: (entry) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
197
|
-
Explorer,
|
|
198
|
-
{
|
|
199
|
-
value,
|
|
200
|
-
renderer,
|
|
201
|
-
filterSubEntries,
|
|
202
|
-
...rest,
|
|
203
|
-
...entry
|
|
204
|
-
},
|
|
205
|
-
entry.label
|
|
206
|
-
),
|
|
207
|
-
type,
|
|
208
|
-
subEntries,
|
|
209
|
-
subEntryPages,
|
|
210
|
-
value,
|
|
211
|
-
expanded,
|
|
212
|
-
toggleExpanded,
|
|
213
|
-
pageSize,
|
|
214
|
-
...rest
|
|
215
|
-
});
|
|
216
|
-
}
|
|
217
|
-
const stylesFactory = () => {
|
|
218
|
-
const { colors, font, size, alpha, shadow, border } = tokens.tokens;
|
|
219
|
-
const { fontFamily, lineHeight, size: fontSize } = font;
|
|
220
|
-
return {
|
|
221
|
-
entry: goober.css`
|
|
222
|
-
font-family: ${fontFamily.mono};
|
|
223
|
-
font-size: ${fontSize.xs};
|
|
224
|
-
line-height: ${lineHeight.sm};
|
|
225
|
-
outline: none;
|
|
226
|
-
word-break: break-word;
|
|
227
|
-
`,
|
|
228
|
-
labelButton: goober.css`
|
|
229
|
-
cursor: pointer;
|
|
230
|
-
color: inherit;
|
|
231
|
-
font: inherit;
|
|
232
|
-
outline: inherit;
|
|
233
|
-
background: transparent;
|
|
234
|
-
border: none;
|
|
235
|
-
padding: 0;
|
|
236
|
-
`,
|
|
237
|
-
expander: goober.css`
|
|
238
|
-
display: inline-flex;
|
|
239
|
-
align-items: center;
|
|
240
|
-
justify-content: center;
|
|
241
|
-
width: ${size[3]};
|
|
242
|
-
height: ${size[3]};
|
|
243
|
-
padding-left: 3px;
|
|
244
|
-
box-sizing: content-box;
|
|
245
|
-
`,
|
|
246
|
-
expanderIcon: (expanded) => {
|
|
247
|
-
if (expanded) {
|
|
248
|
-
return goober.css`
|
|
249
|
-
transform: rotate(90deg);
|
|
250
|
-
transition: transform 0.1s ease;
|
|
251
|
-
`;
|
|
252
|
-
}
|
|
253
|
-
return goober.css`
|
|
254
|
-
transform: rotate(0deg);
|
|
255
|
-
transition: transform 0.1s ease;
|
|
256
|
-
`;
|
|
257
|
-
},
|
|
258
|
-
expandButton: goober.css`
|
|
259
|
-
display: flex;
|
|
260
|
-
gap: ${size[1]};
|
|
261
|
-
align-items: center;
|
|
262
|
-
cursor: pointer;
|
|
263
|
-
color: inherit;
|
|
264
|
-
font: inherit;
|
|
265
|
-
outline: inherit;
|
|
266
|
-
background: transparent;
|
|
267
|
-
border: none;
|
|
268
|
-
padding: 0;
|
|
269
|
-
`,
|
|
270
|
-
value: goober.css`
|
|
271
|
-
color: ${colors.purple[400]};
|
|
272
|
-
`,
|
|
273
|
-
subEntries: goober.css`
|
|
274
|
-
margin-left: ${size[2]};
|
|
275
|
-
padding-left: ${size[2]};
|
|
276
|
-
border-left: 2px solid ${colors.darkGray[400]};
|
|
277
|
-
`,
|
|
278
|
-
info: goober.css`
|
|
279
|
-
color: ${colors.gray[500]};
|
|
280
|
-
font-size: ${fontSize["2xs"]};
|
|
281
|
-
padding-left: ${size[1]};
|
|
282
|
-
`,
|
|
283
|
-
refreshValueBtn: goober.css`
|
|
284
|
-
appearance: none;
|
|
285
|
-
border: 0;
|
|
286
|
-
cursor: pointer;
|
|
287
|
-
background: transparent;
|
|
288
|
-
color: inherit;
|
|
289
|
-
padding: 0;
|
|
290
|
-
font-family: ${fontFamily.mono};
|
|
291
|
-
font-size: ${fontSize.xs};
|
|
292
|
-
`
|
|
293
|
-
};
|
|
294
|
-
};
|
|
295
|
-
let _styles = null;
|
|
296
|
-
function getStyles() {
|
|
297
|
-
if (_styles)
|
|
298
|
-
return _styles;
|
|
299
|
-
_styles = stylesFactory();
|
|
300
|
-
return _styles;
|
|
301
|
-
}
|
|
302
|
-
exports.DefaultRenderer = DefaultRenderer;
|
|
303
|
-
exports.Expander = Expander;
|
|
304
|
-
exports.chunkArray = chunkArray;
|
|
305
|
-
exports.default = Explorer;
|
|
306
|
-
//# sourceMappingURL=Explorer.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Explorer.cjs","sources":["../../src/Explorer.tsx"],"sourcesContent":["import * as React from 'react'\nimport { clsx as cx } from 'clsx'\nimport { tokens } from './tokens'\nimport { displayValue, styled } from './utils'\nimport { css } from 'goober'\n\ntype ExpanderProps = {\n expanded: boolean\n style?: React.CSSProperties\n}\n\nexport const Expander = ({ expanded, style = {} }: ExpanderProps) => (\n <span className={getStyles().expander}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n className={cx(getStyles().expanderIcon(expanded))}\n >\n <path\n stroke=\"currentColor\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n d=\"M9 18l6-6-6-6\"\n ></path>\n </svg>\n </span>\n)\n\ntype Entry = {\n label: string\n}\n\ntype RendererProps = {\n handleEntry: HandleEntryFn\n label?: React.ReactNode\n value: unknown\n subEntries: Entry[]\n subEntryPages: Entry[][]\n type: string\n expanded: boolean\n toggleExpanded: () => void\n pageSize: number\n renderer?: Renderer\n filterSubEntries?: (subEntries: Property[]) => Property[]\n}\n\n/**\n * Chunk elements in the array by size\n *\n * when the array cannot be chunked evenly by size, the last chunk will be\n * filled with the remaining elements\n *\n * @example\n * chunkArray(['a','b', 'c', 'd', 'e'], 2) // returns [['a','b'], ['c', 'd'], ['e']]\n */\nexport function chunkArray<T>(array: T[], size: number): T[][] {\n if (size < 1) return []\n let i = 0\n const result: T[][] = []\n while (i < array.length) {\n result.push(array.slice(i, i + size))\n i = i + size\n }\n return result\n}\n\ntype Renderer = (props: RendererProps) => React.ReactNode\n\nexport const DefaultRenderer: Renderer = ({\n handleEntry,\n label,\n value,\n subEntries = [],\n subEntryPages = [],\n type,\n expanded = false,\n toggleExpanded,\n pageSize,\n renderer,\n}) => {\n const [expandedPages, setExpandedPages] = React.useState<number[]>([])\n const [valueSnapshot, setValueSnapshot] = React.useState(undefined)\n\n const refreshValueSnapshot = () => {\n setValueSnapshot((value as () => any)())\n }\n\n return (\n <div className={getStyles().entry}>\n {subEntryPages.length ? (\n <>\n <button\n className={getStyles().expandButton}\n onClick={() => toggleExpanded()}\n >\n <Expander expanded={expanded} />\n {label}\n <span className={getStyles().info}>\n {String(type).toLowerCase() === 'iterable' ? '(Iterable) ' : ''}\n {subEntries.length} {subEntries.length > 1 ? `items` : `item`}\n </span>\n </button>\n {expanded ? (\n subEntryPages.length === 1 ? (\n <div className={getStyles().subEntries}>\n {subEntries.map((entry, index) => handleEntry(entry))}\n </div>\n ) : (\n <div className={getStyles().subEntries}>\n {subEntryPages.map((entries, index) => {\n return (\n <div key={index}>\n <div className={getStyles().entry}>\n <button\n className={cx(getStyles().labelButton, 'labelButton')}\n onClick={() =>\n setExpandedPages((old) =>\n old.includes(index)\n ? old.filter((d) => d !== index)\n : [...old, index],\n )\n }\n >\n <Expander expanded={expandedPages.includes(index)} />{' '}\n [{index * pageSize} ...{' '}\n {index * pageSize + pageSize - 1}]\n </button>\n {expandedPages.includes(index) ? (\n <div className={getStyles().subEntries}>\n {entries.map((entry) => handleEntry(entry))}\n </div>\n ) : null}\n </div>\n </div>\n )\n })}\n </div>\n )\n ) : null}\n </>\n ) : type === 'function' ? (\n <>\n <Explorer\n renderer={renderer}\n label={\n <button\n onClick={refreshValueSnapshot}\n className={getStyles().refreshValueBtn}\n >\n <span>{label}</span> 🔄{' '}\n </button>\n }\n value={valueSnapshot}\n defaultExpanded={{}}\n />\n </>\n ) : (\n <>\n <span>{label}:</span>{' '}\n <span className={getStyles().value}>{displayValue(value)}</span>\n </>\n )}\n </div>\n )\n}\n\ntype HandleEntryFn = (entry: Entry) => React.ReactNode\n\ntype ExplorerProps = Partial<RendererProps> & {\n renderer?: Renderer\n defaultExpanded?: true | Record<string, boolean>\n}\n\ntype Property = {\n defaultExpanded?: boolean | Record<string, boolean>\n label: string\n value: unknown\n}\n\nfunction isIterable(x: any): x is Iterable<unknown> {\n return Symbol.iterator in x\n}\n\nexport default function Explorer({\n value,\n defaultExpanded,\n renderer = DefaultRenderer,\n pageSize = 100,\n filterSubEntries,\n ...rest\n}: ExplorerProps) {\n const [expanded, setExpanded] = React.useState(Boolean(defaultExpanded))\n const toggleExpanded = React.useCallback(() => setExpanded((old) => !old), [])\n\n let type: string = typeof value\n let subEntries: Property[] = []\n\n const makeProperty = (sub: { label: string; value: unknown }): Property => {\n const subDefaultExpanded =\n defaultExpanded === true\n ? { [sub.label]: true }\n : defaultExpanded?.[sub.label]\n return {\n ...sub,\n defaultExpanded: subDefaultExpanded,\n }\n }\n\n if (Array.isArray(value)) {\n type = 'array'\n subEntries = value.map((d, i) =>\n makeProperty({\n label: i.toString(),\n value: d,\n }),\n )\n } else if (\n value !== null &&\n typeof value === 'object' &&\n isIterable(value) &&\n typeof value[Symbol.iterator] === 'function'\n ) {\n type = 'Iterable'\n subEntries = Array.from(value, (val, i) =>\n makeProperty({\n label: i.toString(),\n value: val,\n }),\n )\n } else if (typeof value === 'object' && value !== null) {\n type = 'object'\n subEntries = Object.entries(value).map(([key, val]) =>\n makeProperty({\n label: key,\n value: val,\n }),\n )\n }\n\n subEntries = filterSubEntries ? filterSubEntries(subEntries) : subEntries\n\n const subEntryPages = chunkArray(subEntries, pageSize)\n\n return renderer({\n handleEntry: (entry) => (\n <Explorer\n key={entry.label}\n value={value}\n renderer={renderer}\n filterSubEntries={filterSubEntries}\n {...rest}\n {...entry}\n />\n ),\n type,\n subEntries,\n subEntryPages,\n value,\n expanded,\n toggleExpanded,\n pageSize,\n ...rest,\n })\n}\n\nconst stylesFactory = () => {\n const { colors, font, size, alpha, shadow, border } = tokens\n const { fontFamily, lineHeight, size: fontSize } = font\n\n return {\n entry: css`\n font-family: ${fontFamily.mono};\n font-size: ${fontSize.xs};\n line-height: ${lineHeight.sm};\n outline: none;\n word-break: break-word;\n `,\n labelButton: css`\n cursor: pointer;\n color: inherit;\n font: inherit;\n outline: inherit;\n background: transparent;\n border: none;\n padding: 0;\n `,\n expander: css`\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: ${size[3]};\n height: ${size[3]};\n padding-left: 3px;\n box-sizing: content-box;\n `,\n expanderIcon: (expanded: boolean) => {\n if (expanded) {\n return css`\n transform: rotate(90deg);\n transition: transform 0.1s ease;\n `\n }\n return css`\n transform: rotate(0deg);\n transition: transform 0.1s ease;\n `\n },\n expandButton: css`\n display: flex;\n gap: ${size[1]};\n align-items: center;\n cursor: pointer;\n color: inherit;\n font: inherit;\n outline: inherit;\n background: transparent;\n border: none;\n padding: 0;\n `,\n value: css`\n color: ${colors.purple[400]};\n `,\n subEntries: css`\n margin-left: ${size[2]};\n padding-left: ${size[2]};\n border-left: 2px solid ${colors.darkGray[400]};\n `,\n info: css`\n color: ${colors.gray[500]};\n font-size: ${fontSize['2xs']};\n padding-left: ${size[1]};\n `,\n refreshValueBtn: css`\n appearance: none;\n border: 0;\n cursor: pointer;\n background: transparent;\n color: inherit;\n padding: 0;\n font-family: ${fontFamily.mono};\n font-size: ${fontSize.xs};\n `,\n }\n}\n\nlet _styles: ReturnType<typeof stylesFactory> | null = null\n\nfunction getStyles() {\n if (_styles) return _styles\n _styles = stylesFactory()\n\n return _styles\n}\n"],"names":["jsx","cx","React","jsxs","Fragment","displayValue","tokens","css"],"mappings":"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"}
|
package/dist/cjs/Explorer.d.cts
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
type ExpanderProps = {
|
|
3
|
-
expanded: boolean;
|
|
4
|
-
style?: React.CSSProperties;
|
|
5
|
-
};
|
|
6
|
-
export declare const Expander: ({ expanded, style }: ExpanderProps) => React.JSX.Element;
|
|
7
|
-
type Entry = {
|
|
8
|
-
label: string;
|
|
9
|
-
};
|
|
10
|
-
type RendererProps = {
|
|
11
|
-
handleEntry: HandleEntryFn;
|
|
12
|
-
label?: React.ReactNode;
|
|
13
|
-
value: unknown;
|
|
14
|
-
subEntries: Entry[];
|
|
15
|
-
subEntryPages: Entry[][];
|
|
16
|
-
type: string;
|
|
17
|
-
expanded: boolean;
|
|
18
|
-
toggleExpanded: () => void;
|
|
19
|
-
pageSize: number;
|
|
20
|
-
renderer?: Renderer;
|
|
21
|
-
filterSubEntries?: (subEntries: Property[]) => Property[];
|
|
22
|
-
};
|
|
23
|
-
/**
|
|
24
|
-
* Chunk elements in the array by size
|
|
25
|
-
*
|
|
26
|
-
* when the array cannot be chunked evenly by size, the last chunk will be
|
|
27
|
-
* filled with the remaining elements
|
|
28
|
-
*
|
|
29
|
-
* @example
|
|
30
|
-
* chunkArray(['a','b', 'c', 'd', 'e'], 2) // returns [['a','b'], ['c', 'd'], ['e']]
|
|
31
|
-
*/
|
|
32
|
-
export declare function chunkArray<T>(array: T[], size: number): T[][];
|
|
33
|
-
type Renderer = (props: RendererProps) => React.ReactNode;
|
|
34
|
-
export declare const DefaultRenderer: Renderer;
|
|
35
|
-
type HandleEntryFn = (entry: Entry) => React.ReactNode;
|
|
36
|
-
type ExplorerProps = Partial<RendererProps> & {
|
|
37
|
-
renderer?: Renderer;
|
|
38
|
-
defaultExpanded?: true | Record<string, boolean>;
|
|
39
|
-
};
|
|
40
|
-
type Property = {
|
|
41
|
-
defaultExpanded?: boolean | Record<string, boolean>;
|
|
42
|
-
label: string;
|
|
43
|
-
value: unknown;
|
|
44
|
-
};
|
|
45
|
-
export default function Explorer({ value, defaultExpanded, renderer, pageSize, filterSubEntries, ...rest }: ExplorerProps): React.ReactNode;
|
|
46
|
-
export {};
|