@kozou/svelte-ui 1.1.1 → 1.3.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 (91) hide show
  1. package/build/client/_app/immutable/chunks/{Cn0w88Fq.js → BLwQsTD2.js} +1 -1
  2. package/build/client/_app/immutable/chunks/BLwQsTD2.js.br +0 -0
  3. package/build/client/_app/immutable/chunks/BLwQsTD2.js.gz +0 -0
  4. package/build/client/_app/immutable/chunks/{DPra5YQV.js → DY0oakY5.js} +1 -1
  5. package/build/client/_app/immutable/chunks/DY0oakY5.js.br +0 -0
  6. package/build/client/_app/immutable/chunks/DY0oakY5.js.gz +0 -0
  7. package/build/client/_app/immutable/chunks/rPPoD7Sp.js +4 -0
  8. package/build/client/_app/immutable/chunks/rPPoD7Sp.js.br +0 -0
  9. package/build/client/_app/immutable/chunks/rPPoD7Sp.js.gz +0 -0
  10. package/build/client/_app/immutable/entry/{app.DHE9drsq.js → app.G2Y8IfhN.js} +2 -2
  11. package/build/client/_app/immutable/entry/app.G2Y8IfhN.js.br +0 -0
  12. package/build/client/_app/immutable/entry/app.G2Y8IfhN.js.gz +0 -0
  13. package/build/client/_app/immutable/entry/start.sPBaDl_M.js +1 -0
  14. package/build/client/_app/immutable/entry/start.sPBaDl_M.js.br +1 -0
  15. package/build/client/_app/immutable/entry/start.sPBaDl_M.js.gz +0 -0
  16. package/build/client/_app/immutable/nodes/{1.D560IYiX.js → 1.D09foNRb.js} +1 -1
  17. package/build/client/_app/immutable/nodes/1.D09foNRb.js.br +2 -0
  18. package/build/client/_app/immutable/nodes/1.D09foNRb.js.gz +0 -0
  19. package/build/client/_app/immutable/nodes/4.5H5WIc-o.js +1 -0
  20. package/build/client/_app/immutable/nodes/4.5H5WIc-o.js.br +0 -0
  21. package/build/client/_app/immutable/nodes/4.5H5WIc-o.js.gz +0 -0
  22. package/build/client/_app/immutable/nodes/{5.DReWNUeS.js → 5.BR2iBXwV.js} +1 -1
  23. package/build/client/_app/immutable/nodes/5.BR2iBXwV.js.br +0 -0
  24. package/build/client/_app/immutable/nodes/5.BR2iBXwV.js.gz +0 -0
  25. package/build/client/_app/immutable/nodes/{6.k15tkojQ.js → 6.ChubZePh.js} +1 -1
  26. package/build/client/_app/immutable/nodes/6.ChubZePh.js.br +0 -0
  27. package/build/client/_app/immutable/nodes/6.ChubZePh.js.gz +0 -0
  28. package/build/client/_app/version.json +1 -1
  29. package/build/client/_app/version.json.br +0 -0
  30. package/build/client/_app/version.json.gz +0 -0
  31. package/build/server/chunks/{1-9vEmRESU.js → 1-BvxsIwwy.js} +3 -3
  32. package/build/server/chunks/{1-9vEmRESU.js.map → 1-BvxsIwwy.js.map} +1 -1
  33. package/build/server/chunks/{4-B5b-ipUm.js → 4-1chJCfPL.js} +5 -3
  34. package/build/server/chunks/4-1chJCfPL.js.map +1 -0
  35. package/build/server/chunks/{5-CsUNrHuc.js → 5-DUCxshKE.js} +13 -11
  36. package/build/server/chunks/5-DUCxshKE.js.map +1 -0
  37. package/build/server/chunks/{6-DDoMrGFt.js → 6-Dh7Tg-XB.js} +13 -11
  38. package/build/server/chunks/6-Dh7Tg-XB.js.map +1 -0
  39. package/build/server/chunks/{_page.svelte-DZ2Ayw0S.js → _page.svelte-CBUJNhG1.js} +6 -6
  40. package/build/server/chunks/{_page.svelte-DZ2Ayw0S.js.map → _page.svelte-CBUJNhG1.js.map} +1 -1
  41. package/build/server/chunks/{_page.svelte-CDGnOeZp.js → _page.svelte-DI_FY3zW.js} +6 -6
  42. package/build/server/chunks/{_page.svelte-CDGnOeZp.js.map → _page.svelte-DI_FY3zW.js.map} +1 -1
  43. package/build/server/chunks/{_page.svelte-BEtFIV7C.js → _page.svelte-DaJwoT9F.js} +9 -4
  44. package/build/server/chunks/_page.svelte-DaJwoT9F.js.map +1 -0
  45. package/build/server/chunks/{app-DST8OmzT.js → app-MIcRQ3KA.js} +2 -2
  46. package/build/server/chunks/{app-DST8OmzT.js.map → app-MIcRQ3KA.js.map} +1 -1
  47. package/build/server/chunks/{client-DLR5dxwU.js → client-C004jkBy.js} +3 -3
  48. package/build/server/chunks/{client-DLR5dxwU.js.map → client-C004jkBy.js.map} +1 -1
  49. package/build/server/chunks/{composite-form-BHZcuFIS.js → composite-form-_tg7iknp.js} +40 -27
  50. package/build/server/chunks/{composite-form-BHZcuFIS.js.map → composite-form-_tg7iknp.js.map} +1 -1
  51. package/build/server/chunks/{error.svelte-B3vg3Q2F.js → error.svelte-u8Vsq8vF.js} +6 -6
  52. package/build/server/chunks/{error.svelte-B3vg3Q2F.js.map → error.svelte-u8Vsq8vF.js.map} +1 -1
  53. package/build/server/chunks/{hooks.server-VuiVxiIQ.js → hooks.server-DtCXcOVD.js} +148 -7
  54. package/build/server/chunks/hooks.server-DtCXcOVD.js.map +1 -0
  55. package/build/server/chunks/index-5kYmxIr9.js.map +1 -1
  56. package/build/server/chunks/index-DBqjc0Yf.js.map +1 -1
  57. package/build/server/chunks/{internal-BkKkeKsj.js → internal-fxcuSPWe.js} +13 -13
  58. package/build/server/chunks/{internal-BkKkeKsj.js.map → internal-fxcuSPWe.js.map} +1 -1
  59. package/build/server/chunks/{widget-registry-hWgMHMd3.js → widget-registry-BcgMXjkA.js} +2 -2
  60. package/build/server/chunks/{widget-registry-hWgMHMd3.js.map → widget-registry-BcgMXjkA.js.map} +1 -1
  61. package/build/server/index.js +31 -31
  62. package/build/server/index.js.map +1 -1
  63. package/build/server/manifest.js +5 -5
  64. package/build/server/manifest.js.map +1 -1
  65. package/package.json +4 -4
  66. package/build/client/_app/immutable/chunks/B1d2TdTR.js +0 -4
  67. package/build/client/_app/immutable/chunks/B1d2TdTR.js.br +0 -0
  68. package/build/client/_app/immutable/chunks/B1d2TdTR.js.gz +0 -0
  69. package/build/client/_app/immutable/chunks/Cn0w88Fq.js.br +0 -0
  70. package/build/client/_app/immutable/chunks/Cn0w88Fq.js.gz +0 -0
  71. package/build/client/_app/immutable/chunks/DPra5YQV.js.br +0 -0
  72. package/build/client/_app/immutable/chunks/DPra5YQV.js.gz +0 -0
  73. package/build/client/_app/immutable/entry/app.DHE9drsq.js.br +0 -0
  74. package/build/client/_app/immutable/entry/app.DHE9drsq.js.gz +0 -0
  75. package/build/client/_app/immutable/entry/start.BzGMfeBV.js +0 -1
  76. package/build/client/_app/immutable/entry/start.BzGMfeBV.js.br +0 -0
  77. package/build/client/_app/immutable/entry/start.BzGMfeBV.js.gz +0 -0
  78. package/build/client/_app/immutable/nodes/1.D560IYiX.js.br +0 -0
  79. package/build/client/_app/immutable/nodes/1.D560IYiX.js.gz +0 -0
  80. package/build/client/_app/immutable/nodes/4.B99LqPAe.js +0 -1
  81. package/build/client/_app/immutable/nodes/4.B99LqPAe.js.br +0 -0
  82. package/build/client/_app/immutable/nodes/4.B99LqPAe.js.gz +0 -0
  83. package/build/client/_app/immutable/nodes/5.DReWNUeS.js.br +0 -0
  84. package/build/client/_app/immutable/nodes/5.DReWNUeS.js.gz +0 -0
  85. package/build/client/_app/immutable/nodes/6.k15tkojQ.js.br +0 -0
  86. package/build/client/_app/immutable/nodes/6.k15tkojQ.js.gz +0 -0
  87. package/build/server/chunks/4-B5b-ipUm.js.map +0 -1
  88. package/build/server/chunks/5-CsUNrHuc.js.map +0 -1
  89. package/build/server/chunks/6-DDoMrGFt.js.map +0 -1
  90. package/build/server/chunks/_page.svelte-BEtFIV7C.js.map +0 -1
  91. package/build/server/chunks/hooks.server-VuiVxiIQ.js.map +0 -1
@@ -1,17 +1,17 @@
1
1
  import 'node:module';
2
2
  import { q as escape_html, x as getContext } from './dev-yFiAtg5l.js';
3
- import './client-DLR5dxwU.js';
3
+ import './client-C004jkBy.js';
4
4
  import 'clsx';
5
- import './internal-BkKkeKsj.js';
5
+ import './internal-fxcuSPWe.js';
6
6
  import './index-DBqjc0Yf.js';
7
7
 
8
8
  //#endregion
9
- //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/app/state/server.js
9
+ //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/app/state/server.js
10
10
  function context() {
11
11
  return getContext("__request__");
12
12
  }
13
13
  //#endregion
14
- //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/app/state/index.js
14
+ //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/app/state/index.js
15
15
  /**
16
16
  * A read-only reactive object with information about the current page, serving several use cases:
17
17
  * - retrieving the combined `data` of all pages/layouts anywhere in your component tree (also see [loading data](https://svelte.dev/docs/kit/load))
@@ -57,7 +57,7 @@ var page = {
57
57
  return context().page.status;
58
58
  }};
59
59
  //#endregion
60
- //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/components/svelte-5/error.svelte
60
+ //#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/components/svelte-5/error.svelte
61
61
  function Error$1($$renderer, $$props) {
62
62
  $$renderer.component(($$renderer) => {
63
63
  $$renderer.push(`<h1>${escape_html(page.status)}</h1> <p>${escape_html(page.error?.message)}</p>`);
@@ -65,4 +65,4 @@ function Error$1($$renderer, $$props) {
65
65
  }
66
66
 
67
67
  export { Error$1 as default };
68
- //# sourceMappingURL=error.svelte-B3vg3Q2F.js.map
68
+ //# sourceMappingURL=error.svelte-u8Vsq8vF.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"error.svelte-B3vg3Q2F.js","sources":["../../../.svelte-kit/adapter-node/entries/fallbacks/error.svelte.js"],"sourcesContent":["import \"../../chunks/environment.js\";\nimport { H as escape_html, tt as getContext } from \"../../chunks/dev.js\";\nimport { c as navigating$1, s as stores } from \"../../chunks/client.js\";\nObject.defineProperty({\n\tget from() {\n\t\treturn navigating$1.current ? navigating$1.current.from : null;\n\t},\n\tget to() {\n\t\treturn navigating$1.current ? navigating$1.current.to : null;\n\t},\n\tget type() {\n\t\treturn navigating$1.current ? navigating$1.current.type : null;\n\t},\n\tget willUnload() {\n\t\treturn navigating$1.current ? navigating$1.current.willUnload : null;\n\t},\n\tget delta() {\n\t\treturn navigating$1.current ? navigating$1.current.delta : null;\n\t},\n\tget complete() {\n\t\treturn navigating$1.current ? navigating$1.current.complete : null;\n\t}\n}, \"current\", { get() {\n\tthrow new Error(\"Replace navigating.current.<prop> with navigating.<prop>\");\n} });\nstores.updated.check;\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/app/state/server.js\nfunction context() {\n\treturn getContext(\"__request__\");\n}\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/app/state/index.js\n/**\n* A read-only reactive object with information about the current page, serving several use cases:\n* - retrieving the combined `data` of all pages/layouts anywhere in your component tree (also see [loading data](https://svelte.dev/docs/kit/load))\n* - retrieving the current value of the `form` prop anywhere in your component tree (also see [form actions](https://svelte.dev/docs/kit/form-actions))\n* - retrieving the page state that was set through `goto`, `pushState` or `replaceState` (also see [goto](https://svelte.dev/docs/kit/$app-navigation#goto) and [shallow routing](https://svelte.dev/docs/kit/shallow-routing))\n* - retrieving metadata such as the URL you're on, the current route and its parameters, and whether or not there was an error\n*\n* ```svelte\n* <!--- file: +layout.svelte --->\n* <script>\n* \timport { page } from '$app/state';\n* <\\/script>\n*\n* <p>Currently at {page.url.pathname}</p>\n*\n* {#if page.error}\n* \t<span class=\"red\">Problem detected</span>\n* {:else}\n* \t<span class=\"small\">All systems operational</span>\n* {/if}\n* ```\n*\n* Changes to `page` are available exclusively with runes. (The legacy reactivity syntax will not reflect any changes)\n*\n* ```svelte\n* <!--- file: +page.svelte --->\n* <script>\n* \timport { page } from '$app/state';\n* \tconst id = $derived(page.params.id); // This will correctly update id for usage on this page\n* \t$: badId = page.params.id; // Do not use; will never update after initial load\n* <\\/script>\n* ```\n*\n* On the server, values can only be read during rendering (in other words _not_ in e.g. `load` functions). In the browser, the values can be read at any time.\n*\n* @type {import('@sveltejs/kit').Page}\n*/\nvar page = {\n\tget data() {\n\t\treturn context().page.data;\n\t},\n\tget error() {\n\t\treturn context().page.error;\n\t},\n\tget form() {\n\t\treturn context().page.form;\n\t},\n\tget params() {\n\t\treturn context().page.params;\n\t},\n\tget route() {\n\t\treturn context().page.route;\n\t},\n\tget state() {\n\t\treturn context().page.state;\n\t},\n\tget status() {\n\t\treturn context().page.status;\n\t},\n\tget url() {\n\t\treturn context().page.url;\n\t}\n};\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_692b2477997906027053802989c8d7b8/node_modules/@sveltejs/kit/src/runtime/components/svelte-5/error.svelte\nfunction Error$1($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t$$renderer.push(`<h1>${escape_html(page.status)}</h1> <p>${escape_html(page.error?.message)}</p>`);\n\t});\n}\n//#endregion\nexport { Error$1 as default };\n"],"names":[],"mappings":";;;;;;;AA0BA;AACA;AACA,SAAS,OAAO,GAAG;AACnB,CAAC,OAAO,UAAU,CAAC,aAAa,CAAC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,IAAI,GAAG;AACX,CAGC,IAAI,KAAK,GAAG;AACb,EAAE,OAAO,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK;AAC7B,CAAC,CAAC;AACF,CAYC,IAAI,MAAM,GAAG;AACd,EAAE,OAAO,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM;AAC9B,CAAC,CAID,CAAC;AACD;AACA;AACA,SAAS,OAAO,CAAC,UAAU,EAAE,OAAO,EAAE;AACtC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,UAAU,KAAK;AACtC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;AACpG,CAAC,CAAC,CAAC;AACH;;;;"}
1
+ {"version":3,"file":"error.svelte-u8Vsq8vF.js","sources":["../../../.svelte-kit/adapter-node/entries/fallbacks/error.svelte.js"],"sourcesContent":["import \"../../chunks/environment.js\";\nimport { H as escape_html, tt as getContext } from \"../../chunks/dev.js\";\nimport { c as navigating$1, s as stores } from \"../../chunks/client.js\";\nObject.defineProperty({\n\tget from() {\n\t\treturn navigating$1.current ? navigating$1.current.from : null;\n\t},\n\tget to() {\n\t\treturn navigating$1.current ? navigating$1.current.to : null;\n\t},\n\tget type() {\n\t\treturn navigating$1.current ? navigating$1.current.type : null;\n\t},\n\tget willUnload() {\n\t\treturn navigating$1.current ? navigating$1.current.willUnload : null;\n\t},\n\tget delta() {\n\t\treturn navigating$1.current ? navigating$1.current.delta : null;\n\t},\n\tget complete() {\n\t\treturn navigating$1.current ? navigating$1.current.complete : null;\n\t}\n}, \"current\", { get() {\n\tthrow new Error(\"Replace navigating.current.<prop> with navigating.<prop>\");\n} });\nstores.updated.check;\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/app/state/server.js\nfunction context() {\n\treturn getContext(\"__request__\");\n}\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/app/state/index.js\n/**\n* A read-only reactive object with information about the current page, serving several use cases:\n* - retrieving the combined `data` of all pages/layouts anywhere in your component tree (also see [loading data](https://svelte.dev/docs/kit/load))\n* - retrieving the current value of the `form` prop anywhere in your component tree (also see [form actions](https://svelte.dev/docs/kit/form-actions))\n* - retrieving the page state that was set through `goto`, `pushState` or `replaceState` (also see [goto](https://svelte.dev/docs/kit/$app-navigation#goto) and [shallow routing](https://svelte.dev/docs/kit/shallow-routing))\n* - retrieving metadata such as the URL you're on, the current route and its parameters, and whether or not there was an error\n*\n* ```svelte\n* <!--- file: +layout.svelte --->\n* <script>\n* \timport { page } from '$app/state';\n* <\\/script>\n*\n* <p>Currently at {page.url.pathname}</p>\n*\n* {#if page.error}\n* \t<span class=\"red\">Problem detected</span>\n* {:else}\n* \t<span class=\"small\">All systems operational</span>\n* {/if}\n* ```\n*\n* Changes to `page` are available exclusively with runes. (The legacy reactivity syntax will not reflect any changes)\n*\n* ```svelte\n* <!--- file: +page.svelte --->\n* <script>\n* \timport { page } from '$app/state';\n* \tconst id = $derived(page.params.id); // This will correctly update id for usage on this page\n* \t$: badId = page.params.id; // Do not use; will never update after initial load\n* <\\/script>\n* ```\n*\n* On the server, values can only be read during rendering (in other words _not_ in e.g. `load` functions). In the browser, the values can be read at any time.\n*\n* @type {import('@sveltejs/kit').Page}\n*/\nvar page = {\n\tget data() {\n\t\treturn context().page.data;\n\t},\n\tget error() {\n\t\treturn context().page.error;\n\t},\n\tget form() {\n\t\treturn context().page.form;\n\t},\n\tget params() {\n\t\treturn context().page.params;\n\t},\n\tget route() {\n\t\treturn context().page.route;\n\t},\n\tget state() {\n\t\treturn context().page.state;\n\t},\n\tget status() {\n\t\treturn context().page.status;\n\t},\n\tget url() {\n\t\treturn context().page.url;\n\t}\n};\n//#endregion\n//#region ../../node_modules/.pnpm/@sveltejs+kit@2.61.1_@sveltejs+vite-plugin-svelte@7.1.2_svelte@5.55.9_@typescript-eslin_31b35890553a27fb0d8f940d66156f76/node_modules/@sveltejs/kit/src/runtime/components/svelte-5/error.svelte\nfunction Error$1($$renderer, $$props) {\n\t$$renderer.component(($$renderer) => {\n\t\t$$renderer.push(`<h1>${escape_html(page.status)}</h1> <p>${escape_html(page.error?.message)}</p>`);\n\t});\n}\n//#endregion\nexport { Error$1 as default };\n"],"names":[],"mappings":";;;;;;;AA0BA;AACA;AACA,SAAS,OAAO,GAAG;AACnB,CAAC,OAAO,UAAU,CAAC,aAAa,CAAC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,IAAI,GAAG;AACX,CAGC,IAAI,KAAK,GAAG;AACb,EAAE,OAAO,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK;AAC7B,CAAC,CAAC;AACF,CAYC,IAAI,MAAM,GAAG;AACd,EAAE,OAAO,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM;AAC9B,CAAC,CAID,CAAC;AACD;AACA;AACA,SAAS,OAAO,CAAC,UAAU,EAAE,OAAO,EAAE;AACtC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,UAAU,KAAK;AACtC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;AACpG,CAAC,CAAC,CAAC;AACH;;;;"}
@@ -1,4 +1,4 @@
1
- import { _ as __commonJSMin, b as __require } from './internal-BkKkeKsj.js';
1
+ import { _ as __commonJSMin, b as __require } from './internal-fxcuSPWe.js';
2
2
  import { e as encodeResourceId } from './resource-id-PDcQeAnc.js';
3
3
  import { z } from 'zod';
4
4
  import require$$0$3 from 'events';
@@ -6482,6 +6482,37 @@ var KNOWN_TAGS = new Set([
6482
6482
  ]);
6483
6483
  var TAG_RE = /^\s*@([a-zA-Z_][a-zA-Z0-9_]*)\s*:(.*)$/;
6484
6484
  var INDENT_RE = /^[ \t]/;
6485
+ var LINE_WS_RE = /\s/;
6486
+ function isIdentStart(code) {
6487
+ return code >= 97 && code <= 122 || code >= 65 && code <= 90 || code === 95;
6488
+ }
6489
+ function isIdentChar(code) {
6490
+ return isIdentStart(code) || code >= 48 && code <= 57;
6491
+ }
6492
+ function tagTokenAt(line, start) {
6493
+ let i = start;
6494
+ if (i >= line.length || !isIdentStart(line.charCodeAt(i))) return null;
6495
+ i += 1;
6496
+ while (i < line.length && isIdentChar(line.charCodeAt(i))) i += 1;
6497
+ const token = line.slice(start, i);
6498
+ while (i < line.length && LINE_WS_RE.test(line[i])) i += 1;
6499
+ return i < line.length && line[i] === ":" ? token : null;
6500
+ }
6501
+ function midlineKnownTag(line) {
6502
+ let seenContent = false;
6503
+ for (let i = 0; i < line.length; i += 1) {
6504
+ const ch = line[i];
6505
+ if (ch === "@" && seenContent) {
6506
+ const token = tagTokenAt(line, i + 1);
6507
+ if (token !== null && KNOWN_TAGS.has(token.toLowerCase())) return `@${token}:`;
6508
+ }
6509
+ if (!seenContent && !LINE_WS_RE.test(ch)) seenContent = true;
6510
+ }
6511
+ return null;
6512
+ }
6513
+ function warnMidlineTag(token) {
6514
+ console.warn(`[@kozou/core] parseCommentTags: mid-line "${token}" is not parsed (tags are recognized at line start only; the text stays in the description verbatim)`);
6515
+ }
6485
6516
  function isWidgetType(value) {
6486
6517
  return KNOWN_WIDGETS.has(value);
6487
6518
  }
@@ -6518,12 +6549,16 @@ function parseCommentTags(comment) {
6518
6549
  continue;
6519
6550
  }
6520
6551
  } else if (line.trim().length > 0 && INDENT_RE.test(line) && !TAG_RE.test(line)) {
6552
+ const midline = midlineKnownTag(line);
6553
+ if (midline !== null) warnMidlineTag(midline);
6521
6554
  pending.lines.push(line.trim());
6522
6555
  bodyLines.push(line);
6523
6556
  continue;
6524
6557
  }
6525
6558
  flushPending();
6526
6559
  }
6560
+ const midline = midlineKnownTag(line);
6561
+ if (midline !== null) warnMidlineTag(midline);
6527
6562
  const match = TAG_RE.exec(line);
6528
6563
  if (!match) {
6529
6564
  bodyLines.push(line);
@@ -6708,6 +6743,9 @@ function buildColumn(input) {
6708
6743
  commentBody: parsed.body
6709
6744
  });
6710
6745
  const label = hints?.label ?? deriveLabel(column.name);
6746
+ const priv = column.privileges;
6747
+ const insertable = priv === void 0 ? void 0 : priv.insert;
6748
+ const updatable = priv === void 0 ? void 0 : priv.update;
6711
6749
  return {
6712
6750
  name: column.name,
6713
6751
  dataType: column.dataType,
@@ -6721,7 +6759,9 @@ function buildColumn(input) {
6721
6759
  policy: parsed.policy,
6722
6760
  widget,
6723
6761
  enumValues,
6724
- readonly: hints?.readonly ?? false
6762
+ readonly: hints?.readonly ?? false,
6763
+ ...insertable === void 0 ? {} : { insertable },
6764
+ ...updatable === void 0 ? {} : { updatable }
6725
6765
  };
6726
6766
  }
6727
6767
  function buildRelations(table, issues) {
@@ -6904,13 +6944,32 @@ async function buildSchemaContext(opts) {
6904
6944
  message: `UIHints view "${viewName}" does not exist in raw.views`
6905
6945
  });
6906
6946
  }
6907
- const tables = raw.tables.map((t) => buildTableContext({
6947
+ const hiddenNames = [];
6948
+ const visibleRawTables = raw.tables.filter((t) => {
6949
+ if (t.privileges?.select === false) {
6950
+ hiddenNames.push(t.name);
6951
+ return false;
6952
+ }
6953
+ return true;
6954
+ });
6955
+ const visibleRawViews = raw.views.filter((v) => {
6956
+ if (v.privileges?.select === false) {
6957
+ hiddenNames.push(v.name);
6958
+ return false;
6959
+ }
6960
+ return true;
6961
+ });
6962
+ if (hiddenNames.length > 0) {
6963
+ const role = raw.tables.find((t) => t.privileges !== void 0)?.privileges?.role ?? raw.views.find((v) => v.privileges !== void 0)?.privileges?.role ?? "the role";
6964
+ console.warn(`[@kozou/core] privilege-aware introspection: hid ${hiddenNames.length} relation(s) that "${role}" cannot SELECT: ${hiddenNames.join(", ")}`);
6965
+ }
6966
+ const tables = visibleRawTables.map((t) => buildTableContext({
6908
6967
  table: t,
6909
6968
  hints: uiHints?.tables?.[t.name],
6910
6969
  issues,
6911
6970
  knownTables
6912
6971
  }));
6913
- const views = raw.views.map((v) => buildViewContext({
6972
+ const views = visibleRawViews.map((v) => buildViewContext({
6914
6973
  view: v,
6915
6974
  hints: uiHints?.views?.[v.name],
6916
6975
  issues
@@ -6921,7 +6980,7 @@ async function buildSchemaContext(opts) {
6921
6980
  values: e.values,
6922
6981
  description: null
6923
6982
  }));
6924
- const concepts = raw.views.map(buildConcept);
6983
+ const concepts = visibleRawViews.map(buildConcept);
6925
6984
  if (issues.length > 0) {
6926
6985
  if (strict) throw new KozouBuildError(`buildSchemaContext: ${issues.length} validation issue(s) (strict=true)`, issues);
6927
6986
  for (const issue of issues) console.warn(`[@kozou/core] ${issue.path}: ${issue.message}`);
@@ -13900,6 +13959,83 @@ async function fetchEnums(client, schemas) {
13900
13959
  }));
13901
13960
  }
13902
13961
  //#endregion
13962
+ //#region ../introspect/dist/privileges.js
13963
+ var tableKey = (schema, name) => `${schema}.${name}`;
13964
+ /** Throw a clear error if the configured privilege role does not exist, rather
13965
+ * than letting `has_table_privilege` fail mid-query with a terse pg message. */
13966
+ async function assertRoleExists(client, role) {
13967
+ if ((await runQuery(client, "SELECT EXISTS (SELECT 1 FROM pg_roles WHERE rolname = $1) AS exists", [role], "fetchPrivileges (role check)"))[0]?.exists !== true) throw new KozouIntrospectError(`introspection.respectPrivileges is on but the role "${role}" does not exist. Set it to the role the Admin UI assumes (auth.ui.role / auth.defaultRole), or turn privilege-aware introspection off.`);
13968
+ }
13969
+ /**
13970
+ * Evaluate the privileges of `role` on every base table / view (and base-table
13971
+ * columns) in `schemas`, and attach them to the matching `RawTable` /
13972
+ * `RawColumn` / `RawView`. Mutates the inputs in place (mirrors
13973
+ * `mergeTableMetadata`). Call only when privilege-aware mode is on; otherwise
13974
+ * the privilege fields stay `undefined`.
13975
+ */
13976
+ async function fetchAndAttachPrivileges(client, schemas, role, tables, views) {
13977
+ if (schemas.length === 0 || tables.length === 0 && views.length === 0) return;
13978
+ await assertRoleExists(client, role);
13979
+ const tableRows = await runQuery(client, `SELECT
13980
+ n.nspname AS schema,
13981
+ c.relname AS name,
13982
+ has_schema_privilege($2, n.nspname, 'USAGE') AS usage,
13983
+ has_table_privilege($2, c.oid, 'SELECT') AS sel,
13984
+ has_table_privilege($2, c.oid, 'INSERT') AS ins,
13985
+ has_table_privilege($2, c.oid, 'UPDATE') AS upd,
13986
+ has_table_privilege($2, c.oid, 'DELETE') AS del
13987
+ FROM pg_class c
13988
+ JOIN pg_namespace n ON n.oid = c.relnamespace
13989
+ WHERE c.relkind IN ('r', 'v', 'm')
13990
+ AND n.nspname = ANY($1)`, [schemas, role], "fetchPrivileges (relations)");
13991
+ const columnRows = await runQuery(client, `SELECT
13992
+ n.nspname AS schema,
13993
+ c.relname AS table,
13994
+ a.attname AS name,
13995
+ has_schema_privilege($2, n.nspname, 'USAGE') AS usage,
13996
+ has_column_privilege($2, c.oid, a.attname, 'INSERT') AS ins,
13997
+ has_column_privilege($2, c.oid, a.attname, 'UPDATE') AS upd
13998
+ FROM pg_attribute a
13999
+ JOIN pg_class c ON c.oid = a.attrelid
14000
+ JOIN pg_namespace n ON n.oid = c.relnamespace
14001
+ WHERE c.relkind = 'r'
14002
+ AND n.nspname = ANY($1)
14003
+ AND a.attnum > 0
14004
+ AND NOT a.attisdropped`, [schemas, role], "fetchPrivileges (columns)");
14005
+ const tablePrivByKey = /* @__PURE__ */ new Map();
14006
+ for (const row of tableRows) tablePrivByKey.set(tableKey(row.schema, row.name), row);
14007
+ const columnPrivByKey = /* @__PURE__ */ new Map();
14008
+ for (const row of columnRows) {
14009
+ const key = tableKey(row.schema, row.table);
14010
+ if (!columnPrivByKey.has(key)) columnPrivByKey.set(key, /* @__PURE__ */ new Map());
14011
+ columnPrivByKey.get(key).set(row.name, row);
14012
+ }
14013
+ const gate = (tp) => ({
14014
+ role,
14015
+ select: tp.usage && tp.sel,
14016
+ insert: tp.usage && tp.ins,
14017
+ update: tp.usage && tp.upd,
14018
+ delete: tp.usage && tp.del
14019
+ });
14020
+ for (const table of tables) {
14021
+ const key = tableKey(table.schema, table.name);
14022
+ const tp = tablePrivByKey.get(key);
14023
+ if (tp !== void 0) table.privileges = gate(tp);
14024
+ const cols = columnPrivByKey.get(key);
14025
+ if (cols !== void 0) for (const column of table.columns) {
14026
+ const cp = cols.get(column.name);
14027
+ if (cp !== void 0) column.privileges = {
14028
+ insert: cp.usage && cp.ins,
14029
+ update: cp.usage && cp.upd
14030
+ };
14031
+ }
14032
+ }
14033
+ for (const view of views) {
14034
+ const vp = tablePrivByKey.get(tableKey(view.schema, view.name));
14035
+ if (vp !== void 0) view.privileges = gate(vp);
14036
+ }
14037
+ }
14038
+ //#endregion
13903
14039
  //#region ../introspect/dist/filter.js
13904
14040
  function compilePattern(pattern) {
13905
14041
  const qualified = pattern.includes(".") ? pattern : `*.${pattern}`;
@@ -13983,6 +14119,7 @@ async function introspect(opts) {
13983
14119
  mergeTableMetadata(allTables, await fetchForeignKeys(client, validSchemas), await fetchChecks(client, validSchemas));
13984
14120
  const allViews = await fetchViews(client, validSchemas);
13985
14121
  const enums = await fetchEnums(client, validSchemas);
14122
+ if (opts.privilegeRole !== void 0) await fetchAndAttachPrivileges(client, validSchemas, opts.privilegeRole, allTables, allViews);
13986
14123
  const filterOpts = {
13987
14124
  include: opts.include,
13988
14125
  exclude: opts.exclude
@@ -14092,7 +14229,11 @@ var SchemaCache = class {
14092
14229
  var cache = new SchemaCache({ loader: async () => {
14093
14230
  const connection = process.env.DATABASE_URL;
14094
14231
  if (typeof connection !== "string" || connection.length === 0) throw new Error("hooks.server: DATABASE_URL is required to introspect the schema.");
14095
- return buildSchemaContext({ raw: await introspect({ connection }) });
14232
+ const privilegeRole = process.env.KOZOU_INTROSPECTION_ROLE;
14233
+ return buildSchemaContext({ raw: await introspect({
14234
+ connection,
14235
+ ...typeof privilegeRole === "string" && privilegeRole.length > 0 ? { privilegeRole } : {}
14236
+ }) });
14096
14237
  } });
14097
14238
  var fkRowCache = new FkRowCache();
14098
14239
  var handle = async ({ event, resolve }) => {
@@ -14102,4 +14243,4 @@ var handle = async ({ event, resolve }) => {
14102
14243
  };
14103
14244
 
14104
14245
  export { handle };
14105
- //# sourceMappingURL=hooks.server-VuiVxiIQ.js.map
14246
+ //# sourceMappingURL=hooks.server-DtCXcOVD.js.map