@tanstack/router-devtools-core 1.121.0-alpha.1 → 1.121.0-alpha.14
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.
|
@@ -6,7 +6,7 @@ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot
|
|
|
6
6
|
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
7
7
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
8
8
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
9
|
-
var _router, _routerState, _position, _initialIsOpen, _shadowDOMTarget, _panelProps, _closeButtonProps, _toggleButtonProps, _isMounted, _Component, _dispose;
|
|
9
|
+
var _router, _routerState, _position, _initialIsOpen, _shadowDOMTarget, _panelProps, _closeButtonProps, _toggleButtonProps, _containerElement, _isMounted, _Component, _dispose;
|
|
10
10
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
11
11
|
const web = require("solid-js/web");
|
|
12
12
|
const solidJs = require("solid-js");
|
|
@@ -20,6 +20,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
20
20
|
__privateAdd(this, _panelProps);
|
|
21
21
|
__privateAdd(this, _closeButtonProps);
|
|
22
22
|
__privateAdd(this, _toggleButtonProps);
|
|
23
|
+
__privateAdd(this, _containerElement);
|
|
23
24
|
__privateAdd(this, _isMounted, false);
|
|
24
25
|
__privateAdd(this, _Component);
|
|
25
26
|
__privateAdd(this, _dispose);
|
|
@@ -31,6 +32,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
31
32
|
__privateSet(this, _panelProps, config.panelProps);
|
|
32
33
|
__privateSet(this, _closeButtonProps, config.closeButtonProps);
|
|
33
34
|
__privateSet(this, _toggleButtonProps, config.toggleButtonProps);
|
|
35
|
+
__privateSet(this, _containerElement, config.containerElement);
|
|
34
36
|
}
|
|
35
37
|
mount(el) {
|
|
36
38
|
if (__privateGet(this, _isMounted)) {
|
|
@@ -45,6 +47,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
45
47
|
const panelProps = __privateGet(this, _panelProps);
|
|
46
48
|
const closeButtonProps = __privateGet(this, _closeButtonProps);
|
|
47
49
|
const toggleButtonProps = __privateGet(this, _toggleButtonProps);
|
|
50
|
+
const containerElement = __privateGet(this, _containerElement);
|
|
48
51
|
let Devtools;
|
|
49
52
|
if (__privateGet(this, _Component)) {
|
|
50
53
|
Devtools = __privateGet(this, _Component);
|
|
@@ -60,7 +63,8 @@ class TanStackRouterDevtoolsCore {
|
|
|
60
63
|
routerState,
|
|
61
64
|
panelProps,
|
|
62
65
|
closeButtonProps,
|
|
63
|
-
toggleButtonProps
|
|
66
|
+
toggleButtonProps,
|
|
67
|
+
containerElement
|
|
64
68
|
});
|
|
65
69
|
}, el);
|
|
66
70
|
__privateSet(this, _isMounted, true);
|
|
@@ -90,6 +94,9 @@ class TanStackRouterDevtoolsCore {
|
|
|
90
94
|
if (options.shadowDOMTarget !== void 0) {
|
|
91
95
|
__privateSet(this, _shadowDOMTarget, options.shadowDOMTarget);
|
|
92
96
|
}
|
|
97
|
+
if (options.containerElement !== void 0) {
|
|
98
|
+
__privateSet(this, _containerElement, options.containerElement);
|
|
99
|
+
}
|
|
93
100
|
}
|
|
94
101
|
}
|
|
95
102
|
_router = new WeakMap();
|
|
@@ -100,6 +107,7 @@ _shadowDOMTarget = new WeakMap();
|
|
|
100
107
|
_panelProps = new WeakMap();
|
|
101
108
|
_closeButtonProps = new WeakMap();
|
|
102
109
|
_toggleButtonProps = new WeakMap();
|
|
110
|
+
_containerElement = new WeakMap();
|
|
103
111
|
_isMounted = new WeakMap();
|
|
104
112
|
_Component = new WeakMap();
|
|
105
113
|
_dispose = new WeakMap();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TanStackRouterDevtoolsCore.cjs","sources":["../../src/TanStackRouterDevtoolsCore.tsx"],"sourcesContent":["import { createSignal, lazy } from 'solid-js'\nimport { render } from 'solid-js/web'\nimport type { AnyRouter } from '@tanstack/router-core'\nimport type { Signal } from 'solid-js'\n\ninterface DevtoolsOptions {\n /**\n * Set this true if you want the dev tools to default to being open\n */\n initialIsOpen?: boolean\n /**\n * Use this to add props to the panel. For example, you can add class, style (merge and override default style), etc.\n */\n panelProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the close button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n closeButtonProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the toggle button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n toggleButtonProps?: any & {\n ref?: any\n }\n /**\n * The position of the TanStack Router logo to open and close the devtools panel.\n * Defaults to 'bottom-left'.\n */\n position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n /**\n * Use this to render the devtools inside a different type of container element for a11y purposes.\n * Any string which corresponds to a valid intrinsic JSX element is allowed.\n * Defaults to 'footer'.\n */\n containerElement?: string | any\n /**\n * A boolean variable indicating if the \"lite\" version of the library is being used\n */\n router: AnyRouter\n routerState: any\n /**\n * Use this to attach the devtool's styles to specific element in the DOM.\n */\n shadowDOMTarget?: ShadowRoot\n}\n\nclass TanStackRouterDevtoolsCore {\n #router: Signal<AnyRouter>\n #routerState: Signal<any>\n #position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n #initialIsOpen: boolean\n #shadowDOMTarget?: ShadowRoot\n\n #panelProps: any\n #closeButtonProps: any\n #toggleButtonProps: any\n\n #isMounted = false\n #Component: any\n #dispose?: () => void\n\n constructor(config: DevtoolsOptions) {\n this.#router = createSignal(config.router)\n this.#routerState = createSignal(config.routerState)\n this.#position = config.position ?? 'bottom-left'\n this.#initialIsOpen = config.initialIsOpen ?? false\n this.#shadowDOMTarget = config.shadowDOMTarget\n\n this.#panelProps = config.panelProps\n this.#closeButtonProps = config.closeButtonProps\n this.#toggleButtonProps = config.toggleButtonProps\n }\n\n mount<T extends HTMLElement>(el: T) {\n if (this.#isMounted) {\n throw new Error('Devtools is already mounted')\n }\n\n const dispose = render(() => {\n const [router] = this.#router\n const [routerState] = this.#routerState\n const position = this.#position\n const initialIsOpen = this.#initialIsOpen\n const shadowDOMTarget = this.#shadowDOMTarget\n\n const panelProps = this.#panelProps\n const closeButtonProps = this.#closeButtonProps\n const toggleButtonProps = this.#toggleButtonProps\n\n let Devtools\n\n if (this.#Component) {\n Devtools = this.#Component\n } else {\n Devtools = lazy(() => import('./FloatingTanStackRouterDevtools'))\n this.#Component = Devtools\n }\n\n return (\n <Devtools\n position={position}\n initialIsOpen={initialIsOpen}\n shadowDOMTarget={shadowDOMTarget}\n router={router}\n routerState={routerState}\n panelProps={panelProps}\n closeButtonProps={closeButtonProps}\n toggleButtonProps={toggleButtonProps}\n />\n )\n }, el)\n\n this.#isMounted = true\n this.#dispose = dispose\n }\n\n unmount() {\n if (!this.#isMounted) {\n throw new Error('Devtools is not mounted')\n }\n this.#dispose?.()\n this.#isMounted = false\n }\n\n setRouter(router: AnyRouter) {\n this.#router[1](router)\n }\n\n setRouterState(routerState: any) {\n this.#routerState[1](routerState)\n }\n\n setOptions(options: Partial<DevtoolsOptions>) {\n if (options.position !== undefined) {\n this.#position = options.position\n }\n\n if (options.initialIsOpen !== undefined) {\n this.#initialIsOpen = options.initialIsOpen\n }\n\n if (options.shadowDOMTarget !== undefined) {\n this.#shadowDOMTarget = options.shadowDOMTarget\n }\n }\n}\n\nexport { TanStackRouterDevtoolsCore }\n"],"names":["TanStackRouterDevtoolsCore","constructor","config","createSignal","router","routerState","position","initialIsOpen","shadowDOMTarget","panelProps","closeButtonProps","toggleButtonProps","mount","el","Error","dispose","render","Devtools","lazy","_$createComponent","unmount","setRouter","setRouterState","setOptions","options","undefined"],"mappings":";;;;;;;;;;;;AAkDA,MAAMA,2BAA2B;AAAA,
|
|
1
|
+
{"version":3,"file":"TanStackRouterDevtoolsCore.cjs","sources":["../../src/TanStackRouterDevtoolsCore.tsx"],"sourcesContent":["import { createSignal, lazy } from 'solid-js'\nimport { render } from 'solid-js/web'\nimport type { AnyRouter } from '@tanstack/router-core'\nimport type { Signal } from 'solid-js'\n\ninterface DevtoolsOptions {\n /**\n * Set this true if you want the dev tools to default to being open\n */\n initialIsOpen?: boolean\n /**\n * Use this to add props to the panel. For example, you can add class, style (merge and override default style), etc.\n */\n panelProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the close button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n closeButtonProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the toggle button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n toggleButtonProps?: any & {\n ref?: any\n }\n /**\n * The position of the TanStack Router logo to open and close the devtools panel.\n * Defaults to 'bottom-left'.\n */\n position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n /**\n * Use this to render the devtools inside a different type of container element for a11y purposes.\n * Any string which corresponds to a valid intrinsic JSX element is allowed.\n * Defaults to 'footer'.\n */\n containerElement?: string | any\n /**\n * A boolean variable indicating if the \"lite\" version of the library is being used\n */\n router: AnyRouter\n routerState: any\n /**\n * Use this to attach the devtool's styles to specific element in the DOM.\n */\n shadowDOMTarget?: ShadowRoot\n}\n\nclass TanStackRouterDevtoolsCore {\n #router: Signal<AnyRouter>\n #routerState: Signal<any>\n #position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n #initialIsOpen: boolean\n #shadowDOMTarget?: ShadowRoot\n\n #panelProps: any\n #closeButtonProps: any\n #toggleButtonProps: any\n #containerElement?: string | any\n\n #isMounted = false\n #Component: any\n #dispose?: () => void\n\n constructor(config: DevtoolsOptions) {\n this.#router = createSignal(config.router)\n this.#routerState = createSignal(config.routerState)\n this.#position = config.position ?? 'bottom-left'\n this.#initialIsOpen = config.initialIsOpen ?? false\n this.#shadowDOMTarget = config.shadowDOMTarget\n\n this.#panelProps = config.panelProps\n this.#closeButtonProps = config.closeButtonProps\n this.#toggleButtonProps = config.toggleButtonProps\n this.#containerElement = config.containerElement\n }\n\n mount<T extends HTMLElement>(el: T) {\n if (this.#isMounted) {\n throw new Error('Devtools is already mounted')\n }\n\n const dispose = render(() => {\n const [router] = this.#router\n const [routerState] = this.#routerState\n const position = this.#position\n const initialIsOpen = this.#initialIsOpen\n const shadowDOMTarget = this.#shadowDOMTarget\n\n const panelProps = this.#panelProps\n const closeButtonProps = this.#closeButtonProps\n const toggleButtonProps = this.#toggleButtonProps\n const containerElement = this.#containerElement\n\n let Devtools\n\n if (this.#Component) {\n Devtools = this.#Component\n } else {\n Devtools = lazy(() => import('./FloatingTanStackRouterDevtools'))\n this.#Component = Devtools\n }\n\n return (\n <Devtools\n position={position}\n initialIsOpen={initialIsOpen}\n shadowDOMTarget={shadowDOMTarget}\n router={router}\n routerState={routerState}\n panelProps={panelProps}\n closeButtonProps={closeButtonProps}\n toggleButtonProps={toggleButtonProps}\n containerElement={containerElement}\n />\n )\n }, el)\n\n this.#isMounted = true\n this.#dispose = dispose\n }\n\n unmount() {\n if (!this.#isMounted) {\n throw new Error('Devtools is not mounted')\n }\n this.#dispose?.()\n this.#isMounted = false\n }\n\n setRouter(router: AnyRouter) {\n this.#router[1](router)\n }\n\n setRouterState(routerState: any) {\n this.#routerState[1](routerState)\n }\n\n setOptions(options: Partial<DevtoolsOptions>) {\n if (options.position !== undefined) {\n this.#position = options.position\n }\n\n if (options.initialIsOpen !== undefined) {\n this.#initialIsOpen = options.initialIsOpen\n }\n\n if (options.shadowDOMTarget !== undefined) {\n this.#shadowDOMTarget = options.shadowDOMTarget\n }\n\n if (options.containerElement !== undefined) {\n this.#containerElement = options.containerElement\n }\n }\n}\n\nexport { TanStackRouterDevtoolsCore }\n"],"names":["TanStackRouterDevtoolsCore","constructor","config","createSignal","router","routerState","position","initialIsOpen","shadowDOMTarget","panelProps","closeButtonProps","toggleButtonProps","containerElement","mount","el","Error","dispose","render","Devtools","lazy","_$createComponent","unmount","setRouter","setRouterState","setOptions","options","undefined"],"mappings":";;;;;;;;;;;;AAkDA,MAAMA,2BAA2B;AAAA,EAgB/BC,YAAYC,QAAyB;AAfrC;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA,mCAAa;AACb;AACA;AAGO,uBAAA,SAAUC,qBAAaD,OAAOE,MAAM;AACpC,uBAAA,cAAeD,qBAAaD,OAAOG,WAAW;AAC9C,uBAAA,WAAYH,OAAOI,YAAY;AAC/B,uBAAA,gBAAiBJ,OAAOK,iBAAiB;AAC9C,uBAAK,kBAAmBL,OAAOM;AAE/B,uBAAK,aAAcN,OAAOO;AAC1B,uBAAK,mBAAoBP,OAAOQ;AAChC,uBAAK,oBAAqBR,OAAOS;AACjC,uBAAK,mBAAoBT,OAAOU;AAAAA,EAAAA;AAAAA,EAGlCC,MAA6BC,IAAO;AAClC,QAAI,mBAAK,aAAY;AACb,YAAA,IAAIC,MAAM,6BAA6B;AAAA,IAAA;AAGzCC,UAAAA,UAAUC,IAAAA,OAAO,MAAM;AACrB,YAAA,CAACb,MAAM,IAAI,mBAAK;AAChB,YAAA,CAACC,WAAW,IAAI,mBAAK;AAC3B,YAAMC,WAAW,mBAAK;AACtB,YAAMC,gBAAgB,mBAAK;AAC3B,YAAMC,kBAAkB,mBAAK;AAE7B,YAAMC,aAAa,mBAAK;AACxB,YAAMC,mBAAmB,mBAAK;AAC9B,YAAMC,oBAAoB,mBAAK;AAC/B,YAAMC,mBAAmB,mBAAK;AAE1BM,UAAAA;AAEJ,UAAI,mBAAK,aAAY;AACnBA,mBAAW,mBAAK;AAAA,MAAA,OACX;AACLA,mBAAWC,QAAK,KAAA,MAAM,QAAO,QAAA,EAAA,KAAA,MAAA,QAAA,sCAAkC,EAAC;AAChE,2BAAK,YAAaD;AAAAA,MAAAA;AAGpB,aAAAE,IAAAA,gBACGF,UAAQ;AAAA,QACPZ;AAAAA,QACAC;AAAAA,QACAC;AAAAA,QACAJ;AAAAA,QACAC;AAAAA,QACAI;AAAAA,QACAC;AAAAA,QACAC;AAAAA,QACAC;AAAAA,MAAAA,CAAkC;AAAA,OAGrCE,EAAE;AAEL,uBAAK,YAAa;AAClB,uBAAK,UAAWE;AAAAA,EAAAA;AAAAA,EAGlBK,UAAU;;AACJ,QAAA,CAAC,mBAAK,aAAY;AACd,YAAA,IAAIN,MAAM,yBAAyB;AAAA,IAAA;AAE3C,6BAAK,cAAL;AACA,uBAAK,YAAa;AAAA,EAAA;AAAA,EAGpBO,UAAUlB,QAAmB;AACtB,uBAAA,SAAQ,CAAC,EAAEA,MAAM;AAAA,EAAA;AAAA,EAGxBmB,eAAelB,aAAkB;AAC1B,uBAAA,cAAa,CAAC,EAAEA,WAAW;AAAA,EAAA;AAAA,EAGlCmB,WAAWC,SAAmC;AACxCA,QAAAA,QAAQnB,aAAaoB,QAAW;AAClC,yBAAK,WAAYD,QAAQnB;AAAAA,IAAAA;AAGvBmB,QAAAA,QAAQlB,kBAAkBmB,QAAW;AACvC,yBAAK,gBAAiBD,QAAQlB;AAAAA,IAAAA;AAG5BkB,QAAAA,QAAQjB,oBAAoBkB,QAAW;AACzC,yBAAK,kBAAmBD,QAAQjB;AAAAA,IAAAA;AAG9BiB,QAAAA,QAAQb,qBAAqBc,QAAW;AAC1C,yBAAK,mBAAoBD,QAAQb;AAAAA,IAAAA;AAAAA,EACnC;AAEJ;AA1GE;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;;"}
|
|
@@ -5,7 +5,7 @@ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot
|
|
|
5
5
|
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
6
6
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
7
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
|
-
var _router, _routerState, _position, _initialIsOpen, _shadowDOMTarget, _panelProps, _closeButtonProps, _toggleButtonProps, _isMounted, _Component, _dispose;
|
|
8
|
+
var _router, _routerState, _position, _initialIsOpen, _shadowDOMTarget, _panelProps, _closeButtonProps, _toggleButtonProps, _containerElement, _isMounted, _Component, _dispose;
|
|
9
9
|
import { render, createComponent } from "solid-js/web";
|
|
10
10
|
import { createSignal, lazy } from "solid-js";
|
|
11
11
|
class TanStackRouterDevtoolsCore {
|
|
@@ -18,6 +18,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
18
18
|
__privateAdd(this, _panelProps);
|
|
19
19
|
__privateAdd(this, _closeButtonProps);
|
|
20
20
|
__privateAdd(this, _toggleButtonProps);
|
|
21
|
+
__privateAdd(this, _containerElement);
|
|
21
22
|
__privateAdd(this, _isMounted, false);
|
|
22
23
|
__privateAdd(this, _Component);
|
|
23
24
|
__privateAdd(this, _dispose);
|
|
@@ -29,6 +30,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
29
30
|
__privateSet(this, _panelProps, config.panelProps);
|
|
30
31
|
__privateSet(this, _closeButtonProps, config.closeButtonProps);
|
|
31
32
|
__privateSet(this, _toggleButtonProps, config.toggleButtonProps);
|
|
33
|
+
__privateSet(this, _containerElement, config.containerElement);
|
|
32
34
|
}
|
|
33
35
|
mount(el) {
|
|
34
36
|
if (__privateGet(this, _isMounted)) {
|
|
@@ -43,6 +45,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
43
45
|
const panelProps = __privateGet(this, _panelProps);
|
|
44
46
|
const closeButtonProps = __privateGet(this, _closeButtonProps);
|
|
45
47
|
const toggleButtonProps = __privateGet(this, _toggleButtonProps);
|
|
48
|
+
const containerElement = __privateGet(this, _containerElement);
|
|
46
49
|
let Devtools;
|
|
47
50
|
if (__privateGet(this, _Component)) {
|
|
48
51
|
Devtools = __privateGet(this, _Component);
|
|
@@ -58,7 +61,8 @@ class TanStackRouterDevtoolsCore {
|
|
|
58
61
|
routerState,
|
|
59
62
|
panelProps,
|
|
60
63
|
closeButtonProps,
|
|
61
|
-
toggleButtonProps
|
|
64
|
+
toggleButtonProps,
|
|
65
|
+
containerElement
|
|
62
66
|
});
|
|
63
67
|
}, el);
|
|
64
68
|
__privateSet(this, _isMounted, true);
|
|
@@ -88,6 +92,9 @@ class TanStackRouterDevtoolsCore {
|
|
|
88
92
|
if (options.shadowDOMTarget !== void 0) {
|
|
89
93
|
__privateSet(this, _shadowDOMTarget, options.shadowDOMTarget);
|
|
90
94
|
}
|
|
95
|
+
if (options.containerElement !== void 0) {
|
|
96
|
+
__privateSet(this, _containerElement, options.containerElement);
|
|
97
|
+
}
|
|
91
98
|
}
|
|
92
99
|
}
|
|
93
100
|
_router = new WeakMap();
|
|
@@ -98,6 +105,7 @@ _shadowDOMTarget = new WeakMap();
|
|
|
98
105
|
_panelProps = new WeakMap();
|
|
99
106
|
_closeButtonProps = new WeakMap();
|
|
100
107
|
_toggleButtonProps = new WeakMap();
|
|
108
|
+
_containerElement = new WeakMap();
|
|
101
109
|
_isMounted = new WeakMap();
|
|
102
110
|
_Component = new WeakMap();
|
|
103
111
|
_dispose = new WeakMap();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TanStackRouterDevtoolsCore.js","sources":["../../src/TanStackRouterDevtoolsCore.tsx"],"sourcesContent":["import { createSignal, lazy } from 'solid-js'\nimport { render } from 'solid-js/web'\nimport type { AnyRouter } from '@tanstack/router-core'\nimport type { Signal } from 'solid-js'\n\ninterface DevtoolsOptions {\n /**\n * Set this true if you want the dev tools to default to being open\n */\n initialIsOpen?: boolean\n /**\n * Use this to add props to the panel. For example, you can add class, style (merge and override default style), etc.\n */\n panelProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the close button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n closeButtonProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the toggle button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n toggleButtonProps?: any & {\n ref?: any\n }\n /**\n * The position of the TanStack Router logo to open and close the devtools panel.\n * Defaults to 'bottom-left'.\n */\n position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n /**\n * Use this to render the devtools inside a different type of container element for a11y purposes.\n * Any string which corresponds to a valid intrinsic JSX element is allowed.\n * Defaults to 'footer'.\n */\n containerElement?: string | any\n /**\n * A boolean variable indicating if the \"lite\" version of the library is being used\n */\n router: AnyRouter\n routerState: any\n /**\n * Use this to attach the devtool's styles to specific element in the DOM.\n */\n shadowDOMTarget?: ShadowRoot\n}\n\nclass TanStackRouterDevtoolsCore {\n #router: Signal<AnyRouter>\n #routerState: Signal<any>\n #position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n #initialIsOpen: boolean\n #shadowDOMTarget?: ShadowRoot\n\n #panelProps: any\n #closeButtonProps: any\n #toggleButtonProps: any\n\n #isMounted = false\n #Component: any\n #dispose?: () => void\n\n constructor(config: DevtoolsOptions) {\n this.#router = createSignal(config.router)\n this.#routerState = createSignal(config.routerState)\n this.#position = config.position ?? 'bottom-left'\n this.#initialIsOpen = config.initialIsOpen ?? false\n this.#shadowDOMTarget = config.shadowDOMTarget\n\n this.#panelProps = config.panelProps\n this.#closeButtonProps = config.closeButtonProps\n this.#toggleButtonProps = config.toggleButtonProps\n }\n\n mount<T extends HTMLElement>(el: T) {\n if (this.#isMounted) {\n throw new Error('Devtools is already mounted')\n }\n\n const dispose = render(() => {\n const [router] = this.#router\n const [routerState] = this.#routerState\n const position = this.#position\n const initialIsOpen = this.#initialIsOpen\n const shadowDOMTarget = this.#shadowDOMTarget\n\n const panelProps = this.#panelProps\n const closeButtonProps = this.#closeButtonProps\n const toggleButtonProps = this.#toggleButtonProps\n\n let Devtools\n\n if (this.#Component) {\n Devtools = this.#Component\n } else {\n Devtools = lazy(() => import('./FloatingTanStackRouterDevtools'))\n this.#Component = Devtools\n }\n\n return (\n <Devtools\n position={position}\n initialIsOpen={initialIsOpen}\n shadowDOMTarget={shadowDOMTarget}\n router={router}\n routerState={routerState}\n panelProps={panelProps}\n closeButtonProps={closeButtonProps}\n toggleButtonProps={toggleButtonProps}\n />\n )\n }, el)\n\n this.#isMounted = true\n this.#dispose = dispose\n }\n\n unmount() {\n if (!this.#isMounted) {\n throw new Error('Devtools is not mounted')\n }\n this.#dispose?.()\n this.#isMounted = false\n }\n\n setRouter(router: AnyRouter) {\n this.#router[1](router)\n }\n\n setRouterState(routerState: any) {\n this.#routerState[1](routerState)\n }\n\n setOptions(options: Partial<DevtoolsOptions>) {\n if (options.position !== undefined) {\n this.#position = options.position\n }\n\n if (options.initialIsOpen !== undefined) {\n this.#initialIsOpen = options.initialIsOpen\n }\n\n if (options.shadowDOMTarget !== undefined) {\n this.#shadowDOMTarget = options.shadowDOMTarget\n }\n }\n}\n\nexport { TanStackRouterDevtoolsCore }\n"],"names":["TanStackRouterDevtoolsCore","constructor","config","createSignal","router","routerState","position","initialIsOpen","shadowDOMTarget","panelProps","closeButtonProps","toggleButtonProps","mount","el","Error","dispose","render","Devtools","lazy","_$createComponent","unmount","setRouter","setRouterState","setOptions","options","undefined"],"mappings":";;;;;;;;;;AAkDA,MAAMA,2BAA2B;AAAA,
|
|
1
|
+
{"version":3,"file":"TanStackRouterDevtoolsCore.js","sources":["../../src/TanStackRouterDevtoolsCore.tsx"],"sourcesContent":["import { createSignal, lazy } from 'solid-js'\nimport { render } from 'solid-js/web'\nimport type { AnyRouter } from '@tanstack/router-core'\nimport type { Signal } from 'solid-js'\n\ninterface DevtoolsOptions {\n /**\n * Set this true if you want the dev tools to default to being open\n */\n initialIsOpen?: boolean\n /**\n * Use this to add props to the panel. For example, you can add class, style (merge and override default style), etc.\n */\n panelProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the close button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n closeButtonProps?: any & {\n ref?: any\n }\n /**\n * Use this to add props to the toggle button. For example, you can add class, style (merge and override default style), onClick (extend default handler), etc.\n */\n toggleButtonProps?: any & {\n ref?: any\n }\n /**\n * The position of the TanStack Router logo to open and close the devtools panel.\n * Defaults to 'bottom-left'.\n */\n position?: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n /**\n * Use this to render the devtools inside a different type of container element for a11y purposes.\n * Any string which corresponds to a valid intrinsic JSX element is allowed.\n * Defaults to 'footer'.\n */\n containerElement?: string | any\n /**\n * A boolean variable indicating if the \"lite\" version of the library is being used\n */\n router: AnyRouter\n routerState: any\n /**\n * Use this to attach the devtool's styles to specific element in the DOM.\n */\n shadowDOMTarget?: ShadowRoot\n}\n\nclass TanStackRouterDevtoolsCore {\n #router: Signal<AnyRouter>\n #routerState: Signal<any>\n #position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right'\n #initialIsOpen: boolean\n #shadowDOMTarget?: ShadowRoot\n\n #panelProps: any\n #closeButtonProps: any\n #toggleButtonProps: any\n #containerElement?: string | any\n\n #isMounted = false\n #Component: any\n #dispose?: () => void\n\n constructor(config: DevtoolsOptions) {\n this.#router = createSignal(config.router)\n this.#routerState = createSignal(config.routerState)\n this.#position = config.position ?? 'bottom-left'\n this.#initialIsOpen = config.initialIsOpen ?? false\n this.#shadowDOMTarget = config.shadowDOMTarget\n\n this.#panelProps = config.panelProps\n this.#closeButtonProps = config.closeButtonProps\n this.#toggleButtonProps = config.toggleButtonProps\n this.#containerElement = config.containerElement\n }\n\n mount<T extends HTMLElement>(el: T) {\n if (this.#isMounted) {\n throw new Error('Devtools is already mounted')\n }\n\n const dispose = render(() => {\n const [router] = this.#router\n const [routerState] = this.#routerState\n const position = this.#position\n const initialIsOpen = this.#initialIsOpen\n const shadowDOMTarget = this.#shadowDOMTarget\n\n const panelProps = this.#panelProps\n const closeButtonProps = this.#closeButtonProps\n const toggleButtonProps = this.#toggleButtonProps\n const containerElement = this.#containerElement\n\n let Devtools\n\n if (this.#Component) {\n Devtools = this.#Component\n } else {\n Devtools = lazy(() => import('./FloatingTanStackRouterDevtools'))\n this.#Component = Devtools\n }\n\n return (\n <Devtools\n position={position}\n initialIsOpen={initialIsOpen}\n shadowDOMTarget={shadowDOMTarget}\n router={router}\n routerState={routerState}\n panelProps={panelProps}\n closeButtonProps={closeButtonProps}\n toggleButtonProps={toggleButtonProps}\n containerElement={containerElement}\n />\n )\n }, el)\n\n this.#isMounted = true\n this.#dispose = dispose\n }\n\n unmount() {\n if (!this.#isMounted) {\n throw new Error('Devtools is not mounted')\n }\n this.#dispose?.()\n this.#isMounted = false\n }\n\n setRouter(router: AnyRouter) {\n this.#router[1](router)\n }\n\n setRouterState(routerState: any) {\n this.#routerState[1](routerState)\n }\n\n setOptions(options: Partial<DevtoolsOptions>) {\n if (options.position !== undefined) {\n this.#position = options.position\n }\n\n if (options.initialIsOpen !== undefined) {\n this.#initialIsOpen = options.initialIsOpen\n }\n\n if (options.shadowDOMTarget !== undefined) {\n this.#shadowDOMTarget = options.shadowDOMTarget\n }\n\n if (options.containerElement !== undefined) {\n this.#containerElement = options.containerElement\n }\n }\n}\n\nexport { TanStackRouterDevtoolsCore }\n"],"names":["TanStackRouterDevtoolsCore","constructor","config","createSignal","router","routerState","position","initialIsOpen","shadowDOMTarget","panelProps","closeButtonProps","toggleButtonProps","containerElement","mount","el","Error","dispose","render","Devtools","lazy","_$createComponent","unmount","setRouter","setRouterState","setOptions","options","undefined"],"mappings":";;;;;;;;;;AAkDA,MAAMA,2BAA2B;AAAA,EAgB/BC,YAAYC,QAAyB;AAfrC;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA,mCAAa;AACb;AACA;AAGO,uBAAA,SAAUC,aAAaD,OAAOE,MAAM;AACpC,uBAAA,cAAeD,aAAaD,OAAOG,WAAW;AAC9C,uBAAA,WAAYH,OAAOI,YAAY;AAC/B,uBAAA,gBAAiBJ,OAAOK,iBAAiB;AAC9C,uBAAK,kBAAmBL,OAAOM;AAE/B,uBAAK,aAAcN,OAAOO;AAC1B,uBAAK,mBAAoBP,OAAOQ;AAChC,uBAAK,oBAAqBR,OAAOS;AACjC,uBAAK,mBAAoBT,OAAOU;AAAAA,EAAAA;AAAAA,EAGlCC,MAA6BC,IAAO;AAClC,QAAI,mBAAK,aAAY;AACb,YAAA,IAAIC,MAAM,6BAA6B;AAAA,IAAA;AAGzCC,UAAAA,UAAUC,OAAO,MAAM;AACrB,YAAA,CAACb,MAAM,IAAI,mBAAK;AAChB,YAAA,CAACC,WAAW,IAAI,mBAAK;AAC3B,YAAMC,WAAW,mBAAK;AACtB,YAAMC,gBAAgB,mBAAK;AAC3B,YAAMC,kBAAkB,mBAAK;AAE7B,YAAMC,aAAa,mBAAK;AACxB,YAAMC,mBAAmB,mBAAK;AAC9B,YAAMC,oBAAoB,mBAAK;AAC/B,YAAMC,mBAAmB,mBAAK;AAE1BM,UAAAA;AAEJ,UAAI,mBAAK,aAAY;AACnBA,mBAAW,mBAAK;AAAA,MAAA,OACX;AACLA,mBAAWC,KAAK,MAAM,OAAO,qCAAkC,CAAC;AAChE,2BAAK,YAAaD;AAAAA,MAAAA;AAGpB,aAAAE,gBACGF,UAAQ;AAAA,QACPZ;AAAAA,QACAC;AAAAA,QACAC;AAAAA,QACAJ;AAAAA,QACAC;AAAAA,QACAI;AAAAA,QACAC;AAAAA,QACAC;AAAAA,QACAC;AAAAA,MAAAA,CAAkC;AAAA,OAGrCE,EAAE;AAEL,uBAAK,YAAa;AAClB,uBAAK,UAAWE;AAAAA,EAAAA;AAAAA,EAGlBK,UAAU;;AACJ,QAAA,CAAC,mBAAK,aAAY;AACd,YAAA,IAAIN,MAAM,yBAAyB;AAAA,IAAA;AAE3C,6BAAK,cAAL;AACA,uBAAK,YAAa;AAAA,EAAA;AAAA,EAGpBO,UAAUlB,QAAmB;AACtB,uBAAA,SAAQ,CAAC,EAAEA,MAAM;AAAA,EAAA;AAAA,EAGxBmB,eAAelB,aAAkB;AAC1B,uBAAA,cAAa,CAAC,EAAEA,WAAW;AAAA,EAAA;AAAA,EAGlCmB,WAAWC,SAAmC;AACxCA,QAAAA,QAAQnB,aAAaoB,QAAW;AAClC,yBAAK,WAAYD,QAAQnB;AAAAA,IAAAA;AAGvBmB,QAAAA,QAAQlB,kBAAkBmB,QAAW;AACvC,yBAAK,gBAAiBD,QAAQlB;AAAAA,IAAAA;AAG5BkB,QAAAA,QAAQjB,oBAAoBkB,QAAW;AACzC,yBAAK,kBAAmBD,QAAQjB;AAAAA,IAAAA;AAG9BiB,QAAAA,QAAQb,qBAAqBc,QAAW;AAC1C,yBAAK,mBAAoBD,QAAQb;AAAAA,IAAAA;AAAAA,EACnC;AAEJ;AA1GE;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tanstack/router-devtools-core",
|
|
3
|
-
"version": "1.121.0-alpha.
|
|
3
|
+
"version": "1.121.0-alpha.14",
|
|
4
4
|
"description": "Modern and scalable routing for Web applications",
|
|
5
5
|
"author": "Tanner Linsley",
|
|
6
6
|
"license": "MIT",
|
|
@@ -60,7 +60,7 @@
|
|
|
60
60
|
"tiny-invariant": "^1.3.3",
|
|
61
61
|
"csstype": "^3.0.10",
|
|
62
62
|
"solid-js": ">=1.9.5",
|
|
63
|
-
"@tanstack/router-core": "^1.121.0-alpha.
|
|
63
|
+
"@tanstack/router-core": "^1.121.0-alpha.14"
|
|
64
64
|
},
|
|
65
65
|
"peerDependenciesMeta": {
|
|
66
66
|
"csstype": {
|
|
@@ -58,6 +58,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
58
58
|
#panelProps: any
|
|
59
59
|
#closeButtonProps: any
|
|
60
60
|
#toggleButtonProps: any
|
|
61
|
+
#containerElement?: string | any
|
|
61
62
|
|
|
62
63
|
#isMounted = false
|
|
63
64
|
#Component: any
|
|
@@ -73,6 +74,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
73
74
|
this.#panelProps = config.panelProps
|
|
74
75
|
this.#closeButtonProps = config.closeButtonProps
|
|
75
76
|
this.#toggleButtonProps = config.toggleButtonProps
|
|
77
|
+
this.#containerElement = config.containerElement
|
|
76
78
|
}
|
|
77
79
|
|
|
78
80
|
mount<T extends HTMLElement>(el: T) {
|
|
@@ -90,6 +92,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
90
92
|
const panelProps = this.#panelProps
|
|
91
93
|
const closeButtonProps = this.#closeButtonProps
|
|
92
94
|
const toggleButtonProps = this.#toggleButtonProps
|
|
95
|
+
const containerElement = this.#containerElement
|
|
93
96
|
|
|
94
97
|
let Devtools
|
|
95
98
|
|
|
@@ -110,6 +113,7 @@ class TanStackRouterDevtoolsCore {
|
|
|
110
113
|
panelProps={panelProps}
|
|
111
114
|
closeButtonProps={closeButtonProps}
|
|
112
115
|
toggleButtonProps={toggleButtonProps}
|
|
116
|
+
containerElement={containerElement}
|
|
113
117
|
/>
|
|
114
118
|
)
|
|
115
119
|
}, el)
|
|
@@ -146,6 +150,10 @@ class TanStackRouterDevtoolsCore {
|
|
|
146
150
|
if (options.shadowDOMTarget !== undefined) {
|
|
147
151
|
this.#shadowDOMTarget = options.shadowDOMTarget
|
|
148
152
|
}
|
|
153
|
+
|
|
154
|
+
if (options.containerElement !== undefined) {
|
|
155
|
+
this.#containerElement = options.containerElement
|
|
156
|
+
}
|
|
149
157
|
}
|
|
150
158
|
}
|
|
151
159
|
|