mongoku 2.0.1 → 2.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Dockerfile +27 -0
- package/README.md +8 -0
- package/build/client/_app/immutable/assets/0.BHsXFfsc.css.gz +0 -0
- package/build/client/_app/immutable/assets/PrettyJson.CtngcfyW.css.gz +0 -0
- package/build/client/_app/immutable/chunks/{W-qL5_8w.js → BAM9w9EL.js} +1 -1
- package/build/client/_app/immutable/chunks/BAM9w9EL.js.br +0 -0
- package/build/client/_app/immutable/chunks/BAM9w9EL.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BKCvWebR.js +23 -0
- package/build/client/_app/immutable/chunks/BKCvWebR.js.br +0 -0
- package/build/client/_app/immutable/chunks/BKCvWebR.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{Dbyirw23.js → BMa204Dm.js} +3 -3
- package/build/client/_app/immutable/chunks/BMa204Dm.js.br +0 -0
- package/build/client/_app/immutable/chunks/BMa204Dm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BN_N9-2s.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BY57TmdO.js +1 -0
- package/build/client/_app/immutable/chunks/BY57TmdO.js.br +0 -0
- package/build/client/_app/immutable/chunks/BY57TmdO.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BaB-cr9N.js +2 -0
- package/build/client/_app/immutable/chunks/BaB-cr9N.js.br +0 -0
- package/build/client/_app/immutable/chunks/BaB-cr9N.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BdR-m9Ad.js +1 -0
- package/build/client/_app/immutable/chunks/BdR-m9Ad.js.br +0 -0
- package/build/client/_app/immutable/chunks/BdR-m9Ad.js.gz +0 -0
- package/build/client/_app/immutable/chunks/ByjLCPv2.js +1 -0
- package/build/client/_app/immutable/chunks/ByjLCPv2.js.br +0 -0
- package/build/client/_app/immutable/chunks/ByjLCPv2.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BzAcxkRZ.js +4 -0
- package/build/client/_app/immutable/chunks/BzAcxkRZ.js.br +0 -0
- package/build/client/_app/immutable/chunks/BzAcxkRZ.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CyQLXPZI.js +2 -0
- package/build/client/_app/immutable/chunks/CyQLXPZI.js.br +0 -0
- package/build/client/_app/immutable/chunks/CyQLXPZI.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D17Lj1H7.js +1 -0
- package/build/client/_app/immutable/chunks/D17Lj1H7.js.br +0 -0
- package/build/client/_app/immutable/chunks/D17Lj1H7.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D4VhtiDg.js +1 -0
- package/build/client/_app/immutable/chunks/D4VhtiDg.js.br +0 -0
- package/build/client/_app/immutable/chunks/D4VhtiDg.js.gz +0 -0
- package/build/client/_app/immutable/chunks/D72Du7TF.js +1 -0
- package/build/client/_app/immutable/chunks/D72Du7TF.js.br +2 -0
- package/build/client/_app/immutable/chunks/D72Du7TF.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{DZSJW-Zm.js → XYFbSe2V.js} +1 -1
- package/build/client/_app/immutable/chunks/XYFbSe2V.js.br +0 -0
- package/build/client/_app/immutable/chunks/XYFbSe2V.js.gz +0 -0
- package/build/client/_app/immutable/chunks/iHsChU5o.js +1 -0
- package/build/client/_app/immutable/chunks/iHsChU5o.js.br +0 -0
- package/build/client/_app/immutable/chunks/iHsChU5o.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{DzSHMQR7.js → p23QjN60.js} +1 -1
- package/build/client/_app/immutable/chunks/p23QjN60.js.br +2 -0
- package/build/client/_app/immutable/chunks/p23QjN60.js.gz +0 -0
- package/build/client/_app/immutable/chunks/sBKW2MYH.js +1 -0
- package/build/client/_app/immutable/chunks/sBKW2MYH.js.br +0 -0
- package/build/client/_app/immutable/chunks/sBKW2MYH.js.gz +0 -0
- package/build/client/_app/immutable/chunks/{BEuO9qGi.js → uMNMODvc.js} +1 -1
- package/build/client/_app/immutable/chunks/uMNMODvc.js.br +0 -0
- package/build/client/_app/immutable/chunks/uMNMODvc.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.9nC_873E.js +2 -0
- package/build/client/_app/immutable/entry/app.9nC_873E.js.br +0 -0
- package/build/client/_app/immutable/entry/app.9nC_873E.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.Bn88Alw2.js +1 -0
- package/build/client/_app/immutable/entry/start.Bn88Alw2.js.br +2 -0
- package/build/client/_app/immutable/entry/start.Bn88Alw2.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{0.B2lBDs71.js → 0.COxTCtn2.js} +1 -1
- package/build/client/_app/immutable/nodes/0.COxTCtn2.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.COxTCtn2.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js +1 -0
- package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.CI2GcqTf.js +1 -0
- package/build/client/_app/immutable/nodes/3.CI2GcqTf.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.CI2GcqTf.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{4.BqBphmVX.js → 4.ChSdW7ac.js} +1 -1
- package/build/client/_app/immutable/nodes/4.ChSdW7ac.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.ChSdW7ac.js.gz +0 -0
- package/build/client/_app/immutable/nodes/{5.BkAWRgl4.js → 5.DaMML2go.js} +1 -1
- package/build/client/_app/immutable/nodes/5.DaMML2go.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.DaMML2go.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js +1 -0
- package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.CU-ncPes.js +1 -0
- package/build/client/_app/immutable/nodes/7.CU-ncPes.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.CU-ncPes.js.gz +0 -0
- package/build/client/_app/version.json +1 -1
- package/build/client/_app/version.json.br +0 -0
- package/build/client/_app/version.json.gz +0 -0
- package/build/server/chunks/{0-BGoFMRn2.js → 0-C1NyHW8A.js} +3 -3
- package/build/server/chunks/{0-BGoFMRn2.js.map → 0-C1NyHW8A.js.map} +1 -1
- package/build/server/chunks/1-CThf4W5r.js +9 -0
- package/build/server/chunks/{1-Ch0AY58K.js.map → 1-CThf4W5r.js.map} +1 -1
- package/build/server/chunks/{3-Bmk9Qof9.js → 3-CJf0NbiV.js} +3 -3
- package/build/server/chunks/{3-Bmk9Qof9.js.map → 3-CJf0NbiV.js.map} +1 -1
- package/build/server/chunks/{4-DnpScx2e.js → 4-Dfbpsagm.js} +3 -3
- package/build/server/chunks/{4-DnpScx2e.js.map → 4-Dfbpsagm.js.map} +1 -1
- package/build/server/chunks/{5-Bw8bTTBj.js → 5-DLB6GOjf.js} +3 -3
- package/build/server/chunks/{5-Bw8bTTBj.js.map → 5-DLB6GOjf.js.map} +1 -1
- package/build/server/chunks/{6-D8zNoyW_.js → 6-DfCARDKO.js} +10 -5
- package/build/server/chunks/6-DfCARDKO.js.map +1 -0
- package/build/server/chunks/{7-Cim4qVL3.js → 7-B5o4OymX.js} +3 -3
- package/build/server/chunks/{7-Cim4qVL3.js.map → 7-B5o4OymX.js.map} +1 -1
- package/build/server/chunks/{Panel-DTdYk-gk.js → Panel-Box8ld78.js} +3 -3
- package/build/server/chunks/Panel-Box8ld78.js.map +1 -0
- package/build/server/chunks/{PrettyJson-wIuHvehp.js → PrettyJson-C2c9xGNo.js} +5 -5
- package/build/server/chunks/PrettyJson-C2c9xGNo.js.map +1 -0
- package/build/server/chunks/{TooltipTable-J278e1CA.js → TooltipTable-0z4HkHlH.js} +3 -1
- package/build/server/chunks/TooltipTable-0z4HkHlH.js.map +1 -0
- package/build/server/chunks/{_layout.svelte-D7RD9tLN.js → _layout.svelte-CU7AVRSZ.js} +14 -11
- package/build/server/chunks/_layout.svelte-CU7AVRSZ.js.map +1 -0
- package/build/server/chunks/{_page.svelte-4PYYtPii.js → _page.svelte-B_T8EFk3.js} +7 -6
- package/build/server/chunks/_page.svelte-B_T8EFk3.js.map +1 -0
- package/build/server/chunks/{_page.svelte-Be5VTn1e.js → _page.svelte-CflJkclc.js} +7 -6
- package/build/server/chunks/_page.svelte-CflJkclc.js.map +1 -0
- package/build/server/chunks/{_page.svelte-DZ59Sr3N.js → _page.svelte-D1QIZqLv.js} +65 -42
- package/build/server/chunks/_page.svelte-D1QIZqLv.js.map +1 -0
- package/build/server/chunks/{_page.svelte-DIPUjSjm.js → _page.svelte-PuIVQ52p.js} +20 -8
- package/build/server/chunks/_page.svelte-PuIVQ52p.js.map +1 -0
- package/build/server/chunks/_page.svelte-zlHeUnJK.js +101 -0
- package/build/server/chunks/_page.svelte-zlHeUnJK.js.map +1 -0
- package/build/server/chunks/{context-BU6gUbSI.js → async-BfR0vYHo.js} +8 -46
- package/build/server/chunks/async-BfR0vYHo.js.map +1 -0
- package/build/server/chunks/client-bj7sePQc.js +7 -0
- package/build/server/chunks/{client-BZtxOgbR.js.map → client-bj7sePQc.js.map} +1 -1
- package/build/server/chunks/{client2-LilSGYJA.js → client2-BX4-xbM4.js} +6 -5
- package/build/server/chunks/{client2-LilSGYJA.js.map → client2-BX4-xbM4.js.map} +1 -1
- package/build/server/chunks/error.svelte-D5sIJv3P.js +18 -0
- package/build/server/chunks/error.svelte-D5sIJv3P.js.map +1 -0
- package/build/server/chunks/event-DVH-6ISX.js +64 -0
- package/build/server/chunks/event-DVH-6ISX.js.map +1 -0
- package/build/server/chunks/{exports-DiyTWREe.js → exports-Cv9LZeD1.js} +2 -39
- package/build/server/chunks/exports-Cv9LZeD1.js.map +1 -0
- package/build/server/chunks/hooks.server-_TKfdzGA.js +26 -0
- package/build/server/chunks/hooks.server-_TKfdzGA.js.map +1 -0
- package/build/server/chunks/{index-XFKuhGxM.js → index-EKt9-9bV.js} +2 -2
- package/build/server/chunks/{index-XFKuhGxM.js.map → index-EKt9-9bV.js.map} +1 -1
- package/build/server/chunks/{index3-CUhdJ7wv.js → index3-DquTjlmp.js} +3 -3
- package/build/server/chunks/index3-DquTjlmp.js.map +1 -0
- package/build/server/chunks/{notifications.svelte-CrTIrfvL.js → notifications.svelte-CIqkoPWX.js} +6 -12
- package/build/server/chunks/notifications.svelte-CIqkoPWX.js.map +1 -0
- package/build/server/chunks/remote-xxtqbu-BFzaWXy0.js +234 -0
- package/build/server/chunks/remote-xxtqbu-BFzaWXy0.js.map +1 -0
- package/build/server/chunks/{routing-zIlQn_LN.js → routing-Ddj5b-2K.js} +25 -4
- package/build/server/chunks/routing-Ddj5b-2K.js.map +1 -0
- package/build/server/chunks/{server2-DfQrrcsk.js → server2-BOoUfKd7.js} +3 -3
- package/build/server/chunks/{server2-DfQrrcsk.js.map → server2-BOoUfKd7.js.map} +1 -1
- package/build/server/chunks/{state.svelte-s-CFCWQX.js → state.svelte-CRHA9yov.js} +3 -2
- package/build/server/chunks/{state.svelte-s-CFCWQX.js.map → state.svelte-CRHA9yov.js.map} +1 -1
- package/build/server/chunks/utils-DGYJFmnf.js +39 -0
- package/build/server/chunks/utils-DGYJFmnf.js.map +1 -0
- package/build/server/index.js +71 -24
- package/build/server/index.js.map +1 -1
- package/build/server/manifest.js +9 -30
- package/build/server/manifest.js.map +1 -1
- package/cli.ts +148 -0
- package/dist/cli.js +3 -4
- package/ecosystem.config.js +9 -0
- package/package.json +88 -81
- package/src/api/servers.remote.ts +98 -0
- package/src/app.css +228 -0
- package/src/app.d.ts +16 -0
- package/src/app.html +11 -0
- package/src/hooks.server.ts +34 -0
- package/src/lib/components/Breadcrumbs.svelte +133 -0
- package/src/lib/components/JsonValue.svelte +248 -0
- package/src/lib/components/Notifications.svelte +81 -0
- package/src/lib/components/Panel.svelte +37 -0
- package/src/lib/components/PrettyJson.svelte +187 -0
- package/src/lib/components/SearchBox.svelte +160 -0
- package/src/lib/components/TooltipTable.svelte +137 -0
- package/src/lib/server/HostsManager.ts +105 -0
- package/src/lib/server/JsonEncoder.ts +62 -0
- package/src/lib/server/mongo.ts +199 -0
- package/src/lib/stores/notifications.svelte.ts +45 -0
- package/src/lib/types.ts +56 -0
- package/src/lib/utils/filters.ts +25 -0
- package/src/lib/utils/jsonParser.ts +125 -0
- package/src/routes/+layout.server.ts +7 -0
- package/src/routes/+layout.svelte +27 -0
- package/src/routes/+page.server.ts +6 -0
- package/src/routes/servers/+page.server.ts +53 -0
- package/src/routes/servers/+page.svelte +196 -0
- package/src/routes/servers/[server]/databases/+page.server.ts +47 -0
- package/src/routes/servers/[server]/databases/+page.svelte +88 -0
- package/src/routes/servers/[server]/databases/[database]/collections/+page.server.ts +21 -0
- package/src/routes/servers/[server]/databases/[database]/collections/+page.svelte +110 -0
- package/src/routes/servers/[server]/databases/[database]/collections/[collection]/+page.server.ts +106 -0
- package/src/routes/servers/[server]/databases/[database]/collections/[collection]/+page.svelte +174 -0
- package/src/routes/servers/[server]/databases/[database]/collections/[collection]/documents/[document]/+page.server.ts +25 -0
- package/src/routes/servers/[server]/databases/[database]/collections/[collection]/documents/[document]/+page.svelte +90 -0
- package/src/tests/api/readonly.test.ts +89 -0
- package/src/tests/setup.ts +19 -0
- package/svelte.config.js +28 -0
- package/tsconfig.cli.json +15 -0
- package/tsconfig.json +19 -0
- package/vite.config.ts +7 -0
- package/build/client/_app/immutable/chunks/B-Z1NsR7.js +0 -1
- package/build/client/_app/immutable/chunks/B-Z1NsR7.js.br +0 -0
- package/build/client/_app/immutable/chunks/B-Z1NsR7.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BEuO9qGi.js.br +0 -0
- package/build/client/_app/immutable/chunks/BEuO9qGi.js.gz +0 -0
- package/build/client/_app/immutable/chunks/BuIrCFA_.js +0 -1
- package/build/client/_app/immutable/chunks/BuIrCFA_.js.br +0 -0
- package/build/client/_app/immutable/chunks/BuIrCFA_.js.gz +0 -0
- package/build/client/_app/immutable/chunks/C9b4uNov.js +0 -1
- package/build/client/_app/immutable/chunks/C9b4uNov.js.br +0 -0
- package/build/client/_app/immutable/chunks/C9b4uNov.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CIYBIyvN.js +0 -1
- package/build/client/_app/immutable/chunks/CIYBIyvN.js.br +0 -0
- package/build/client/_app/immutable/chunks/CIYBIyvN.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CWUhQKKC.js +0 -1
- package/build/client/_app/immutable/chunks/CWUhQKKC.js.br +0 -0
- package/build/client/_app/immutable/chunks/CWUhQKKC.js.gz +0 -0
- package/build/client/_app/immutable/chunks/CrJSDly5.js +0 -2
- package/build/client/_app/immutable/chunks/CrJSDly5.js.br +0 -0
- package/build/client/_app/immutable/chunks/CrJSDly5.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DRy_44ib.js +0 -1
- package/build/client/_app/immutable/chunks/DRy_44ib.js.br +0 -0
- package/build/client/_app/immutable/chunks/DRy_44ib.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DS5yzhLt.js +0 -1
- package/build/client/_app/immutable/chunks/DS5yzhLt.js.br +0 -0
- package/build/client/_app/immutable/chunks/DS5yzhLt.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DZSJW-Zm.js.br +0 -0
- package/build/client/_app/immutable/chunks/DZSJW-Zm.js.gz +0 -0
- package/build/client/_app/immutable/chunks/Dbyirw23.js.br +0 -0
- package/build/client/_app/immutable/chunks/Dbyirw23.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DsnmJJEf.js +0 -1
- package/build/client/_app/immutable/chunks/DsnmJJEf.js.br +0 -2
- package/build/client/_app/immutable/chunks/DsnmJJEf.js.gz +0 -0
- package/build/client/_app/immutable/chunks/DzSHMQR7.js.br +0 -0
- package/build/client/_app/immutable/chunks/DzSHMQR7.js.gz +0 -0
- package/build/client/_app/immutable/chunks/W-qL5_8w.js.br +0 -0
- package/build/client/_app/immutable/chunks/W-qL5_8w.js.gz +0 -0
- package/build/client/_app/immutable/chunks/aB6hH3ax.js +0 -3
- package/build/client/_app/immutable/chunks/aB6hH3ax.js.br +0 -0
- package/build/client/_app/immutable/chunks/aB6hH3ax.js.gz +0 -0
- package/build/client/_app/immutable/chunks/nJ6DKbk8.js +0 -1
- package/build/client/_app/immutable/chunks/nJ6DKbk8.js.br +0 -0
- package/build/client/_app/immutable/chunks/nJ6DKbk8.js.gz +0 -0
- package/build/client/_app/immutable/chunks/zeTqHWB5.js +0 -2
- package/build/client/_app/immutable/chunks/zeTqHWB5.js.br +0 -0
- package/build/client/_app/immutable/chunks/zeTqHWB5.js.gz +0 -0
- package/build/client/_app/immutable/entry/app.CW91YXu8.js +0 -2
- package/build/client/_app/immutable/entry/app.CW91YXu8.js.br +0 -0
- package/build/client/_app/immutable/entry/app.CW91YXu8.js.gz +0 -0
- package/build/client/_app/immutable/entry/start.CidwPVgO.js +0 -1
- package/build/client/_app/immutable/entry/start.CidwPVgO.js.br +0 -2
- package/build/client/_app/immutable/entry/start.CidwPVgO.js.gz +0 -0
- package/build/client/_app/immutable/nodes/0.B2lBDs71.js.br +0 -0
- package/build/client/_app/immutable/nodes/0.B2lBDs71.js.gz +0 -0
- package/build/client/_app/immutable/nodes/1.CueZCvtl.js +0 -1
- package/build/client/_app/immutable/nodes/1.CueZCvtl.js.br +0 -0
- package/build/client/_app/immutable/nodes/1.CueZCvtl.js.gz +0 -0
- package/build/client/_app/immutable/nodes/3.alYAlI3j.js +0 -1
- package/build/client/_app/immutable/nodes/3.alYAlI3j.js.br +0 -0
- package/build/client/_app/immutable/nodes/3.alYAlI3j.js.gz +0 -0
- package/build/client/_app/immutable/nodes/4.BqBphmVX.js.br +0 -0
- package/build/client/_app/immutable/nodes/4.BqBphmVX.js.gz +0 -0
- package/build/client/_app/immutable/nodes/5.BkAWRgl4.js.br +0 -0
- package/build/client/_app/immutable/nodes/5.BkAWRgl4.js.gz +0 -0
- package/build/client/_app/immutable/nodes/6.KI4mq5ln.js +0 -1
- package/build/client/_app/immutable/nodes/6.KI4mq5ln.js.br +0 -0
- package/build/client/_app/immutable/nodes/6.KI4mq5ln.js.gz +0 -0
- package/build/client/_app/immutable/nodes/7.Brjrw0K8.js +0 -1
- package/build/client/_app/immutable/nodes/7.Brjrw0K8.js.br +0 -0
- package/build/client/_app/immutable/nodes/7.Brjrw0K8.js.gz +0 -0
- package/build/server/chunks/1-Ch0AY58K.js +0 -9
- package/build/server/chunks/6-D8zNoyW_.js.map +0 -1
- package/build/server/chunks/Panel-DTdYk-gk.js.map +0 -1
- package/build/server/chunks/PrettyJson-wIuHvehp.js.map +0 -1
- package/build/server/chunks/TooltipTable-J278e1CA.js.map +0 -1
- package/build/server/chunks/_layout.svelte-D7RD9tLN.js.map +0 -1
- package/build/server/chunks/_page.svelte-4PYYtPii.js.map +0 -1
- package/build/server/chunks/_page.svelte-Be5VTn1e.js.map +0 -1
- package/build/server/chunks/_page.svelte-DIPUjSjm.js.map +0 -1
- package/build/server/chunks/_page.svelte-DZ59Sr3N.js.map +0 -1
- package/build/server/chunks/_page.svelte-sdKGQrEF.js +0 -91
- package/build/server/chunks/_page.svelte-sdKGQrEF.js.map +0 -1
- package/build/server/chunks/_server.ts-BIRebnb3.js +0 -20
- package/build/server/chunks/_server.ts-BIRebnb3.js.map +0 -1
- package/build/server/chunks/_server.ts-MnKJDybo.js +0 -19
- package/build/server/chunks/_server.ts-MnKJDybo.js.map +0 -1
- package/build/server/chunks/_server.ts-Tog8k3Mh.js +0 -52
- package/build/server/chunks/_server.ts-Tog8k3Mh.js.map +0 -1
- package/build/server/chunks/client-BZtxOgbR.js +0 -7
- package/build/server/chunks/context-BU6gUbSI.js.map +0 -1
- package/build/server/chunks/error.svelte-BfneeC-d.js +0 -16
- package/build/server/chunks/error.svelte-BfneeC-d.js.map +0 -1
- package/build/server/chunks/exports-DiyTWREe.js.map +0 -1
- package/build/server/chunks/hooks.server-DNhdbQNi.js +0 -7
- package/build/server/chunks/hooks.server-DNhdbQNi.js.map +0 -1
- package/build/server/chunks/index3-CUhdJ7wv.js.map +0 -1
- package/build/server/chunks/notifications.svelte-CrTIrfvL.js.map +0 -1
- package/build/server/chunks/routing-zIlQn_LN.js.map +0 -1
package/src/routes/servers/[server]/databases/[database]/collections/[collection]/+page.svelte
ADDED
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import {
|
|
3
|
+
deleteDocument as deleteDocumentCommand,
|
|
4
|
+
updateDocument as updateDocumentCommand,
|
|
5
|
+
} from "$api/servers.remote";
|
|
6
|
+
import { resolve } from "$app/paths";
|
|
7
|
+
import Panel from "$lib/components/Panel.svelte";
|
|
8
|
+
import PrettyJson from "$lib/components/PrettyJson.svelte";
|
|
9
|
+
import SearchBox from "$lib/components/SearchBox.svelte";
|
|
10
|
+
import { notificationStore } from "$lib/stores/notifications.svelte";
|
|
11
|
+
import type { MongoDocument, SearchParams } from "$lib/types";
|
|
12
|
+
import { formatNumber } from "$lib/utils/filters";
|
|
13
|
+
import { SvelteURLSearchParams } from "svelte/reactivity";
|
|
14
|
+
import type { PageData } from "./$types";
|
|
15
|
+
|
|
16
|
+
let { data }: { data: PageData } = $props();
|
|
17
|
+
|
|
18
|
+
let params = $state<SearchParams>({ ...data.params });
|
|
19
|
+
|
|
20
|
+
// Handle errors from streamed promises
|
|
21
|
+
$effect(() => {
|
|
22
|
+
// @ts-expect-error I just want to trigger the dependency
|
|
23
|
+
if (data.results) {
|
|
24
|
+
modifiedItems = null;
|
|
25
|
+
}
|
|
26
|
+
data.results.then((result) => {
|
|
27
|
+
if (result.error) {
|
|
28
|
+
notificationStore.notifyError(result.error);
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
$effect(() => {
|
|
34
|
+
data.count.then((result) => {
|
|
35
|
+
if (result.error) {
|
|
36
|
+
notificationStore.notifyError(result.error);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
let modifiedItems = $state<MongoDocument[] | null>(null);
|
|
42
|
+
let items = $derived(modifiedItems ? { data: modifiedItems, error: null } : data.results);
|
|
43
|
+
|
|
44
|
+
async function editDocument(_id: { $value?: string } | undefined, json: MongoDocument, items: MongoDocument[]) {
|
|
45
|
+
const partial = Boolean(
|
|
46
|
+
params.project && params.project !== "{}" && Object.keys(JSON.parse(params.project)).length > 0,
|
|
47
|
+
);
|
|
48
|
+
const newId = json?._id?.$value;
|
|
49
|
+
const oldId = _id?.$value;
|
|
50
|
+
|
|
51
|
+
if (newId !== oldId) {
|
|
52
|
+
notificationStore.notifyError("ObjectId changed. This is not supported, update canceled.");
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (!oldId) return;
|
|
57
|
+
|
|
58
|
+
try {
|
|
59
|
+
const result = await updateDocumentCommand({
|
|
60
|
+
server: data.server,
|
|
61
|
+
database: data.database,
|
|
62
|
+
collection: data.collection,
|
|
63
|
+
document: oldId,
|
|
64
|
+
value: json,
|
|
65
|
+
partial,
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
if (result.ok) {
|
|
69
|
+
notificationStore.notifySuccess("Document updated successfully");
|
|
70
|
+
// Update the document in the list
|
|
71
|
+
const index = items.findIndex((item) => item._id?.$value === oldId);
|
|
72
|
+
if (index !== -1) {
|
|
73
|
+
items[index] = result.update;
|
|
74
|
+
}
|
|
75
|
+
modifiedItems = items;
|
|
76
|
+
}
|
|
77
|
+
} catch (error) {
|
|
78
|
+
console.log(error);
|
|
79
|
+
notificationStore.notifyError(error, "Failed to update document");
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
async function removeDocument(_id: { $value?: string } | undefined, items: MongoDocument[]) {
|
|
84
|
+
const documentId = _id?.$value;
|
|
85
|
+
if (!documentId) return;
|
|
86
|
+
|
|
87
|
+
try {
|
|
88
|
+
await deleteDocumentCommand({
|
|
89
|
+
server: data.server,
|
|
90
|
+
database: data.database,
|
|
91
|
+
collection: data.collection,
|
|
92
|
+
document: documentId,
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
notificationStore.notifySuccess("Document removed successfully");
|
|
96
|
+
modifiedItems = items.filter((item) => item._id?.$value !== documentId);
|
|
97
|
+
} catch (error) {
|
|
98
|
+
notificationStore.notifyError(error, "Failed to remove document");
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
function buildUrl(skip: number) {
|
|
103
|
+
const queryParams = new SvelteURLSearchParams();
|
|
104
|
+
queryParams.set("query", params.query || "{}");
|
|
105
|
+
queryParams.set("sort", params.sort || "");
|
|
106
|
+
queryParams.set("project", params.project || "");
|
|
107
|
+
queryParams.set("skip", String(skip));
|
|
108
|
+
queryParams.set("limit", String(params.limit));
|
|
109
|
+
|
|
110
|
+
return `/servers/${encodeURIComponent(data.server)}/databases/${encodeURIComponent(data.database)}/collections/${encodeURIComponent(data.collection)}?${queryParams.toString()}`;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const nextUrl = $derived(buildUrl(params.skip + params.limit));
|
|
114
|
+
const previousUrl = $derived(buildUrl(Math.max(0, params.skip - params.limit)));
|
|
115
|
+
</script>
|
|
116
|
+
|
|
117
|
+
<SearchBox bind:params />
|
|
118
|
+
|
|
119
|
+
{#await items}
|
|
120
|
+
<Panel title="Loading documents...">
|
|
121
|
+
{#snippet actions()}
|
|
122
|
+
<span class="text-sm text-gray-500">Loading...</span>
|
|
123
|
+
{/snippet}
|
|
124
|
+
</Panel>
|
|
125
|
+
{:then resultsData}
|
|
126
|
+
{@const items = resultsData.data}
|
|
127
|
+
{#await data.count}
|
|
128
|
+
<Panel
|
|
129
|
+
title={items.length > 0
|
|
130
|
+
? `${formatNumber(data.params.skip + 1)} - ${formatNumber(data.params.skip + items.length)} Documents (counting...)`
|
|
131
|
+
: "No documents"}
|
|
132
|
+
>
|
|
133
|
+
{#snippet actions()}
|
|
134
|
+
{#if data.params.skip > 0}
|
|
135
|
+
<!-- eslint-disable-next-line @typescript-eslint/no-explicit-any -->
|
|
136
|
+
<a href={resolve(previousUrl as any)} class="btn btn-default btn-sm -my-2">Previous</a>
|
|
137
|
+
{/if}
|
|
138
|
+
{/snippet}
|
|
139
|
+
</Panel>
|
|
140
|
+
{:then countData}
|
|
141
|
+
{@const count = countData.data}
|
|
142
|
+
{@const hasNext = data.params.skip + items.length < count}
|
|
143
|
+
{@const hasPrevious = data.params.skip > 0}
|
|
144
|
+
<Panel
|
|
145
|
+
title={count > 0
|
|
146
|
+
? `${formatNumber(data.params.skip + 1)} - ${formatNumber(data.params.skip + items.length)} of ${formatNumber(count)} Documents`
|
|
147
|
+
: "No documents"}
|
|
148
|
+
>
|
|
149
|
+
{#snippet actions()}
|
|
150
|
+
{#if hasPrevious}
|
|
151
|
+
<!-- eslint-disable-next-line @typescript-eslint/no-explicit-any -->
|
|
152
|
+
<a href={resolve(previousUrl as any)} class="btn btn-default btn-sm -my-2">Previous</a>
|
|
153
|
+
{/if}
|
|
154
|
+
{#if hasNext}
|
|
155
|
+
<!-- eslint-disable-next-line @typescript-eslint/no-explicit-any -->
|
|
156
|
+
<a href={resolve(nextUrl as any)} class="btn btn-default btn-sm -my-2">Next</a>
|
|
157
|
+
{/if}
|
|
158
|
+
{/snippet}
|
|
159
|
+
</Panel>
|
|
160
|
+
{/await}
|
|
161
|
+
|
|
162
|
+
{#each items as item (item._id?.$value)}
|
|
163
|
+
<PrettyJson
|
|
164
|
+
json={item}
|
|
165
|
+
autoCollapse={true}
|
|
166
|
+
readOnly={data.readOnly}
|
|
167
|
+
onedit={(json) => editDocument(item._id, json, items)}
|
|
168
|
+
onremove={() => removeDocument(item._id, items)}
|
|
169
|
+
server={data.server}
|
|
170
|
+
database={data.database}
|
|
171
|
+
collection={data.collection}
|
|
172
|
+
/>
|
|
173
|
+
{/each}
|
|
174
|
+
{/await}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import JsonEncoder from "$lib/server/JsonEncoder";
|
|
2
|
+
import { getMongo } from "$lib/server/mongo";
|
|
3
|
+
import { ObjectId } from "mongodb";
|
|
4
|
+
import type { PageServerLoad } from "./$types";
|
|
5
|
+
|
|
6
|
+
export const load: PageServerLoad = async ({ params }) => {
|
|
7
|
+
const mongo = await getMongo();
|
|
8
|
+
const collection = mongo.getCollection(params.server, params.database, params.collection);
|
|
9
|
+
|
|
10
|
+
let document = null;
|
|
11
|
+
if (collection) {
|
|
12
|
+
const obj = await collection.findOne({
|
|
13
|
+
_id: new ObjectId(params.document),
|
|
14
|
+
});
|
|
15
|
+
document = JsonEncoder.encode(obj);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
return {
|
|
19
|
+
server: params.server,
|
|
20
|
+
database: params.database,
|
|
21
|
+
collection: params.collection,
|
|
22
|
+
documentId: params.document,
|
|
23
|
+
document,
|
|
24
|
+
};
|
|
25
|
+
};
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import {
|
|
3
|
+
deleteDocument as deleteDocumentCommand,
|
|
4
|
+
updateDocument as updateDocumentCommand,
|
|
5
|
+
} from "$api/servers.remote";
|
|
6
|
+
import { goto } from "$app/navigation";
|
|
7
|
+
import { resolve } from "$app/paths";
|
|
8
|
+
import PrettyJson from "$lib/components/PrettyJson.svelte";
|
|
9
|
+
import { notificationStore } from "$lib/stores/notifications.svelte";
|
|
10
|
+
import type { MongoDocument } from "$lib/types";
|
|
11
|
+
import type { PageData } from "./$types";
|
|
12
|
+
|
|
13
|
+
let { data }: { data: PageData } = $props();
|
|
14
|
+
|
|
15
|
+
let loading = $state(false);
|
|
16
|
+
let item = $derived(data.document);
|
|
17
|
+
|
|
18
|
+
async function editDocument(json: MongoDocument) {
|
|
19
|
+
const newId = json?._id?.$value;
|
|
20
|
+
const oldId = item?._id?.$value;
|
|
21
|
+
|
|
22
|
+
if (newId !== oldId) {
|
|
23
|
+
notificationStore.notifyError("ObjectId changed. This is not supported, update canceled.");
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
if (!oldId) return;
|
|
28
|
+
|
|
29
|
+
loading = true;
|
|
30
|
+
try {
|
|
31
|
+
const result = await updateDocumentCommand({
|
|
32
|
+
server: data.server,
|
|
33
|
+
database: data.database,
|
|
34
|
+
collection: data.collection,
|
|
35
|
+
document: oldId,
|
|
36
|
+
value: json,
|
|
37
|
+
partial: false,
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
if (result.ok) {
|
|
41
|
+
notificationStore.notifySuccess("Document updated successfully");
|
|
42
|
+
item = result.update;
|
|
43
|
+
}
|
|
44
|
+
} catch (error) {
|
|
45
|
+
notificationStore.notifyError(error, "Failed to update document");
|
|
46
|
+
} finally {
|
|
47
|
+
loading = false;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
async function removeDocument() {
|
|
52
|
+
const documentId = item?._id?.$value;
|
|
53
|
+
if (!documentId) return;
|
|
54
|
+
|
|
55
|
+
try {
|
|
56
|
+
await deleteDocumentCommand({
|
|
57
|
+
server: data.server,
|
|
58
|
+
database: data.database,
|
|
59
|
+
collection: data.collection,
|
|
60
|
+
document: documentId,
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
notificationStore.notifySuccess("Document removed successfully");
|
|
64
|
+
// Navigate back to the collection explore page
|
|
65
|
+
goto(
|
|
66
|
+
resolve(
|
|
67
|
+
`/servers/${encodeURIComponent(data.server)}/databases/${encodeURIComponent(data.database)}/collections/${encodeURIComponent(data.collection)}?query=${encodeURIComponent("{}")}&sort=&project=&skip=0&limit=20`,
|
|
68
|
+
),
|
|
69
|
+
);
|
|
70
|
+
} catch (error) {
|
|
71
|
+
notificationStore.notifyError(error, "Failed to remove document");
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
</script>
|
|
75
|
+
|
|
76
|
+
{#if loading}
|
|
77
|
+
<div class="loading">Loading...</div>
|
|
78
|
+
{:else if item}
|
|
79
|
+
<PrettyJson
|
|
80
|
+
json={item}
|
|
81
|
+
readOnly={data.readOnly}
|
|
82
|
+
onedit={editDocument}
|
|
83
|
+
onremove={removeDocument}
|
|
84
|
+
server={data.server}
|
|
85
|
+
database={data.database}
|
|
86
|
+
collection={data.collection}
|
|
87
|
+
/>
|
|
88
|
+
{:else}
|
|
89
|
+
<div class="text-center">Document not found</div>
|
|
90
|
+
{/if}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
|
|
3
|
+
|
|
4
|
+
// Skipping for now, not sure how to handle tests with remote functions that throw errors
|
|
5
|
+
describe.skip("Read-Only Mode Remote Functions Tests", () => {
|
|
6
|
+
let originalEnv: string | undefined;
|
|
7
|
+
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
// Store original env value
|
|
10
|
+
originalEnv = process.env.MONGOKU_READ_ONLY_MODE;
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
afterEach(() => {
|
|
14
|
+
// Restore original env value
|
|
15
|
+
if (originalEnv !== undefined) {
|
|
16
|
+
process.env.MONGOKU_READ_ONLY_MODE = originalEnv;
|
|
17
|
+
} else {
|
|
18
|
+
delete process.env.MONGOKU_READ_ONLY_MODE;
|
|
19
|
+
}
|
|
20
|
+
vi.clearAllMocks();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
describe("updateDocument", () => {
|
|
24
|
+
it("should throw error when trying to update a document in read-only mode", async () => {
|
|
25
|
+
process.env.MONGOKU_READ_ONLY_MODE = "true";
|
|
26
|
+
|
|
27
|
+
const { updateDocument } = await import("../../api/servers.remote");
|
|
28
|
+
|
|
29
|
+
try {
|
|
30
|
+
await updateDocument({
|
|
31
|
+
server: "test",
|
|
32
|
+
database: "testdb",
|
|
33
|
+
collection: "testcol",
|
|
34
|
+
document: "507f1f77bcf86cd799439011",
|
|
35
|
+
value: { name: "updated" },
|
|
36
|
+
partial: false,
|
|
37
|
+
});
|
|
38
|
+
expect.fail("Should have thrown an error");
|
|
39
|
+
} catch (error: any) {
|
|
40
|
+
expect(error.status).toBe(403);
|
|
41
|
+
expect(error.body.message).toContain("Read-only mode");
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it("should allow updates when not in read-only mode", async () => {
|
|
46
|
+
delete process.env.MONGOKU_READ_ONLY_MODE;
|
|
47
|
+
|
|
48
|
+
const { updateDocument } = await import("../../api/servers.remote");
|
|
49
|
+
|
|
50
|
+
// Should work or fail for a different reason
|
|
51
|
+
try {
|
|
52
|
+
const response = await updateDocument({
|
|
53
|
+
server: "test",
|
|
54
|
+
database: "testdb",
|
|
55
|
+
collection: "testcol",
|
|
56
|
+
document: "507f1f77bcf86cd799439011",
|
|
57
|
+
value: { name: "updated" },
|
|
58
|
+
partial: false,
|
|
59
|
+
});
|
|
60
|
+
// Success case
|
|
61
|
+
expect(response.ok).toBe(true);
|
|
62
|
+
} catch (error: any) {
|
|
63
|
+
// If it fails, it shouldn't be because of read-only mode
|
|
64
|
+
expect(error.status).not.toBe(403);
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
describe("deleteDocument", () => {
|
|
70
|
+
it("should throw error when trying to delete a document in read-only mode", async () => {
|
|
71
|
+
process.env.MONGOKU_READ_ONLY_MODE = "true";
|
|
72
|
+
|
|
73
|
+
const { deleteDocument } = await import("../../api/servers.remote");
|
|
74
|
+
|
|
75
|
+
try {
|
|
76
|
+
await deleteDocument({
|
|
77
|
+
server: "test",
|
|
78
|
+
database: "testdb",
|
|
79
|
+
collection: "testcol",
|
|
80
|
+
document: "507f1f77bcf86cd799439011",
|
|
81
|
+
});
|
|
82
|
+
expect.fail("Should have thrown an error");
|
|
83
|
+
} catch (error: any) {
|
|
84
|
+
expect(error.status).toBe(403);
|
|
85
|
+
expect(error.body.message).toContain("Read-only mode");
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
});
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { vi } from "vitest";
|
|
2
|
+
|
|
3
|
+
// Mock the mongo module to avoid actual MongoDB connections during tests
|
|
4
|
+
vi.mock("$lib/server/mongo", () => ({
|
|
5
|
+
getMongo: vi.fn(() =>
|
|
6
|
+
Promise.resolve({
|
|
7
|
+
findOne: vi.fn(),
|
|
8
|
+
find: vi.fn(),
|
|
9
|
+
count: vi.fn(),
|
|
10
|
+
updateOne: vi.fn(),
|
|
11
|
+
removeOne: vi.fn(),
|
|
12
|
+
getServersJson: vi.fn(() => Promise.resolve([])),
|
|
13
|
+
getDatabasesJson: vi.fn(() => Promise.resolve([])),
|
|
14
|
+
getCollectionsJson: vi.fn(() => Promise.resolve([])),
|
|
15
|
+
addServer: vi.fn(),
|
|
16
|
+
removeServer: vi.fn(),
|
|
17
|
+
}),
|
|
18
|
+
),
|
|
19
|
+
}));
|
package/svelte.config.js
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import adapter from "@sveltejs/adapter-node";
|
|
2
|
+
import { vitePreprocess } from "@sveltejs/vite-plugin-svelte";
|
|
3
|
+
|
|
4
|
+
/** @type {import('@sveltejs/kit').Config} */
|
|
5
|
+
const config = {
|
|
6
|
+
preprocess: vitePreprocess(),
|
|
7
|
+
|
|
8
|
+
kit: {
|
|
9
|
+
adapter: adapter({
|
|
10
|
+
out: "build",
|
|
11
|
+
envPrefix: "MONGOKU_SERVER_",
|
|
12
|
+
}),
|
|
13
|
+
experimental: {
|
|
14
|
+
remoteFunctions: true,
|
|
15
|
+
},
|
|
16
|
+
alias: {
|
|
17
|
+
$api: "src/api",
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
|
|
21
|
+
compilerOptions: {
|
|
22
|
+
experimental: {
|
|
23
|
+
async: true,
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export default config;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "./tsconfig.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"module": "esnext",
|
|
5
|
+
"target": "es2022",
|
|
6
|
+
"moduleResolution": "bundler",
|
|
7
|
+
"outDir": "./dist",
|
|
8
|
+
"rootDir": ".",
|
|
9
|
+
"declaration": false,
|
|
10
|
+
"esModuleInterop": true,
|
|
11
|
+
"skipLibCheck": true
|
|
12
|
+
},
|
|
13
|
+
"include": ["cli.ts"],
|
|
14
|
+
"exclude": ["node_modules", "src", "build", ".svelte-kit"]
|
|
15
|
+
}
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "./.svelte-kit/tsconfig.json",
|
|
3
|
+
"compilerOptions": {
|
|
4
|
+
"allowJs": true,
|
|
5
|
+
"checkJs": true,
|
|
6
|
+
"esModuleInterop": true,
|
|
7
|
+
"forceConsistentCasingInFileNames": true,
|
|
8
|
+
"resolveJsonModule": true,
|
|
9
|
+
"skipLibCheck": true,
|
|
10
|
+
"sourceMap": true,
|
|
11
|
+
"strict": true,
|
|
12
|
+
"moduleResolution": "bundler"
|
|
13
|
+
}
|
|
14
|
+
// Path aliases are handled by https://svelte.dev/docs/kit/configuration#alias
|
|
15
|
+
// except $lib which is handled by https://svelte.dev/docs/kit/configuration#files
|
|
16
|
+
//
|
|
17
|
+
// To make changes to top-level options such as include and exclude, we recommend extending
|
|
18
|
+
// the generated config; see https://svelte.dev/docs/kit/configuration#typescript
|
|
19
|
+
}
|
package/vite.config.ts
ADDED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import"./DsnmJJEf.js";import{l as L,p as U,M as B,V as X,a1 as Y,i as t,Q as Z,N as w,f as c,d as b,aa as $,ab as tt,r as n,s as N,a8 as Q,b as h,c as et,t as H,e as V}from"./zeTqHWB5.js";import{i as j}from"./DRy_44ib.js";import{t as rt,e as M,i as P,b as k}from"./CrJSDly5.js";import{b as q}from"./BuIrCFA_.js";function R(o,a={},i,r){for(var l in i){var e=i[l];a[l]!==e&&(i[l]==null?o.style.removeProperty(l):o.style.setProperty(l,e,r))}}function ot(o,a,i,r){var l=o.__style;if(L||l!==a){var e=rt(a,r);(!L||e!==o.getAttribute("style"))&&(e==null?o.removeAttribute("style"):o.style.cssText=e),o.__style=a}else r&&(Array.isArray(r)?(R(o,i?.[0],r[0]),R(o,i?.[1],r[1],"important")):R(o,i,r));return r}var at=c("<th> </th>"),it=c("<thead><tr></tr></thead>"),lt=c("<td> </td>"),st=c("<tr></tr>"),nt=c('<div class="absolute bg-[var(--color-2)] border border-[var(--color-3)] rounded p-0 z-[1000] whitespace-nowrap shadow-lg"><table class="w-full border-collapse text-base font-medium"><!><tbody></tbody></table></div>'),dt=c('<div class="relative inline-block"><button class="dotted text-center"><!></button> <!></div>');function ht(o,a){U(a,!0);let i=B(!1),r=B(void 0),l=B(void 0),e=B(X({left:"",right:"",top:"",bottom:"",marginTop:"",marginBottom:""}));function D(){w(i,!0)}function F(){w(i,!1)}Y(()=>{t(i)&&t(r)&&t(l)&&Z().then(()=>{if(!t(l)||!t(r))return;const f=t(r).getBoundingClientRect(),v=window.innerWidth,y=window.innerHeight;w(e,{left:"",right:"",top:"",bottom:"",marginTop:"",marginBottom:""},!0),f.right>v?t(e).right="0":t(e).left="0",f.bottom>y?(t(e).bottom="100%",t(e).marginBottom="5px"):(t(e).top="100%",t(e).marginTop="5px")})});var x=dt(),m=b(x),G=b(m);$(G,()=>a.children??tt),n(m);var I=N(m,2);{var J=f=>{var v=nt();let y;var W=b(v),z=b(W);{var K=d=>{var u=it(),g=b(u);M(g,21,()=>a.columns,P,(A,s)=>{var _=at();let E;var p=b(_,!0);n(_),H(T=>{E=k(_,1,"px-2 py-1 border-b border-[var(--color-3)] bg-[var(--color-4)] font-bold",null,E,T),V(p,t(s).header)},[()=>({"text-left":t(s).align==="left"||!t(s).align,"text-right":t(s).align==="right","text-center":t(s).align==="center"})]),h(A,_)}),n(g),n(u),h(d,u)};j(z,d=>{a.hideHeader||d(K)})}var C=N(z);M(C,21,()=>a.rows,P,(d,u)=>{var g=st();M(g,21,()=>a.columns,P,(A,s,_,E)=>{var p=lt();let T;var O=b(p,!0);n(p),H(S=>{T=k(p,1,"px-2 py-1 border-b border-[var(--color-3)]",null,T,S),V(O,t(u)[t(s).key])},[()=>({"text-left":t(s).align==="left"||!t(s).align,"text-right":t(s).align==="right","text-center":t(s).align==="center"})]),h(A,p)}),n(g),h(d,g)}),n(C),n(W),n(v),q(v,d=>w(r,d),()=>t(r)),H(d=>y=ot(v,"",y,d),[()=>({left:t(e).left,right:t(e).right,top:t(e).top,bottom:t(e).bottom,"margin-top":t(e).marginTop,"margin-bottom":t(e).marginBottom})]),h(f,v)};j(I,f=>{t(i)&&f(J)})}n(x),q(x,f=>w(l,f),()=>t(l)),Q("mouseenter",m,D),Q("mouseleave",m,F),h(o,x),et()}export{ht as T};
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{W as t,S,R as b,B as h,X as k}from"./zeTqHWB5.js";function u(r,i){return r===i||r?.[k]===i}function c(r={},i,a,B){return t(()=>{var f,s;return S(()=>{f=s,s=[],b(()=>{r!==a(...s)&&(i(r,...s),f&&u(a(...f),r)&&i(null,...f))})}),()=>{h(()=>{s&&u(a(...s),r)&&i(null,...s)})}}),r}export{c as b};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{ac as L,i as g,a5 as T,V as m,N as D,ad as B,ae as N,af as Y,X as h,ag as M,ah as U,R as x,ai as y,aj as $,ak as j,al as q,am as w,an as z,ao as C}from"./zeTqHWB5.js";let c=!1;function G(a){var r=c;try{return c=!1,[a(),c]}finally{c=r}}function X(a,r,t,d){var f=!z||(t&C)!==0,v=(t&w)!==0,E=(t&q)!==0,n=d,S=!0,o=()=>(S&&(S=!1,n=E?x(d):d),n),u;if(v){var O=h in a||M in a;u=L(a,r)?.set??(O&&r in a?e=>a[r]=e:void 0)}var _,I=!1;v?[_,I]=G(()=>a[r]):_=a[r],_===void 0&&d!==void 0&&(_=o(),u&&(f&&y(),u(_)));var i;if(f?i=()=>{var e=a[r];return e===void 0?o():(S=!0,e)}:i=()=>{var e=a[r];return e!==void 0&&(n=void 0),e===void 0?n:e},f&&(t&$)===0)return i;if(u){var A=a.$$legacy;return(function(e,l){return arguments.length>0?((!f||!l||A||I)&&u(l?i():e),e):i()})}var P=!1,s=((t&j)!==0?T:U)(()=>(P=!1,i()));v&&g(s);var b=N;return(function(e,l){if(arguments.length>0){const R=l?g(s):f&&v?m(e):e;return D(s,R),P=!0,n!==void 0&&(n=R),e}return B&&P||(b.f&Y)!==0?s.v:g(s)})}export{X as p};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{aR as a,a1 as d,aS as i,aT as g,G as t,au as m,aU as f,an as v,R as c,aV as y,L as x,aW as S,aX as h,aY as C,aL as O,aM as j,aZ as k,a_ as M,Q as w,aO as A}from"./zeTqHWB5.js";function P(){return i===null&&g(),(i.ac??=new AbortController).signal}function _(e){t===null&&a(),v&&t.l!==null?u(t).m.push(e):d(()=>{const n=c(e);if(typeof n=="function")return n})}function R(e){t===null&&a(),_(()=>()=>c(e))}function T(e,n,{bubbles:l=!1,cancelable:s=!1}={}){return new CustomEvent(e,{detail:n,bubbles:l,cancelable:s})}function U(){const e=t;return e===null&&a(),(n,l,s)=>{const o=e.s.$$events?.[n];if(o){const p=m(o)?o.slice():[o],r=T(n,l,s);for(const b of p)b.call(e.x,r);return!r.defaultPrevented}return!0}}function z(e){t===null&&a(),t.l===null&&f(),u(t).b.push(e)}function D(e){t===null&&a(),t.l===null&&f(),u(t).a.push(e)}function u(e){var n=e.l;return n.u??={a:[],b:[],m:[]}}const L=Object.freeze(Object.defineProperty({__proto__:null,afterUpdate:D,beforeUpdate:z,createEventDispatcher:U,createRawSnippet:y,flushSync:x,getAbortSignal:P,getAllContexts:S,getContext:h,hasContext:C,hydrate:O,mount:j,onDestroy:R,onMount:_,setContext:k,settled:M,tick:w,unmount:A,untrack:c},Symbol.toStringTag,{value:"Module"})),$=Object.freeze(Object.defineProperty({__proto__:null},Symbol.toStringTag,{value:"Module"}));export{$ as _,_ as o,L as s};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{M as r,V as c,N as a,i as e}from"./zeTqHWB5.js";let o=r(c([])),f=1;const m={get items(){return e(o)},notify(s,t="info"){const i=f++;a(o,[...e(o),{id:i,message:s,type:t}],!0),setTimeout(()=>{this.remove(i)},5e3)},async notifyError(s,t){const i=[s];if(t)try{const n=await t.json();i.push(`${t.status}: ${n.message}`)}catch{i.push(`${t.status}: ${await t.text()}`)}this.notify(i.join(" - "),"error")},notifySuccess(s){this.notify(s,"success")},remove(s){a(o,e(o).filter(t=>t.id!==s),!0)}};export{m as n};
|
|
Binary file
|
|
Binary file
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{_ as j,k as ur,v as P,l as m,aq as lr,m as vr,i as K,ah as or,Z as dr,H as cr,q as V,w as U,C as O,ar as _r,as as hr,A as F,$ as pr,P as Ar,x as X,z as Er,y as Z,at as y,au as Nr,av as x,I as rr,J as mr,aw as q,ax as Tr,ay as Y,az as er,aA as Ir,aB as gr,aC as Sr,aD as Mr,ae as Cr,B as ar,aE as fr,aF as wr,aG as br,aH as Hr,aI as Lr,aJ as Or,aK as Rr}from"./zeTqHWB5.js";import{b as Dr,r as xr}from"./BEuO9qGi.js";function Jr(e,a){return a}function qr(e,a,r){for(var f=e.items,i=[],t=a.length,n=0;n<t;n++)gr(a[n].e,i,!0);var o=t>0&&i.length===0&&r!==null;if(o){var E=r.parentNode;Sr(E),E.append(r),f.clear(),S(e,a[0].prev,a[t-1].next)}Mr(i,()=>{for(var _=0;_<t;_++){var h=a[_];o||(f.delete(h.k),S(e,h.prev,h.next)),er(h.e,!o)}})}function Kr(e,a,r,f,i,t=null){var n=e,o={flags:a,items:new Map,first:null},E=(a&fr)!==0;if(E){var _=e;n=m?P(lr(_)):_.appendChild(j())}m&&vr();var h=null,C=!1,T=new Map,w=or(()=>{var c=r();return Nr(c)?c:c==null?[]:y(c)}),u,d;function v(){Br(d,u,o,T,n,i,a,f,r),t!==null&&(u.length===0?h?rr(h):h=F(()=>t(n)):h!==null&&mr(h,()=>{h=null}))}ur(()=>{d??=Cr,u=K(w);var c=u.length;if(C&&c===0)return;C=c===0;let N=!1;if(m){var I=dr(n)===cr;I!==(c===0)&&(n=V(),P(n),U(!1),N=!0)}if(m){for(var M=null,p,s=0;s<c;s++){if(O.nodeType===_r&&O.data===hr){n=O,N=!0,U(!1);break}var l=u[s],A=f(l,s);p=J(O,o,M,null,l,A,s,i,a,r),o.items.set(A,p),M=p}c>0&&P(V())}if(m)c===0&&t&&(h=F(()=>t(n)));else if(pr()){var H=new Set,R=Ar;for(s=0;s<c;s+=1){l=u[s],A=f(l,s);var b=o.items.get(A)??T.get(A);b?(a&(q|x))!==0&&ir(b,l,s,a):(p=J(null,o,null,null,l,A,s,i,a,r,!0),T.set(A,p)),H.add(A)}for(const[g,D]of o.items)H.has(g)||R.skipped_effects.add(D.e);R.add_callback(v)}else v();N&&U(!0),K(w)}),m&&(n=O)}function Br(e,a,r,f,i,t,n,o,E){var _=(n&wr)!==0,h=(n&(q|x))!==0,C=a.length,T=r.items,w=r.first,u=w,d,v=null,c,N=[],I=[],M,p,s,l;if(_)for(l=0;l<C;l+=1)M=a[l],p=o(M,l),s=T.get(p),s!==void 0&&(s.a?.measure(),(c??=new Set).add(s));for(l=0;l<C;l+=1){if(M=a[l],p=o(M,l),s=T.get(p),s===void 0){var A=f.get(p);if(A!==void 0){f.delete(p),T.set(p,A);var H=v?v.next:u;S(r,v,A),S(r,A,H),z(A,H,i),v=A}else{var R=u?u.e.nodes_start:i;v=J(R,r,v,v===null?r.first:v.next,M,p,l,t,n,E)}T.set(p,v),N=[],I=[],u=v.next;continue}if(h&&ir(s,M,l,n),(s.e.f&Y)!==0&&(rr(s.e),_&&(s.a?.unfix(),(c??=new Set).delete(s))),s!==u){if(d!==void 0&&d.has(s)){if(N.length<I.length){var b=I[0],g;v=b.prev;var D=N[0],B=N[N.length-1];for(g=0;g<N.length;g+=1)z(N[g],b,i);for(g=0;g<I.length;g+=1)d.delete(I[g]);S(r,D.prev,B.next),S(r,v,D),S(r,B,b),u=b,v=B,l-=1,N=[],I=[]}else d.delete(s),z(s,u,i),S(r,s.prev,s.next),S(r,s,v===null?r.first:v.next),S(r,v,s),v=s;continue}for(N=[],I=[];u!==null&&u.k!==p;)(u.e.f&Y)===0&&(d??=new Set).add(u),I.push(u),u=u.next;if(u===null)continue;s=u}N.push(s),v=s,u=s.next}if(u!==null||d!==void 0){for(var L=d===void 0?[]:y(d);u!==null;)(u.e.f&Y)===0&&L.push(u),u=u.next;var G=L.length;if(G>0){var sr=(n&fr)!==0&&C===0?i:null;if(_){for(l=0;l<G;l+=1)L[l].a?.measure();for(l=0;l<G;l+=1)L[l].a?.fix()}qr(r,L,sr)}}_&&ar(()=>{if(c!==void 0)for(s of c)s.a?.apply()}),e.first=r.first&&r.first.e,e.last=v&&v.e;for(var tr of f.values())er(tr.e);f.clear()}function ir(e,a,r,f){(f&q)!==0&&X(e.v,a),(f&x)!==0?X(e.i,r):e.i=r}function J(e,a,r,f,i,t,n,o,E,_,h){var C=(E&q)!==0,T=(E&Tr)===0,w=C?T?Er(i,!1,!1):Z(i):i,u=(E&x)===0?n:Z(n),d={i:u,v:w,k:t,a:null,e:null,prev:r,next:f};try{if(e===null){var v=document.createDocumentFragment();v.append(e=j())}return d.e=F(()=>o(e,w,u,_),m),d.e.prev=r&&r.e,d.e.next=f&&f.e,r===null?h||(a.first=d):(r.next=d,r.e.next=d.e),f!==null&&(f.prev=d,f.e.prev=d.e),d}finally{}}function z(e,a,r){for(var f=e.next?e.next.e.nodes_start:r,i=a?a.e.nodes_start:r,t=e.e.nodes_start;t!==null&&t!==f;){var n=Ir(t);i.before(t),t=n}}function S(e,a,r){a===null?e.first=r:(a.next=r,a.e.next=r&&r.e),r!==null&&(r.prev=a,r.e.prev=a&&a.e)}const $=[...`
|
|
2
|
-
\r\f \v\uFEFF`];function Gr(e,a,r){var f=e==null?"":""+e;if(a&&(f=f?f+" "+a:a),r){for(var i in r)if(r[i])f=f?f+" "+i:i;else if(f.length)for(var t=i.length,n=0;(n=f.indexOf(i,n))>=0;){var o=n+t;(n===0||$.includes(f[n-1]))&&(o===f.length||$.includes(f[o]))?f=(n===0?"":f.substring(0,n))+f.substring(o+1):n=o}}return f===""?null:f}function Q(e,a=!1){var r=a?" !important;":";",f="";for(var i in e){var t=e[i];t!=null&&t!==""&&(f+=" "+i+": "+t+r)}return f}function Vr(e,a){if(a){var r="",f,i;return Array.isArray(a)?(f=a[0],i=a[1]):f=a,f&&(r+=Q(f)),i&&(r+=Q(i,!0)),r=r.trim(),r===""?null:r}return String(e)}function Xr(e,a,r,f,i,t){var n=e.__className;if(m||n!==r||n===void 0){var o=Gr(r,f,t);(!m||o!==e.getAttribute("class"))&&(o==null?e.removeAttribute("class"):e.className=o),e.__className=r}else if(t&&i!==t)for(var E in t){var _=!!t[E];(i==null||_!==!!i[E])&&e.classList.toggle(E,_)}return t}const Pr=Symbol("is custom element"),Ur=Symbol("is html");function Zr(e){if(m){var a=!1,r=()=>{if(!a){if(a=!0,e.hasAttribute("value")){var f=e.value;W(e,"value",null),e.value=f}if(e.hasAttribute("checked")){var i=e.checked;W(e,"checked",null),e.checked=i}}};e.__on_r=r,ar(r),Hr()}}function $r(e,a){var r=nr(e);r.value===(r.value=a??void 0)||e.value===a&&(a!==0||e.nodeName!=="PROGRESS")||(e.value=a??"")}function W(e,a,r,f){var i=nr(e);m&&(i[a]=e.getAttribute(a),a==="src"||a==="srcset"||a==="href"&&e.nodeName==="LINK")||i[a]!==(i[a]=r)&&(a==="loading"&&(e[Lr]=r),r==null?e.removeAttribute(a):typeof r!="string"&&Yr(e).includes(a)?e[a]=r:e.setAttribute(a,r))}function nr(e){return e.__attributes??={[Pr]:e.nodeName.includes("-"),[Ur]:e.namespaceURI===br}}var k=new Map;function Yr(e){var a=e.getAttribute("is")||e.nodeName,r=k.get(a);if(r)return r;k.set(a,r=[]);for(var f,i=e,t=Element.prototype;t!==i;){f=Rr(i);for(var n in f)f[n].set&&r.push(n);i=Or(i)}return r}function Qr(...e){return Dr+xr(e[0],e[1])}export{Zr as a,Xr as b,$r as c,Kr as e,Jr as i,Qr as r,W as s,Vr as t};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{k as I,l as _,m as N,Y as R,Z as x,H as C,q as D,v as F,w as p,_ as S,A as b,P as q,U as H,$ as L,I as P,J as U,C as Y}from"./zeTqHWB5.js";function w(k,T,g=!1){_&&N();var r=k,s=null,t=null,e=H,y=g?R:0,l=!1;const A=(n,a=!0)=>{l=!0,o(a,n)};var f=null;function d(){f!==null&&(f.lastChild.remove(),r.before(f),f=null);var n=e?s:t,a=e?t:s;n&&P(n),a&&U(a,()=>{e?t=null:s=null})}const o=(n,a)=>{if(e===(e=n))return;let u=!1;if(_){const E=x(r)===C;!!e===E&&(r=D(),F(r),p(!1),u=!0)}var v=L(),i=r;if(v&&(f=document.createDocumentFragment(),f.append(i=S())),e?s??=a&&b(()=>a(i)):t??=a&&b(()=>a(i)),v){var c=q,h=e?s:t,m=e?t:s;h&&c.skipped_effects.delete(h),m&&c.skipped_effects.add(m),c.add_callback(d)}else d();u&&p(!0)};I(()=>{l=!1,T(A),l||o(null,null)},y),_&&(r=Y)}export{w as i};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{G as d,a0 as g,a1 as c,R as m,a2 as i,a3 as b,i as p,a4 as v,a5 as h,a6 as k}from"./zeTqHWB5.js";function x(t=!1){const a=d,e=a.l.u;if(!e)return;let f=()=>v(a.s);if(t){let n=0,s={};const _=h(()=>{let l=!1;const r=a.s;for(const o in r)r[o]!==s[o]&&(s[o]=r[o],l=!0);return l&&n++,n});f=()=>p(_)}e.b.length&&g(()=>{u(a,f),i(e.b)}),c(()=>{const n=m(()=>e.m.map(b));return()=>{for(const s of n)typeof s=="function"&&s()}}),e.a.length&&c(()=>{u(a,f),i(e.a)})}function u(t,a){if(t.l.s)for(const e of t.l.s)p(e);a()}k();export{x as i};
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
typeof window<"u"&&((window.__svelte??={}).v??=new Set).add("5");
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|