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.
Files changed (292) hide show
  1. package/Dockerfile +27 -0
  2. package/README.md +8 -0
  3. package/build/client/_app/immutable/assets/0.BHsXFfsc.css.gz +0 -0
  4. package/build/client/_app/immutable/assets/PrettyJson.CtngcfyW.css.gz +0 -0
  5. package/build/client/_app/immutable/chunks/{W-qL5_8w.js → BAM9w9EL.js} +1 -1
  6. package/build/client/_app/immutable/chunks/BAM9w9EL.js.br +0 -0
  7. package/build/client/_app/immutable/chunks/BAM9w9EL.js.gz +0 -0
  8. package/build/client/_app/immutable/chunks/BKCvWebR.js +23 -0
  9. package/build/client/_app/immutable/chunks/BKCvWebR.js.br +0 -0
  10. package/build/client/_app/immutable/chunks/BKCvWebR.js.gz +0 -0
  11. package/build/client/_app/immutable/chunks/{Dbyirw23.js → BMa204Dm.js} +3 -3
  12. package/build/client/_app/immutable/chunks/BMa204Dm.js.br +0 -0
  13. package/build/client/_app/immutable/chunks/BMa204Dm.js.gz +0 -0
  14. package/build/client/_app/immutable/chunks/BN_N9-2s.js.gz +0 -0
  15. package/build/client/_app/immutable/chunks/BY57TmdO.js +1 -0
  16. package/build/client/_app/immutable/chunks/BY57TmdO.js.br +0 -0
  17. package/build/client/_app/immutable/chunks/BY57TmdO.js.gz +0 -0
  18. package/build/client/_app/immutable/chunks/BaB-cr9N.js +2 -0
  19. package/build/client/_app/immutable/chunks/BaB-cr9N.js.br +0 -0
  20. package/build/client/_app/immutable/chunks/BaB-cr9N.js.gz +0 -0
  21. package/build/client/_app/immutable/chunks/BdR-m9Ad.js +1 -0
  22. package/build/client/_app/immutable/chunks/BdR-m9Ad.js.br +0 -0
  23. package/build/client/_app/immutable/chunks/BdR-m9Ad.js.gz +0 -0
  24. package/build/client/_app/immutable/chunks/ByjLCPv2.js +1 -0
  25. package/build/client/_app/immutable/chunks/ByjLCPv2.js.br +0 -0
  26. package/build/client/_app/immutable/chunks/ByjLCPv2.js.gz +0 -0
  27. package/build/client/_app/immutable/chunks/BzAcxkRZ.js +4 -0
  28. package/build/client/_app/immutable/chunks/BzAcxkRZ.js.br +0 -0
  29. package/build/client/_app/immutable/chunks/BzAcxkRZ.js.gz +0 -0
  30. package/build/client/_app/immutable/chunks/CyQLXPZI.js +2 -0
  31. package/build/client/_app/immutable/chunks/CyQLXPZI.js.br +0 -0
  32. package/build/client/_app/immutable/chunks/CyQLXPZI.js.gz +0 -0
  33. package/build/client/_app/immutable/chunks/D17Lj1H7.js +1 -0
  34. package/build/client/_app/immutable/chunks/D17Lj1H7.js.br +0 -0
  35. package/build/client/_app/immutable/chunks/D17Lj1H7.js.gz +0 -0
  36. package/build/client/_app/immutable/chunks/D4VhtiDg.js +1 -0
  37. package/build/client/_app/immutable/chunks/D4VhtiDg.js.br +0 -0
  38. package/build/client/_app/immutable/chunks/D4VhtiDg.js.gz +0 -0
  39. package/build/client/_app/immutable/chunks/D72Du7TF.js +1 -0
  40. package/build/client/_app/immutable/chunks/D72Du7TF.js.br +2 -0
  41. package/build/client/_app/immutable/chunks/D72Du7TF.js.gz +0 -0
  42. package/build/client/_app/immutable/chunks/{DZSJW-Zm.js → XYFbSe2V.js} +1 -1
  43. package/build/client/_app/immutable/chunks/XYFbSe2V.js.br +0 -0
  44. package/build/client/_app/immutable/chunks/XYFbSe2V.js.gz +0 -0
  45. package/build/client/_app/immutable/chunks/iHsChU5o.js +1 -0
  46. package/build/client/_app/immutable/chunks/iHsChU5o.js.br +0 -0
  47. package/build/client/_app/immutable/chunks/iHsChU5o.js.gz +0 -0
  48. package/build/client/_app/immutable/chunks/{DzSHMQR7.js → p23QjN60.js} +1 -1
  49. package/build/client/_app/immutable/chunks/p23QjN60.js.br +2 -0
  50. package/build/client/_app/immutable/chunks/p23QjN60.js.gz +0 -0
  51. package/build/client/_app/immutable/chunks/sBKW2MYH.js +1 -0
  52. package/build/client/_app/immutable/chunks/sBKW2MYH.js.br +0 -0
  53. package/build/client/_app/immutable/chunks/sBKW2MYH.js.gz +0 -0
  54. package/build/client/_app/immutable/chunks/{BEuO9qGi.js → uMNMODvc.js} +1 -1
  55. package/build/client/_app/immutable/chunks/uMNMODvc.js.br +0 -0
  56. package/build/client/_app/immutable/chunks/uMNMODvc.js.gz +0 -0
  57. package/build/client/_app/immutable/entry/app.9nC_873E.js +2 -0
  58. package/build/client/_app/immutable/entry/app.9nC_873E.js.br +0 -0
  59. package/build/client/_app/immutable/entry/app.9nC_873E.js.gz +0 -0
  60. package/build/client/_app/immutable/entry/start.Bn88Alw2.js +1 -0
  61. package/build/client/_app/immutable/entry/start.Bn88Alw2.js.br +2 -0
  62. package/build/client/_app/immutable/entry/start.Bn88Alw2.js.gz +0 -0
  63. package/build/client/_app/immutable/nodes/{0.B2lBDs71.js → 0.COxTCtn2.js} +1 -1
  64. package/build/client/_app/immutable/nodes/0.COxTCtn2.js.br +0 -0
  65. package/build/client/_app/immutable/nodes/0.COxTCtn2.js.gz +0 -0
  66. package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js +1 -0
  67. package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js.br +0 -0
  68. package/build/client/_app/immutable/nodes/1.Bc8yPK_D.js.gz +0 -0
  69. package/build/client/_app/immutable/nodes/3.CI2GcqTf.js +1 -0
  70. package/build/client/_app/immutable/nodes/3.CI2GcqTf.js.br +0 -0
  71. package/build/client/_app/immutable/nodes/3.CI2GcqTf.js.gz +0 -0
  72. package/build/client/_app/immutable/nodes/{4.BqBphmVX.js → 4.ChSdW7ac.js} +1 -1
  73. package/build/client/_app/immutable/nodes/4.ChSdW7ac.js.br +0 -0
  74. package/build/client/_app/immutable/nodes/4.ChSdW7ac.js.gz +0 -0
  75. package/build/client/_app/immutable/nodes/{5.BkAWRgl4.js → 5.DaMML2go.js} +1 -1
  76. package/build/client/_app/immutable/nodes/5.DaMML2go.js.br +0 -0
  77. package/build/client/_app/immutable/nodes/5.DaMML2go.js.gz +0 -0
  78. package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js +1 -0
  79. package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js.br +0 -0
  80. package/build/client/_app/immutable/nodes/6.Dcq0qwvO.js.gz +0 -0
  81. package/build/client/_app/immutable/nodes/7.CU-ncPes.js +1 -0
  82. package/build/client/_app/immutable/nodes/7.CU-ncPes.js.br +0 -0
  83. package/build/client/_app/immutable/nodes/7.CU-ncPes.js.gz +0 -0
  84. package/build/client/_app/version.json +1 -1
  85. package/build/client/_app/version.json.br +0 -0
  86. package/build/client/_app/version.json.gz +0 -0
  87. package/build/server/chunks/{0-BGoFMRn2.js → 0-C1NyHW8A.js} +3 -3
  88. package/build/server/chunks/{0-BGoFMRn2.js.map → 0-C1NyHW8A.js.map} +1 -1
  89. package/build/server/chunks/1-CThf4W5r.js +9 -0
  90. package/build/server/chunks/{1-Ch0AY58K.js.map → 1-CThf4W5r.js.map} +1 -1
  91. package/build/server/chunks/{3-Bmk9Qof9.js → 3-CJf0NbiV.js} +3 -3
  92. package/build/server/chunks/{3-Bmk9Qof9.js.map → 3-CJf0NbiV.js.map} +1 -1
  93. package/build/server/chunks/{4-DnpScx2e.js → 4-Dfbpsagm.js} +3 -3
  94. package/build/server/chunks/{4-DnpScx2e.js.map → 4-Dfbpsagm.js.map} +1 -1
  95. package/build/server/chunks/{5-Bw8bTTBj.js → 5-DLB6GOjf.js} +3 -3
  96. package/build/server/chunks/{5-Bw8bTTBj.js.map → 5-DLB6GOjf.js.map} +1 -1
  97. package/build/server/chunks/{6-D8zNoyW_.js → 6-DfCARDKO.js} +10 -5
  98. package/build/server/chunks/6-DfCARDKO.js.map +1 -0
  99. package/build/server/chunks/{7-Cim4qVL3.js → 7-B5o4OymX.js} +3 -3
  100. package/build/server/chunks/{7-Cim4qVL3.js.map → 7-B5o4OymX.js.map} +1 -1
  101. package/build/server/chunks/{Panel-DTdYk-gk.js → Panel-Box8ld78.js} +3 -3
  102. package/build/server/chunks/Panel-Box8ld78.js.map +1 -0
  103. package/build/server/chunks/{PrettyJson-wIuHvehp.js → PrettyJson-C2c9xGNo.js} +5 -5
  104. package/build/server/chunks/PrettyJson-C2c9xGNo.js.map +1 -0
  105. package/build/server/chunks/{TooltipTable-J278e1CA.js → TooltipTable-0z4HkHlH.js} +3 -1
  106. package/build/server/chunks/TooltipTable-0z4HkHlH.js.map +1 -0
  107. package/build/server/chunks/{_layout.svelte-D7RD9tLN.js → _layout.svelte-CU7AVRSZ.js} +14 -11
  108. package/build/server/chunks/_layout.svelte-CU7AVRSZ.js.map +1 -0
  109. package/build/server/chunks/{_page.svelte-4PYYtPii.js → _page.svelte-B_T8EFk3.js} +7 -6
  110. package/build/server/chunks/_page.svelte-B_T8EFk3.js.map +1 -0
  111. package/build/server/chunks/{_page.svelte-Be5VTn1e.js → _page.svelte-CflJkclc.js} +7 -6
  112. package/build/server/chunks/_page.svelte-CflJkclc.js.map +1 -0
  113. package/build/server/chunks/{_page.svelte-DZ59Sr3N.js → _page.svelte-D1QIZqLv.js} +65 -42
  114. package/build/server/chunks/_page.svelte-D1QIZqLv.js.map +1 -0
  115. package/build/server/chunks/{_page.svelte-DIPUjSjm.js → _page.svelte-PuIVQ52p.js} +20 -8
  116. package/build/server/chunks/_page.svelte-PuIVQ52p.js.map +1 -0
  117. package/build/server/chunks/_page.svelte-zlHeUnJK.js +101 -0
  118. package/build/server/chunks/_page.svelte-zlHeUnJK.js.map +1 -0
  119. package/build/server/chunks/{context-BU6gUbSI.js → async-BfR0vYHo.js} +8 -46
  120. package/build/server/chunks/async-BfR0vYHo.js.map +1 -0
  121. package/build/server/chunks/client-bj7sePQc.js +7 -0
  122. package/build/server/chunks/{client-BZtxOgbR.js.map → client-bj7sePQc.js.map} +1 -1
  123. package/build/server/chunks/{client2-LilSGYJA.js → client2-BX4-xbM4.js} +6 -5
  124. package/build/server/chunks/{client2-LilSGYJA.js.map → client2-BX4-xbM4.js.map} +1 -1
  125. package/build/server/chunks/error.svelte-D5sIJv3P.js +18 -0
  126. package/build/server/chunks/error.svelte-D5sIJv3P.js.map +1 -0
  127. package/build/server/chunks/event-DVH-6ISX.js +64 -0
  128. package/build/server/chunks/event-DVH-6ISX.js.map +1 -0
  129. package/build/server/chunks/{exports-DiyTWREe.js → exports-Cv9LZeD1.js} +2 -39
  130. package/build/server/chunks/exports-Cv9LZeD1.js.map +1 -0
  131. package/build/server/chunks/hooks.server-_TKfdzGA.js +26 -0
  132. package/build/server/chunks/hooks.server-_TKfdzGA.js.map +1 -0
  133. package/build/server/chunks/{index-XFKuhGxM.js → index-EKt9-9bV.js} +2 -2
  134. package/build/server/chunks/{index-XFKuhGxM.js.map → index-EKt9-9bV.js.map} +1 -1
  135. package/build/server/chunks/{index3-CUhdJ7wv.js → index3-DquTjlmp.js} +3 -3
  136. package/build/server/chunks/index3-DquTjlmp.js.map +1 -0
  137. package/build/server/chunks/{notifications.svelte-CrTIrfvL.js → notifications.svelte-CIqkoPWX.js} +6 -12
  138. package/build/server/chunks/notifications.svelte-CIqkoPWX.js.map +1 -0
  139. package/build/server/chunks/remote-xxtqbu-BFzaWXy0.js +234 -0
  140. package/build/server/chunks/remote-xxtqbu-BFzaWXy0.js.map +1 -0
  141. package/build/server/chunks/{routing-zIlQn_LN.js → routing-Ddj5b-2K.js} +25 -4
  142. package/build/server/chunks/routing-Ddj5b-2K.js.map +1 -0
  143. package/build/server/chunks/{server2-DfQrrcsk.js → server2-BOoUfKd7.js} +3 -3
  144. package/build/server/chunks/{server2-DfQrrcsk.js.map → server2-BOoUfKd7.js.map} +1 -1
  145. package/build/server/chunks/{state.svelte-s-CFCWQX.js → state.svelte-CRHA9yov.js} +3 -2
  146. package/build/server/chunks/{state.svelte-s-CFCWQX.js.map → state.svelte-CRHA9yov.js.map} +1 -1
  147. package/build/server/chunks/utils-DGYJFmnf.js +39 -0
  148. package/build/server/chunks/utils-DGYJFmnf.js.map +1 -0
  149. package/build/server/index.js +71 -24
  150. package/build/server/index.js.map +1 -1
  151. package/build/server/manifest.js +9 -30
  152. package/build/server/manifest.js.map +1 -1
  153. package/cli.ts +148 -0
  154. package/dist/cli.js +3 -4
  155. package/ecosystem.config.js +9 -0
  156. package/package.json +88 -81
  157. package/src/api/servers.remote.ts +98 -0
  158. package/src/app.css +228 -0
  159. package/src/app.d.ts +16 -0
  160. package/src/app.html +11 -0
  161. package/src/hooks.server.ts +34 -0
  162. package/src/lib/components/Breadcrumbs.svelte +133 -0
  163. package/src/lib/components/JsonValue.svelte +248 -0
  164. package/src/lib/components/Notifications.svelte +81 -0
  165. package/src/lib/components/Panel.svelte +37 -0
  166. package/src/lib/components/PrettyJson.svelte +187 -0
  167. package/src/lib/components/SearchBox.svelte +160 -0
  168. package/src/lib/components/TooltipTable.svelte +137 -0
  169. package/src/lib/server/HostsManager.ts +105 -0
  170. package/src/lib/server/JsonEncoder.ts +62 -0
  171. package/src/lib/server/mongo.ts +199 -0
  172. package/src/lib/stores/notifications.svelte.ts +45 -0
  173. package/src/lib/types.ts +56 -0
  174. package/src/lib/utils/filters.ts +25 -0
  175. package/src/lib/utils/jsonParser.ts +125 -0
  176. package/src/routes/+layout.server.ts +7 -0
  177. package/src/routes/+layout.svelte +27 -0
  178. package/src/routes/+page.server.ts +6 -0
  179. package/src/routes/servers/+page.server.ts +53 -0
  180. package/src/routes/servers/+page.svelte +196 -0
  181. package/src/routes/servers/[server]/databases/+page.server.ts +47 -0
  182. package/src/routes/servers/[server]/databases/+page.svelte +88 -0
  183. package/src/routes/servers/[server]/databases/[database]/collections/+page.server.ts +21 -0
  184. package/src/routes/servers/[server]/databases/[database]/collections/+page.svelte +110 -0
  185. package/src/routes/servers/[server]/databases/[database]/collections/[collection]/+page.server.ts +106 -0
  186. package/src/routes/servers/[server]/databases/[database]/collections/[collection]/+page.svelte +174 -0
  187. package/src/routes/servers/[server]/databases/[database]/collections/[collection]/documents/[document]/+page.server.ts +25 -0
  188. package/src/routes/servers/[server]/databases/[database]/collections/[collection]/documents/[document]/+page.svelte +90 -0
  189. package/src/tests/api/readonly.test.ts +89 -0
  190. package/src/tests/setup.ts +19 -0
  191. package/svelte.config.js +28 -0
  192. package/tsconfig.cli.json +15 -0
  193. package/tsconfig.json +19 -0
  194. package/vite.config.ts +7 -0
  195. package/build/client/_app/immutable/chunks/B-Z1NsR7.js +0 -1
  196. package/build/client/_app/immutable/chunks/B-Z1NsR7.js.br +0 -0
  197. package/build/client/_app/immutable/chunks/B-Z1NsR7.js.gz +0 -0
  198. package/build/client/_app/immutable/chunks/BEuO9qGi.js.br +0 -0
  199. package/build/client/_app/immutable/chunks/BEuO9qGi.js.gz +0 -0
  200. package/build/client/_app/immutable/chunks/BuIrCFA_.js +0 -1
  201. package/build/client/_app/immutable/chunks/BuIrCFA_.js.br +0 -0
  202. package/build/client/_app/immutable/chunks/BuIrCFA_.js.gz +0 -0
  203. package/build/client/_app/immutable/chunks/C9b4uNov.js +0 -1
  204. package/build/client/_app/immutable/chunks/C9b4uNov.js.br +0 -0
  205. package/build/client/_app/immutable/chunks/C9b4uNov.js.gz +0 -0
  206. package/build/client/_app/immutable/chunks/CIYBIyvN.js +0 -1
  207. package/build/client/_app/immutable/chunks/CIYBIyvN.js.br +0 -0
  208. package/build/client/_app/immutable/chunks/CIYBIyvN.js.gz +0 -0
  209. package/build/client/_app/immutable/chunks/CWUhQKKC.js +0 -1
  210. package/build/client/_app/immutable/chunks/CWUhQKKC.js.br +0 -0
  211. package/build/client/_app/immutable/chunks/CWUhQKKC.js.gz +0 -0
  212. package/build/client/_app/immutable/chunks/CrJSDly5.js +0 -2
  213. package/build/client/_app/immutable/chunks/CrJSDly5.js.br +0 -0
  214. package/build/client/_app/immutable/chunks/CrJSDly5.js.gz +0 -0
  215. package/build/client/_app/immutable/chunks/DRy_44ib.js +0 -1
  216. package/build/client/_app/immutable/chunks/DRy_44ib.js.br +0 -0
  217. package/build/client/_app/immutable/chunks/DRy_44ib.js.gz +0 -0
  218. package/build/client/_app/immutable/chunks/DS5yzhLt.js +0 -1
  219. package/build/client/_app/immutable/chunks/DS5yzhLt.js.br +0 -0
  220. package/build/client/_app/immutable/chunks/DS5yzhLt.js.gz +0 -0
  221. package/build/client/_app/immutable/chunks/DZSJW-Zm.js.br +0 -0
  222. package/build/client/_app/immutable/chunks/DZSJW-Zm.js.gz +0 -0
  223. package/build/client/_app/immutable/chunks/Dbyirw23.js.br +0 -0
  224. package/build/client/_app/immutable/chunks/Dbyirw23.js.gz +0 -0
  225. package/build/client/_app/immutable/chunks/DsnmJJEf.js +0 -1
  226. package/build/client/_app/immutable/chunks/DsnmJJEf.js.br +0 -2
  227. package/build/client/_app/immutable/chunks/DsnmJJEf.js.gz +0 -0
  228. package/build/client/_app/immutable/chunks/DzSHMQR7.js.br +0 -0
  229. package/build/client/_app/immutable/chunks/DzSHMQR7.js.gz +0 -0
  230. package/build/client/_app/immutable/chunks/W-qL5_8w.js.br +0 -0
  231. package/build/client/_app/immutable/chunks/W-qL5_8w.js.gz +0 -0
  232. package/build/client/_app/immutable/chunks/aB6hH3ax.js +0 -3
  233. package/build/client/_app/immutable/chunks/aB6hH3ax.js.br +0 -0
  234. package/build/client/_app/immutable/chunks/aB6hH3ax.js.gz +0 -0
  235. package/build/client/_app/immutable/chunks/nJ6DKbk8.js +0 -1
  236. package/build/client/_app/immutable/chunks/nJ6DKbk8.js.br +0 -0
  237. package/build/client/_app/immutable/chunks/nJ6DKbk8.js.gz +0 -0
  238. package/build/client/_app/immutable/chunks/zeTqHWB5.js +0 -2
  239. package/build/client/_app/immutable/chunks/zeTqHWB5.js.br +0 -0
  240. package/build/client/_app/immutable/chunks/zeTqHWB5.js.gz +0 -0
  241. package/build/client/_app/immutable/entry/app.CW91YXu8.js +0 -2
  242. package/build/client/_app/immutable/entry/app.CW91YXu8.js.br +0 -0
  243. package/build/client/_app/immutable/entry/app.CW91YXu8.js.gz +0 -0
  244. package/build/client/_app/immutable/entry/start.CidwPVgO.js +0 -1
  245. package/build/client/_app/immutable/entry/start.CidwPVgO.js.br +0 -2
  246. package/build/client/_app/immutable/entry/start.CidwPVgO.js.gz +0 -0
  247. package/build/client/_app/immutable/nodes/0.B2lBDs71.js.br +0 -0
  248. package/build/client/_app/immutable/nodes/0.B2lBDs71.js.gz +0 -0
  249. package/build/client/_app/immutable/nodes/1.CueZCvtl.js +0 -1
  250. package/build/client/_app/immutable/nodes/1.CueZCvtl.js.br +0 -0
  251. package/build/client/_app/immutable/nodes/1.CueZCvtl.js.gz +0 -0
  252. package/build/client/_app/immutable/nodes/3.alYAlI3j.js +0 -1
  253. package/build/client/_app/immutable/nodes/3.alYAlI3j.js.br +0 -0
  254. package/build/client/_app/immutable/nodes/3.alYAlI3j.js.gz +0 -0
  255. package/build/client/_app/immutable/nodes/4.BqBphmVX.js.br +0 -0
  256. package/build/client/_app/immutable/nodes/4.BqBphmVX.js.gz +0 -0
  257. package/build/client/_app/immutable/nodes/5.BkAWRgl4.js.br +0 -0
  258. package/build/client/_app/immutable/nodes/5.BkAWRgl4.js.gz +0 -0
  259. package/build/client/_app/immutable/nodes/6.KI4mq5ln.js +0 -1
  260. package/build/client/_app/immutable/nodes/6.KI4mq5ln.js.br +0 -0
  261. package/build/client/_app/immutable/nodes/6.KI4mq5ln.js.gz +0 -0
  262. package/build/client/_app/immutable/nodes/7.Brjrw0K8.js +0 -1
  263. package/build/client/_app/immutable/nodes/7.Brjrw0K8.js.br +0 -0
  264. package/build/client/_app/immutable/nodes/7.Brjrw0K8.js.gz +0 -0
  265. package/build/server/chunks/1-Ch0AY58K.js +0 -9
  266. package/build/server/chunks/6-D8zNoyW_.js.map +0 -1
  267. package/build/server/chunks/Panel-DTdYk-gk.js.map +0 -1
  268. package/build/server/chunks/PrettyJson-wIuHvehp.js.map +0 -1
  269. package/build/server/chunks/TooltipTable-J278e1CA.js.map +0 -1
  270. package/build/server/chunks/_layout.svelte-D7RD9tLN.js.map +0 -1
  271. package/build/server/chunks/_page.svelte-4PYYtPii.js.map +0 -1
  272. package/build/server/chunks/_page.svelte-Be5VTn1e.js.map +0 -1
  273. package/build/server/chunks/_page.svelte-DIPUjSjm.js.map +0 -1
  274. package/build/server/chunks/_page.svelte-DZ59Sr3N.js.map +0 -1
  275. package/build/server/chunks/_page.svelte-sdKGQrEF.js +0 -91
  276. package/build/server/chunks/_page.svelte-sdKGQrEF.js.map +0 -1
  277. package/build/server/chunks/_server.ts-BIRebnb3.js +0 -20
  278. package/build/server/chunks/_server.ts-BIRebnb3.js.map +0 -1
  279. package/build/server/chunks/_server.ts-MnKJDybo.js +0 -19
  280. package/build/server/chunks/_server.ts-MnKJDybo.js.map +0 -1
  281. package/build/server/chunks/_server.ts-Tog8k3Mh.js +0 -52
  282. package/build/server/chunks/_server.ts-Tog8k3Mh.js.map +0 -1
  283. package/build/server/chunks/client-BZtxOgbR.js +0 -7
  284. package/build/server/chunks/context-BU6gUbSI.js.map +0 -1
  285. package/build/server/chunks/error.svelte-BfneeC-d.js +0 -16
  286. package/build/server/chunks/error.svelte-BfneeC-d.js.map +0 -1
  287. package/build/server/chunks/exports-DiyTWREe.js.map +0 -1
  288. package/build/server/chunks/hooks.server-DNhdbQNi.js +0 -7
  289. package/build/server/chunks/hooks.server-DNhdbQNi.js.map +0 -1
  290. package/build/server/chunks/index3-CUhdJ7wv.js.map +0 -1
  291. package/build/server/chunks/notifications.svelte-CrTIrfvL.js.map +0 -1
  292. package/build/server/chunks/routing-zIlQn_LN.js.map +0 -1
@@ -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
+ }));
@@ -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
@@ -0,0 +1,7 @@
1
+ import { sveltekit } from "@sveltejs/kit/vite";
2
+ import tailwindcss from "@tailwindcss/vite";
3
+ import { defineConfig } from "vite";
4
+
5
+ export default defineConfig({
6
+ plugins: [tailwindcss(), sveltekit()],
7
+ });
@@ -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};
@@ -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};
@@ -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};
@@ -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};
@@ -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};
@@ -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};
@@ -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};
@@ -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};
@@ -1 +0,0 @@
1
- typeof window<"u"&&((window.__svelte??={}).v??=new Set).add("5");
@@ -1,2 +0,0 @@
1
- � �typeof window<"u"&&((window.__svelte??={}).v??=new Set).add("5");
2
-