@tanstack/devtools 0.4.5 → 0.5.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.
Files changed (86) hide show
  1. package/dist/esm/components/main-panel.js +3 -1
  2. package/dist/esm/components/main-panel.js.map +1 -1
  3. package/dist/esm/components/tab-content.js +3 -6
  4. package/dist/esm/components/tab-content.js.map +1 -1
  5. package/dist/esm/components/tabs.js +34 -19
  6. package/dist/esm/components/tabs.js.map +1 -1
  7. package/dist/esm/context/pip-context.d.ts +14 -0
  8. package/dist/esm/context/pip-context.js +118 -0
  9. package/dist/esm/context/pip-context.js.map +1 -0
  10. package/dist/esm/core.js +8 -3
  11. package/dist/esm/core.js.map +1 -1
  12. package/dist/esm/devtools.js +45 -41
  13. package/dist/esm/devtools.js.map +1 -1
  14. package/dist/esm/styles/tokens.js +3 -0
  15. package/dist/esm/styles/tokens.js.map +1 -1
  16. package/dist/esm/styles/use-styles.d.ts +1 -1
  17. package/dist/esm/styles/use-styles.js +11 -4
  18. package/dist/esm/styles/use-styles.js.map +1 -1
  19. package/package.json +2 -7
  20. package/src/components/main-panel.tsx +7 -2
  21. package/src/components/tab-content.tsx +4 -9
  22. package/src/components/tabs.tsx +58 -20
  23. package/src/context/pip-context.tsx +178 -0
  24. package/src/core.tsx +6 -3
  25. package/src/devtools.tsx +36 -26
  26. package/src/styles/use-styles.ts +11 -3
  27. package/dist/cjs/components/content-panel.cjs +0 -32
  28. package/dist/cjs/components/content-panel.cjs.map +0 -1
  29. package/dist/cjs/components/content-panel.d.cts +0 -6
  30. package/dist/cjs/components/main-panel.cjs +0 -34
  31. package/dist/cjs/components/main-panel.cjs.map +0 -1
  32. package/dist/cjs/components/main-panel.d.cts +0 -6
  33. package/dist/cjs/components/tab-content.cjs +0 -26
  34. package/dist/cjs/components/tab-content.cjs.map +0 -1
  35. package/dist/cjs/components/tab-content.d.cts +0 -2
  36. package/dist/cjs/components/tabs.cjs +0 -47
  37. package/dist/cjs/components/tabs.cjs.map +0 -1
  38. package/dist/cjs/components/tabs.d.cts +0 -5
  39. package/dist/cjs/components/trigger.cjs +0 -31
  40. package/dist/cjs/components/trigger.cjs.map +0 -1
  41. package/dist/cjs/components/trigger.d.cts +0 -5
  42. package/dist/cjs/constants.cjs +0 -7
  43. package/dist/cjs/constants.cjs.map +0 -1
  44. package/dist/cjs/constants.d.cts +0 -2
  45. package/dist/cjs/context/devtools-context.cjs +0 -77
  46. package/dist/cjs/context/devtools-context.cjs.map +0 -1
  47. package/dist/cjs/context/devtools-context.d.cts +0 -62
  48. package/dist/cjs/context/devtools-store.cjs +0 -28
  49. package/dist/cjs/context/devtools-store.cjs.map +0 -1
  50. package/dist/cjs/context/devtools-store.d.cts +0 -54
  51. package/dist/cjs/context/use-devtools-context.cjs +0 -78
  52. package/dist/cjs/context/use-devtools-context.cjs.map +0 -1
  53. package/dist/cjs/context/use-devtools-context.d.cts +0 -35
  54. package/dist/cjs/core.cjs +0 -74
  55. package/dist/cjs/core.cjs.map +0 -1
  56. package/dist/cjs/core.d.cts +0 -39
  57. package/dist/cjs/devtools.cjs +0 -184
  58. package/dist/cjs/devtools.cjs.map +0 -1
  59. package/dist/cjs/devtools.d.cts +0 -1
  60. package/dist/cjs/hooks/use-disable-tabbing.cjs +0 -23
  61. package/dist/cjs/hooks/use-disable-tabbing.cjs.map +0 -1
  62. package/dist/cjs/hooks/use-disable-tabbing.d.cts +0 -6
  63. package/dist/cjs/index.cjs +0 -8
  64. package/dist/cjs/index.cjs.map +0 -1
  65. package/dist/cjs/index.d.cts +0 -4
  66. package/dist/cjs/styles/tokens.cjs +0 -50
  67. package/dist/cjs/styles/tokens.cjs.map +0 -1
  68. package/dist/cjs/styles/tokens.d.cts +0 -298
  69. package/dist/cjs/styles/use-styles.cjs +0 -326
  70. package/dist/cjs/styles/use-styles.cjs.map +0 -1
  71. package/dist/cjs/styles/use-styles.d.cts +0 -29
  72. package/dist/cjs/tabs/index.cjs +0 -19
  73. package/dist/cjs/tabs/index.cjs.map +0 -1
  74. package/dist/cjs/tabs/index.d.cts +0 -12
  75. package/dist/cjs/tabs/plugins-tab.cjs +0 -69
  76. package/dist/cjs/tabs/plugins-tab.cjs.map +0 -1
  77. package/dist/cjs/tabs/plugins-tab.d.cts +0 -1
  78. package/dist/cjs/tabs/settings-tab.cjs +0 -251
  79. package/dist/cjs/tabs/settings-tab.cjs.map +0 -1
  80. package/dist/cjs/tabs/settings-tab.d.cts +0 -1
  81. package/dist/cjs/utils/sanitize.cjs +0 -31
  82. package/dist/cjs/utils/sanitize.cjs.map +0 -1
  83. package/dist/cjs/utils/sanitize.d.cts +0 -3
  84. package/dist/cjs/utils/storage.cjs +0 -19
  85. package/dist/cjs/utils/storage.cjs.map +0 -1
  86. package/dist/cjs/utils/storage.d.cts +0 -5
@@ -1,19 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const web = require("solid-js/web");
4
- const settingsTab = require("./settings-tab.cjs");
5
- const pluginsTab = require("./plugins-tab.cjs");
6
- var _tmpl$ = /* @__PURE__ */ web.template(`<svg xmlns=http://www.w3.org/2000/svg width=24 height=24 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M8 6h10"></path><path d="M6 12h9"></path><path d="M11 18h7">`), _tmpl$2 = /* @__PURE__ */ web.template(`<svg xmlns=http://www.w3.org/2000/svg width=24 height=24 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M12 20a8 8 0 1 0 0-16 8 8 0 0 0 0 16Z"></path><path d="M12 14a2 2 0 1 0 0-4 2 2 0 0 0 0 4Z"></path><path d="M12 2v2"></path><path d="M12 22v-2"></path><path d="m17 20.66-1-1.73"></path><path d="M11 10.27 7 3.34"></path><path d="m20.66 17-1.73-1"></path><path d="m3.34 7 1.73 1"></path><path d="M14 12h8"></path><path d="M2 12h2"></path><path d="m20.66 7-1.73 1"></path><path d="m3.34 17 1.73-1"></path><path d="m17 3.34-1 1.73"></path><path d="m11 13.73-4 6.93">`);
7
- const tabs = [{
8
- name: "Plugins",
9
- id: "plugins",
10
- component: () => web.createComponent(pluginsTab.PluginsTab, {}),
11
- icon: _tmpl$()
12
- }, {
13
- name: "Settings",
14
- id: "settings",
15
- component: () => web.createComponent(settingsTab.SettingsTab, {}),
16
- icon: _tmpl$2()
17
- }];
18
- exports.tabs = tabs;
19
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.cjs","sources":["../../../src/tabs/index.tsx"],"sourcesContent":["import { SettingsTab } from './settings-tab'\nimport { PluginsTab } from './plugins-tab'\n\nexport const tabs = [\n {\n name: 'Plugins',\n id: 'plugins',\n component: () => <PluginsTab />,\n icon: (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n <path d=\"M8 6h10\" />\n <path d=\"M6 12h9\" />\n <path d=\"M11 18h7\" />\n </svg>\n ),\n },\n {\n name: 'Settings',\n id: 'settings',\n component: () => <SettingsTab />,\n icon: (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n <path d=\"M12 20a8 8 0 1 0 0-16 8 8 0 0 0 0 16Z\" />\n <path d=\"M12 14a2 2 0 1 0 0-4 2 2 0 0 0 0 4Z\" />\n <path d=\"M12 2v2\" />\n <path d=\"M12 22v-2\" />\n <path d=\"m17 20.66-1-1.73\" />\n <path d=\"M11 10.27 7 3.34\" />\n <path d=\"m20.66 17-1.73-1\" />\n <path d=\"m3.34 7 1.73 1\" />\n <path d=\"M14 12h8\" />\n <path d=\"M2 12h2\" />\n <path d=\"m20.66 7-1.73 1\" />\n <path d=\"m3.34 17 1.73-1\" />\n <path d=\"m17 3.34-1 1.73\" />\n <path d=\"m11 13.73-4 6.93\" />\n </svg>\n ),\n },\n] as const\n\nexport type TabName = (typeof tabs)[number]['id']\n"],"names":["tabs","name","id","component","_$createComponent","PluginsTab","icon","_tmpl$","SettingsTab","_tmpl$2"],"mappings":";;;;;;AAGO,MAAMA,OAAO,CAClB;AAAA,EACEC,MAAM;AAAA,EACNC,IAAI;AAAA,EACJC,WAAWA,MAAAC,IAAAA,gBAAOC,WAAAA,YAAU,EAAA;AAAA,EAC5BC,MAAIC,OAAAA;AAiBN,GACA;AAAA,EACEN,MAAM;AAAA,EACNC,IAAI;AAAA,EACJC,WAAWA,MAAAC,IAAAA,gBAAOI,YAAAA,aAAW,EAAA;AAAA,EAC7BF,MAAIG,QAAAA;AA4BN,CAAC;;"}
@@ -1,12 +0,0 @@
1
- export declare const tabs: readonly [{
2
- readonly name: "Plugins";
3
- readonly id: "plugins";
4
- readonly component: () => import("solid-js").JSX.Element;
5
- readonly icon: import("solid-js").JSX.Element;
6
- }, {
7
- readonly name: "Settings";
8
- readonly id: "settings";
9
- readonly component: () => import("solid-js").JSX.Element;
10
- readonly icon: import("solid-js").JSX.Element;
11
- }];
12
- export type TabName = (typeof tabs)[number]['id'];
@@ -1,69 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const web = require("solid-js/web");
4
- const solidJs = require("solid-js");
5
- const clsx = require("clsx");
6
- const useDevtoolsContext = require("../context/use-devtools-context.cjs");
7
- const useStyles = require("../styles/use-styles.cjs");
8
- const constants = require("../constants.cjs");
9
- var _tmpl$ = /* @__PURE__ */ web.template(`<div><div></div><div>`), _tmpl$2 = /* @__PURE__ */ web.template(`<div><h3>`);
10
- const PluginsTab = () => {
11
- const {
12
- plugins,
13
- activePlugin,
14
- setActivePlugin
15
- } = useDevtoolsContext.usePlugins();
16
- let activePluginRef;
17
- solidJs.createEffect(() => {
18
- const currentActivePlugin = plugins()?.find((plugin) => plugin.id === activePlugin());
19
- if (activePluginRef && currentActivePlugin) {
20
- currentActivePlugin.render(activePluginRef);
21
- }
22
- });
23
- const styles = useStyles.useStyles();
24
- return (() => {
25
- var _el$ = _tmpl$(), _el$2 = _el$.firstChild, _el$3 = _el$2.nextSibling;
26
- web.insert(_el$2, web.createComponent(solidJs.For, {
27
- get each() {
28
- return plugins();
29
- },
30
- children: (plugin) => {
31
- let pluginHeading;
32
- solidJs.createEffect(() => {
33
- if (pluginHeading) {
34
- typeof plugin.name === "string" ? pluginHeading.textContent = plugin.name : plugin.name(pluginHeading);
35
- }
36
- });
37
- return (() => {
38
- var _el$4 = _tmpl$2(), _el$5 = _el$4.firstChild;
39
- _el$4.$$click = () => setActivePlugin(plugin.id);
40
- var _ref$2 = pluginHeading;
41
- typeof _ref$2 === "function" ? web.use(_ref$2, _el$5) : pluginHeading = _el$5;
42
- web.setAttribute(_el$5, "id", constants.PLUGIN_TITLE_CONTAINER_ID);
43
- web.effect(() => web.className(_el$4, clsx(styles().pluginName, {
44
- active: activePlugin() === plugin.id
45
- })));
46
- return _el$4;
47
- })();
48
- }
49
- }));
50
- var _ref$ = activePluginRef;
51
- typeof _ref$ === "function" ? web.use(_ref$, _el$3) : activePluginRef = _el$3;
52
- web.setAttribute(_el$3, "id", constants.PLUGIN_CONTAINER_ID);
53
- web.effect((_p$) => {
54
- var _v$ = styles().pluginsTabPanel, _v$2 = styles().pluginsTabSidebar, _v$3 = styles().pluginsTabContent;
55
- _v$ !== _p$.e && web.className(_el$, _p$.e = _v$);
56
- _v$2 !== _p$.t && web.className(_el$2, _p$.t = _v$2);
57
- _v$3 !== _p$.a && web.className(_el$3, _p$.a = _v$3);
58
- return _p$;
59
- }, {
60
- e: void 0,
61
- t: void 0,
62
- a: void 0
63
- });
64
- return _el$;
65
- })();
66
- };
67
- web.delegateEvents(["click"]);
68
- exports.PluginsTab = PluginsTab;
69
- //# sourceMappingURL=plugins-tab.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"plugins-tab.cjs","sources":["../../../src/tabs/plugins-tab.tsx"],"sourcesContent":["import { For, createEffect } from 'solid-js'\nimport clsx from 'clsx'\nimport { usePlugins } from '../context/use-devtools-context'\nimport { useStyles } from '../styles/use-styles'\nimport { PLUGIN_CONTAINER_ID, PLUGIN_TITLE_CONTAINER_ID } from '../constants'\n\nexport const PluginsTab = () => {\n const { plugins, activePlugin, setActivePlugin } = usePlugins()\n let activePluginRef: HTMLDivElement | undefined\n\n createEffect(() => {\n const currentActivePlugin = plugins()?.find(\n (plugin) => plugin.id === activePlugin(),\n )\n if (activePluginRef && currentActivePlugin) {\n currentActivePlugin.render(activePluginRef)\n }\n })\n const styles = useStyles()\n return (\n <div class={styles().pluginsTabPanel}>\n <div class={styles().pluginsTabSidebar}>\n <For each={plugins()}>\n {(plugin) => {\n let pluginHeading: HTMLHeadingElement | undefined\n createEffect(() => {\n if (pluginHeading) {\n typeof plugin.name === 'string'\n ? (pluginHeading.textContent = plugin.name)\n : plugin.name(pluginHeading)\n }\n })\n return (\n <div\n onClick={() => setActivePlugin(plugin.id!)}\n class={clsx(styles().pluginName, {\n active: activePlugin() === plugin.id,\n })}\n >\n <h3 id={PLUGIN_TITLE_CONTAINER_ID} ref={pluginHeading} />\n </div>\n )\n }}\n </For>\n </div>\n <div\n id={PLUGIN_CONTAINER_ID}\n ref={activePluginRef}\n class={styles().pluginsTabContent}\n ></div>\n </div>\n )\n}\n"],"names":["PluginsTab","plugins","activePlugin","setActivePlugin","usePlugins","activePluginRef","createEffect","currentActivePlugin","find","plugin","id","render","styles","useStyles","_el$","_tmpl$","_el$2","firstChild","_el$3","nextSibling","_$insert","_$createComponent","For","each","children","pluginHeading","name","textContent","_el$4","_tmpl$2","_el$5","$$click","_ref$2","_$use","_$setAttribute","PLUGIN_TITLE_CONTAINER_ID","_$effect","_$className","clsx","pluginName","active","_ref$","PLUGIN_CONTAINER_ID","_p$","_v$","pluginsTabPanel","_v$2","pluginsTabSidebar","_v$3","pluginsTabContent","e","t","a","undefined","_$delegateEvents"],"mappings":";;;;;;;;;AAMO,MAAMA,aAAaA,MAAM;AAC9B,QAAM;AAAA,IAAEC;AAAAA,IAASC;AAAAA,IAAcC;AAAAA,EAAAA,IAAoBC,8BAAAA;AACnD,MAAIC;AAEJC,UAAAA,aAAa,MAAM;AACjB,UAAMC,sBAAsBN,WAAWO,KACpCC,YAAWA,OAAOC,OAAOR,cAC5B;AACA,QAAIG,mBAAmBE,qBAAqB;AAC1CA,0BAAoBI,OAAON,eAAe;AAAA,IAC5C;AAAA,EACF,CAAC;AACD,QAAMO,SAASC,UAAAA,UAAAA;AACf,UAAA,MAAA;AAAA,QAAAC,OAAAC,OAAAA,GAAAC,QAAAF,KAAAG,YAAAC,QAAAF,MAAAG;AAAAC,eAAAJ,OAAAK,IAAAA,gBAGOC,aAAG;AAAA,MAAA,IAACC,OAAI;AAAA,eAAEtB,QAAAA;AAAAA,MAAS;AAAA,MAAAuB,UAChBf,CAAAA,WAAW;AACX,YAAIgB;AACJnB,gBAAAA,aAAa,MAAM;AACjB,cAAImB,eAAe;AACjB,mBAAOhB,OAAOiB,SAAS,WAClBD,cAAcE,cAAclB,OAAOiB,OACpCjB,OAAOiB,KAAKD,aAAa;AAAA,UAC/B;AAAA,QACF,CAAC;AACD,gBAAA,MAAA;AAAA,cAAAG,QAAAC,QAAAA,GAAAC,QAAAF,MAAAX;AAAAW,gBAAAG,UAEa,MAAM5B,gBAAgBM,OAAOC,EAAG;AAAC,cAAAsB,SAKFP;AAAa,iBAAAO,WAAA,aAAAC,IAAAA,IAAAD,QAAAF,KAAA,IAAbL,gBAAaK;AAAAI,2BAAAJ,OAAA,MAA7CK,mCAAyB;AAAAC,cAAAA,OAAA,MAAAC,IAAAA,UAAAT,OAJ1BU,KAAK1B,OAAAA,EAAS2B,YAAY;AAAA,YAC/BC,QAAQtC,aAAAA,MAAmBO,OAAOC;AAAAA,UAAAA,CACnC,CAAC,CAAA;AAAA,iBAAAkB;AAAAA,QAAA,GAAA;AAAA,MAKR;AAAA,IAAA,CAAC,CAAA;AAAA,QAAAa,QAKEpC;AAAe,WAAAoC,UAAA,aAAAR,IAAAA,IAAAQ,OAAAvB,KAAA,IAAfb,kBAAea;AAAAgB,qBAAAhB,OAAA,MADhBwB,6BAAmB;AAAAN,QAAAA,OAAAO,CAAAA,QAAA;AAAA,UAAAC,MA1BfhC,SAASiC,iBAAeC,OACtBlC,SAASmC,mBAAiBC,OA2B7BpC,OAAAA,EAASqC;AAAiBL,cAAAD,IAAAO,KAAAb,IAAAA,UAAAvB,MAAA6B,IAAAO,IAAAN,GAAA;AAAAE,eAAAH,IAAAQ,KAAAd,IAAAA,UAAArB,OAAA2B,IAAAQ,IAAAL,IAAA;AAAAE,eAAAL,IAAAS,KAAAf,IAAAA,UAAAnB,OAAAyB,IAAAS,IAAAJ,IAAA;AAAA,aAAAL;AAAAA,IAAA,GAAA;AAAA,MAAAO,GAAAG;AAAAA,MAAAF,GAAAE;AAAAA,MAAAD,GAAAC;AAAAA,IAAAA,CAAA;AAAA,WAAAvC;AAAAA,EAAA,GAAA;AAIzC;AAACwC,IAAAA,eAAA,CAAA,OAAA,CAAA;;"}
@@ -1 +0,0 @@
1
- export declare const PluginsTab: () => import("solid-js").JSX.Element;
@@ -1,251 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const web = require("solid-js/web");
4
- const solidJs = require("solid-js");
5
- const devtoolsUi = require("@tanstack/devtools-ui");
6
- const useDevtoolsContext = require("../context/use-devtools-context.cjs");
7
- const sanitize = require("../utils/sanitize.cjs");
8
- const useStyles = require("../styles/use-styles.cjs");
9
- var _tmpl$ = /* @__PURE__ */ web.template(`<div>`), _tmpl$2 = /* @__PURE__ */ web.template(`<div><div><h3><svg xmlns=http://www.w3.org/2000/svg width=20 height=20 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M9.671 4.136a2.34 2.34 0 0 1 4.659 0 2.34 2.34 0 0 0 3.319 1.915 2.34 2.34 0 0 1 2.33 4.033 2.34 2.34 0 0 0 0 3.831 2.34 2.34 0 0 1-2.33 4.033 2.34 2.34 0 0 0-3.319 1.915 2.34 2.34 0 0 1-4.659 0 2.34 2.34 0 0 0-3.32-1.915 2.34 2.34 0 0 1-2.33-4.033 2.34 2.34 0 0 0 0-3.831A2.34 2.34 0 0 1 6.35 6.051a2.34 2.34 0 0 0 3.319-1.915"></path><circle cx=12 cy=12 r=3></circle></svg>General</h3><p>Configure general behavior of the devtools panel.</p><div></div></div><div><h3><svg xmlns=http://www.w3.org/2000/svg width=20 height=20 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M9 17H7A5 5 0 0 1 7 7h2"></path><path d="M15 7h2a5 5 0 1 1 0 10h-2"></path><line x1=8 x2=16 y1=12 y2=12></line></svg>URL Configuration</h3><p>Control when devtools are available based on URL parameters.</p><div></div></div><div><h3><svg xmlns=http://www.w3.org/2000/svg width=20 height=20 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M10 8h.01"></path><path d="M12 12h.01"></path><path d="M14 8h.01"></path><path d="M16 12h.01"></path><path d="M18 8h.01"></path><path d="M6 8h.01"></path><path d="M7 16h10"></path><path d="M8 12h.01"></path><rect width=20 height=16 x=2 y=4 rx=2></rect></svg>Keyboard</h3><p>Customize keyboard shortcuts for quick access.</p><div><div></div>Final shortcut is: </div></div><div><h3><svg xmlns=http://www.w3.org/2000/svg width=20 height=20 viewBox="0 0 24 24"fill=none stroke=currentColor stroke-width=2 stroke-linecap=round stroke-linejoin=round><path d="M20 10c0 4.993-5.539 10.193-7.399 11.799a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 16 0"></path><circle cx=12 cy=10 r=3></circle></svg>Position</h3><p>Adjust the position of the trigger button and devtools panel.</p><div><div>`);
10
- const SettingsTab = () => {
11
- const {
12
- setSettings,
13
- settings
14
- } = useDevtoolsContext.useDevtoolsSettings();
15
- const styles = useStyles.useStyles();
16
- const hotkey = solidJs.createMemo(() => settings().openHotkey);
17
- const modifiers = ["Control", "Alt", "Meta", "Shift"];
18
- const changeHotkey = (newHotkey) => () => {
19
- if (hotkey().includes(newHotkey)) {
20
- return setSettings({
21
- openHotkey: hotkey().filter((key) => key !== newHotkey)
22
- });
23
- }
24
- const existingModifiers = hotkey().filter((key) => modifiers.includes(key));
25
- const otherModifiers = hotkey().filter((key) => !modifiers.includes(key));
26
- setSettings({
27
- openHotkey: [...existingModifiers, newHotkey, ...otherModifiers]
28
- });
29
- };
30
- return (() => {
31
- var _el$ = _tmpl$2(), _el$2 = _el$.firstChild, _el$3 = _el$2.firstChild, _el$4 = _el$3.firstChild, _el$5 = _el$3.nextSibling, _el$6 = _el$5.nextSibling, _el$7 = _el$2.nextSibling, _el$8 = _el$7.firstChild, _el$9 = _el$8.firstChild, _el$0 = _el$8.nextSibling, _el$1 = _el$0.nextSibling, _el$11 = _el$7.nextSibling, _el$12 = _el$11.firstChild, _el$13 = _el$12.firstChild, _el$14 = _el$12.nextSibling, _el$15 = _el$14.nextSibling, _el$16 = _el$15.firstChild, _el$17 = _el$16.nextSibling, _el$18 = _el$11.nextSibling, _el$19 = _el$18.firstChild, _el$20 = _el$19.firstChild, _el$21 = _el$19.nextSibling, _el$22 = _el$21.nextSibling, _el$23 = _el$22.firstChild;
32
- web.insert(_el$6, web.createComponent(devtoolsUi.Checkbox, {
33
- label: "Default open",
34
- description: "Automatically open the devtools panel when the page loads",
35
- onChange: () => setSettings({
36
- defaultOpen: !settings().defaultOpen
37
- }),
38
- get checked() {
39
- return settings().defaultOpen;
40
- }
41
- }), null);
42
- web.insert(_el$6, web.createComponent(devtoolsUi.Checkbox, {
43
- label: "Hide trigger until hovered",
44
- description: "Keep the devtools trigger button hidden until you hover over its area",
45
- onChange: () => setSettings({
46
- hideUntilHover: !settings().hideUntilHover
47
- }),
48
- get checked() {
49
- return settings().hideUntilHover;
50
- }
51
- }), null);
52
- web.insert(_el$1, web.createComponent(devtoolsUi.Checkbox, {
53
- label: "Require URL Flag",
54
- description: "Only show devtools when a specific URL parameter is present",
55
- get checked() {
56
- return settings().requireUrlFlag;
57
- },
58
- onChange: (checked) => setSettings({
59
- requireUrlFlag: checked
60
- })
61
- }), null);
62
- web.insert(_el$1, web.createComponent(solidJs.Show, {
63
- get when() {
64
- return settings().requireUrlFlag;
65
- },
66
- get children() {
67
- var _el$10 = _tmpl$();
68
- web.insert(_el$10, web.createComponent(devtoolsUi.Input, {
69
- label: "URL flag",
70
- description: "Enter the URL parameter name (e.g., 'debug' for ?debug=true)",
71
- placeholder: "debug",
72
- get value() {
73
- return settings().urlFlag;
74
- },
75
- onChange: (e) => setSettings({
76
- urlFlag: e
77
- })
78
- }));
79
- web.effect(() => web.className(_el$10, styles().conditionalSetting));
80
- return _el$10;
81
- }
82
- }), null);
83
- web.insert(_el$16, web.createComponent(solidJs.Show, {
84
- keyed: true,
85
- get when() {
86
- return hotkey();
87
- },
88
- get children() {
89
- return [web.createComponent(devtoolsUi.Button, {
90
- variant: "success",
91
- get onclick() {
92
- return changeHotkey("Shift");
93
- },
94
- get outline() {
95
- return !hotkey().includes("Shift");
96
- },
97
- children: "Shift"
98
- }), web.createComponent(devtoolsUi.Button, {
99
- variant: "success",
100
- get onclick() {
101
- return changeHotkey("Alt");
102
- },
103
- get outline() {
104
- return !hotkey().includes("Alt");
105
- },
106
- children: "Alt"
107
- }), web.createComponent(devtoolsUi.Button, {
108
- variant: "success",
109
- get onclick() {
110
- return changeHotkey("Meta");
111
- },
112
- get outline() {
113
- return !hotkey().includes("Meta");
114
- },
115
- children: "Meta"
116
- }), web.createComponent(devtoolsUi.Button, {
117
- variant: "success",
118
- get onclick() {
119
- return changeHotkey("Control");
120
- },
121
- get outline() {
122
- return !hotkey().includes("Control");
123
- },
124
- children: "Control"
125
- })];
126
- }
127
- }));
128
- web.insert(_el$15, web.createComponent(devtoolsUi.Input, {
129
- label: "Hotkey to open/close devtools",
130
- description: "Use '+' to combine keys (e.g., 'a+b' or 'd'). This will be used with the enabled modifiers from above",
131
- placeholder: "a",
132
- get value() {
133
- return hotkey().filter((key) => !["Shift", "Meta", "Alt", "Ctrl"].includes(key)).join("+");
134
- },
135
- onChange: (e) => {
136
- const makeModifierArray = (key) => {
137
- if (key.length === 1) return [sanitize.uppercaseFirstLetter(key)];
138
- const modifiers3 = [];
139
- for (const character of key) {
140
- const newLetter = sanitize.uppercaseFirstLetter(character);
141
- if (!modifiers3.includes(newLetter)) modifiers3.push(newLetter);
142
- }
143
- return modifiers3;
144
- };
145
- const modifiers2 = e.split("+").flatMap((key) => makeModifierArray(key)).filter(Boolean);
146
- return setSettings({
147
- openHotkey: [...hotkey().filter((key) => ["Shift", "Meta", "Alt", "Ctrl"].includes(key)), ...modifiers2]
148
- });
149
- }
150
- }), _el$17);
151
- web.insert(_el$15, () => hotkey().join(" + "), null);
152
- web.insert(_el$23, web.createComponent(devtoolsUi.Select, {
153
- label: "Trigger Position",
154
- options: [{
155
- label: "Bottom Right",
156
- value: "bottom-right"
157
- }, {
158
- label: "Bottom Left",
159
- value: "bottom-left"
160
- }, {
161
- label: "Top Right",
162
- value: "top-right"
163
- }, {
164
- label: "Top Left",
165
- value: "top-left"
166
- }, {
167
- label: "Middle Right",
168
- value: "middle-right"
169
- }, {
170
- label: "Middle Left",
171
- value: "middle-left"
172
- }],
173
- get value() {
174
- return settings().position;
175
- },
176
- onChange: (value) => setSettings({
177
- position: value
178
- })
179
- }), null);
180
- web.insert(_el$23, web.createComponent(devtoolsUi.Select, {
181
- label: "Panel Position",
182
- get value() {
183
- return settings().panelLocation;
184
- },
185
- options: [{
186
- label: "Top",
187
- value: "top"
188
- }, {
189
- label: "Bottom",
190
- value: "bottom"
191
- }],
192
- onChange: (value) => setSettings({
193
- panelLocation: value
194
- })
195
- }), null);
196
- web.effect((_p$) => {
197
- var _v$ = styles().settingsContainer, _v$2 = styles().settingsSection, _v$3 = styles().sectionTitle, _v$4 = styles().sectionIcon, _v$5 = styles().sectionDescription, _v$6 = styles().settingsGroup, _v$7 = styles().settingsSection, _v$8 = styles().sectionTitle, _v$9 = styles().sectionIcon, _v$0 = styles().sectionDescription, _v$1 = styles().settingsGroup, _v$10 = styles().settingsSection, _v$11 = styles().sectionTitle, _v$12 = styles().sectionIcon, _v$13 = styles().sectionDescription, _v$14 = styles().settingsGroup, _v$15 = styles().settingsModifiers, _v$16 = styles().settingsSection, _v$17 = styles().sectionTitle, _v$18 = styles().sectionIcon, _v$19 = styles().sectionDescription, _v$20 = styles().settingsGroup, _v$21 = styles().settingRow;
198
- _v$ !== _p$.e && web.className(_el$, _p$.e = _v$);
199
- _v$2 !== _p$.t && web.className(_el$2, _p$.t = _v$2);
200
- _v$3 !== _p$.a && web.className(_el$3, _p$.a = _v$3);
201
- _v$4 !== _p$.o && web.setAttribute(_el$4, "class", _p$.o = _v$4);
202
- _v$5 !== _p$.i && web.className(_el$5, _p$.i = _v$5);
203
- _v$6 !== _p$.n && web.className(_el$6, _p$.n = _v$6);
204
- _v$7 !== _p$.s && web.className(_el$7, _p$.s = _v$7);
205
- _v$8 !== _p$.h && web.className(_el$8, _p$.h = _v$8);
206
- _v$9 !== _p$.r && web.setAttribute(_el$9, "class", _p$.r = _v$9);
207
- _v$0 !== _p$.d && web.className(_el$0, _p$.d = _v$0);
208
- _v$1 !== _p$.l && web.className(_el$1, _p$.l = _v$1);
209
- _v$10 !== _p$.u && web.className(_el$11, _p$.u = _v$10);
210
- _v$11 !== _p$.c && web.className(_el$12, _p$.c = _v$11);
211
- _v$12 !== _p$.w && web.setAttribute(_el$13, "class", _p$.w = _v$12);
212
- _v$13 !== _p$.m && web.className(_el$14, _p$.m = _v$13);
213
- _v$14 !== _p$.f && web.className(_el$15, _p$.f = _v$14);
214
- _v$15 !== _p$.y && web.className(_el$16, _p$.y = _v$15);
215
- _v$16 !== _p$.g && web.className(_el$18, _p$.g = _v$16);
216
- _v$17 !== _p$.p && web.className(_el$19, _p$.p = _v$17);
217
- _v$18 !== _p$.b && web.setAttribute(_el$20, "class", _p$.b = _v$18);
218
- _v$19 !== _p$.T && web.className(_el$21, _p$.T = _v$19);
219
- _v$20 !== _p$.A && web.className(_el$22, _p$.A = _v$20);
220
- _v$21 !== _p$.O && web.className(_el$23, _p$.O = _v$21);
221
- return _p$;
222
- }, {
223
- e: void 0,
224
- t: void 0,
225
- a: void 0,
226
- o: void 0,
227
- i: void 0,
228
- n: void 0,
229
- s: void 0,
230
- h: void 0,
231
- r: void 0,
232
- d: void 0,
233
- l: void 0,
234
- u: void 0,
235
- c: void 0,
236
- w: void 0,
237
- m: void 0,
238
- f: void 0,
239
- y: void 0,
240
- g: void 0,
241
- p: void 0,
242
- b: void 0,
243
- T: void 0,
244
- A: void 0,
245
- O: void 0
246
- });
247
- return _el$;
248
- })();
249
- };
250
- exports.SettingsTab = SettingsTab;
251
- //# sourceMappingURL=settings-tab.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"settings-tab.cjs","sources":["../../../src/tabs/settings-tab.tsx"],"sourcesContent":["import { Show, createMemo } from 'solid-js'\nimport { Button, Checkbox, Input, Select } from '@tanstack/devtools-ui'\nimport { useDevtoolsSettings } from '../context/use-devtools-context'\nimport { uppercaseFirstLetter } from '../utils/sanitize'\nimport { useStyles } from '../styles/use-styles'\nimport type { ModifierKey } from '@solid-primitives/keyboard'\n\nexport const SettingsTab = () => {\n const { setSettings, settings } = useDevtoolsSettings()\n const styles = useStyles()\n const hotkey = createMemo(() => settings().openHotkey)\n const modifiers: Array<ModifierKey> = ['Control', 'Alt', 'Meta', 'Shift']\n const changeHotkey = (newHotkey: ModifierKey) => () => {\n if (hotkey().includes(newHotkey)) {\n return setSettings({\n openHotkey: hotkey().filter((key) => key !== newHotkey),\n })\n }\n const existingModifiers = hotkey().filter((key) =>\n modifiers.includes(key as any),\n )\n const otherModifiers = hotkey().filter(\n (key) => !modifiers.includes(key as any),\n )\n setSettings({\n openHotkey: [...existingModifiers, newHotkey, ...otherModifiers],\n })\n }\n return (\n <div class={styles().settingsContainer}>\n {/* General Settings */}\n <div class={styles().settingsSection}>\n <h3 class={styles().sectionTitle}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n class={styles().sectionIcon}\n >\n <path d=\"M9.671 4.136a2.34 2.34 0 0 1 4.659 0 2.34 2.34 0 0 0 3.319 1.915 2.34 2.34 0 0 1 2.33 4.033 2.34 2.34 0 0 0 0 3.831 2.34 2.34 0 0 1-2.33 4.033 2.34 2.34 0 0 0-3.319 1.915 2.34 2.34 0 0 1-4.659 0 2.34 2.34 0 0 0-3.32-1.915 2.34 2.34 0 0 1-2.33-4.033 2.34 2.34 0 0 0 0-3.831A2.34 2.34 0 0 1 6.35 6.051a2.34 2.34 0 0 0 3.319-1.915\" />\n <circle cx=\"12\" cy=\"12\" r=\"3\" />\n </svg>\n General\n </h3>\n <p class={styles().sectionDescription}>\n Configure general behavior of the devtools panel.\n </p>\n <div class={styles().settingsGroup}>\n <Checkbox\n label=\"Default open\"\n description=\"Automatically open the devtools panel when the page loads\"\n onChange={() =>\n setSettings({ defaultOpen: !settings().defaultOpen })\n }\n checked={settings().defaultOpen}\n />\n <Checkbox\n label=\"Hide trigger until hovered\"\n description=\"Keep the devtools trigger button hidden until you hover over its area\"\n onChange={() =>\n setSettings({ hideUntilHover: !settings().hideUntilHover })\n }\n checked={settings().hideUntilHover}\n />\n </div>\n </div>\n\n {/* URL Flag Settings */}\n <div class={styles().settingsSection}>\n <h3 class={styles().sectionTitle}>\n <svg\n class={styles().sectionIcon}\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n <path d=\"M9 17H7A5 5 0 0 1 7 7h2\" />\n <path d=\"M15 7h2a5 5 0 1 1 0 10h-2\" />\n <line x1=\"8\" x2=\"16\" y1=\"12\" y2=\"12\" />\n </svg>\n URL Configuration\n </h3>\n <p class={styles().sectionDescription}>\n Control when devtools are available based on URL parameters.\n </p>\n <div class={styles().settingsGroup}>\n <Checkbox\n label=\"Require URL Flag\"\n description=\"Only show devtools when a specific URL parameter is present\"\n checked={settings().requireUrlFlag}\n onChange={(checked) =>\n setSettings({\n requireUrlFlag: checked,\n })\n }\n />\n <Show when={settings().requireUrlFlag}>\n <div class={styles().conditionalSetting}>\n <Input\n label=\"URL flag\"\n description=\"Enter the URL parameter name (e.g., 'debug' for ?debug=true)\"\n placeholder=\"debug\"\n value={settings().urlFlag}\n onChange={(e) =>\n setSettings({\n urlFlag: e,\n })\n }\n />\n </div>\n </Show>\n </div>\n </div>\n\n {/* Keyboard Settings */}\n <div class={styles().settingsSection}>\n <h3 class={styles().sectionTitle}>\n <svg\n class={styles().sectionIcon}\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n <path d=\"M10 8h.01\" />\n <path d=\"M12 12h.01\" />\n <path d=\"M14 8h.01\" />\n <path d=\"M16 12h.01\" />\n <path d=\"M18 8h.01\" />\n <path d=\"M6 8h.01\" />\n <path d=\"M7 16h10\" />\n <path d=\"M8 12h.01\" />\n <rect width=\"20\" height=\"16\" x=\"2\" y=\"4\" rx=\"2\" />\n </svg>\n Keyboard\n </h3>\n <p class={styles().sectionDescription}>\n Customize keyboard shortcuts for quick access.\n </p>\n <div class={styles().settingsGroup}>\n <div class={styles().settingsModifiers}>\n <Show keyed when={hotkey()}>\n <Button\n variant=\"success\"\n onclick={changeHotkey('Shift')}\n outline={!hotkey().includes('Shift')}\n >\n Shift\n </Button>\n <Button\n variant=\"success\"\n onclick={changeHotkey('Alt')}\n outline={!hotkey().includes('Alt')}\n >\n Alt\n </Button>\n <Button\n variant=\"success\"\n onclick={changeHotkey('Meta')}\n outline={!hotkey().includes('Meta')}\n >\n Meta\n </Button>\n <Button\n variant=\"success\"\n onclick={changeHotkey('Control')}\n outline={!hotkey().includes('Control')}\n >\n Control\n </Button>\n </Show>\n </div>\n <Input\n label=\"Hotkey to open/close devtools\"\n description=\"Use '+' to combine keys (e.g., 'a+b' or 'd'). This will be used with the enabled modifiers from above\"\n placeholder=\"a\"\n value={hotkey()\n .filter((key) => !['Shift', 'Meta', 'Alt', 'Ctrl'].includes(key))\n .join('+')}\n onChange={(e) => {\n const makeModifierArray = (key: string) => {\n if (key.length === 1) return [uppercaseFirstLetter(key)]\n const modifiers: Array<string> = []\n for (const character of key) {\n const newLetter = uppercaseFirstLetter(character)\n if (!modifiers.includes(newLetter)) modifiers.push(newLetter)\n }\n return modifiers\n }\n const modifiers = e\n .split('+')\n .flatMap((key) => makeModifierArray(key))\n .filter(Boolean)\n return setSettings({\n openHotkey: [\n ...hotkey().filter((key) =>\n ['Shift', 'Meta', 'Alt', 'Ctrl'].includes(key),\n ),\n ...modifiers,\n ],\n })\n }}\n />\n Final shortcut is: {hotkey().join(' + ')}\n </div>\n </div>\n\n {/* Position Settings */}\n <div class={styles().settingsSection}>\n <h3 class={styles().sectionTitle}>\n <svg\n class={styles().sectionIcon}\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"20\"\n height=\"20\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n >\n <path d=\"M20 10c0 4.993-5.539 10.193-7.399 11.799a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 16 0\" />\n <circle cx=\"12\" cy=\"10\" r=\"3\" />\n </svg>\n Position\n </h3>\n <p class={styles().sectionDescription}>\n Adjust the position of the trigger button and devtools panel.\n </p>\n <div class={styles().settingsGroup}>\n <div class={styles().settingRow}>\n <Select\n label=\"Trigger Position\"\n options={[\n { label: 'Bottom Right', value: 'bottom-right' },\n { label: 'Bottom Left', value: 'bottom-left' },\n { label: 'Top Right', value: 'top-right' },\n { label: 'Top Left', value: 'top-left' },\n { label: 'Middle Right', value: 'middle-right' },\n { label: 'Middle Left', value: 'middle-left' },\n ]}\n value={settings().position}\n onChange={(value) =>\n setSettings({\n position: value,\n })\n }\n />\n <Select\n label=\"Panel Position\"\n value={settings().panelLocation}\n options={[\n { label: 'Top', value: 'top' },\n { label: 'Bottom', value: 'bottom' },\n ]}\n onChange={(value) =>\n setSettings({\n panelLocation: value,\n })\n }\n />\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"names":["SettingsTab","setSettings","settings","useDevtoolsSettings","styles","useStyles","hotkey","createMemo","openHotkey","modifiers","changeHotkey","newHotkey","includes","filter","key","existingModifiers","otherModifiers","_el$","_tmpl$2","_el$2","firstChild","_el$3","_el$4","_el$5","nextSibling","_el$6","_el$7","_el$8","_el$9","_el$0","_el$1","_el$11","_el$12","_el$13","_el$14","_el$15","_el$16","_el$17","_el$18","_el$19","_el$20","_el$21","_el$22","_el$23","_$insert","_$createComponent","Checkbox","label","description","onChange","defaultOpen","checked","hideUntilHover","requireUrlFlag","Show","when","children","_el$10","_tmpl$","Input","placeholder","value","urlFlag","e","_$effect","_$className","conditionalSetting","keyed","Button","variant","onclick","outline","join","makeModifierArray","length","uppercaseFirstLetter","character","newLetter","push","split","flatMap","Boolean","Select","options","position","panelLocation","_p$","_v$","settingsContainer","_v$2","settingsSection","_v$3","sectionTitle","_v$4","sectionIcon","_v$5","sectionDescription","_v$6","settingsGroup","_v$7","_v$8","_v$9","_v$0","_v$1","_v$10","_v$11","_v$12","_v$13","_v$14","_v$15","settingsModifiers","_v$16","_v$17","_v$18","_v$19","_v$20","_v$21","settingRow","t","a","o","_$setAttribute","i","n","s","h","r","d","l","u","c","w","m","f","y","g","p","b","T","A","O","undefined"],"mappings":"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"}
@@ -1 +0,0 @@
1
- export declare const SettingsTab: () => import("solid-js").JSX.Element;
@@ -1,31 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const tryParseJson = (json) => {
4
- if (!json) return void 0;
5
- try {
6
- return JSON.parse(json);
7
- } catch (_e) {
8
- return void 0;
9
- }
10
- };
11
- const uppercaseFirstLetter = (value) => value.charAt(0).toUpperCase() + value.slice(1);
12
- const getAllPermutations = (arr) => {
13
- const res = [];
14
- function permutate(arr2, start) {
15
- if (start === arr2.length - 1) {
16
- res.push([...arr2]);
17
- return;
18
- }
19
- for (let i = start; i < arr2.length; i++) {
20
- [arr2[start], arr2[i]] = [arr2[i], arr2[start]];
21
- permutate(arr2, start + 1);
22
- [arr2[start], arr2[i]] = [arr2[i], arr2[start]];
23
- }
24
- }
25
- permutate(arr, 0);
26
- return res;
27
- };
28
- exports.getAllPermutations = getAllPermutations;
29
- exports.tryParseJson = tryParseJson;
30
- exports.uppercaseFirstLetter = uppercaseFirstLetter;
31
- //# sourceMappingURL=sanitize.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sanitize.cjs","sources":["../../../src/utils/sanitize.ts"],"sourcesContent":["export const tryParseJson = <T>(json: string | null): T | undefined => {\n if (!json) return undefined\n try {\n return JSON.parse(json)\n } catch (_e) {\n return undefined\n }\n}\n\nexport const uppercaseFirstLetter = (value: string) =>\n value.charAt(0).toUpperCase() + value.slice(1)\n\nexport const getAllPermutations = <T extends any>(arr: Array<T>) => {\n const res: Array<Array<T>> = []\n\n function permutate(arr: Array<T>, start: number) {\n if (start === arr.length - 1) {\n res.push([...arr] as any)\n return\n }\n for (let i = start; i < arr.length; i++) {\n ;[arr[start], arr[i]] = [arr[i]!, arr[start]!]\n permutate(arr, start + 1)\n ;[arr[start], arr[i]] = [arr[i]!, arr[start]]\n }\n }\n permutate(arr, 0)\n\n return res\n}\n"],"names":["arr"],"mappings":";;AAAO,MAAM,eAAe,CAAI,SAAuC;AACrE,MAAI,CAAC,KAAM,QAAO;AAClB,MAAI;AACF,WAAO,KAAK,MAAM,IAAI;AAAA,EACxB,SAAS,IAAI;AACX,WAAO;AAAA,EACT;AACF;AAEO,MAAM,uBAAuB,CAAC,UACnC,MAAM,OAAO,CAAC,EAAE,YAAA,IAAgB,MAAM,MAAM,CAAC;AAExC,MAAM,qBAAqB,CAAgB,QAAkB;AAClE,QAAM,MAAuB,CAAA;AAE7B,WAAS,UAAUA,MAAe,OAAe;AAC/C,QAAI,UAAUA,KAAI,SAAS,GAAG;AAC5B,UAAI,KAAK,CAAC,GAAGA,IAAG,CAAQ;AACxB;AAAA,IACF;AACA,aAAS,IAAI,OAAO,IAAIA,KAAI,QAAQ,KAAK;AACtC,OAACA,KAAI,KAAK,GAAGA,KAAI,CAAC,CAAC,IAAI,CAACA,KAAI,CAAC,GAAIA,KAAI,KAAK,CAAE;AAC7C,gBAAUA,MAAK,QAAQ,CAAC;AACvB,OAACA,KAAI,KAAK,GAAGA,KAAI,CAAC,CAAC,IAAI,CAACA,KAAI,CAAC,GAAIA,KAAI,KAAK,CAAC;AAAA,IAC9C;AAAA,EACF;AACA,YAAU,KAAK,CAAC;AAEhB,SAAO;AACT;;;;"}
@@ -1,3 +0,0 @@
1
- export declare const tryParseJson: <T>(json: string | null) => T | undefined;
2
- export declare const uppercaseFirstLetter: (value: string) => string;
3
- export declare const getAllPermutations: <T extends any>(arr: Array<T>) => T[][];
@@ -1,19 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const getStorageItem = (key) => localStorage.getItem(key);
4
- const setStorageItem = (key, value) => {
5
- try {
6
- localStorage.setItem(key, value);
7
- } catch (_e) {
8
- return;
9
- }
10
- };
11
- const TANSTACK_DEVTOOLS = "tanstack_devtools";
12
- const TANSTACK_DEVTOOLS_STATE = "tanstack_devtools_state";
13
- const TANSTACK_DEVTOOLS_SETTINGS = "tanstack_devtools_settings";
14
- exports.TANSTACK_DEVTOOLS = TANSTACK_DEVTOOLS;
15
- exports.TANSTACK_DEVTOOLS_SETTINGS = TANSTACK_DEVTOOLS_SETTINGS;
16
- exports.TANSTACK_DEVTOOLS_STATE = TANSTACK_DEVTOOLS_STATE;
17
- exports.getStorageItem = getStorageItem;
18
- exports.setStorageItem = setStorageItem;
19
- //# sourceMappingURL=storage.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"storage.cjs","sources":["../../../src/utils/storage.ts"],"sourcesContent":["export const getStorageItem = (key: string) => localStorage.getItem(key)\nexport const setStorageItem = (key: string, value: string) => {\n try {\n localStorage.setItem(key, value)\n } catch (_e) {\n return\n }\n}\n\nexport const TANSTACK_DEVTOOLS = 'tanstack_devtools'\nexport const TANSTACK_DEVTOOLS_STATE = 'tanstack_devtools_state'\nexport const TANSTACK_DEVTOOLS_SETTINGS = 'tanstack_devtools_settings'\n"],"names":[],"mappings":";;AAAO,MAAM,iBAAiB,CAAC,QAAgB,aAAa,QAAQ,GAAG;AAChE,MAAM,iBAAiB,CAAC,KAAa,UAAkB;AAC5D,MAAI;AACF,iBAAa,QAAQ,KAAK,KAAK;AAAA,EACjC,SAAS,IAAI;AACX;AAAA,EACF;AACF;AAEO,MAAM,oBAAoB;AAC1B,MAAM,0BAA0B;AAChC,MAAM,6BAA6B;;;;;;"}
@@ -1,5 +0,0 @@
1
- export declare const getStorageItem: (key: string) => string | null;
2
- export declare const setStorageItem: (key: string, value: string) => void;
3
- export declare const TANSTACK_DEVTOOLS = "tanstack_devtools";
4
- export declare const TANSTACK_DEVTOOLS_STATE = "tanstack_devtools_state";
5
- export declare const TANSTACK_DEVTOOLS_SETTINGS = "tanstack_devtools_settings";