@edge-base/server 0.1.1 → 0.1.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/LICENSE +21 -0
- package/admin-build/_app/immutable/assets/21.x9OgMBdi.css +1 -0
- package/admin-build/_app/immutable/assets/TableSqlTab.BHquaMBM.css +1 -0
- package/admin-build/_app/immutable/chunks/{BkrCkgYp.js → 9Ch6RgcX.js} +1 -1
- package/admin-build/_app/immutable/chunks/B-pVQkKM.js +1 -0
- package/admin-build/_app/immutable/chunks/{eFQHTGwA.js → B0HRJ657.js} +1 -1
- package/admin-build/_app/immutable/chunks/B2bEC_Hm.js +1 -0
- package/admin-build/_app/immutable/chunks/{CwROoZK0.js → B8s_s9QY.js} +1 -1
- package/admin-build/_app/immutable/chunks/{8wJeQ7LN.js → BOSBsYO8.js} +1 -1
- package/admin-build/_app/immutable/chunks/{ehbppgYb.js → Bb0e0sAP.js} +1 -1
- package/admin-build/_app/immutable/chunks/{glwixJlP.js → BdTBlfLy.js} +1 -1
- package/admin-build/_app/immutable/chunks/{DoPXzH7F.js → Bn2NtlTj.js} +1 -1
- package/admin-build/_app/immutable/chunks/BvukSxhJ.js +128 -0
- package/admin-build/_app/immutable/chunks/BwxFS5FL.js +2 -0
- package/admin-build/_app/immutable/chunks/{Cs0GwzJA.js → C72lTcG0.js} +1 -1
- package/admin-build/_app/immutable/chunks/{BmRjiP5k.js → C8s55wKu.js} +1 -1
- package/admin-build/_app/immutable/chunks/{BdrwyZv8.js → CBVE2cdU.js} +1 -1
- package/admin-build/_app/immutable/chunks/{DuXuUBWN.js → CF95mcQY.js} +1 -1
- package/admin-build/_app/immutable/chunks/CGgVJi7f.js +1 -0
- package/admin-build/_app/immutable/chunks/{NuUjtcO2.js → CYatlt7w.js} +1 -1
- package/admin-build/_app/immutable/chunks/{DttM2zNO.js → CnWwy2Sf.js} +1 -1
- package/admin-build/_app/immutable/chunks/{C6puvcoR.js → CoI6jjbg.js} +2 -2
- package/admin-build/_app/immutable/chunks/{B8vJP3wz.js → Cp8V0Xy2.js} +1 -1
- package/admin-build/_app/immutable/chunks/{BcR-Rdj9.js → D8o7yzcA.js} +1 -1
- package/admin-build/_app/immutable/chunks/{BR_fL5Yv.js → DEELgv7K.js} +1 -1
- package/admin-build/_app/immutable/chunks/{7f08Id8e.js → DHWOQ9Ui.js} +1 -1
- package/admin-build/_app/immutable/chunks/{Bh56EfQ_.js → DILS_-VJ.js} +1 -1
- package/admin-build/_app/immutable/chunks/{zfauFM8P.js → DTmaM1M6.js} +1 -1
- package/admin-build/_app/immutable/chunks/{w89G9Xpi.js → DroeC-Do.js} +1 -1
- package/admin-build/_app/immutable/chunks/{BsokvhWC.js → DskOoVLT.js} +1 -1
- package/admin-build/_app/immutable/chunks/{7B47DvSx.js → Dt4vL4Df.js} +1 -1
- package/admin-build/_app/immutable/chunks/{D5h5A1cc.js → DtZk82gG.js} +2 -2
- package/admin-build/_app/immutable/chunks/{C4D51vTW.js → F9_4wRrd.js} +1 -1
- package/admin-build/_app/immutable/chunks/{cOYbrQxx.js → I0AZRbV2.js} +1 -1
- package/admin-build/_app/immutable/chunks/{CCKNu7m7.js → MKsm6wXE.js} +1 -1
- package/admin-build/_app/immutable/chunks/WtDa8jKW.js +1 -0
- package/admin-build/_app/immutable/chunks/XmteHKH_.js +1 -0
- package/admin-build/_app/immutable/chunks/{UUazaC_N.js → Y22E1hJM.js} +1 -1
- package/admin-build/_app/immutable/chunks/{vApWTCBs.js → Z41NK6i6.js} +1 -1
- package/admin-build/_app/immutable/chunks/{DrQSgw-f.js → _teD5ji5.js} +1 -1
- package/admin-build/_app/immutable/chunks/{MdeqaOQx.js → gtu8uwJD.js} +1 -1
- package/admin-build/_app/immutable/chunks/{DnyL7Zq-.js → m9eWh0Cd.js} +1 -1
- package/admin-build/_app/immutable/chunks/{B-h2afW5.js → v2HHbTgy.js} +1 -1
- package/admin-build/_app/immutable/entry/app.Dh4eYd90.js +2 -0
- package/admin-build/_app/immutable/entry/start.DjnjDre4.js +1 -0
- package/admin-build/_app/immutable/nodes/{0.CjtHKU-6.js → 0._kCczuod.js} +1 -1
- package/admin-build/_app/immutable/nodes/{1.DEisjlM0.js → 1.C8vaAzdV.js} +1 -1
- package/admin-build/_app/immutable/nodes/{10.CvhdyWVB.js → 10.TsbpWcyB.js} +1 -1
- package/admin-build/_app/immutable/nodes/{11.DjHqcOvy.js → 11.DbwjQWdP.js} +1 -1
- package/admin-build/_app/immutable/nodes/{12.mQLz4Mj_.js → 12.BMCb3LcM.js} +1 -1
- package/admin-build/_app/immutable/nodes/{13.CBonZZyP.js → 13.CTXx-p7a.js} +1 -1
- package/admin-build/_app/immutable/nodes/{14.d-oiZL0j.js → 14.BW1Sfg3E.js} +1 -1
- package/admin-build/_app/immutable/nodes/{15.CKPQsUYF.js → 15.DAKEfLVF.js} +1 -1
- package/admin-build/_app/immutable/nodes/{16.wPzAPQGx.js → 16.BZHOIVRq.js} +1 -1
- package/admin-build/_app/immutable/nodes/{17.DayhKyEZ.js → 17.DcntvsXi.js} +1 -1
- package/admin-build/_app/immutable/nodes/{18.DKwS0Ir0.js → 18.Badw-bZ2.js} +1 -1
- package/admin-build/_app/immutable/nodes/{19.wPzAPQGx.js → 19.BZHOIVRq.js} +1 -1
- package/admin-build/_app/immutable/nodes/2.Bn3R2oDm.js +1 -0
- package/admin-build/_app/immutable/nodes/{20.BvIkkkrW.js → 20.DDTfgFOS.js} +1 -1
- package/admin-build/_app/immutable/nodes/21.BbdBT511.js +1 -0
- package/admin-build/_app/immutable/nodes/{22.3xdgwuK1.js → 22.DLaL76VE.js} +1 -1
- package/admin-build/_app/immutable/nodes/{23.8Bvgjbsl.js → 23.D1tjWuvB.js} +1 -1
- package/admin-build/_app/immutable/nodes/{24.DzSSzRhG.js → 24.8cwANb8Q.js} +1 -1
- package/admin-build/_app/immutable/nodes/{25.9KKYBnAE.js → 25.DCU-ztvR.js} +1 -1
- package/admin-build/_app/immutable/nodes/{26.Bhn9dfhY.js → 26.CuHUfaEI.js} +1 -1
- package/admin-build/_app/immutable/nodes/{27.kRLiC24G.js → 27.fOpy2ckO.js} +1 -1
- package/admin-build/_app/immutable/nodes/{28.BVIN1-7N.js → 28.DWB877rH.js} +1 -1
- package/admin-build/_app/immutable/nodes/{29.3yabZWj4.js → 29.D9hvrxFP.js} +1 -1
- package/admin-build/_app/immutable/nodes/{3.BFtSOkX7.js → 3.BJG5UaW0.js} +1 -1
- package/admin-build/_app/immutable/nodes/{30.CyCQlwaP.js → 30.52Okvb4S.js} +1 -1
- package/admin-build/_app/immutable/nodes/{31.C4LDXjES.js → 31.B2rKWEXY.js} +1 -1
- package/admin-build/_app/immutable/nodes/{4.CvbiMlCa.js → 4.BMrPKdZ6.js} +1 -1
- package/admin-build/_app/immutable/nodes/{5.C6BLv2eM.js → 5.BHBRNfgt.js} +1 -1
- package/admin-build/_app/immutable/nodes/{6.BcXvfl2P.js → 6.Uq3G0mmd.js} +1 -1
- package/admin-build/_app/immutable/nodes/{7.CIuqhPiK.js → 7.BS-ss8zw.js} +1 -1
- package/admin-build/_app/immutable/nodes/{8.BQOR_JfO.js → 8.5bzwkzMM.js} +1 -1
- package/admin-build/_app/immutable/nodes/{9.NZqXQxPy.js → 9.BA61CCFG.js} +1 -1
- package/admin-build/_app/version.json +1 -1
- package/admin-build/favicon.svg +3 -2
- package/admin-build/index.html +17 -16
- package/package.json +64 -65
- package/admin-build/_app/immutable/assets/21.Dz2RJ56c.css +0 -1
- package/admin-build/_app/immutable/chunks/BY92tFS2.js +0 -1
- package/admin-build/_app/immutable/chunks/CxCPv_Ut.js +0 -1
- package/admin-build/_app/immutable/chunks/CxbRue-5.js +0 -1
- package/admin-build/_app/immutable/chunks/CyqB6g-D.js +0 -1
- package/admin-build/_app/immutable/entry/app.CcO-Uos3.js +0 -2
- package/admin-build/_app/immutable/entry/start.COebYq3I.js +0 -1
- package/admin-build/_app/immutable/nodes/2.BKoKrw1i.js +0 -1
- package/admin-build/_app/immutable/nodes/21.DMaFhdHk.js +0 -128
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import"../chunks/CWj6FrbW.js";import{p as ea,M as nt,w as Ot,g as e,at as fr,f as Ve,a as ta,d as N,s as d,c as s,r,t as y,ag as Da,b as a,u as A,I as Pr,ae as Ae,af as Er}from"../chunks/glwixJlP.js";import{d as la,e as na,s as I,a as ie}from"../chunks/D5h5A1cc.js";import{c as Yt,a as l,f as c,t as Qe}from"../chunks/BR_fL5Yv.js";import{i as D}from"../chunks/UUazaC_N.js";import{e as tt,i as Bt,t as lt,b as Et,A as Tr,a as pt}from"../chunks/CCKNu7m7.js";import{a as Ce,s as Tt,b as da,r as Ft,c as Ha,e as Ta,i as Rr,h as zr}from"../chunks/C6puvcoR.js";import{b as $t,a as Ua}from"../chunks/NuUjtcO2.js";import{a as pa,s as Ia}from"../chunks/B8vJP3wz.js";import{g as Aa}from"../chunks/BY92tFS2.js";import{p as Dr}from"../chunks/BcR-Rdj9.js";import{b as Ra}from"../chunks/CxCPv_Ut.js";import{M as pr}from"../chunks/7B47DvSx.js";import{B as ct}from"../chunks/Cs0GwzJA.js";import{s as qt,b as jr,a as Oa,c as Ga}from"../chunks/B-h2afW5.js";import{d as Ya}from"../chunks/wJsUhbfZ.js";import{A as $a,S as qr,C as Qr}from"../chunks/cOYbrQxx.js";import{b as ja}from"../chunks/CyqB6g-D.js";import{p as wt}from"../chunks/C4D51vTW.js";import{g as Ur,p as er}from"../chunks/Ce-ngf4p.js";import{o as Lr,a as Br}from"../chunks/DoPXzH7F.js";import{e as Fr,b as Ar,l as Mr,m as Kr,i as Vr,c as Jr,f as Xr,s as Wr,t as ft,E as Zr,L as Hr,g as Gr,q as La,v as Yr,w as $r,x as es,y as ts,z as as,A as rs,B as ss,D as ns,F as ls}from"../chunks/MdeqaOQx.js";import{d as mr}from"../chunks/DuXuUBWN.js";import{T as os}from"../chunks/8wJeQ7LN.js";import{C as tr}from"../chunks/Bh56EfQ_.js";import{I as is}from"../chunks/DrQSgw-f.js";import{T as ds}from"../chunks/vApWTCBs.js";import{e as cs}from"../chunks/Q2nPFxS6.js";const vs=/^[A-Za-z0-9_-]+$/,us="Record ID must use English letters, numbers, hyphen (-), or underscore (_).";function fs(n){return n?vs.test(n)?null:us:null}var ps=c(`<div class="crp-note svelte-sxc7i5">Leave <strong>Record ID</strong> blank to let EdgeBase generate <code>id</code>, <code>createdAt</code>,
|
|
2
|
-
and <code>updatedAt</code> automatically.</div>`),ms=c('<div class="crp-note svelte-sxc7i5">This table does not expose any manual fields. EdgeBase will create the row with auto-managed values only.</div>'),_s=c("<select><option>Unset</option><option>true</option><option>false</option></select>"),hs=c("<option> </option>"),bs=c("<select><option>Select value</option><!></select>"),gs=c('<textarea rows="6"></textarea>'),ys=c("<input/>"),ws=c(`<p class="crp-helper svelte-sxc7i5">Optional. Leave blank to auto-generate. Custom IDs may only use English letters, numbers,
|
|
3
|
-
hyphen (-), or underscore (_).</p>`),ks=c('<p class="crp-error svelte-sxc7i5"> </p>'),xs=c('<div class="crp-field svelte-sxc7i5"><div class="crp-field__header svelte-sxc7i5"><label class="crp-field__name svelte-sxc7i5"> </label> <span class="crp-field__type svelte-sxc7i5"> </span></div> <!> <!> <!></div>'),Ss=c('<span class="crp-spinner svelte-sxc7i5"></span>'),Os=c('<button type="button" class="crp-overlay svelte-sxc7i5" aria-label="Close create record panel"></button> <div class="crp svelte-sxc7i5" role="dialog" aria-modal="true" aria-labelledby="create-record-title"><div class="crp-header svelte-sxc7i5"><div><h3 id="create-record-title" class="crp-title svelte-sxc7i5">Create Record</h3> <p class="crp-subtitle svelte-sxc7i5"><!></p></div> <button type="button" class="crp-close svelte-sxc7i5" aria-label="Close create record panel">×</button></div> <form class="crp-body svelte-sxc7i5"><!> <!> <div class="crp-footer svelte-sxc7i5"><button type="button" class="crp-btn svelte-sxc7i5">Cancel</button> <button type="submit" class="crp-btn crp-btn--primary svelte-sxc7i5"><!></button></div></form></div>',1);function Cs(n,t){ea(t,!0);let u=wt(t,"columns",19,()=>[]),o=wt(t,"values",31,()=>nt({})),h=wt(t,"errors",31,()=>nt({})),_=wt(t,"saving",3,!1);const P=new Set(["createdAt","updatedAt"]);let x=N(null),R=A(()=>u().find(T=>T.key==="id")??null),M=A(()=>u().filter(T=>!P.has(T.key)&&T.key!=="id"&&T.editable!==!1)),ee=A(()=>[...e(R)?[{...e(R),label:"Record ID",editable:!0}]:[],...e(M)]),F=A(()=>!!e(R)&&e(M).length===0),U=A(()=>e(ee).length===0);Ot(()=>{t.open&&requestAnimationFrame(()=>{var W;const T=(W=e(x))==null?void 0:W.querySelector("input, select, textarea");T==null||T.focus()})});function ve(T){t.open&&T.key==="Escape"&&!_()&&t.onClose()}function G(T){return T.type==="number"?"number":T.type==="datetime"?"datetime-local":"text"}function de(T){return T.key==="id"?"Leave blank to auto-generate":T.type==="json"?'{ "key": "value" }':T.type==="number"?"0":T.label}function S(T){return`create-row-${T}`}function Y(T){if(!h()[T])return;const W={...h()};delete W[T],h(W)}var re=Yt();na("keydown",fr,ve);var ae=Ve(re);{var pe=T=>{var W=Os(),k=Ve(W),j=d(k,2),$=s(j),fe=s($),b=d(s(fe),2),L=s(b);{var me=w=>{var z=Qe("This table only uses auto-managed fields. Creating a row will generate the record automatically.");l(w,z)},Se=w=>{var z=Qe("This table only uses auto-managed fields. You can optionally set a custom record ID.");l(w,z)},ke=w=>{var z=Qe("Fill in the fields for the new row. Record ID is optional.");l(w,z)};D(L,w=>{e(U)?w(me):e(F)?w(Se,1):w(ke,!1)})}r(b),r(fe);var Z=d(fe,2);r($);var q=d($,2),Q=s(q);{var be=w=>{var z=ps();l(w,z)},ze=w=>{var z=ms();l(w,z)};D(Q,w=>{e(F)?w(be):e(U)&&w(ze,1)})}var ge=d(Q,2);tt(ge,17,()=>e(ee),w=>w.key,(w,z)=>{var Fe=xs(),xe=s(Fe),m=s(xe),B=s(m,!0);r(m);var _e=d(m,2),je=s(_e,!0);r(_e),r(xe);var Ct=d(xe,2);{var Qt=Ne=>{var f=_s();let g;var K=s(f);K.value=K.__value="";var E=d(K);E.value=E.__value="true";var J=d(E);J.value=J.__value="false",r(f),y((X,V)=>{Ce(f,"id",X),g=Tt(f,1,"crp-input svelte-sxc7i5",null,g,V),f.disabled=_()},[()=>S(e(z).key),()=>({"crp-input--error":!!h()[e(z).key]})]),ie("change",f,()=>Y(e(z).key)),da(f,()=>o()[e(z).key],X=>o(o()[e(z).key]=X,!0)),l(Ne,f)},Rt=Ne=>{var f=bs();let g;var K=s(f);K.value=K.__value="";var E=d(K);tt(E,17,()=>e(z).enumValues,Bt,(J,X)=>{var V=hs(),se=s(V,!0);r(V);var he={};y(()=>{I(se,e(X)),he!==(he=e(X))&&(V.value=(V.__value=e(X))??"")}),l(J,V)}),r(f),y((J,X)=>{Ce(f,"id",J),g=Tt(f,1,"crp-input svelte-sxc7i5",null,g,X),f.disabled=_()},[()=>S(e(z).key),()=>({"crp-input--error":!!h()[e(z).key]})]),ie("change",f,()=>Y(e(z).key)),da(f,()=>o()[e(z).key],J=>o(o()[e(z).key]=J,!0)),l(Ne,f)},Jt=Ne=>{var f=gs();Da(f);let g;y((K,E,J)=>{Ce(f,"id",K),g=Tt(f,1,"crp-input crp-input--textarea svelte-sxc7i5",null,g,E),Ce(f,"placeholder",J),f.disabled=_()},[()=>S(e(z).key),()=>({"crp-input--error":!!h()[e(z).key]}),()=>de(e(z))]),ie("input",f,()=>Y(e(z).key)),$t(f,()=>o()[e(z).key],K=>o(o()[e(z).key]=K,!0)),l(Ne,f)},Xt=Ne=>{var f=ys();Ft(f);let g;y((K,E,J,X)=>{Ce(f,"id",K),g=Tt(f,1,"crp-input svelte-sxc7i5",null,g,E),Ce(f,"type",J),Ce(f,"placeholder",X),f.disabled=_()},[()=>S(e(z).key),()=>({"crp-input--error":!!h()[e(z).key]}),()=>G(e(z)),()=>de(e(z))]),ie("input",f,()=>Y(e(z).key)),$t(f,()=>o()[e(z).key],K=>o(o()[e(z).key]=K,!0)),l(Ne,f)};D(Ct,Ne=>{e(z).type==="boolean"?Ne(Qt):e(z).type==="enum"&&e(z).enumValues?Ne(Rt,1):e(z).type==="json"?Ne(Jt,2):Ne(Xt,!1)})}var Ke=d(Ct,2);{var Ee=Ne=>{var f=ws();l(Ne,f)};D(Ke,Ne=>{e(z).key==="id"&&Ne(Ee)})}var st=d(Ke,2);{var ot=Ne=>{var f=ks(),g=s(f,!0);r(f),y(()=>I(g,h()[e(z).key])),l(Ne,f)};D(st,Ne=>{h()[e(z).key]&&Ne(ot)})}r(Fe),y(Ne=>{Ce(m,"for",Ne),I(B,e(z).label),I(je,e(z).type)},[()=>S(e(z).key)]),l(w,Fe)});var Me=d(ge,2),De=s(Me),Re=d(De,2),We=s(Re);{var at=w=>{var z=Ss();l(w,z)},oe=w=>{var z=Qe();y(()=>I(z,e(U)?"Create Empty Row":"Create Row")),l(w,z)};D(We,w=>{_()?w(at):w(oe,!1)})}r(Re),r(Me),r(q),r(j),ja(j,w=>a(x,w),()=>e(x)),y(()=>{Z.disabled=_(),De.disabled=_(),Re.disabled=_()}),ie("click",k,()=>!_()&&t.onClose()),ie("click",Z,function(...w){var z;(z=t.onClose)==null||z.apply(this,w)}),na("submit",q,w=>{w.preventDefault(),t.onSubmit()}),ie("click",De,function(...w){var z;(z=t.onClose)==null||z.apply(this,w)}),l(T,W)};D(ae,T=>{t.open&&T(pe)})}l(n,re),ta()}la(["click","change","input"]);var Ns=c('<button class="dg-btn svelte-45rfpz"> </button>'),Is=c('<button class="dg-btn dg-btn--danger svelte-45rfpz"> </button> <!>',1),Ps=c('<button class="dg-btn dg-btn--primary svelte-45rfpz">Save All Changes</button> <button class="dg-btn svelte-45rfpz">Revert All</button>',1),Es=c('<label class="dg-col-picker__item svelte-45rfpz"><input type="checkbox" class="svelte-45rfpz"/> <span class="svelte-45rfpz"> </span></label>'),Ts=c('<button type="button" class="dg-col-picker-backdrop svelte-45rfpz" aria-label="Close column picker"></button> <div class="dg-col-picker svelte-45rfpz" role="dialog" aria-modal="true" aria-label="Column picker"></div>',1),Rs=c('<div class="dg-col-picker-wrap svelte-45rfpz"><button class="dg-btn svelte-45rfpz" aria-haspopup="dialog"> </button> <!></div>'),zs=c('<button class="dg-btn dg-btn--primary svelte-45rfpz">+ Add Row</button>'),Ds=c('<div class="dg-toolbar svelte-45rfpz"><div class="dg-toolbar__left svelte-45rfpz"><!> <!></div> <div class="dg-toolbar__right svelte-45rfpz"><!> <!></div></div>'),js=c('<th class="dg-th dg-th--checkbox svelte-45rfpz" style="width:36px;"><input type="checkbox"/></th>'),qs=c('<span class="dg-sort-icon svelte-45rfpz"> </span>'),Qs=c('<button type="button" class="dg-resize-handle svelte-45rfpz" tabindex="-1"></button>'),Us=c('<th class="dg-th svelte-45rfpz"><div class="dg-th__inner svelte-45rfpz"><button class="dg-sort-btn svelte-45rfpz"> <!></button> <!></div></th>'),Ls=c('<th class="dg-th dg-th--actions svelte-45rfpz" style="width:80px;">Actions</th>'),Bs=c('<tr><td class="dg-td dg-td--empty svelte-45rfpz"><div class="dg-loading svelte-45rfpz"><span class="dg-spinner svelte-45rfpz"></span> Loading...</div></td></tr>'),Fs=c('<tr><td class="dg-td dg-td--empty svelte-45rfpz"> </td></tr>'),As=c('<td class="dg-td dg-td--checkbox svelte-45rfpz"><input type="checkbox"/></td>'),Ms=c('<select class="dg-cell-editor svelte-45rfpz"><option>null</option><option>true</option><option>false</option></select>'),Ks=c("<option> </option>"),Vs=c('<select class="dg-cell-editor svelte-45rfpz"><option>—</option><!></select>'),Js=c('<textarea class="dg-cell-editor dg-cell-editor--json svelte-45rfpz" rows="4"></textarea>'),Xs=c('<input class="dg-cell-editor svelte-45rfpz"/>'),Ws=c('<a class="dg-cell-link svelte-45rfpz" title="Navigate to related record"> </a>'),Zs=c("<em>null</em>"),Hs=c('<span class="dg-bool svelte-45rfpz"> </span>'),Gs=c('<button type="button"><span><!></span></button>'),Ys=c("<td><!></td>"),$s=c('<button class="dg-act-btn svelte-45rfpz" title="Duplicate"><svg width="14" height="14" viewBox="0 0 16 16" fill="none"><rect x="5" y="5" width="8" height="8" rx="1.5" stroke="currentColor" stroke-width="1.5"></rect><path d="M3 11V3.5C3 2.67 3.67 2 4.5 2H11" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path></svg></button>'),en=c('<button class="dg-act-btn svelte-45rfpz" title="Inspect"><svg width="14" height="14" viewBox="0 0 16 16" fill="none"><circle cx="7" cy="7" r="4.5" stroke="currentColor" stroke-width="1.5"></circle><path d="M10.5 10.5L14 14" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path></svg></button>'),tn=c('<span class="dg-spinner-sm svelte-45rfpz"></span>'),an=c('<button class="dg-act-btn dg-act-btn--save svelte-45rfpz" title="Save"><!></button> <button class="dg-act-btn svelte-45rfpz" title="Revert">↩</button>',1),rn=c('<td class="dg-td dg-td--actions svelte-45rfpz"><!> <!> <!></td>'),sn=c("<tr><!><!><!></tr>"),nn=c('<select class="dg-page-size svelte-45rfpz"><option>20 / page</option><option>50 / page</option><option>100 / page</option><option>200 / page</option><option>500 / page</option></select>'),ln=c('<div class="dg-footer__right svelte-45rfpz"><button class="dg-btn dg-btn--sm svelte-45rfpz">← Prev</button> <span class="dg-page-info svelte-45rfpz"> </span> <button class="dg-btn dg-btn--sm svelte-45rfpz">Next →</button></div>'),on=c('<div class="dg svelte-45rfpz" role="grid" tabindex="0"><!> <div class="dg-table-wrap svelte-45rfpz"><table class="dg-table svelte-45rfpz"><thead><tr><!><!><!></tr></thead><tbody><!></tbody></table></div> <div class="dg-footer svelte-45rfpz"><div class="dg-footer__left svelte-45rfpz"><span class="dg-count svelte-45rfpz"> </span> <!></div> <!></div></div> <!>',1);function _r(n,t){ea(t,!0);let u=wt(t,"columns",19,()=>[]),o=wt(t,"rows",19,()=>[]),h=wt(t,"loading",3,!1),_=wt(t,"readonly",3,!1),P=wt(t,"emptyMessage",3,"No data available."),x=wt(t,"totalCount",3,0),R=wt(t,"page",3,1),M=wt(t,"pageSize",3,20),ee=wt(t,"tableName",3,""),F=N(nt(new Set)),U=N(nt(new Map)),ve=N(nt(new Set)),G=N(null),de=N(null),S=N(""),Y=N(null),re=N("asc"),ae=N(nt(new Map)),pe=N(null),T=N(0),W=N(0),k=N(null),j=N(nt(new Set)),$=N(!1),fe=N(!1),b=N(nt({})),L=N(nt({})),me=N(!1),Se=A(()=>o().length>0&&o().every(i=>e(F).has(String(i.id)))),ke=A(()=>e(F).size>0),Z=A(()=>Math.max(1,Math.ceil(x()/M()))),q=A(()=>e(U).size>0),Q=A(()=>u().filter(i=>!e(j).has(i.key)));function be(i,p){requestAnimationFrame(()=>{var H;const O=(H=e(k))==null?void 0:H.querySelector(`[data-row-id="${i}"][data-col-key="${p}"]`);O==null||O.focus()})}Ot(()=>{!e(G)||e(de)||be(e(G).rowId,e(G).colKey)}),Ot(()=>{if(ee())try{const i=localStorage.getItem(`edgebase_grid_columns_${ee()}`);a(j,i?new Set(JSON.parse(i)):new Set,!0)}catch{a(j,new Set,!0)}});function ze(i){const p=new Set(e(j));if(p.has(i)?p.delete(i):p.add(i),a(j,p,!0),ee())try{localStorage.setItem(`edgebase_grid_columns_${ee()}`,JSON.stringify([...p]))}catch{}}function ge(i){return e(ae).get(i.key)??i.width??Me(i)}function Me(i){return i.type==="boolean"?80:i.type==="number"?120:i.type==="datetime"?180:i.type==="json"?200:160}function De(){e(Se)?a(F,new Set,!0):a(F,new Set(o().map(i=>String(i.id))),!0)}function Re(i){const p=new Set(e(F));p.has(i)?p.delete(i):p.add(i),a(F,p,!0)}function We(i){var p;e(Y)===i?a(re,e(re)==="asc"?"desc":"asc",!0):(a(Y,i,!0),a(re,"asc")),(p=t.onSort)==null||p.call(t,i,e(re))}function at(i,p){const O=e(U).get(String(i.id));return O!=null&&O.has(p)?O.get(p):i[p]}function oe(i,p){if(i==null)return"";if(p.type==="boolean")return i?"true":"false";if(p.type==="json"&&typeof i=="object")return JSON.stringify(i);if(p.type==="datetime"&&typeof i=="string")try{return new Date(i).toLocaleString()}catch{return String(i)}return String(i)}function w(i){return i==null}function z(i,p){var O;return((O=e(U).get(i))==null?void 0:O.has(p))??!1}async function Fe(i){const p=i==null?"":typeof i=="object"?JSON.stringify(i):String(i);try{await navigator.clipboard.writeText(p),Et("Copied to clipboard")}catch{}}function xe(i,p,O){if(_())return;const H=u().find(ye=>ye.key===p);!H||H.editable===!1||p==="id"||p==="createdAt"||p==="updatedAt"||(a(de,{rowId:i,colKey:p},!0),O==null?a(S,""):typeof O=="object"?a(S,JSON.stringify(O,null,2),!0):a(S,String(O),!0),requestAnimationFrame(()=>{const ye=document.querySelector(".dg-cell-editor");ye==null||ye.focus()}))}function m(){if(!e(de))return;const{rowId:i,colKey:p}=e(de),O=u().find(rt=>rt.key===p);if(!O){B();return}let H;if(e(S)===""&&O.type!=="text")H=null;else if(O.type==="number"){if(H=e(S)===""?null:Number(e(S)),H!==null&&isNaN(H)){B();return}}else if(O.type==="boolean")H=e(S)==="true"||e(S)==="1";else if(O.type==="json")try{H=e(S)?JSON.parse(e(S)):null}catch{lt("Invalid JSON");return}else H=e(S);const ye=o().find(rt=>String(rt.id)===i),ce=ye==null?void 0:ye[p];if(JSON.stringify(H)===JSON.stringify(ce)){const rt=e(U).get(i);rt&&(rt.delete(p),rt.size===0&&e(U).delete(i),a(U,new Map(e(U)),!0))}else e(U).has(i)||e(U).set(i,new Map),e(U).get(i).set(p,H),a(U,new Map(e(U)),!0);a(de,null)}function B(){a(de,null)}async function _e(i){const p=e(U).get(i);if(!(!p||!t.onSave)){a(ve,new Set([...e(ve),i]),!0);try{const O={};for(const[H,ye]of p)O[H]=ye;await t.onSave(i,O),e(U).delete(i),a(U,new Map(e(U)),!0)}catch(O){lt(O instanceof Error?O.message:"Save failed")}finally{const O=new Set(e(ve));O.delete(i),a(ve,O,!0)}}}function je(i){e(U).delete(i),a(U,new Map(e(U)),!0)}async function Ct(){for(const i of e(U).keys())await _e(i)}function Qt(){a(U,new Map,!0)}async function Rt(){if(e(F).size===0||!t.onDelete)return;const i=[...e(F)];try{await t.onDelete(i),a(F,new Set,!0)}catch(p){lt(p instanceof Error?p.message:"Delete failed")}}function Jt(){a(fe,!0),a(b,{},!0),a(L,{},!0)}function Xt(i){if(!(i instanceof Tr)||!i.data||typeof i.data!="object")return{};const p={};for(const[O,H]of Object.entries(i.data))H&&typeof H=="object"&&"message"in H&&typeof H.message=="string"&&(p[O]=H.message);return p}async function Ke(){if(t.onCreate){a(me,!0),a(L,{},!0);try{const i={};for(const p of u()){if(p.key==="createdAt"||p.key==="updatedAt")continue;const O=e(b)[p.key];if(p.key==="id"){const H=String(O??"").trim(),ye=fs(H);if(ye){a(L,{id:ye},!0);return}H&&(i.id=H);continue}if(!(!O&&O!=="0"))if(p.type==="number")i[p.key]=Number(O);else if(p.type==="boolean")i[p.key]=O==="true"||O==="1";else if(p.type==="json")try{i[p.key]=JSON.parse(O)}catch{a(L,{[p.key]:`Invalid JSON for ${p.label}`},!0);return}else i[p.key]=O}await t.onCreate(i),a(fe,!1),a(b,{},!0),a(L,{},!0)}catch(i){const p=Xt(i);if(Object.keys(p).length>0){a(L,p,!0);return}lt(i instanceof Error?i.message:"Create failed")}finally{a(me,!1)}}}function Ee(){a(fe,!1),a(b,{},!0),a(L,{},!0)}function st(i,p){i.preventDefault(),i.stopPropagation(),a(pe,p,!0),a(T,i.clientX,!0),a(W,ge(u().find(O=>O.key===p)),!0),document.addEventListener("mousemove",ot),document.addEventListener("mouseup",Ne)}function ot(i){if(!e(pe))return;const p=i.clientX-e(T),O=u().find(ce=>ce.key===e(pe)),H=(O==null?void 0:O.minWidth)??60,ye=Math.max(H,e(W)+p);e(ae).set(e(pe),ye),a(ae,new Map(e(ae)),!0)}function Ne(){a(pe,null),document.removeEventListener("mousemove",ot),document.removeEventListener("mouseup",Ne)}function f(i){if(i.target instanceof HTMLAnchorElement&&i.key==="Enter")return;if(e(de)){if(i.key==="Escape")B(),i.preventDefault();else if(i.key==="Enter"&&!i.shiftKey){const ce=u().find(rt=>rt.key===e(de).colKey);(ce==null?void 0:ce.type)!=="json"&&(m(),i.preventDefault())}else i.key==="Tab"&&m();return}if(!e(G))return;const p=o().map(ce=>String(ce.id)),O=e(Q).map(ce=>ce.key),H=p.indexOf(e(G).rowId),ye=O.indexOf(e(G).colKey);if(i.key==="ArrowDown"&&H<p.length-1)a(G,{rowId:p[H+1],colKey:e(G).colKey},!0),i.preventDefault();else if(i.key==="ArrowUp"&&H>0)a(G,{rowId:p[H-1],colKey:e(G).colKey},!0),i.preventDefault();else if(i.key==="ArrowRight"&&ye<O.length-1)a(G,{rowId:e(G).rowId,colKey:O[ye+1]},!0),i.preventDefault();else if(i.key==="ArrowLeft"&&ye>0)a(G,{rowId:e(G).rowId,colKey:O[ye-1]},!0),i.preventDefault();else if(i.key==="Enter"||i.key==="F2"){const ce=at(o().find(rt=>String(rt.id)===e(G).rowId),e(G).colKey);xe(e(G).rowId,e(G).colKey,ce),i.preventDefault()}else if(i.key==="c"&&(i.metaKey||i.ctrlKey)){const ce=at(o().find(rt=>String(rt.id)===e(G).rowId),e(G).colKey);Fe(ce),i.preventDefault()}else i.key==="Delete"&&e(ke)&&!_()&&(Rt(),i.preventDefault())}function g(){var i;R()>1&&((i=t.onPageChange)==null||i.call(t,R()-1))}function K(){var i;R()<e(Z)&&((i=t.onPageChange)==null||i.call(t,R()+1))}function E(i){var O;const p=parseInt(i.target.value,10);(O=t.onPageSizeChange)==null||O.call(t,p)}var J=on(),X=Ve(J),V=s(X);{var se=i=>{var p=Ds(),O=s(p),H=s(O);{var ye=ue=>{var Le=Is(),te=Ve(Le),le=s(te);r(te);var Oe=d(te,2);{var _t=Ze=>{var kt=Ns(),He=s(kt);r(kt),y(()=>I(He,`Edit ${e(F).size??""} row${e(F).size>1?"s":""}`)),ie("click",kt,()=>{var ht;return(ht=t.onBulkEdit)==null?void 0:ht.call(t,[...e(F)])}),l(Ze,kt)};D(Oe,Ze=>{t.onBulkEdit&&Ze(_t)})}y(()=>I(le,`Delete ${e(F).size??""} row${e(F).size>1?"s":""}`)),ie("click",te,Rt),l(ue,Le)};D(H,ue=>{e(ke)&&ue(ye)})}var ce=d(H,2);{var rt=ue=>{var Le=Ps(),te=Ve(Le),le=d(te,2);ie("click",te,Ct),ie("click",le,Qt),l(ue,Le)};D(ce,ue=>{e(q)&&ue(rt)})}r(O);var At=d(O,2),Vt=s(At);{var v=ue=>{var Le=Rs(),te=s(Le),le=s(te);r(te);var Oe=d(te,2);{var _t=Ze=>{var kt=Ts(),He=Ve(kt),ht=d(He,2);tt(ht,21,u,bt=>bt.key,(bt,xt)=>{var dt=Es(),Je=s(dt);Ft(Je);var vt=d(Je,2),Be=s(vt,!0);r(vt),r(dt),y(Nt=>{Ta(Je,Nt),Je.disabled=e(xt).key==="id",I(Be,e(xt).label)},[()=>!e(j).has(e(xt).key)]),ie("change",Je,()=>ze(e(xt).key)),l(bt,dt)}),r(ht),ie("click",He,()=>a($,!1)),l(Ze,kt)};D(Oe,Ze=>{e($)&&Ze(_t)})}r(Le),y(()=>{Ce(te,"aria-expanded",e($)),I(le,`Columns (${e(Q).length??""}/${u().length??""})`)}),ie("click",te,()=>a($,!e($))),l(ue,Le)};D(Vt,ue=>{ee()&&ue(v)})}var C=d(Vt,2);{var ne=ue=>{var Le=zs();ie("click",Le,Jt),l(ue,Le)};D(C,ue=>{e(fe)||ue(ne)})}r(At),r(p),l(i,p)};D(V,i=>{_()||i(se)})}var he=d(V,2),Ie=s(he),Ue=s(Ie),Ut=s(Ue),Lt=s(Ut);{var it=i=>{var p=js(),O=s(p);Ft(O),r(p),y(()=>Ta(O,e(Se))),ie("change",O,De),l(i,p)};D(Lt,i=>{_()||i(it)})}var mt=d(Lt);tt(mt,17,()=>e(Q),i=>i.key,(i,p)=>{var O=Us(),H=s(O),ye=s(H),ce=s(ye),rt=d(ce);{var At=C=>{var ne=qs(),ue=s(ne,!0);r(ne),y(()=>I(ue,e(re)==="asc"?"▲":"▼")),l(C,ne)};D(rt,C=>{e(Y)===e(p).key&&C(At)})}r(ye);var Vt=d(ye,2);{var v=C=>{var ne=Qs();y(()=>Ce(ne,"aria-label",`Resize ${e(p).label} column`)),ie("mousedown",ne,ue=>st(ue,e(p).key)),l(C,ne)};D(Vt,C=>{_()||C(v)})}r(H),r(O),y(C=>{Ha(O,`width:${C??""}px;min-width:${e(p).minWidth??60??""}px;`),I(ce,`${e(p).label??""} `)},[()=>ge(e(p))]),ie("click",ye,()=>We(e(p).key)),l(i,O)});var Mt=d(mt);{var ca=i=>{var p=Ls();l(i,p)};D(Mt,i=>{_()||i(ca)})}r(Ut),r(Ue);var va=d(Ue),ya=s(va);{var ma=i=>{var p=Bs(),O=s(p);r(p),y(()=>Ce(O,"colspan",e(Q).length+(_()?0:2))),l(i,p)},ua=i=>{var p=Fs(),O=s(p),H=s(O,!0);r(O),r(p),y(()=>{Ce(O,"colspan",e(Q).length+(_()?0:2)),I(H,P())}),l(i,p)},wa=i=>{var p=Yt(),O=Ve(p);tt(O,17,o,H=>H.id??o().indexOf(H),(H,ye)=>{const ce=A(()=>String(e(ye).id)),rt=A(()=>e(U).has(e(ce)));var At=sn();let Vt;var v=s(At);{var C=te=>{var le=As(),Oe=s(le);Ft(Oe),r(le),y(_t=>Ta(Oe,_t),[()=>e(F).has(e(ce))]),ie("change",Oe,()=>Re(e(ce))),l(te,le)};D(v,te=>{_()||te(C)})}var ne=d(v);tt(ne,17,()=>e(Q),te=>te.key,(te,le)=>{const Oe=A(()=>at(e(ye),e(le).key)),_t=A(()=>z(e(ce),e(le).key)),Ze=A(()=>{var Je,vt;return((Je=e(de))==null?void 0:Je.rowId)===e(ce)&&((vt=e(de))==null?void 0:vt.colKey)===e(le).key}),kt=A(()=>{var Je,vt;return((Je=e(G))==null?void 0:Je.rowId)===e(ce)&&((vt=e(G))==null?void 0:vt.colKey)===e(le).key});var He=Ys();let ht;var bt=s(He);{var xt=Je=>{var vt=Yt(),Be=Ve(vt);{var Nt=Pe=>{var qe=Ms(),yt=s(qe);yt.value=yt.__value="";var Ht=d(yt);Ht.value=Ht.__value="true";var Xe=d(Ht);Xe.value=Xe.__value="false",r(qe),na("blur",qe,m),ie("keydown",qe,Ge=>{Ge.key==="Escape"&&B()}),da(qe,()=>e(S),Ge=>a(S,Ge)),l(Pe,qe)},Zt=Pe=>{var qe=Vs(),yt=s(qe);yt.value=yt.__value="";var Ht=d(yt);tt(Ht,17,()=>e(le).enumValues,Bt,(Xe,Ge)=>{var St=Ks(),sa=s(St,!0);r(St);var Dt={};y(()=>{I(sa,e(Ge)),Dt!==(Dt=e(Ge))&&(St.value=(St.__value=e(Ge))??"")}),l(Xe,St)}),r(qe),na("blur",qe,m),ie("keydown",qe,Xe=>{Xe.key==="Escape"&&B()}),da(qe,()=>e(S),Xe=>a(S,Xe)),l(Pe,qe)},It=Pe=>{var qe=Js();Da(qe),na("blur",qe,m),$t(qe,()=>e(S),yt=>a(S,yt)),l(Pe,qe)},gt=Pe=>{var qe=Xs();Ft(qe),y(()=>Ce(qe,"type",e(le).type==="number"?"number":e(le).type==="datetime"?"datetime-local":"text")),na("blur",qe,m),$t(qe,()=>e(S),yt=>a(S,yt)),l(Pe,qe)};D(Be,Pe=>{e(le).type==="boolean"?Pe(Nt):e(le).type==="enum"&&e(le).enumValues?Pe(Zt,1):e(le).type==="json"?Pe(It,2):Pe(gt,!1)})}l(Je,vt)},dt=Je=>{const vt=A(()=>e(le).linkFn&&!w(e(Oe))?e(le).linkFn(e(Oe)):null);var Be=Yt(),Nt=Ve(Be);{var Zt=gt=>{var Pe=Ws(),qe=s(Pe,!0);r(Pe),y(yt=>{Ce(Pe,"href",e(vt)),Ce(Pe,"data-row-id",e(ce)),Ce(Pe,"data-col-key",e(le).key),I(qe,yt)},[()=>oe(e(Oe),e(le))]),na("focus",Pe,()=>{a(G,{rowId:e(ce),colKey:e(le).key},!0)}),l(gt,Pe)},It=gt=>{var Pe=Gs();let qe;var yt=s(Pe);let Ht;var Xe=s(yt);{var Ge=Ye=>{var $e=Zs();l(Ye,$e)},St=A(()=>w(e(Oe))),sa=Ye=>{var $e=Hs(),Pt=s($e,!0);r($e),y(()=>I(Pt,e(Oe)?"✔":"✘")),l(Ye,$e)},Dt=Ye=>{var $e=Qe();y(Pt=>I($e,Pt),[()=>oe(e(Oe),e(le))]),l(Ye,$e)};D(Xe,Ye=>{e(St)?Ye(Ge):e(le).type==="boolean"?Ye(sa,1):Ye(Dt,!1)})}r(yt),r(Pe),y((Ye,$e,Pt)=>{qe=Tt(Pe,1,"dg-cell-trigger svelte-45rfpz",null,qe,Ye),Ce(Pe,"data-row-id",e(ce)),Ce(Pe,"data-col-key",e(le).key),Ce(Pe,"aria-label",$e),Ht=Tt(yt,1,"dg-cell-value svelte-45rfpz",null,Ht,Pt)},[()=>({"dg-cell-trigger--null":w(e(Oe))}),()=>`${e(le).label}: ${w(e(Oe))?"null":oe(e(Oe),e(le))}`,()=>({"dg-cell-value--null":w(e(Oe))})]),ie("click",Pe,()=>{a(G,{rowId:e(ce),colKey:e(le).key},!0)}),ie("dblclick",Pe,()=>xe(e(ce),e(le).key,e(Oe))),na("focus",Pe,()=>{a(G,{rowId:e(ce),colKey:e(le).key},!0)}),l(gt,Pe)};D(Nt,gt=>{e(vt)?gt(Zt):gt(It,!1)})}l(Je,Be)};D(bt,Je=>{e(Ze)?Je(xt):Je(dt,!1)})}r(He),y(Je=>{ht=Tt(He,1,"dg-td svelte-45rfpz",null,ht,{"dg-td--dirty":e(_t),"dg-td--focused":e(kt),"dg-td--editing":e(Ze)}),Ha(He,`width:${Je??""}px;`)},[()=>ge(e(le))]),l(te,He)});var ue=d(ne);{var Le=te=>{var le=rn(),Oe=s(le);{var _t=bt=>{var xt=$s();ie("click",xt,()=>{var dt;return(dt=t.onDuplicate)==null?void 0:dt.call(t,e(ye))}),l(bt,xt)};D(Oe,bt=>{t.onDuplicate&&bt(_t)})}var Ze=d(Oe,2);{var kt=bt=>{var xt=en();ie("click",xt,()=>{var dt;return(dt=t.onRowInspect)==null?void 0:dt.call(t,e(ye))}),l(bt,xt)};D(Ze,bt=>{t.onRowInspect&&bt(kt)})}var He=d(Ze,2);{var ht=bt=>{var xt=an(),dt=Ve(xt),Je=s(dt);{var vt=It=>{var gt=tn();l(It,gt)},Be=A(()=>e(ve).has(e(ce))),Nt=It=>{var gt=Qe("✔");l(It,gt)};D(Je,It=>{e(Be)?It(vt):It(Nt,!1)})}r(dt);var Zt=d(dt,2);y(It=>dt.disabled=It,[()=>e(ve).has(e(ce))]),ie("click",dt,()=>_e(e(ce))),ie("click",Zt,()=>je(e(ce))),l(bt,xt)};D(He,bt=>{e(rt)&&bt(ht)})}r(le),l(te,le)};D(ue,te=>{_()||te(Le)})}r(At),y(te=>Vt=Tt(At,1,"dg-row svelte-45rfpz",null,Vt,te),[()=>({"dg-row--selected":e(F).has(e(ce)),"dg-row--dirty":e(rt)})]),l(H,At)}),l(i,p)};D(ya,i=>{h()?i(ma):o().length===0?i(ua,1):i(wa,!1)})}r(va),r(Ie),r(he),ja(he,i=>a(k,i),()=>e(k));var _a=d(he,2),aa=s(_a),Kt=s(aa),zt=s(Kt);r(Kt);var Wt=d(Kt,2);{var ha=i=>{var p=nn(),O=s(p);O.value=O.__value="20";var H=d(O);H.value=H.__value="50";var ye=d(H);ye.value=ye.__value="100";var ce=d(ye);ce.value=ce.__value="200";var rt=d(ce);rt.value=rt.__value="500",r(p);var At;Rr(p),y(Vt=>{At!==(At=Vt)&&(p.value=(p.__value=Vt)??"",zr(p,Vt))},[()=>String(M())]),ie("change",p,E),l(i,p)};D(Wt,i=>{_()||i(ha)})}r(aa);var ra=d(aa,2);{var oa=i=>{var p=ln(),O=s(p),H=d(O,2),ye=s(H);r(H);var ce=d(H,2);r(p),y(()=>{O.disabled=R()<=1,I(ye,`Page ${R()??""} / ${e(Z)??""}`),ce.disabled=R()>=e(Z)}),ie("click",O,g),ie("click",ce,K),l(i,p)};D(ra,i=>{e(Z)>1&&i(oa)})}r(_a),r(X);var ka=d(X,2);{var fa=i=>{Cs(i,{get columns(){return u()},get saving(){return e(me)},onClose:Ee,onSubmit:Ke,get open(){return e(fe)},set open(p){a(fe,p,!0)},get values(){return e(b)},set values(p){a(b,p,!0)},get errors(){return e(L)},set errors(p){a(L,p,!0)}})};D(ka,i=>{_()||i(fa)})}y(()=>I(zt,`${x()??""} row${x()!==1?"s":""}`)),ie("keydown",X,f),l(n,J),ta()}la(["keydown","click","change","mousedown","dblclick"]);function ar({limit:n,offset:t,search:u,sortKey:o,sortDir:h="asc",includeTotal:_}){const P=new URLSearchParams({limit:String(n),offset:String(t)});return u&&P.set("search",u),o&&P.set("sort",`${o}:${h}`),_===!1&&P.set("includeTotal","0"),P.toString()}var dn=c('<label class="rdp-field__name svelte-yphh8m"> </label>'),cn=c('<span class="rdp-field__name svelte-yphh8m"> </span>'),vn=c('<select class="rdp-input svelte-yphh8m"><option>Unset</option><option>true</option><option>false</option></select>'),un=c("<option> </option>"),fn=c('<select class="rdp-input svelte-yphh8m"><option>Select value</option><!></select>'),pn=c('<textarea class="rdp-input rdp-input--textarea svelte-yphh8m" rows="6"></textarea>'),mn=c('<input class="rdp-input svelte-yphh8m"/>'),_n=c("<em>null</em>"),hn=c('<span class="rdp-bool svelte-yphh8m"> </span>'),bn=c('<pre class="rdp-json svelte-yphh8m"> </pre>'),gn=c('<a class="rdp-link svelte-yphh8m"> </a>'),yn=c("<div><!></div>"),wn=c('<div class="rdp-field svelte-yphh8m"><div class="rdp-field__header svelte-yphh8m"><!> <span class="rdp-field__type svelte-yphh8m"> </span></div> <!></div>'),kn=c('<span class="rdp-spinner svelte-yphh8m"></span>'),xn=c('<button type="button" class="rdp-btn svelte-yphh8m">Reset</button> <button type="button" class="rdp-btn rdp-btn--primary svelte-yphh8m"><!></button>',1),Sn=c('<button type="button" class="rdp-overlay svelte-yphh8m" aria-label="Close row detail"></button> <div class="rdp svelte-yphh8m" role="dialog" aria-modal="true" aria-labelledby="row-detail-title"><div class="rdp-header svelte-yphh8m"><div><h3 id="row-detail-title" class="rdp-title svelte-yphh8m">Row Detail</h3> <p class="rdp-subtitle svelte-yphh8m"><!></p></div> <button type="button" class="rdp-close svelte-yphh8m" aria-label="Close row detail">×</button></div> <div class="rdp-body svelte-yphh8m"></div> <div class="rdp-footer svelte-yphh8m"><button type="button" class="rdp-btn svelte-yphh8m">Close</button> <!></div></div>',1);function On(n,t){ea(t,!0);const u=new Set(["id","createdAt","updatedAt"]),o=Symbol("invalid-value");let h=N(null),_=N(nt({})),P=N(null),x=N(!1),R=A(()=>t.columns.filter(b=>!u.has(b.key)&&b.editable!==!1)),M=A(()=>e(R).length>0&&!!t.onSave),ee=A(()=>!!ae());Ot(()=>{!t.open||!t.row||(a(P,{...t.row},!0),a(_,F(t.row),!0),requestAnimationFrame(()=>{var L;const b=(L=e(h))==null?void 0:L.querySelector("input, select, textarea");b==null||b.focus()}))});function F(b){const L={};for(const me of t.columns){const Se=b[me.key];if(Se==null){L[me.key]="";continue}if(me.type==="boolean"){L[me.key]=Se?"true":"false";continue}if(me.type==="json"&&typeof Se=="object"){L[me.key]=JSON.stringify(Se,null,2);continue}if(me.type==="datetime"&&typeof Se=="string"){L[me.key]=U(Se);continue}L[me.key]=String(Se)}return L}function U(b){const L=new Date(b);return Number.isNaN(L.getTime())?b:new Date(L.getTime()-L.getTimezoneOffset()*6e4).toISOString().slice(0,16)}function ve(b){t.open&&b.key==="Escape"&&!e(x)&&t.onClose()}function G(b,L){if(b==null)return"null";if(L.type==="boolean")return b?"true":"false";if(L.type==="json"&&typeof b=="object")return JSON.stringify(b,null,2);if(L.type==="datetime"&&typeof b=="string")try{return new Date(b).toLocaleString()}catch{return String(b)}return String(b)}function de(b,L){if(L===""&&b.type!=="text")return null;if(b.type==="number"){const me=Number(L);return Number.isNaN(me)?o:me}if(b.type==="boolean")return L===""?null:L==="true"||L==="1";if(b.type==="json"){if(L==="")return null;try{return JSON.parse(L)}catch{return o}}return L}function S(b){return b==null}function Y(b){return typeof b=="object"&&b!==null}function re(b,L){return JSON.stringify(b)===JSON.stringify(L)}function ae(){if(!e(P))return null;const b={};for(const L of e(R)){const me=de(L,e(_)[L.key]??"");if(me===o)return null;re(me,e(P)[L.key])||(b[L.key]=me)}return Object.keys(b).length>0?b:null}function pe(b){return b.type==="number"?"number":b.type==="datetime"?"datetime-local":"text"}function T(b){return`row-detail-field-${b}`}async function W(){if(!e(P)||!t.onSave)return;const b=ae();if(b){for(const L of e(R))if(de(L,e(_)[L.key]??"")===o){lt(`Invalid ${L.type} value for ${L.label}`);return}a(x,!0);try{await t.onSave(String(e(P).id),b),a(P,{...e(P),...b},!0),a(_,F(e(P)),!0)}catch(L){lt(L instanceof Error?L.message:"Save failed")}finally{a(x,!1)}}}function k(){e(P)&&a(_,F(e(P)),!0)}var j=Yt();na("keydown",fr,ve);var $=Ve(j);{var fe=b=>{var L=Sn(),me=Ve(L),Se=d(me,2),ke=s(Se),Z=s(ke),q=d(s(Z),2),Q=s(q);{var be=oe=>{var w=Qe("Inspect and update this record without leaving the table.");l(oe,w)},ze=oe=>{var w=Qe("This record is read-only.");l(oe,w)};D(Q,oe=>{e(M)?oe(be):oe(ze,!1)})}r(q),r(Z);var ge=d(Z,2);r(ke);var Me=d(ke,2);tt(Me,21,()=>t.columns,oe=>oe.key,(oe,w)=>{const z=A(()=>e(P)[e(w).key]),Fe=A(()=>!u.has(e(w).key)&&e(w).editable!==!1&&!!t.onSave);var xe=wn(),m=s(xe),B=s(m);{var _e=Ke=>{var Ee=dn(),st=s(Ee,!0);r(Ee),y(ot=>{Ce(Ee,"for",ot),I(st,e(w).label)},[()=>T(e(w).key)]),l(Ke,Ee)},je=Ke=>{var Ee=cn(),st=s(Ee,!0);r(Ee),y(()=>I(st,e(w).label)),l(Ke,Ee)};D(B,Ke=>{e(Fe)?Ke(_e):Ke(je,!1)})}var Ct=d(B,2),Qt=s(Ct,!0);r(Ct),r(m);var Rt=d(m,2);{var Jt=Ke=>{var Ee=Yt(),st=Ve(Ee);{var ot=K=>{var E=vn(),J=s(E);J.value=J.__value="";var X=d(J);X.value=X.__value="true";var V=d(X);V.value=V.__value="false",r(E),y(se=>{Ce(E,"id",se),E.disabled=e(x)},[()=>T(e(w).key)]),da(E,()=>e(_)[e(w).key],se=>e(_)[e(w).key]=se),l(K,E)},Ne=K=>{var E=fn(),J=s(E);J.value=J.__value="";var X=d(J);tt(X,17,()=>e(w).enumValues,Bt,(V,se)=>{var he=un(),Ie=s(he,!0);r(he);var Ue={};y(()=>{I(Ie,e(se)),Ue!==(Ue=e(se))&&(he.value=(he.__value=e(se))??"")}),l(V,he)}),r(E),y(V=>{Ce(E,"id",V),E.disabled=e(x)},[()=>T(e(w).key)]),da(E,()=>e(_)[e(w).key],V=>e(_)[e(w).key]=V),l(K,E)},f=K=>{var E=pn();Da(E),y(J=>{Ce(E,"id",J),E.disabled=e(x)},[()=>T(e(w).key)]),$t(E,()=>e(_)[e(w).key],J=>e(_)[e(w).key]=J),l(K,E)},g=K=>{var E=mn();Ft(E),y((J,X)=>{Ce(E,"id",J),Ce(E,"type",X),E.disabled=e(x)},[()=>T(e(w).key),()=>pe(e(w))]),$t(E,()=>e(_)[e(w).key],J=>e(_)[e(w).key]=J),l(K,E)};D(st,K=>{e(w).type==="boolean"?K(ot):e(w).type==="enum"&&e(w).enumValues?K(Ne,1):e(w).type==="json"?K(f,2):K(g,!1)})}l(Ke,Ee)},Xt=Ke=>{var Ee=yn();let st;var ot=s(Ee);{var Ne=V=>{var se=_n();l(V,se)},f=A(()=>S(e(z))),g=V=>{var se=hn(),he=s(se,!0);r(se),y(()=>I(he,e(z)?"true":"false")),l(V,se)},K=V=>{var se=bn(),he=s(se,!0);r(se),y(Ie=>I(he,Ie),[()=>JSON.stringify(e(z),null,2)]),l(V,se)},E=A(()=>e(w).type==="json"&&Y(e(z))),J=V=>{const se=A(()=>e(w).linkFn(e(z)));var he=Yt(),Ie=Ve(he);{var Ue=Lt=>{var it=gn(),mt=s(it,!0);r(it),y(Mt=>{Ce(it,"href",e(se)),I(mt,Mt)},[()=>G(e(z),e(w))]),l(Lt,it)},Ut=Lt=>{var it=Qe();y(mt=>I(it,mt),[()=>G(e(z),e(w))]),l(Lt,it)};D(Ie,Lt=>{e(se)?Lt(Ue):Lt(Ut,!1)})}l(V,he)},X=V=>{var se=Qe();y(he=>I(se,he),[()=>G(e(z),e(w))]),l(V,se)};D(ot,V=>{e(f)?V(Ne):e(w).type==="boolean"?V(g,1):e(E)?V(K,2):e(w).linkFn?V(J,3):V(X,!1)})}r(Ee),y(V=>st=Tt(Ee,1,"rdp-field__value svelte-yphh8m",null,st,V),[()=>({"rdp-field__value--null":S(e(z))})]),l(Ke,Ee)};D(Rt,Ke=>{e(Fe)?Ke(Jt):Ke(Xt,!1)})}r(xe),y(()=>I(Qt,e(w).type)),l(oe,xe)}),r(Me);var De=d(Me,2),Re=s(De),We=d(Re,2);{var at=oe=>{var w=xn(),z=Ve(w),Fe=d(z,2),xe=s(Fe);{var m=_e=>{var je=kn();l(_e,je)},B=_e=>{var je=Qe("Save Changes");l(_e,je)};D(xe,_e=>{e(x)?_e(m):_e(B,!1)})}r(Fe),y(()=>{z.disabled=e(x)||!e(ee),Fe.disabled=e(x)||!e(ee)}),ie("click",z,k),ie("click",Fe,W),l(oe,w)};D(We,oe=>{e(M)&&oe(at)})}r(De),r(Se),ja(Se,oe=>a(h,oe),()=>e(h)),y(()=>{ge.disabled=e(x),Re.disabled=e(x)}),ie("click",me,()=>!e(x)&&t.onClose()),ie("click",ge,function(...oe){var w;(w=t.onClose)==null||w.apply(this,oe)}),ie("click",Re,function(...oe){var w;(w=t.onClose)==null||w.apply(this,oe)}),l(b,L)};D($,b=>{t.open&&e(P)&&b(fe)})}l(n,j),ta()}la(["click"]);var Cn=c("<!> <!>",1),Nn=c('<div class="csv-error svelte-198lwhz"> </div>'),In=c('<span class="csv-filename svelte-198lwhz"> </span>'),Pn=c("<option> </option>"),En=c('<div class="csv-map-row svelte-198lwhz"><span class="csv-map-from svelte-198lwhz"> </span> <span class="csv-map-arrow svelte-198lwhz">→</span> <select class="csv-map-select svelte-198lwhz"><option>— Skip —</option><!></select></div>'),Tn=c('<th class="csv-preview-th svelte-198lwhz"> </th>'),Rn=c('<td class="csv-preview-td svelte-198lwhz"> </td>'),zn=c("<tr></tr>"),Dn=c('<div class="csv-section svelte-198lwhz"><h4 class="csv-section-title svelte-198lwhz">Column Mapping</h4> <div class="csv-mappings svelte-198lwhz"></div></div> <div class="csv-section svelte-198lwhz"><h4 class="csv-section-title svelte-198lwhz">Preview (first 5 rows)</h4> <div class="csv-preview-wrap svelte-198lwhz"><table class="csv-preview-table svelte-198lwhz"><thead><tr></tr></thead><tbody></tbody></table></div></div>',1),jn=c('<div class="csv-import svelte-198lwhz"><!> <div class="csv-upload svelte-198lwhz"><label class="csv-upload-label svelte-198lwhz"><span>Choose CSV file</span> <input type="file" accept=".csv,text/csv" class="csv-file-input svelte-198lwhz"/></label> <!></div> <!></div>'),qn=c('<div class="records-tab svelte-198lwhz"><div class="toolbar svelte-198lwhz"><form class="search-bar svelte-198lwhz"><input class="search-input svelte-198lwhz" type="text" placeholder="Search records..."/> <!> <!></form> <div class="toolbar__right svelte-198lwhz"><div class="toolbar__meta svelte-198lwhz"> </div> <!> <!> <!></div></div> <!> <!> <!></div>');function Qn(n,t){ea(t,!0);const u=()=>pa(qt,"$schemaStore",o),[o,h]=Ia();let _=N(!0),P=N(nt([])),x=N(nt({})),R=N(0),M=N(void 0),ee=N(1),F=N(20),U=N(""),ve=N(""),G=N(""),de=N("asc"),S=N(null),Y=N(!1),re=N(!1),ae=N(null),pe=N(nt([])),T=N(nt([])),W=N(nt({})),k=N(!1),j=N(""),$=A(()=>Object.entries(e(x)).filter(([f])=>!$a.includes(f))),fe=A(()=>Object.keys(e(x))),b=A(()=>e(fe).map(f=>{const g=e(x)[f],K=$a.includes(f);let E="text";(g==null?void 0:g.type)==="number"||(g==null?void 0:g.type)==="integer"||(g==null?void 0:g.type)==="float"?E="number":(g==null?void 0:g.type)==="boolean"?E="boolean":(g==null?void 0:g.type)==="json"?E="json":(g==null?void 0:g.type)==="datetime"||(g==null?void 0:g.type)==="date"?E="datetime":g!=null&&g.enum&&g.enum.length>0&&(E="enum");let J;if(g!=null&&g.references){const X=g.references,V=typeof X=="string"?X:X.table;J=se=>se==null||se===""?null:jr(Ra,V,{instanceId:t.instanceId,search:String(se)})}return{key:f,label:f,type:E,editable:!K&&f!=="id",width:f==="id"?280:E==="json"?200:150,enumValues:g==null?void 0:g.enum,linkFn:J}}));function L(f){const g=f?`data/tables/${encodeURIComponent(t.tableName)}/records/${encodeURIComponent(f)}`:`data/tables/${encodeURIComponent(t.tableName)}/records`;if(!t.instanceId)return g;const K=new URLSearchParams({instanceId:t.instanceId});return`${g}?${K.toString()}`}function me(){return e(M)==="postgres"||e(M)==="neon"}async function Se(){try{const f=ar({limit:1,offset:0,search:e(U),includeTotal:!0}),g=await pt.fetch(Oa(t.tableName,{instanceId:t.instanceId,params:new URLSearchParams(f)}));typeof g.total=="number"&&a(R,g.total,!0)}catch{}}async function ke(f={}){a(_,!0);try{const g=(e(ee)-1)*e(F),K=ar({limit:e(F),offset:g,search:e(U),sortKey:e(G),sortDir:e(de),includeTotal:!me()}),E=await pt.fetch(Oa(t.tableName,{instanceId:t.instanceId,params:new URLSearchParams(K)})),J=E.items??E.data??E.rows??[];if(a(P,J,!0),a(R,typeof E.total=="number"?E.total:e(P).length,!0),e(Y)&&e(S)){const X=J.find(V=>{var se;return String(V.id)===String((se=e(S))==null?void 0:se.id)});X&&a(S,X,!0)}me()&&f.refreshTotal!==!1&&Se()}catch(g){lt(g instanceof Error?g.message:"Failed to load records"),a(P,[],!0)}finally{a(_,!1)}}Ot(()=>{const f=t.tableName;if(t.instanceId,f){const g=u().schema[t.tableName];g&&(a(x,g.fields,!0),a(M,g.provider,!0)),a(ee,1),a(U,""),a(ve,""),a(G,""),a(de,"asc"),Pr(()=>ke())}});function Z(){a(U,e(ve),!0),a(ee,1),ke()}function q(){a(ve,""),a(U,""),a(ee,1),ke()}async function Q(f,g){await pt.fetch(L(f),{method:"PUT",body:g}),e(S)&&String(e(S).id)===f&&a(S,{...e(S),...g},!0),Et("Record updated"),await ke({refreshTotal:!1})}async function be(f){for(const g of f)await pt.fetch(L(g),{method:"DELETE"});Et(`${f.length} record${f.length>1?"s":""} deleted`),await ke()}async function ze(f){await pt.fetch(Oa(t.tableName,{instanceId:t.instanceId}),{method:"POST",body:f}),Et("Record created"),await ke()}function ge(f){a(ee,f,!0),ke({refreshTotal:!1})}function Me(f){a(F,f,!0),a(ee,1),ke()}function De(f,g){a(G,f,!0),a(de,g,!0),ke({refreshTotal:!1})}function Re(f){a(S,f,!0),a(Y,!0)}async function We(){try{const f=await pt.fetch(Oa(t.tableName,{instanceId:t.instanceId,params:{limit:1e4,includeTotal:0}})),g=f.items??f.data??f.rows??[];if(g.length===0){lt("No records to export");return}const K=Ur(e(fe),g),E=new Blob([K],{type:"text/csv;charset=utf-8;"});Ya(E,`${t.tableName}.csv`),Et("CSV exported")}catch(f){lt(f instanceof Error?f.message:"Export failed")}}async function at(){try{const f=await pt.fetch(Oa(t.tableName,{instanceId:t.instanceId,params:{limit:1e4,includeTotal:0}})),g=f.items??f.data??f.rows??[];if(g.length===0){lt("No records to export");return}const K=new Blob([JSON.stringify(g,null,2)],{type:"application/json"});Ya(K,`${t.tableName}.json`),Et("JSON exported")}catch(f){lt(f instanceof Error?f.message:"JSON export failed")}}function oe(){a(ae,null),a(pe,[],!0),a(T,[],!0),a(W,{},!0),a(j,""),a(re,!0)}async function w(f){var E;const K=(E=f.target.files)==null?void 0:E[0];if(K){a(ae,K,!0),a(j,"");try{const J=await K.text(),X=er(J);a(pe,X.headers,!0),a(T,X.rows.slice(0,5),!0);const V={};for(const se of X.headers){const he=se.toLowerCase().trim();for(const[Ie]of e($))if(Ie.toLowerCase()===he){V[se]=Ie;break}}a(W,V,!0)}catch{a(j,"Failed to parse CSV file")}}}async function z(){if(e(ae)){a(k,!0),a(j,"");try{const f=await e(ae).text(),g=er(f),K=[];for(const J of g.rows){const X={};for(let V=0;V<g.headers.length;V++){const se=g.headers[V],he=e(W)[se];if(!he)continue;const Ie=J[V];if(Ie===""||Ie===void 0)continue;const Ue=e(x)[he];if((Ue==null?void 0:Ue.type)==="number"||(Ue==null?void 0:Ue.type)==="integer"||(Ue==null?void 0:Ue.type)==="float")X[he]=Number(Ie);else if((Ue==null?void 0:Ue.type)==="boolean")X[he]=Ie==="true"||Ie==="1";else if((Ue==null?void 0:Ue.type)==="json")try{X[he]=JSON.parse(Ie)}catch{X[he]=Ie}else X[he]=Ie}Object.keys(X).length>0&&K.push(X)}if(K.length===0){a(j,"No valid records to import. Check column mapping.");return}const E=await pt.fetch(`data/tables/${encodeURIComponent(t.tableName)}/import`,{method:"POST",body:{records:K,mode:"create"}});E.errors&&E.errors.length>0?lt(`Imported ${E.imported} records with ${E.errors.length} errors`):Et(`Imported ${E.imported} records`),a(re,!1),await ke()}catch(f){a(j,f instanceof Error?f.message:"Import failed",!0)}finally{a(k,!1)}}}var Fe=qn(),xe=s(Fe),m=s(xe),B=s(m);Ft(B);var _e=d(B,2);ct(_e,{variant:"secondary",size:"sm",type:"submit",children:(f,g)=>{Ae();var K=Qe("Search");l(f,K)},$$slots:{default:!0}});var je=d(_e,2);{var Ct=f=>{ct(f,{variant:"ghost",size:"sm",onclick:q,children:(g,K)=>{Ae();var E=Qe("Clear");l(g,E)},$$slots:{default:!0}})};D(je,f=>{e(U)&&f(Ct)})}r(m);var Qt=d(m,2),Rt=s(Qt),Jt=s(Rt);r(Rt);var Xt=d(Rt,2);ct(Xt,{variant:"ghost",size:"sm",onclick:oe,children:(f,g)=>{Ae();var K=Qe("Import CSV");l(f,K)},$$slots:{default:!0}});var Ke=d(Xt,2);ct(Ke,{variant:"ghost",size:"sm",onclick:We,children:(f,g)=>{Ae();var K=Qe("Export CSV");l(f,K)},$$slots:{default:!0}});var Ee=d(Ke,2);ct(Ee,{variant:"ghost",size:"sm",onclick:at,children:(f,g)=>{Ae();var K=Qe("Export JSON");l(f,K)},$$slots:{default:!0}}),r(Qt),r(xe);var st=d(xe,2);{let f=A(()=>e(U)?"No records match your search.":"This table has no records yet.");_r(st,{get columns(){return e(b)},get rows(){return e(P)},get tableName(){return t.tableName},get loading(){return e(_)},get totalCount(){return e(R)},get page(){return e(ee)},get pageSize(){return e(F)},get emptyMessage(){return e(f)},onSave:Q,onDelete:be,onCreate:ze,onPageChange:ge,onPageSizeChange:Me,onSort:De,onRowInspect:Re})}var ot=d(st,2);pr(ot,{title:"Import CSV",get open(){return e(re)},set open(g){a(re,g,!0)},footer:g=>{var K=Cn(),E=Ve(K);ct(E,{variant:"secondary",onclick:()=>a(re,!1),children:(X,V)=>{Ae();var se=Qe("Cancel");l(X,se)},$$slots:{default:!0}});var J=d(E,2);{let X=A(()=>!e(ae)||e(pe).length===0);ct(J,{variant:"primary",get disabled(){return e(X)},get loading(){return e(k)},onclick:z,children:(V,se)=>{Ae();var he=Qe("Import");l(V,he)},$$slots:{default:!0}})}l(g,K)},children:(g,K)=>{var E=jn(),J=s(E);{var X=it=>{var mt=Nn(),Mt=s(mt,!0);r(mt),y(()=>I(Mt,e(j))),l(it,mt)};D(J,it=>{e(j)&&it(X)})}var V=d(J,2),se=s(V),he=d(s(se),2);r(se);var Ie=d(se,2);{var Ue=it=>{var mt=In(),Mt=s(mt,!0);r(mt),y(()=>I(Mt,e(ae).name)),l(it,mt)};D(Ie,it=>{e(ae)&&it(Ue)})}r(V);var Ut=d(V,2);{var Lt=it=>{var mt=Dn(),Mt=Ve(mt),ca=d(s(Mt),2);tt(ca,21,()=>e(pe),Bt,(aa,Kt)=>{var zt=En(),Wt=s(zt),ha=s(Wt,!0);r(Wt);var ra=d(Wt,4),oa=s(ra);oa.value=oa.__value="";var ka=d(oa);tt(ka,17,()=>e($),Bt,(fa,i)=>{var p=A(()=>Er(e(i),1));let O=()=>e(p)[0];var H=Pn(),ye=s(H,!0);r(H);var ce={};y(()=>{I(ye,O()),ce!==(ce=O())&&(H.value=(H.__value=O())??"")}),l(fa,H)}),r(ra),r(zt),y(()=>I(ha,e(Kt))),da(ra,()=>e(W)[e(Kt)],fa=>e(W)[e(Kt)]=fa),l(aa,zt)}),r(ca),r(Mt);var va=d(Mt,2),ya=d(s(va),2),ma=s(ya),ua=s(ma),wa=s(ua);tt(wa,21,()=>e(pe),Bt,(aa,Kt)=>{var zt=Tn(),Wt=s(zt,!0);r(zt),y(()=>I(Wt,e(Kt))),l(aa,zt)}),r(wa),r(ua);var _a=d(ua);tt(_a,21,()=>e(T),Bt,(aa,Kt)=>{var zt=zn();tt(zt,21,()=>e(Kt),Bt,(Wt,ha)=>{var ra=Rn(),oa=s(ra,!0);r(ra),y(()=>I(oa,e(ha))),l(Wt,ra)}),r(zt),l(aa,zt)}),r(_a),r(ma),r(ya),r(va),l(it,mt)};D(Ut,it=>{e(pe).length>0&&it(Lt)})}r(E),ie("change",he,w),l(g,E)},$$slots:{footer:!0,default:!0}});var Ne=d(ot,2);On(Ne,{get row(){return e(S)},get columns(){return e(b)},onSave:Q,onClose:()=>{a(Y,!1)},get open(){return e(Y)},set open(f){a(Y,f,!0)}}),r(Fe),y(()=>I(Jt,`${e(R)??""} record${e(R)!==1?"s":""}`)),na("submit",m,f=>{f.preventDefault(),Z()}),$t(B,()=>e(ve),f=>a(ve,f)),l(n,Fe),ta(),h()}la(["change"]);const Un=36,rr=1,Ln=2,Sa=3,Ba=4,Bn=5,Fn=6,An=7,Mn=8,Kn=9,Vn=10,Jn=11,Xn=12,Wn=13,Zn=14,Hn=15,Gn=16,Yn=17,sr=18,$n=19,hr=20,br=21,nr=22,el=23,tl=24;function Ma(n){return n>=65&&n<=90||n>=97&&n<=122||n>=48&&n<=57}function al(n){return n>=48&&n<=57||n>=97&&n<=102||n>=65&&n<=70}function ga(n,t,u){for(let o=!1;;){if(n.next<0)return;if(n.next==t&&!o){n.advance();return}o=u&&!o&&n.next==92,n.advance()}}function rl(n,t){e:for(;;){if(n.next<0)return;if(n.next==36){n.advance();for(let u=0;u<t.length;u++){if(n.next!=t.charCodeAt(u))continue e;n.advance()}if(n.next==36){n.advance();return}}else n.advance()}}function sl(n,t){let u="[{<(".indexOf(String.fromCharCode(t)),o=u<0?t:"]}>)".charCodeAt(u);for(;;){if(n.next<0)return;if(n.next==o&&n.peek(1)==39){n.advance(2);return}n.advance()}}function Ka(n,t){for(;!(n.next!=95&&!Ma(n.next));)t!=null&&(t+=String.fromCharCode(n.next)),n.advance();return t}function nl(n){if(n.next==39||n.next==34||n.next==96){let t=n.next;n.advance(),ga(n,t,!1)}else Ka(n)}function lr(n,t){for(;n.next==48||n.next==49;)n.advance();t&&n.next==t&&n.advance()}function or(n,t){for(;;){if(n.next==46){if(t)break;t=!0}else if(n.next<48||n.next>57)break;n.advance()}if(n.next==69||n.next==101)for(n.advance(),(n.next==43||n.next==45)&&n.advance();n.next>=48&&n.next<=57;)n.advance()}function ir(n){for(;!(n.next<0||n.next==10);)n.advance()}function ba(n,t){for(let u=0;u<t.length;u++)if(t.charCodeAt(u)==n)return!0;return!1}const Fa=` \r
|
|
4
|
-
`;function gr(n,t,u){let o=Object.create(null);o.true=o.false=Bn,o.null=o.unknown=Fn;for(let h of n.split(" "))h&&(o[h]=hr);for(let h of t.split(" "))h&&(o[h]=br);for(let h of(u||"").split(" "))h&&(o[h]=tl);return o}const yr="array binary bit boolean char character clob date decimal double float int integer interval large national nchar nclob numeric object precision real smallint time timestamp varchar varying ",wr="absolute action add after all allocate alter and any are as asc assertion at authorization before begin between both breadth by call cascade cascaded case cast catalog check close collate collation column commit condition connect connection constraint constraints constructor continue corresponding count create cross cube current current_date current_default_transform_group current_transform_group_for_type current_path current_role current_time current_timestamp current_user cursor cycle data day deallocate declare default deferrable deferred delete depth deref desc describe descriptor deterministic diagnostics disconnect distinct do domain drop dynamic each else elseif end end-exec equals escape except exception exec execute exists exit external fetch first for foreign found from free full function general get global go goto grant group grouping handle having hold hour identity if immediate in indicator initially inner inout input insert intersect into is isolation join key language last lateral leading leave left level like limit local localtime localtimestamp locator loop map match method minute modifies module month names natural nesting new next no none not of old on only open option or order ordinality out outer output overlaps pad parameter partial path prepare preserve primary prior privileges procedure public read reads recursive redo ref references referencing relative release repeat resignal restrict result return returns revoke right role rollback rollup routine row rows savepoint schema scroll search second section select session session_user set sets signal similar size some space specific specifictype sql sqlexception sqlstate sqlwarning start state static system_user table temporary then timezone_hour timezone_minute to trailing transaction translation treat trigger under undo union unique unnest until update usage user using value values view when whenever where while with without work write year zone ",Va={backslashEscapes:!1,hashComments:!1,spaceAfterDashes:!1,slashComments:!1,doubleQuotedStrings:!1,doubleDollarQuotedStrings:!1,unquotedBitLiterals:!1,treatBitsAsBytes:!1,charSetCasts:!1,plsqlQuotingMechanism:!1,operatorChars:"*+-%<>!=&|~^/",specialVar:"?",identifierQuotes:'"',caseInsensitiveIdentifiers:!1,words:gr(wr,yr)};function ll(n,t,u,o){let h={};for(let _ in Va)h[_]=(n.hasOwnProperty(_)?n:Va)[_];return t&&(h.words=gr(t,u||"",o)),h}function kr(n){return new Zr(t=>{var u;let{next:o}=t;if(t.advance(),ba(o,Fa)){for(;ba(t.next,Fa);)t.advance();t.acceptToken(Un)}else if(o==36&&n.doubleDollarQuotedStrings){let h=Ka(t,"");t.next==36&&(t.advance(),rl(t,h),t.acceptToken(Sa))}else if(o==39||o==34&&n.doubleQuotedStrings)ga(t,o,n.backslashEscapes),t.acceptToken(Sa);else if(o==35&&n.hashComments||o==47&&t.next==47&&n.slashComments)ir(t),t.acceptToken(rr);else if(o==45&&t.next==45&&(!n.spaceAfterDashes||t.peek(1)==32))ir(t),t.acceptToken(rr);else if(o==47&&t.next==42){t.advance();for(let h=1;;){let _=t.next;if(t.next<0)break;if(t.advance(),_==42&&t.next==47){if(h--,t.advance(),!h)break}else _==47&&t.next==42&&(h++,t.advance())}t.acceptToken(Ln)}else if((o==101||o==69)&&t.next==39)t.advance(),ga(t,39,!0),t.acceptToken(Sa);else if((o==110||o==78)&&t.next==39&&n.charSetCasts)t.advance(),ga(t,39,n.backslashEscapes),t.acceptToken(Sa);else if(o==95&&n.charSetCasts)for(let h=0;;h++){if(t.next==39&&h>1){t.advance(),ga(t,39,n.backslashEscapes),t.acceptToken(Sa);break}if(!Ma(t.next))break;t.advance()}else if(n.plsqlQuotingMechanism&&(o==113||o==81)&&t.next==39&&t.peek(1)>0&&!ba(t.peek(1),Fa)){let h=t.peek(1);t.advance(2),sl(t,h),t.acceptToken(Sa)}else if(ba(o,n.identifierQuotes)){const h=o==91?93:o;ga(t,h,!1),t.acceptToken($n)}else if(o==40)t.acceptToken(An);else if(o==41)t.acceptToken(Mn);else if(o==123)t.acceptToken(Kn);else if(o==125)t.acceptToken(Vn);else if(o==91)t.acceptToken(Jn);else if(o==93)t.acceptToken(Xn);else if(o==59)t.acceptToken(Wn);else if(n.unquotedBitLiterals&&o==48&&t.next==98)t.advance(),lr(t),t.acceptToken(nr);else if((o==98||o==66)&&(t.next==39||t.next==34)){const h=t.next;t.advance(),n.treatBitsAsBytes?(ga(t,h,n.backslashEscapes),t.acceptToken(el)):(lr(t,h),t.acceptToken(nr))}else if(o==48&&(t.next==120||t.next==88)||(o==120||o==88)&&t.next==39){let h=t.next==39;for(t.advance();al(t.next);)t.advance();h&&t.next==39&&t.advance(),t.acceptToken(Ba)}else if(o==46&&t.next>=48&&t.next<=57)or(t,!0),t.acceptToken(Ba);else if(o==46)t.acceptToken(Zn);else if(o>=48&&o<=57)or(t,!1),t.acceptToken(Ba);else if(ba(o,n.operatorChars)){for(;ba(t.next,n.operatorChars);)t.advance();t.acceptToken(Hn)}else if(ba(o,n.specialVar))t.next==o&&t.advance(),nl(t),t.acceptToken(Yn);else if(o==58||o==44)t.acceptToken(Gn);else if(Ma(o)){let h=Ka(t,String.fromCharCode(o));t.acceptToken(t.next==46||t.peek(-h.length-1)==46?sr:(u=n.words[h.toLowerCase()])!==null&&u!==void 0?u:sr)}})}const xr=kr(Va),ol=Hr.deserialize({version:14,states:"%vQ]QQOOO#wQRO'#DSO$OQQO'#CwO%eQQO'#CxO%lQQO'#CyO%sQQO'#CzOOQQ'#DS'#DSOOQQ'#C}'#C}O'UQRO'#C{OOQQ'#Cv'#CvOOQQ'#C|'#C|Q]QQOOQOQQOOO'`QQO'#DOO(xQRO,59cO)PQQO,59cO)UQQO'#DSOOQQ,59d,59dO)cQQO,59dOOQQ,59e,59eO)jQQO,59eOOQQ,59f,59fO)qQQO,59fOOQQ-E6{-E6{OOQQ,59b,59bOOQQ-E6z-E6zOOQQ,59j,59jOOQQ-E6|-E6|O+VQRO1G.}O+^QQO,59cOOQQ1G/O1G/OOOQQ1G/P1G/POOQQ1G/Q1G/QP+kQQO'#C}O+rQQO1G.}O)PQQO,59cO,PQQO'#Cw",stateData:",[~OtOSPOSQOS~ORUOSUOTUOUUOVROXSOZTO]XO^QO_UO`UOaPObPOcPOdUOeUOfUOgUOhUO~O^]ORvXSvXTvXUvXVvXXvXZvX]vX_vX`vXavXbvXcvXdvXevXfvXgvXhvX~OsvX~P!jOa_Ob_Oc_O~ORUOSUOTUOUUOVROXSOZTO^tO_UO`UOa`Ob`Oc`OdUOeUOfUOgUOhUO~OWaO~P$ZOYcO~P$ZO[eO~P$ZORUOSUOTUOUUOVROXSOZTO^QO_UO`UOaPObPOcPOdUOeUOfUOgUOhUO~O]hOsoX~P%zOajObjOcjO~O^]ORkaSkaTkaUkaVkaXkaZka]ka_ka`kaakabkackadkaekafkagkahka~Oska~P'kO^]O~OWvXYvX[vX~P!jOWnO~P$ZOYoO~P$ZO[pO~P$ZO^]ORkiSkiTkiUkiVkiXkiZki]ki_ki`kiakibkickidkiekifkigkihki~Oski~P)xOWkaYka[ka~P'kO]hO~P$ZOWkiYki[ki~P)xOasObsOcsO~O",goto:"#hwPPPPPPPPPPPPPPPPPPPPPPPPPPx||||!Y!^!d!xPPP#[TYOZeUORSTWZbdfqT[OZQZORiZSWOZQbRQdSQfTZgWbdfqQ^PWk^lmrQl_Qm`RrseVORSTWZbdfq",nodeNames:"⚠ LineComment BlockComment String Number Bool Null ( ) { } [ ] ; . Operator Punctuation SpecialVar Identifier QuotedIdentifier Keyword Type Bits Bytes Builtin Script Statement CompositeIdentifier Parens Braces Brackets Statement",maxTerm:38,nodeProps:[["isolate",-4,1,2,3,19,""]],skippedNodes:[0,1,2],repeatNodeCount:3,tokenData:"RORO",tokenizers:[0,xr],topRules:{Script:[0,25]},tokenPrec:0});function Ja(n){let t=n.cursor().moveTo(n.from,-1);for(;/Comment/.test(t.name);)t.moveTo(t.from,-1);return t.node}function Ca(n,t){let u=n.sliceString(t.from,t.to),o=/^([`'"\[])(.*)([`'"\]])$/.exec(u);return o?o[2]:u}function za(n){return n&&(n.name=="Identifier"||n.name=="QuotedIdentifier")}function il(n,t){if(t.name=="CompositeIdentifier"){let u=[];for(let o=t.firstChild;o;o=o.nextSibling)za(o)&&u.push(Ca(n,o));return u}return[Ca(n,t)]}function dr(n,t){for(let u=[];;){if(!t||t.name!=".")return u;let o=Ja(t);if(!za(o))return u;u.unshift(Ca(n,o)),t=Ja(o)}}function dl(n,t){let u=Gr(n).resolveInner(t,-1),o=vl(n.doc,u);return u.name=="Identifier"||u.name=="QuotedIdentifier"||u.name=="Keyword"?{from:u.from,quoted:u.name=="QuotedIdentifier"?n.doc.sliceString(u.from,u.from+1):null,parents:dr(n.doc,Ja(u)),aliases:o}:u.name=="."?{from:t,quoted:null,parents:dr(n.doc,u),aliases:o}:{from:t,quoted:null,parents:[],empty:!0,aliases:o}}const cl=new Set("where group having order union intersect except all distinct limit offset fetch for".split(" "));function vl(n,t){let u;for(let h=t;!u;h=h.parent){if(!h)return null;h.name=="Statement"&&(u=h)}let o=null;for(let h=u.firstChild,_=!1,P=null;h;h=h.nextSibling){let x=h.name=="Keyword"?n.sliceString(h.from,h.to).toLowerCase():null,R=null;if(!_)_=x=="from";else if(x=="as"&&P&&za(h.nextSibling))R=Ca(n,h.nextSibling);else{if(x&&cl.has(x))break;P&&za(h)&&(R=Ca(n,h))}R&&(o||(o=Object.create(null)),o[R]=il(n,P)),P=/Identifier$/.test(h.name)?h:null}return o}function ul(n,t,u){return u.map(o=>({...o,label:o.label[0]==n?o.label:n+o.label+t,apply:void 0}))}const fl=/^\w*$/,pl=/^[`'"\[]?\w*[`'"\]]?$/;function cr(n){return n.self&&typeof n.self.label=="string"}class Xa{constructor(t,u){this.idQuote=t,this.idCaseInsensitive=u,this.list=[],this.children=void 0}child(t){let u=this.children||(this.children=Object.create(null)),o=u[t];return o||(t&&!this.list.some(h=>h.label==t)&&this.list.push(vr(t,"type",this.idQuote,this.idCaseInsensitive)),u[t]=new Xa(this.idQuote,this.idCaseInsensitive))}maybeChild(t){return this.children?this.children[t]:null}addCompletion(t){let u=this.list.findIndex(o=>o.label==t.label);u>-1?this.list[u]=t:this.list.push(t)}addCompletions(t){for(let u of t)this.addCompletion(typeof u=="string"?vr(u,"property",this.idQuote,this.idCaseInsensitive):u)}addNamespace(t){Array.isArray(t)?this.addCompletions(t):cr(t)?this.addNamespace(t.children):this.addNamespaceObject(t)}addNamespaceObject(t){for(let u of Object.keys(t)){let o=t[u],h=null,_=u.replace(/\\?\./g,x=>x=="."?"\0":x).split("\0"),P=this;cr(o)&&(h=o.self,o=o.children);for(let x=0;x<_.length;x++)h&&x==_.length-1&&P.addCompletion(h),P=P.child(_[x].replace(/\\\./g,"."));P.addNamespace(o)}}}function vr(n,t,u,o){return new RegExp("^[a-z_][a-z_\\d]*$",o?"i":"").test(n)?{label:n,type:t}:{label:n,type:t,apply:u+n+Sr(u)}}function Sr(n){return n==="["?"]":n}function ml(n,t,u,o,h,_){var P;let x=((P=_==null?void 0:_.spec.identifierQuotes)===null||P===void 0?void 0:P[0])||'"',R=new Xa(x,!!(_!=null&&_.spec.caseInsensitiveIdentifiers)),M=h?R.child(h):null;return R.addNamespace(n),t&&(M||R).addCompletions(t),u&&R.addCompletions(u),M&&R.addCompletions(M.list),o&&R.addCompletions((M||R).child(o).list),ee=>{let{parents:F,from:U,quoted:ve,empty:G,aliases:de}=dl(ee.state,ee.pos);if(G&&!ee.explicit)return null;de&&F.length==1&&(F=de[F[0]]||F);let S=R;for(let re of F){for(;!S.children||!S.children[re];)if(S==R&&M)S=M;else if(S==M&&o)S=S.child(o);else return null;let ae=S.maybeChild(re);if(!ae)return null;S=ae}let Y=S.list;if(S==R&&de&&(Y=Y.concat(Object.keys(de).map(re=>({label:re,type:"constant"})))),ve){let re=ve[0],ae=Sr(re),pe=ee.state.sliceDoc(ee.pos,ee.pos+1)==ae;return{from:U,to:pe?ee.pos+1:void 0,options:ul(re,ae,Y),validFor:pl}}else return{from:U,options:Y,validFor:fl}}}function _l(n){return n==br?"type":n==hr?"keyword":"variable"}function hl(n,t,u){let o=Object.keys(n).map(h=>u(t?h.toUpperCase():h,_l(n[h])));return Mr(["QuotedIdentifier","String","LineComment","BlockComment","."],Kr(o))}let bl=ol.configure({props:[Vr.add({Statement:Jr()}),Xr.add({Statement(n,t){return{from:Math.min(n.from+100,t.doc.lineAt(n.from).to),to:n.to}},BlockComment(n){return{from:n.from+2,to:n.to-2}}}),Wr({Keyword:ft.keyword,Type:ft.typeName,Builtin:ft.standard(ft.name),Bits:ft.number,Bytes:ft.string,Bool:ft.bool,Null:ft.null,Number:ft.number,String:ft.string,Identifier:ft.name,QuotedIdentifier:ft.special(ft.string),SpecialVar:ft.special(ft.name),LineComment:ft.lineComment,BlockComment:ft.blockComment,Operator:ft.operator,"Semi Punctuation":ft.punctuation,"( )":ft.paren,"{ }":ft.brace,"[ ]":ft.squareBracket})]});class Na{constructor(t,u,o){this.dialect=t,this.language=u,this.spec=o}get extension(){return this.language.extension}configureLanguage(t,u){return new Na(this.dialect,this.language.configure(t,u),this.spec)}static define(t){let u=ll(t,t.keywords,t.types,t.builtin),o=Ar.define({name:"sql",parser:bl.configure({tokenizers:[{from:xr,to:kr(u)}]}),languageData:{commentTokens:{line:"--",block:{open:"/*",close:"*/"}},closeBrackets:{brackets:["(","[","{","'",'"',"`"]}}});return new Na(u,o,t)}}function gl(n,t){return{label:n,type:t,boost:-1}}function yl(n,t=!1,u){return hl(n.dialect.words,t,u||gl)}function wl(n){return n.schema?ml(n.schema,n.tables,n.schemas,n.defaultTable,n.defaultSchema,n.dialect||Wa):()=>null}function kl(n){return n.schema?(n.dialect||Wa).language.data.of({autocomplete:wl(n)}):[]}function xl(n={}){let t=n.dialect||Wa;return new Fr(t.language,[kl(n),t.language.data.of({autocomplete:yl(t,n.upperCaseKeywords,n.keywordCompletion)})])}const Wa=Na.define({}),Sl=Na.define({keywords:wr+"abort analyze attach autoincrement conflict database detach exclusive fail glob ignore index indexed instead isnull notnull offset plan pragma query raise regexp reindex rename replace temp vacuum virtual",types:yr+"bool blob long longblob longtext medium mediumblob mediumint mediumtext tinyblob tinyint tinytext text bigint int2 int8 unsigned signed real",builtin:"auth backup bail changes clone databases dbinfo dump echo eqp explain fullschema headers help import imposter indexes iotrace lint load log mode nullvalue once print prompt quit restore save scanstats separator shell show stats system tables testcase timeout timer trace vfsinfo vfslist vfsname width",operatorChars:"*+-%<>!=&|/~",identifierQuotes:'`"',specialVar:"@:?$"});var Ol=c('<div class="sql-editor-wrap svelte-392xt8"></div>');function Cl(n,t){ea(t,!0);let u=wt(t,"placeholder",3,""),o=wt(t,"schema",19,()=>({})),h,_,P=N(!1);function x(){return document.documentElement.dataset.theme==="dark"||document.documentElement.dataset.theme!=="light"&&window.matchMedia("(prefers-color-scheme: dark)").matches}function R(){const F=[xl({dialect:Sl,schema:o()}),$r(),es.of([...ts,as,{key:"Mod-Enter",run:()=>{var U;return(U=t.onExecute)==null||U.call(t),!0}}]),La.updateListener.of(U=>{if(U.docChanged){const ve=U.state.doc.toString();t.onchange(ve)}}),La.theme({"&":{fontSize:"13px",maxHeight:"300px"},".cm-scroller":{overflow:"auto",fontFamily:"var(--font-mono)"},".cm-content":{minHeight:"100px",padding:"8px 0"},"&.cm-focused":{outline:"none"}})];return u()&&F.push(rs(u())),e(P)?F.push(ss):F.push(ns(ls)),F}function M(){_&&_.destroy(),_=new La({state:Yr.create({doc:t.value,extensions:R()}),parent:h})}Lr(()=>{a(P,x(),!0),M();const F=new MutationObserver(()=>{const U=x();if(U!==e(P)){a(P,U,!0);const ve=(_==null?void 0:_.state.doc.toString())??t.value;M(),ve!==t.value&&(_==null||_.dispatch({changes:{from:0,to:_.state.doc.length,insert:ve}}))}});return F.observe(document.documentElement,{attributes:!0,attributeFilter:["data-theme"]}),()=>{F.disconnect(),_==null||_.destroy()}}),Br(()=>{_==null||_.destroy()}),Ot(()=>{_&&t.value!==_.state.doc.toString()&&_.dispatch({changes:{from:0,to:_.state.doc.length,insert:t.value}})});var ee=Ol();ja(ee,F=>h=F,()=>h),l(n,ee),ta()}var Nl=c('<div class="table-sql__target svelte-1syrthj"><span class="table-sql__target-label svelte-1syrthj"> </span> <code class="svelte-1syrthj"> </code></div>'),Il=c('<div><button type="button" class="table-sql__result-open svelte-1syrthj"><span> </span></button> <button type="button" class="table-sql__result-close svelte-1syrthj">×</button></div>'),Pl=c('<span class="table-sql__result-error svelte-1syrthj"> </span>'),El=c("<span> </span>"),Tl=c('<pre class="table-sql__error-block svelte-1syrthj"> </pre>'),Rl=c('<div class="table-sql__empty svelte-1syrthj">Query returned no rows.</div>'),zl=c('<div class="table-sql__result-panel svelte-1syrthj"><div class="table-sql__result-meta svelte-1syrthj"><!></div> <!></div>'),Dl=c('<div class="table-sql__result-tabs svelte-1syrthj"></div> <!>',1),jl=c('<div class="table-sql__empty svelte-1syrthj">Run a query against <code> </code> to inspect rows, joins, or aggregates for this target.</div>'),ql=c('<div class="table-sql svelte-1syrthj"><div class="table-sql__toolbar svelte-1syrthj"><div class="table-sql__target svelte-1syrthj"><span class="table-sql__target-label svelte-1syrthj">Database</span> <code class="svelte-1syrthj"> </code></div> <!> <!> <span class="table-sql__shortcut svelte-1syrthj"></span></div> <!> <!></div>');function Ql(n,t){var ke;ea(t,!0);const u=()=>pa(qt,"$schemaStore",o),[o,h]=Ia();let _=N(""),P=N(!1),x=N(nt([])),R=N(0),M=N(0),ee=A(()=>u().schema[t.tableName]),F=A(()=>(()=>{const Z={},q=u().schema;for(const[Q,be]of Object.entries(q)){const ze=be.fields;Z[Q]=ze?Object.keys(ze):[]}return Z})()),U=A(()=>{var Z;return(Z=e(ee))!=null&&Z.dynamic?"Per-tenant DB":"Single DB"}),ve=A(()=>{var Z,q,Q;return((Q=(q=(Z=e(ee))==null?void 0:Z.instanceDiscovery)==null?void 0:q.targetLabel)==null?void 0:Q.trim())||"Target"}),G=A(()=>t.instanceId||"Not selected");function de(Z){return`SELECT * FROM "${Z}" LIMIT 100;`}Ot(()=>{a(_,de(t.tableName),!0)}),Ot(()=>{Object.keys(u().schema).length===0&&qt.loadSchema({silent:!0})});async function S(){if(e(_).trim()){a(P,!0);try{const Z=await pt.fetch("data/sql",{method:"POST",body:{namespace:t.namespace,id:t.instanceId||void 0,sql:e(_).trim()}}),q=(Z.columns??[]).map(Q=>({key:Q,label:Q,type:"text",editable:!1}));a(M,e(M)+1),a(x,[...e(x),{id:e(M),sql:e(_).trim(),columns:q,rows:Z.rows??[],rowCount:Z.rowCount??0,time:Z.time??0}],!0),a(R,e(x).length-1)}catch(Z){const q=Z instanceof Error?Z.message:"Query failed";lt(q),a(M,e(M)+1),a(x,[...e(x),{id:e(M),sql:e(_).trim(),columns:[],rows:[],rowCount:0,time:0,error:q}],!0),a(R,e(x).length-1)}finally{a(P,!1)}}}function Y(Z){const q=e(x).filter((Q,be)=>be!==Z);e(R)>Z?a(R,e(R)-1):e(R)===Z&&a(R,Math.min(Z,Math.max(0,q.length-1)),!0),a(x,q,!0)}var re=ql(),ae=s(re),pe=s(ae),T=d(s(pe),2),W=s(T,!0);r(T),r(pe);var k=d(pe,2);{var j=Z=>{var q=Nl(),Q=s(q),be=s(Q,!0);r(Q);var ze=d(Q,2),ge=s(ze,!0);r(ze),r(q),y(()=>{I(be,e(ve)),I(ge,e(G))}),l(Z,q)};D(k,Z=>{var q;(q=e(ee))!=null&&q.dynamic&&Z(j)})}var $=d(k,2);{let Z=A(()=>e(P)||!e(_).trim());ct($,{variant:"primary",size:"sm",onclick:S,get loading(){return e(P)},get disabled(){return e(Z)},children:(q,Q)=>{Ae();var be=Qe();y(()=>I(be,e(P)?"Executing...":"Execute")),l(q,be)},$$slots:{default:!0}})}var fe=d($,2);fe.textContent=`${(ke=navigator.platform)!=null&&ke.includes("Mac")?"⌘":"Ctrl"}+Enter`,r(ae);var b=d(ae,2);{let Z=A(()=>`SELECT * FROM "${t.tableName}" LIMIT 100;`);Cl(b,{get value(){return e(_)},onchange:q=>a(_,q,!0),onExecute:S,get placeholder(){return e(Z)},get schema(){return e(F)}})}var L=d(b,2);{var me=Z=>{var q=Dl(),Q=Ve(q);tt(Q,23,()=>e(x),ge=>ge.id,(ge,Me,De)=>{var Re=Il();let We;var at=s(Re),oe=s(at),w=s(oe);r(oe),r(at);var z=d(at,2);r(Re),y(()=>{We=Tt(Re,1,"table-sql__result-tab svelte-1syrthj",null,We,{"table-sql__result-tab--active":e(De)===e(R)}),I(w,`Result ${e(De)+1}`),Ce(z,"aria-label",`Close result ${e(De)+1}`)}),ie("click",at,()=>a(R,e(De),!0)),ie("click",z,Fe=>{Fe.stopPropagation(),Y(e(De))}),l(ge,Re)}),r(Q);var be=d(Q,2);{var ze=ge=>{var Me=zl(),De=s(Me),Re=s(De);{var We=xe=>{var m=Pl(),B=s(m,!0);r(m),y(()=>I(B,e(x)[e(R)].error)),l(xe,m)},at=xe=>{var m=El(),B=s(m);r(m),y(()=>I(B,`${e(x)[e(R)].rowCount??""} row${e(x)[e(R)].rowCount===1?"":"s"} · ${e(x)[e(R)].time??""}ms`)),l(xe,m)};D(Re,xe=>{e(x)[e(R)].error?xe(We):xe(at,!1)})}r(De);var oe=d(De,2);{var w=xe=>{var m=Tl(),B=s(m,!0);r(m),y(()=>I(B,e(x)[e(R)].sql)),l(xe,m)},z=xe=>{var m=Rl();l(xe,m)},Fe=xe=>{_r(xe,{get columns(){return e(x)[e(R)].columns},get rows(){return e(x)[e(R)].rows},readonly:!0})};D(oe,xe=>{e(x)[e(R)].error?xe(w):e(x)[e(R)].rows.length===0?xe(z,1):xe(Fe,!1)})}r(Me),l(ge,Me)};D(be,ge=>{e(x)[e(R)]&&ge(ze)})}l(Z,q)},Se=Z=>{var q=jl(),Q=d(s(q)),be=s(Q,!0);r(Q),Ae(),r(q),y(()=>I(be,t.tableName)),l(Z,q)};D(L,Z=>{e(x).length>0?Z(me):Z(Se,!1)})}r(re),y(()=>I(W,e(U))),l(n,re),ta(),h()}la(["click"]);var Ul=c('<div class="index-error svelte-v6rf4z"> </div>'),Ll=c('<div class="index-form svelte-v6rf4z"><!> <div class="index-form__row"><!></div> <div class="index-form__row"><!></div> <div class="index-form__actions svelte-v6rf4z"><!></div></div>'),Bl=c('<div class="index-empty svelte-v6rf4z">No indexes defined.</div>'),Fl=c('<span class="index-unique svelte-v6rf4z">UNIQUE</span>'),Al=c('<button class="index-delete svelte-v6rf4z" title="Remove index"><svg width="14" height="14" viewBox="0 0 14 14" fill="none"><path d="M4 4L10 10M10 4L4 10" stroke="currentColor" stroke-width="1.2" stroke-linecap="round"></path></svg></button>'),Ml=c('<div class="index-row svelte-v6rf4z"><code class="index-fields svelte-v6rf4z"> </code> <!> <!></div>'),Kl=c('<div class="index-editor svelte-v6rf4z"><div class="index-editor__header svelte-v6rf4z"><span class="index-editor__title svelte-v6rf4z"> </span> <!></div> <!> <!></div>');function Vl(n,t){ea(t,!0);let u=wt(t,"indexes",19,()=>[]),o=wt(t,"availableFields",19,()=>[]),h=wt(t,"readonly",3,!1),_=N(!1),P=N(""),x=N(!1),R=N("");function M(){var k;const T=e(P).split(",").map(j=>j.trim()).filter(Boolean);if(T.length===0){a(R,"At least one field is required.");return}const W=T.filter(j=>!o().includes(j));if(W.length>0){a(R,`Unknown field(s): ${W.join(", ")}`);return}(k=t.onadd)==null||k.call(t,{fields:T,unique:e(x)||void 0}),a(P,""),a(x,!1),a(R,""),a(_,!1)}var ee=Kl(),F=s(ee),U=s(F),ve=s(U);r(U);var G=d(U,2);{var de=T=>{ct(T,{variant:"secondary",size:"sm",onclick:()=>a(_,!e(_)),children:(W,k)=>{Ae();var j=Qe();y(()=>I(j,e(_)?"Cancel":"Add Index")),l(W,j)},$$slots:{default:!0}})};D(G,T=>{h()||T(de)})}r(F);var S=d(F,2);{var Y=T=>{var W=Ll(),k=s(W);{var j=ke=>{var Z=Ul(),q=s(Z,!0);r(Z),y(()=>I(q,e(R))),l(ke,Z)};D(k,ke=>{e(R)&&ke(j)})}var $=d(k,2),fe=s($);is(fe,{placeholder:"field1, field2",label:"Fields (comma-separated)",get value(){return e(P)},set value(ke){a(P,ke,!0)}}),r($);var b=d($,2),L=s(b);ds(L,{label:"Unique index",get checked(){return e(x)},set checked(ke){a(x,ke,!0)}}),r(b);var me=d(b,2),Se=s(me);ct(Se,{variant:"primary",size:"sm",onclick:M,children:(ke,Z)=>{Ae();var q=Qe("Add");l(ke,q)},$$slots:{default:!0}}),r(me),r(W),l(T,W)};D(S,T=>{e(_)&&T(Y)})}var re=d(S,2);{var ae=T=>{var W=Bl();l(T,W)},pe=T=>{var W=Yt(),k=Ve(W);tt(k,17,u,Bt,(j,$,fe)=>{var b=Ml(),L=s(b),me=s(L,!0);r(L);var Se=d(L,2);{var ke=Q=>{var be=Fl();l(Q,be)};D(Se,Q=>{e($).unique&&Q(ke)})}var Z=d(Se,2);{var q=Q=>{var be=Al();ie("click",be,()=>{var ze;return(ze=t.ondelete)==null?void 0:ze.call(t,fe)}),l(Q,be)};D(Z,Q=>{h()||Q(q)})}r(b),y(Q=>I(me,Q),[()=>e($).fields.join(", ")]),l(j,b)}),l(T,W)};D(re,T=>{u().length===0&&!e(_)?T(ae):T(pe,!1)})}r(ee),y(()=>I(ve,`Indexes (${u().length??""})`)),l(n,ee),ta()}la(["click"]);var Jl=c('<div class="fts-empty svelte-974m0i">No string/text fields available for FTS.</div>'),Xl=c('<span class="fts-active svelte-974m0i">active</span>'),Wl=c('<label class="fts-item svelte-974m0i"><input type="checkbox"/> <code class="svelte-974m0i"> </code> <!></label>'),Zl=c('<div class="fts-list svelte-974m0i"></div>'),Hl=c('<div class="fts-editor svelte-974m0i"><div class="fts-editor__header svelte-974m0i"><span class="fts-editor__title svelte-974m0i">Full-Text Search</span> <!></div> <!></div>');function Gl(n,t){ea(t,!0);let u=wt(t,"ftsFields",19,()=>[]),o=wt(t,"availableFields",19,()=>[]),h=wt(t,"readonly",3,!1),_=N(nt({})),P=N(!1);Ot(()=>{const S={};for(const Y of o())S[Y]=u().includes(Y);a(_,S,!0),a(P,!1)});function x(S){e(_)[S]=!e(_)[S],a(P,!0)}function R(){var Y;const S=Object.entries(e(_)).filter(([,re])=>re).map(([re])=>re);(Y=t.onsave)==null||Y.call(t,S),a(P,!1)}var M=Hl(),ee=s(M),F=d(s(ee),2);{var U=S=>{ct(S,{variant:"primary",size:"sm",onclick:R,children:(Y,re)=>{Ae();var ae=Qe("Save FTS");l(Y,ae)},$$slots:{default:!0}})};D(F,S=>{!h()&&e(P)&&S(U)})}r(ee);var ve=d(ee,2);{var G=S=>{var Y=Jl();l(S,Y)},de=S=>{var Y=Zl();tt(Y,20,o,re=>re,(re,ae)=>{var pe=Wl(),T=s(pe);Ft(T);var W=d(T,2),k=s(W,!0);r(W);var j=d(W,2);{var $=b=>{var L=Xl();l(b,L)},fe=A(()=>u().includes(ae));D(j,b=>{e(fe)&&b($)})}r(pe),y(()=>{Ta(T,e(_)[ae]??!1),T.disabled=h(),I(k,ae)}),ie("change",T,()=>x(ae)),l(re,pe)}),r(Y),l(S,Y)};D(ve,S=>{o().length===0?S(G):S(de,!1)})}r(M),l(n,M),ta()}la(["change"]);var Yl=c('<div class="schema-empty svelte-aw0zhs">Loading schema...</div>'),$l=c('<div class="schema-empty svelte-aw0zhs"> </div>'),eo=c('<div class="readonly-banner svelte-aw0zhs">Schema editing requires dev mode. Viewing in read-only mode.</div>'),to=c('<div class="rename-inline svelte-aw0zhs"><input class="rename-input svelte-aw0zhs" placeholder="new_name"/> <!> <!></div>'),ao=c("<!> <!>",1),ro=c('<div class="schema-note svelte-aw0zhs"> </div>'),so=c('<div class="schema-actions svelte-aw0zhs"><!></div> <!>',1),no=c('<!> <!> <div class="schema-namespace svelte-aw0zhs">Namespace: <code class="svelte-aw0zhs"> </code></div> <!>',1),lo=c('<div class="schema-tab svelte-aw0zhs"><!></div> <!> <!> <!>',1);function oo(n,t){ea(t,!0);const u=()=>pa(mr,"$devInfoStore",h),o=()=>pa(qt,"$schemaStore",h),[h,_]=Ia();let P=N(null),x=N("columns"),R=A(()=>u().devMode),M=N(!1),ee=N("create"),F=N(""),U=N(nt({type:"string"})),ve=N(!1),G=N(""),de=N(!1),S=N(!1),Y=N("");const re=[{id:"columns",label:"Columns"},{id:"indexes",label:"Indexes"},{id:"fts",label:"FTS"}];Ot(()=>{const m=o();t.tableName&&m.schema[t.tableName]?a(P,m.schema[t.tableName],!0):a(P,null)});let ae=A(()=>{var m;return((m=e(P))==null?void 0:m.fields)??{}}),pe=A(()=>{var m;return((m=e(P))==null?void 0:m.indexes)??[]}),T=A(()=>{var m;return((m=e(P))==null?void 0:m.fts)??[]}),W=A(()=>{var m;return((m=e(P))==null?void 0:m.namespace)??"default"}),k=A(()=>{var m;return(m=e(P))!=null&&m.dynamic?"Table rename is unavailable for per-tenant databases because each tenant instance has its own physical database.":""}),j=A(()=>Object.entries(e(ae)).filter(([,m])=>m.type==="string"||m.type==="text").map(([m])=>m));function $(){a(ee,"create"),a(F,""),a(U,{type:"string"},!0),a(M,!0)}function fe(m,B){a(ee,"edit"),a(F,m,!0),a(U,{...B},!0),a(M,!0)}function b(m){a(G,m,!0),a(ve,!0)}function L(m){return JSON.stringify({fields:m.fields,unique:m.unique===!0?!0:void 0})}function me(m,B){return JSON.stringify(m??null)===JSON.stringify(B)}function Se(m,B){return m.length!==B.length?!1:m.every((_e,je)=>L(_e)===L(B[je]))}function ke(m,B){if(m.length!==B.length)return!1;const _e=[...m].sort(),je=[...B].sort();return _e.every((Ct,Qt)=>Ct===je[Qt])}async function Z(m,B){try{e(ee)==="create"?(await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/columns`,{method:"POST",body:{dbKey:e(W),columnName:m,fieldDef:B}}),Et(`Column "${m}" added`)):(await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/columns/${m}`,{method:"PUT",body:{dbKey:e(W),fieldDef:B}}),Et(`Column "${m}" updated`)),await qt.waitForSchema(_e=>{const je=_e[t.tableName];return!!(je&&me(je.fields[m],B))})}catch(_e){lt(_e instanceof Error?_e.message:"Failed to save column")}}async function q(){a(ve,!1);try{await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/columns/${e(G)}`,{method:"DELETE",body:{dbKey:e(W)}}),Et(`Column "${e(G)}" deleted`),await qt.waitForSchema(m=>{const B=m[t.tableName];return!!(B&&!(e(G)in B.fields))})}catch(m){lt(m instanceof Error?m.message:"Failed to delete column")}}async function Q(m){try{const B=[...e(pe),m];await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/indexes`,{method:"POST",body:{dbKey:e(W),indexDef:m}}),Et("Index added"),await qt.waitForSchema(_e=>{const je=_e[t.tableName];return!!(je&&Se(je.indexes??[],B))})}catch(B){lt(B instanceof Error?B.message:"Failed to add index")}}async function be(m){try{const B=e(pe).filter((_e,je)=>je!==m);await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/indexes/${m}`,{method:"DELETE",body:{dbKey:e(W)}}),Et("Index removed"),await qt.waitForSchema(_e=>{const je=_e[t.tableName];return!!(je&&Se(je.indexes??[],B))})}catch(B){lt(B instanceof Error?B.message:"Failed to remove index")}}async function ze(m){try{await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/fts`,{method:"PUT",body:{dbKey:e(W),fields:m}}),Et("FTS configuration updated"),await qt.waitForSchema(B=>{const _e=B[t.tableName];return!!(_e&&ke(_e.fts??[],m))})}catch(B){lt(B instanceof Error?B.message:"Failed to update FTS")}}async function ge(){a(de,!1);try{await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}`,{method:"DELETE",body:{dbKey:e(W)}}),Et(`Table "${t.tableName}" deleted`),await qt.waitForSchema(m=>!(t.tableName in m)),Aa(`${Ra}/database/tables`)}catch(m){lt(m instanceof Error?m.message:"Failed to delete table")}}async function Me(){const m=e(Y).trim();if(m)try{await pt.schemaMutation(`schema/tables/${encodeURIComponent(t.tableName)}/rename`,{method:"PUT",body:{dbKey:e(W),newName:m}}),Et(`Table renamed to "${m}"`),await qt.waitForSchema(B=>!(t.tableName in B)&&!!B[m],{timeoutMessage:`Table rename to "${m}" did not propagate in time.`}),await qt.waitForTableReady(m,{namespace:e(W)}),Aa(`${Ra}/database/tables/${encodeURIComponent(m)}`)}catch(B){lt(B instanceof Error?B.message:"Failed to rename table")}finally{a(S,!1)}}var De=lo(),Re=Ve(De),We=s(Re);{var at=m=>{var B=Yl();l(m,B)},oe=m=>{var B=$l(),_e=s(B);r(B),y(()=>I(_e,`Table "${t.tableName??""}" not found.`)),l(m,B)},w=m=>{var B=no(),_e=Ve(B);{var je=Ee=>{var st=eo();l(Ee,st)};D(_e,Ee=>{e(R)||Ee(je)})}var Ct=d(_e,2);{var Qt=Ee=>{var st=so(),ot=Ve(st),Ne=s(ot);{var f=J=>{var X=to(),V=s(X);Ft(V);var se=d(V,2);ct(se,{variant:"primary",size:"sm",onclick:Me,children:(Ie,Ue)=>{Ae();var Ut=Qe("Rename");l(Ie,Ut)},$$slots:{default:!0}});var he=d(se,2);ct(he,{variant:"secondary",size:"sm",onclick:()=>a(S,!1),children:(Ie,Ue)=>{Ae();var Ut=Qe("Cancel");l(Ie,Ut)},$$slots:{default:!0}}),r(X),ie("keydown",V,Ie=>Ie.key==="Enter"&&Me()),$t(V,()=>e(Y),Ie=>a(Y,Ie)),l(J,X)},g=J=>{var X=ao(),V=Ve(X);{let he=A(()=>!!e(k));ct(V,{variant:"secondary",size:"sm",get disabled(){return e(he)},onclick:()=>{a(S,!0),a(Y,t.tableName,!0)},children:(Ie,Ue)=>{Ae();var Ut=Qe("Rename");l(Ie,Ut)},$$slots:{default:!0}})}var se=d(V,2);ct(se,{variant:"danger",size:"sm",onclick:()=>a(de,!0),children:(he,Ie)=>{Ae();var Ue=Qe("Delete Table");l(he,Ue)},$$slots:{default:!0}}),l(J,X)};D(Ne,J=>{e(S)?J(f):J(g,!1)})}r(ot);var K=d(ot,2);{var E=J=>{var X=ro(),V=s(X,!0);r(X),y(()=>I(V,e(k))),l(J,X)};D(K,J=>{e(k)&&J(E)})}l(Ee,st)};D(Ct,Ee=>{e(R)&&Ee(Qt)})}var Rt=d(Ct,2),Jt=d(s(Rt)),Xt=s(Jt,!0);r(Jt),r(Rt);var Ke=d(Rt,2);os(Ke,{get tabs(){return re},get activeTab(){return e(x)},set activeTab(Ee){a(x,Ee,!0)},children:(Ee,st)=>{var ot=Yt(),Ne=Ve(ot);{var f=E=>{{let J=A(()=>!e(R));Qr(E,{get fields(){return e(ae)},get readonly(){return e(J)},onaddclick:$,oneditclick:fe,ondeleteclick:b})}},g=E=>{{let J=A(()=>Object.keys(e(ae))),X=A(()=>!e(R));Vl(E,{get indexes(){return e(pe)},get availableFields(){return e(J)},get readonly(){return e(X)},onadd:Q,ondelete:be})}},K=E=>{{let J=A(()=>!e(R));Gl(E,{get ftsFields(){return e(T)},get availableFields(){return e(j)},get readonly(){return e(J)},onsave:ze})}};D(Ne,E=>{e(x)==="columns"?E(f):e(x)==="indexes"?E(g,1):e(x)==="fts"&&E(K,2)})}l(Ee,ot)},$$slots:{default:!0}}),y(()=>I(Xt,e(W))),l(m,B)};D(We,m=>{o().loading?m(at):e(P)?m(w,!1):m(oe,1)})}r(Re);var z=d(Re,2);{let m=A(()=>Object.keys(e(ae)));qr(z,{get mode(){return e(ee)},get columnName(){return e(F)},get field(){return e(U)},get existingColumns(){return e(m)},onsave:Z,get open(){return e(M)},set open(B){a(M,B,!0)}})}var Fe=d(z,2);tr(Fe,{title:"Delete Column",get message(){return`Are you sure you want to delete column "${e(G)??""}"? This action will modify edgebase.config.ts.`},confirmLabel:"Delete",confirmVariant:"danger",onconfirm:q,get open(){return e(ve)},set open(m){a(ve,m,!0)}});var xe=d(Fe,2);tr(xe,{title:"Delete Table",get message(){return`Are you sure you want to delete table "${t.tableName??""}"? This will remove it from edgebase.config.ts.`},confirmLabel:"Delete Table",confirmVariant:"danger",onconfirm:ge,get open(){return e(de)},set open(m){a(de,m,!0)}}),l(n,De),ta(),_()}la(["keydown"]);var io=c("<option> </option>"),co=c('<div class="rt-field svelte-wqn9yg"><label class="rt-label svelte-wqn9yg">User</label> <select class="rt-select svelte-wqn9yg"><option>Select a user...</option><!></select></div>'),vo=c('<div class="rt-field svelte-wqn9yg"><label class="rt-label svelte-wqn9yg">Auth JSON</label> <textarea class="rt-textarea svelte-wqn9yg" rows="5" spellcheck="false"></textarea></div>'),uo=c('<div class="rt-result-error svelte-wqn9yg"> </div>'),fo=c('<div><div class="rt-result-header svelte-wqn9yg"><span class="rt-result-op svelte-wqn9yg"> </span> <span> </span></div> <code class="rt-result-rule svelte-wqn9yg"> </code> <!></div>'),po=c('<div class="rt-results"><h3 class="rt-results-title svelte-wqn9yg">Results</h3> <div class="rt-results-grid svelte-wqn9yg"></div></div>'),mo=c('<div class="rt-layout svelte-wqn9yg"><div class="rt-form svelte-wqn9yg"><fieldset class="rt-field svelte-wqn9yg"><legend class="rt-label svelte-wqn9yg">Auth Context</legend> <div class="rt-radio-group svelte-wqn9yg"><label class="rt-radio svelte-wqn9yg"><input type="radio"/> Anonymous (null)</label> <label class="rt-radio svelte-wqn9yg"><input type="radio"/> Select User</label> <label class="rt-radio svelte-wqn9yg"><input type="radio"/> Custom JSON</label></div></fieldset> <!> <!> <!></div> <!></div>');function _o(n,t){ea(t,!0);const u=[];let o=N(nt([])),h=N(!1),_=N("shared"),P=N("anonymous"),x=N(""),R=N(`{
|
|
5
|
-
"id": "",
|
|
6
|
-
"email": "",
|
|
7
|
-
"role": ""
|
|
8
|
-
}`),M=nt(["read","insert","update","delete","access"]),ee=N(nt([])),F=N(!1);const U=`rules-user-${Math.random().toString(36).slice(2,9)}`,ve=`rules-auth-json-${Math.random().toString(36).slice(2,9)}`;Ot(()=>{t.tableName&&(qt.subscribe(Q=>{const be=Q.schema[t.tableName];be&&a(_,be.namespace,!0)})(),a(ee,[],!0),a(F,!1))}),Ot(()=>{G()});async function G(){try{const q=await pt.fetch("data/users?limit=100");a(o,(q.users??[]).map(Q=>({id:Q.id,email:Q.email??`user-${Q.id.slice(0,8)}`,role:Q.role})),!0)}catch{}}async function de(){a(h,!0),a(F,!1),a(ee,[],!0);let q=null;if(e(P)==="user"&&e(x)){const Q=e(o).find(be=>be.id===e(x));Q&&(q={id:Q.id,email:Q.email,role:Q.role})}else if(e(P)==="custom")try{q=JSON.parse(e(R))}catch{lt("Invalid JSON for custom auth context"),a(h,!1);return}try{const Q=await pt.fetch("data/rules-test",{method:"POST",body:{namespace:e(_),table:t.tableName,auth:q,operations:M}});a(ee,Q.results??[],!0),a(F,!0)}catch(Q){lt(Q instanceof Error?Q.message:"Test failed")}finally{a(h,!1)}}var S=mo(),Y=s(S),re=s(Y),ae=d(s(re),2),pe=s(ae),T=s(pe);Ft(T),T.value=T.__value="anonymous",Ae(),r(pe);var W=d(pe,2),k=s(W);Ft(k),k.value=k.__value="user",Ae(),r(W);var j=d(W,2),$=s(j);Ft($),$.value=$.__value="custom",Ae(),r(j),r(ae),r(re);var fe=d(re,2);{var b=q=>{var Q=co(),be=s(Q),ze=d(be,2),ge=s(ze);ge.value=ge.__value="";var Me=d(ge);tt(Me,17,()=>e(o),Bt,(De,Re)=>{var We=io(),at=s(We);r(We);var oe={};y(()=>{I(at,`${e(Re).email??""} ${e(Re).role?`(${e(Re).role})`:""}`),oe!==(oe=e(Re).id)&&(We.value=(We.__value=e(Re).id)??"")}),l(De,We)}),r(ze),r(Q),y(()=>{Ce(be,"for",U),Ce(ze,"id",U)}),da(ze,()=>e(x),De=>a(x,De)),l(q,Q)};D(fe,q=>{e(P)==="user"&&q(b)})}var L=d(fe,2);{var me=q=>{var Q=vo(),be=s(Q),ze=d(be,2);Da(ze),r(Q),y(()=>{Ce(be,"for",ve),Ce(ze,"id",ve)}),$t(ze,()=>e(R),ge=>a(R,ge)),l(q,Q)};D(L,q=>{e(P)==="custom"&&q(me)})}var Se=d(L,2);ct(Se,{variant:"primary",onclick:de,get loading(){return e(h)},children:(q,Q)=>{Ae();var be=Qe("Test Rules");l(q,be)},$$slots:{default:!0}}),r(Y);var ke=d(Y,2);{var Z=q=>{var Q=po(),be=d(s(Q),2);tt(be,21,()=>e(ee),Bt,(ze,ge)=>{var Me=fo();let De;var Re=s(Me),We=s(Re),at=s(We,!0);r(We);var oe=d(We,2);let w;var z=s(oe,!0);r(oe),r(Re);var Fe=d(Re,2),xe=s(Fe,!0);r(Fe);var m=d(Fe,2);{var B=_e=>{var je=uo(),Ct=s(je,!0);r(je),y(()=>I(Ct,e(ge).error)),l(_e,je)};D(m,_e=>{e(ge).error&&_e(B)})}r(Me),y(()=>{De=Tt(Me,1,"rt-result-card svelte-wqn9yg",null,De,{"rt-result-card--allowed":e(ge).allowed,"rt-result-card--denied":!e(ge).allowed}),I(at,e(ge).operation),w=Tt(oe,1,"rt-result-badge svelte-wqn9yg",null,w,{"rt-badge--allowed":e(ge).allowed,"rt-badge--denied":!e(ge).allowed}),I(z,e(ge).allowed?"✔ Allowed":"✘ Denied"),I(xe,e(ge).rule)}),l(ze,Me)}),r(be),r(Q),l(q,Q)};D(ke,q=>{e(F)&&q(Z)})}r(S),Ua(u,[],T,()=>e(P),q=>a(P,q)),Ua(u,[],k,()=>e(P),q=>a(P,q)),Ua(u,[],$,()=>e(P),q=>a(P,q)),l(n,S),ta()}var ho=c("<button> </button>"),bo=c("<button> </button>"),go=c('<div class="sdk-snippets svelte-hdcl64"><div class="lang-tabs svelte-hdcl64"></div> <div class="op-tabs svelte-hdcl64"></div> <div class="code-block svelte-hdcl64"><button class="copy-btn svelte-hdcl64" title="Copy to clipboard"><svg width="14" height="14" viewBox="0 0 16 16" fill="none"><rect x="5" y="5" width="9" height="9" rx="1" stroke="currentColor" stroke-width="1.5"></rect><path d="M11 5V3C11 2.448 10.552 2 10 2H3C2.448 2 2 2.448 2 3V10C2 10.552 2.448 11 3 11H5" stroke="currentColor" stroke-width="1.5"></path></svg> Copy</button> <pre class="code-pre svelte-hdcl64"><code> </code></pre></div></div>');function yo(n,t){ea(t,!0);const u=()=>pa(qt,"$schemaStore",o),[o,h]=Ia();let _=N("javascript"),P=N("query");const x=[{id:"javascript",label:"JavaScript"},{id:"python",label:"Python"},{id:"dart",label:"Dart"},{id:"swift",label:"Swift"},{id:"kotlin",label:"Kotlin"}],R=[{id:"query",label:"Query"},{id:"insert",label:"Insert"},{id:"update",label:"Update"},{id:"delete",label:"Delete"},{id:"subscribe",label:"Subscribe"}];let M=A(()=>(()=>{const k=u().schema[t.tableName];return(k==null?void 0:k.fields)??{}})()),ee=A(()=>Object.keys(e(M)).filter(k=>k!=="id"&&k!=="createdAt"&&k!=="updatedAt"));function F(k,j){return j.type==="number"||j.type==="integer"||j.type==="float"?"42":j.type==="boolean"?"true":j.type==="json"?'{"key": "value"}':j.type==="datetime"||j.type==="date"?'"2024-01-01T00:00:00Z"':j.enum&&j.enum.length>0?`"${j.enum[0]}"`:`"sample ${k}"`}function U(k){const j=e(ee).slice(0,4).map($=>{const fe=e(M)[$],b=F($,fe);return k==="python"?` "${$}": ${b}`:k==="dart"?` "${$}": ${b}`:k==="swift"?` "${$}": ${b}`:k==="kotlin"?` "${$}" to ${b}`:` ${$}: ${b}`});return j.join(`,
|
|
9
|
-
`)}let ve=A(()=>(()=>{var fe;const k=t.tableName,j=U(e(_));return((fe={javascript:{query:`import { createClient } from '@edge-base/web';
|
|
10
|
-
|
|
11
|
-
const client = createClient('YOUR_URL');
|
|
12
|
-
|
|
13
|
-
const result = await client
|
|
14
|
-
.db('shared').table('${k}')
|
|
15
|
-
.limit(20)
|
|
16
|
-
.getList();
|
|
17
|
-
|
|
18
|
-
console.log(result.items);`,insert:`const record = await client
|
|
19
|
-
.db('shared').table('${k}')
|
|
20
|
-
.insert({
|
|
21
|
-
${j}
|
|
22
|
-
});`,update:`const updated = await client
|
|
23
|
-
.db('shared').table('${k}')
|
|
24
|
-
.update('RECORD_ID', {
|
|
25
|
-
${j}
|
|
26
|
-
});`,delete:`await client
|
|
27
|
-
.db('shared').table('${k}')
|
|
28
|
-
.delete('RECORD_ID');`,subscribe:`const unsubscribe = client
|
|
29
|
-
.db('shared').table('${k}')
|
|
30
|
-
.onSnapshot((snapshot) => {
|
|
31
|
-
console.log(snapshot.items);
|
|
32
|
-
console.log(snapshot.changes);
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
// Later: unsubscribe();`},python:{query:`from edgebase import EdgeBase
|
|
36
|
-
|
|
37
|
-
client = EdgeBase("YOUR_URL")
|
|
38
|
-
|
|
39
|
-
result = client.db("shared").table("${k}").limit(20).get_list()
|
|
40
|
-
print(result.items)`,insert:`record = client.db("shared").table("${k}").insert({
|
|
41
|
-
${j}
|
|
42
|
-
})`,update:`updated = client.db("shared").table("${k}").doc("RECORD_ID").update({
|
|
43
|
-
${j}
|
|
44
|
-
})`,delete:`client.db("shared").table("${k}").doc("RECORD_ID").delete()`,subscribe:`def on_change(change):
|
|
45
|
-
print(change)
|
|
46
|
-
|
|
47
|
-
unsub = client.db("shared").table("${k}").doc("RECORD_ID").on_snapshot(on_change)
|
|
48
|
-
|
|
49
|
-
# Later: unsub()`},dart:{query:`import 'package:edgebase/edgebase.dart';
|
|
50
|
-
|
|
51
|
-
final client = EdgeBase.client('YOUR_URL');
|
|
52
|
-
|
|
53
|
-
final result = await client
|
|
54
|
-
.db('shared').table('${k}')
|
|
55
|
-
.limit(20)
|
|
56
|
-
.getList();
|
|
57
|
-
|
|
58
|
-
print(result.items);`,insert:`final record = await client
|
|
59
|
-
.db('shared').table('${k}')
|
|
60
|
-
.insert({
|
|
61
|
-
${j}
|
|
62
|
-
});`,update:`final updated = await client
|
|
63
|
-
.db('shared').table('${k}')
|
|
64
|
-
.doc('RECORD_ID')
|
|
65
|
-
.update({
|
|
66
|
-
${j}
|
|
67
|
-
});`,delete:`await client
|
|
68
|
-
.db('shared').table('${k}')
|
|
69
|
-
.doc('RECORD_ID')
|
|
70
|
-
.delete();`,subscribe:`final stream = client
|
|
71
|
-
.db('shared').table('${k}')
|
|
72
|
-
.onSnapshot();
|
|
73
|
-
|
|
74
|
-
stream.listen((change) {
|
|
75
|
-
print('\${change.event}: \${change.record}');
|
|
76
|
-
});`},swift:{query:`import EdgeBase
|
|
77
|
-
|
|
78
|
-
let client = EdgeBaseClient("YOUR_URL")
|
|
79
|
-
|
|
80
|
-
let result = try await client
|
|
81
|
-
.db("shared").table("${k}")
|
|
82
|
-
.limit(20)
|
|
83
|
-
.getList()
|
|
84
|
-
|
|
85
|
-
print(result.items)`,insert:`let record = try await client
|
|
86
|
-
.db("shared").table("${k}")
|
|
87
|
-
.insert([
|
|
88
|
-
${j}
|
|
89
|
-
])`,update:`let updated = try await client
|
|
90
|
-
.db("shared").table("${k}")
|
|
91
|
-
.doc("RECORD_ID")
|
|
92
|
-
.update([
|
|
93
|
-
${j}
|
|
94
|
-
])`,delete:`try await client
|
|
95
|
-
.db("shared").table("${k}")
|
|
96
|
-
.doc("RECORD_ID")
|
|
97
|
-
.delete()`,subscribe:`let stream = client
|
|
98
|
-
.db("shared").table("${k}")
|
|
99
|
-
.onSnapshot()
|
|
100
|
-
|
|
101
|
-
for await change in stream {
|
|
102
|
-
print("\\(change.event): \\(change.record)")
|
|
103
|
-
}`},kotlin:{query:`import dev.edgebase.sdk.client.ClientEdgeBase
|
|
104
|
-
|
|
105
|
-
val client = ClientEdgeBase("YOUR_URL")
|
|
106
|
-
|
|
107
|
-
val result = client
|
|
108
|
-
.db("shared").table("${k}")
|
|
109
|
-
.limit(20)
|
|
110
|
-
.getList()
|
|
111
|
-
|
|
112
|
-
println(result.items)`,insert:`val record = client
|
|
113
|
-
.db("shared").table("${k}")
|
|
114
|
-
.insert(mapOf(
|
|
115
|
-
${j}
|
|
116
|
-
))`,update:`val updated = client
|
|
117
|
-
.db("shared").table("${k}")
|
|
118
|
-
.update("RECORD_ID", mapOf(
|
|
119
|
-
${j}
|
|
120
|
-
))`,delete:`client
|
|
121
|
-
.db("shared").table("${k}")
|
|
122
|
-
.delete("RECORD_ID")`,subscribe:`val flow = client
|
|
123
|
-
.db("shared").table("${k}")
|
|
124
|
-
.onSnapshot()
|
|
125
|
-
|
|
126
|
-
flow.collect { change ->
|
|
127
|
-
println("\${change.event}: \${change.record}")
|
|
128
|
-
}`}}[e(_)])==null?void 0:fe[e(P)])??""})());async function G(){try{await navigator.clipboard.writeText(e(ve)),Et("Copied to clipboard")}catch{}}var de=go(),S=s(de);tt(S,21,()=>x,Bt,(k,j)=>{var $=ho();let fe;var b=s($,!0);r($),y(()=>{fe=Tt($,1,"lang-tab svelte-hdcl64",null,fe,{"lang-tab--active":e(_)===e(j).id}),I(b,e(j).label)}),ie("click",$,()=>a(_,e(j).id,!0)),l(k,$)}),r(S);var Y=d(S,2);tt(Y,21,()=>R,Bt,(k,j)=>{var $=bo();let fe;var b=s($,!0);r($),y(()=>{fe=Tt($,1,"op-tab svelte-hdcl64",null,fe,{"op-tab--active":e(P)===e(j).id}),I(b,e(j).label)}),ie("click",$,()=>a(P,e(j).id,!0)),l(k,$)}),r(Y);var re=d(Y,2),ae=s(re),pe=d(ae,2),T=s(pe),W=s(T,!0);r(T),r(pe),r(re),r(de),y(()=>I(W,e(ve))),ie("click",ae,G),l(n,de),ta(),h()}la(["click"]);const Or="edgebase_admin_recent_instances",wo=6;function Cr(){try{const n=localStorage.getItem(Or);if(!n)return{};const t=JSON.parse(n);return t&&typeof t=="object"?t:{}}catch{return{}}}function ko(n){try{localStorage.setItem(Or,JSON.stringify(n))}catch{}}function xo(n){var u,o;const t=n.id.trim();return t?{id:t,label:((u=n.label)==null?void 0:u.trim())||void 0,description:((o=n.description)==null?void 0:o.trim())||void 0}:null}function ur(n){return(Cr()[n]??[]).slice().sort((o,h)=>h.lastUsedAt-o.lastUsedAt).map(({id:o,label:h,description:_})=>({id:o,label:h,description:_}))}function So(n,t){const u=xo(t);if(!u)return;const o=Cr(),h=o[n]??[],_=[{...u,lastUsedAt:Date.now()},...h.filter(P=>P.id!==u.id)].slice(0,wo);ko({...o,[n]:_})}var Oo=c("<span><!></span>"),Co=c('<div class="table-header__hint svelte-11vdap9">Start <code class="svelte-11vdap9">pnpm dev</code> to enable DB block upgrades.</div>'),No=c('<input id="upgrade-env-key" class="upgrade-modal__input svelte-11vdap9"/> <p class="upgrade-modal__hint svelte-11vdap9">Only change this if you already use a specific Postgres env key name.</p>',1),Io=c("<option> </option>"),Po=c("<option> </option>"),Eo=c('<p class="upgrade-modal__hint upgrade-modal__hint--error svelte-11vdap9"> </p>'),To=c('<p class="upgrade-modal__hint svelte-11vdap9">No existing Neon projects were found.</p>'),Ro=c('<p class="upgrade-modal__hint svelte-11vdap9">EdgeBase will use the selected project, restart on Postgres, and restore every table in this block.</p>'),zo=c("<li> </li>"),Do=c('<div class="upgrade-modal__status svelte-11vdap9" role="status" aria-live="polite"><div class="upgrade-modal__status-title svelte-11vdap9"> </div> <p class="upgrade-modal__status-copy svelte-11vdap9">EdgeBase is migrating the full <strong> </strong> database block. This can take a while because every table is exported, the worker restarts on Postgres, and then the block is restored.</p> <div class="upgrade-modal__status-current svelte-11vdap9"> </div> <ol class="upgrade-modal__steps upgrade-modal__steps--status svelte-11vdap9"></ol></div>'),jo=c('<div class="upgrade-modal svelte-11vdap9"><p class="upgrade-modal__text svelte-11vdap9">This migrates the entire <strong> </strong> database block from D1 to Postgres. The current table is just the entry point. Every table in this block is exported, the dev worker restarts on Postgres, and then the full block is restored.</p> <div class="upgrade-modal__notice svelte-11vdap9"><div class="upgrade-modal__notice-title svelte-11vdap9">What happens during this migration</div> <ol class="upgrade-modal__steps svelte-11vdap9"><li>Export all tables from the current D1-backed database block.</li> <li>Connect an existing Neon project or create a new one.</li> <li>Restart the dev worker with `provider: \'postgres\'`.</li> <li>Restore every table in the database block into Postgres.</li></ol></div> <div class="upgrade-modal__field svelte-11vdap9"><label class="upgrade-modal__label svelte-11vdap9" for="upgrade-env-key-display">Automatic Postgres Env Key</label> <div id="upgrade-env-key-display" class="upgrade-modal__static svelte-11vdap9"><code class="svelte-11vdap9"> </code></div> <p class="upgrade-modal__hint svelte-11vdap9">EdgeBase will write this key during migration. Only override it if you already use a specific Postgres env key name.</p> <div class="upgrade-modal__actions-row svelte-11vdap9"><!></div> <!></div> <div class="upgrade-modal__choices svelte-11vdap9"><div class="upgrade-modal__choices-copy svelte-11vdap9"><div class="upgrade-modal__notice-title svelte-11vdap9">Neon Setup</div> <p class="upgrade-modal__hint svelte-11vdap9">Both options migrate the same database block and use the env key above. Pick the path that matches whether the Neon project already exists.</p></div> <div class="upgrade-modal__choice-grid svelte-11vdap9"><section class="upgrade-modal__choice-card svelte-11vdap9"><div class="upgrade-modal__choice-header svelte-11vdap9"><div class="upgrade-modal__choice-eyebrow svelte-11vdap9">Existing project</div> <h3 class="upgrade-modal__choice-title svelte-11vdap9">1. Connect an existing Neon project</h3> <p class="upgrade-modal__hint svelte-11vdap9">Best when the Neon project already exists in your account.</p></div> <label class="upgrade-modal__label svelte-11vdap9" for="upgrade-neon-project">Existing Neon Project</label> <select id="upgrade-neon-project" class="upgrade-modal__select svelte-11vdap9"><!></select> <div class="upgrade-modal__actions-row svelte-11vdap9"><!></div> <!> <div class="upgrade-modal__actions-row upgrade-modal__choice-actions svelte-11vdap9"><!></div></section> <section class="upgrade-modal__choice-card svelte-11vdap9"><div class="upgrade-modal__choice-header svelte-11vdap9"><div class="upgrade-modal__choice-eyebrow svelte-11vdap9">Provision new project</div> <h3 class="upgrade-modal__choice-title svelte-11vdap9">2. Create a new Neon project</h3> <p class="upgrade-modal__hint svelte-11vdap9">Best when you want EdgeBase to provision Neon before migrating.</p></div> <label class="upgrade-modal__label svelte-11vdap9" for="upgrade-project-name">New Neon Project Name</label> <input id="upgrade-project-name" class="upgrade-modal__input svelte-11vdap9"/> <p class="upgrade-modal__hint svelte-11vdap9">EdgeBase will try this name first, then append a suffix if Neon already has one.</p> <div class="upgrade-modal__actions-row upgrade-modal__choice-actions svelte-11vdap9"><!></div></section></div></div> <!></div>'),qo=c('<button class="target-bar__button svelte-11vdap9">Clear</button>'),Qo=c('<span class="target-chip__meta svelte-11vdap9"> </span>'),Uo=c('<button class="target-chip svelte-11vdap9" type="button"><span class="target-chip__label svelte-11vdap9"> </span> <!></button>'),Lo=c('<div class="target-bar__section svelte-11vdap9"><div class="target-bar__section-label svelte-11vdap9"> </div> <div class="target-bar__chip-row svelte-11vdap9"></div></div>'),Bo=c('<span class="target-chip__meta svelte-11vdap9"> </span>'),Fo=c('<button class="target-chip svelte-11vdap9" type="button"><span class="target-chip__label svelte-11vdap9"> </span> <!></button>'),Ao=c('<div class="target-bar__section svelte-11vdap9"><div class="target-bar__section-label svelte-11vdap9"> </div> <div class="target-bar__chip-row svelte-11vdap9"></div></div>'),Mo=c('<div class="target-bar__status svelte-11vdap9">Loading instance suggestions...</div>'),Ko=c('<div class="target-bar__status target-bar__status--error svelte-11vdap9"> </div>'),Vo=c('<div class="target-bar__suggestions svelte-11vdap9"><!> <!> <!></div>'),Jo=c('<div class="target-bar svelte-11vdap9"><div class="target-bar__copy svelte-11vdap9"><div class="target-bar__title svelte-11vdap9"> </div> <div class="target-bar__description svelte-11vdap9"> </div></div> <div class="target-bar__controls svelte-11vdap9"><div class="target-bar__field svelte-11vdap9"><label class="target-bar__field-label svelte-11vdap9" for="database-target-input"> </label> <input id="database-target-input" class="target-bar__input svelte-11vdap9" type="text" maxlength="128"/></div> <button class="target-bar__button target-bar__button--primary svelte-11vdap9"> </button> <!></div> <!></div>'),Xo=c("<button> </button>"),Wo=c('<div class="target-empty svelte-11vdap9"><h3 class="svelte-11vdap9"> </h3> <p class="svelte-11vdap9"> </p></div>'),Zo=c('<div class="target-empty svelte-11vdap9"><h3 class="svelte-11vdap9"> </h3> <p class="svelte-11vdap9"> </p></div>'),Ho=c('<div class="table-detail svelte-11vdap9"><div class="table-header svelte-11vdap9"><div class="table-header__meta svelte-11vdap9"><h2 class="table-title svelte-11vdap9"> </h2> <div class="table-badges svelte-11vdap9"><span class="table-badge svelte-11vdap9"> </span> <span class="table-badge svelte-11vdap9"> </span> <span> </span></div></div> <div class="table-header__actions svelte-11vdap9"><!> <a class="erd-link svelte-11vdap9" title="View ERD Diagram"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><rect x="1" y="2" width="5" height="4" rx="1" stroke="currentColor" stroke-width="1.5"></rect><rect x="10" y="10" width="5" height="4" rx="1" stroke="currentColor" stroke-width="1.5"></rect><path d="M6 4H8.5V12H10" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"></path></svg> ERD</a> <a class="erd-link svelte-11vdap9" target="_blank" rel="noreferrer" title="Open database docs"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><path d="M3 2H10L13 5V14H3V2Z" stroke="currentColor" stroke-width="1.5" stroke-linejoin="round"></path><path d="M10 2V5H13" stroke="currentColor" stroke-width="1.5" stroke-linejoin="round"></path><path d="M6 8H10M6 10.5H9" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"></path></svg> Docs</a> <!></div></div> <!> <!> <div class="tab-bar svelte-11vdap9"></div> <div class="tab-content svelte-11vdap9"><!></div></div>');function Oi(n,t){ea(t,!0);const u=()=>pa(Dr,"$page",_),o=()=>pa(qt,"$schemaStore",_),h=()=>pa(mr,"$devInfoStore",_),[_,P]=Ia();let x=A(()=>u().params.table??""),R=A(()=>o().schema[e(x)]??void 0),M=A(()=>{var v;return((v=e(R))==null?void 0:v.namespace)??""}),ee=A(()=>{var v;return((v=e(R))==null?void 0:v.provider)??"do"}),F=A(()=>{var v;return!!((v=e(R))!=null&&v.dynamic)}),U=A(()=>{var v;return(v=e(R))==null?void 0:v.instanceDiscovery}),ve=A(()=>Ga(u().url.searchParams.get("instance"))),G=A(()=>{const v=u().url.searchParams.get("tab");return e(R)?v==="sql"?"query":v==="records"||v==="query"||v==="schema"||v==="rules"||v==="sdk"?v:e(F)&&!e(ve)?"schema":"records":v==="query"||v==="sql"?"query":"schema"}),de=N(""),S=N(!1),Y=N(""),re=N(nt([])),ae=N(nt([])),pe=N(!1),T=N(""),W=N(!1),k=N(null),j=N(0),$=N(""),fe=N(nt([])),b=N(!1),L=N(!1),me=N(""),Se=N(""),ke=A(()=>h().devMode);Ot(()=>{a(de,e(ve)??"",!0)}),Ot(()=>{if(typeof window>"u"||!e(F)||!e(M)){a(ae,[],!0);return}a(ae,ur(e(M)),!0)}),Ot(()=>{var Le;if(!e(F)||!e(M)){a(S,!1),a(Y,""),a(re,[],!0);return}if(((Le=e(U))==null?void 0:Le.source)==="manual"){a(S,!1),a(Y,""),a(re,[],!0);return}const v=e(de).trim();let C=!1;const ne=v?160:0;a(S,!0),a(Y,"");const ue=window.setTimeout(async()=>{try{const te=new URLSearchParams({limit:"8"});v&&te.set("q",v);const le=await pt.fetch(`data/namespaces/${encodeURIComponent(e(M))}/instances?${te.toString()}`);if(C)return;a(re,le.items??[],!0),a(Y,"")}catch(te){if(C)return;a(re,[],!0),a(Y,te instanceof Error?te.message:"Failed to load instance suggestions",!0)}finally{C||a(S,!1)}},ne);return()=>{C=!0,window.clearTimeout(ue)}});function Z(v){return v==="postgres"||v==="neon"?"PG":v==="d1"?"D1":"DO"}function q(v){const C=v.trim().toUpperCase().replace(/[^A-Z0-9_]+/g,"_");return C?`DB_POSTGRES_${C}_URL`:"DB_POSTGRES_SHARED_URL"}function Q(v){return v.trim().toLowerCase().replace(/[^a-z0-9-]+/g,"-").replace(/^-+|-+$/g,"").replace(/-{2,}/g,"-")||"edgebase-db"}Ot(()=>{e(M)&&(!e(pe)||!e(T).trim())&&!e(W)&&a(T,q(e(M)),!0)}),Ot(()=>{Me()&&!e(L)&&!e(b)&&at()});function be(v){return v?"Per-tenant DB":"Single DB"}function ze(){return e(W)?e(T).trim()||q(e(M)):q(e(M))}function ge(){return e($).trim()||Q(e(M))}function Me(){return e(ke)&&De()}function De(){return!e(F)&&e(ee)==="d1"}function Re(){return De()?e(ke)?"":"Database block upgrades require dev mode with the schema sidecar. Start `pnpm dev` to enable Neon/Postgres migration.":""}function We(){a(W,!e(W)),e(W)&&!e(T).trim()&&a(T,q(e(M)),!0)}Ot(()=>{e(M)&&(e($).trim()||a($,Q(e(M)),!0))}),Ot(()=>{if(!e(k)||typeof window>"u"){a(j,0);return}a(j,0);const v=[window.setTimeout(()=>a(j,1),1200),window.setTimeout(()=>a(j,2),4200),window.setTimeout(()=>a(j,3),8200)];return()=>{for(const C of v)window.clearTimeout(C)}});async function at(v=!1){var C;if(!(!v&&(e(L)||e(b)))){a(b,!0),a(me,"");try{const ne=await pt.schemaMutation(v?"integrations/neon/projects?refresh=1":"integrations/neon/projects",{method:"GET"});a(fe,ne.items??[],!0),a(Se,((C=e(fe)[0])==null?void 0:C.projectId)??"",!0),a(L,!0)}catch(ne){a(me,ne instanceof Error?ne.message:"Failed to load Neon projects.",!0)}finally{a(b,!1)}}}function oe(v){var ne;return((ne=v==null?void 0:v.targetLabel)==null?void 0:ne.trim())||"Target"}function w(v){return`Choose ${oe(v)}`}function z(v){return`${oe(v)} ID`}function Fe(v){return`Paste ${oe(v).toLowerCase()} ID`}function xe(v){return oe(v)==="Target"?"Apply":"Open"}function m(v){const C=v==null?void 0:v.helperText;return C||`Pick a ${oe(v).toLowerCase()} to view this table's records or run queries.`}function B(v){return`${w(v)} First`}function _e(v,C){const ne=oe(v).toLowerCase();return C==="records"?`Select a ${ne} above to view records for this table.`:`Select a ${ne} above to run queries for this table.`}function je(v){const C=oe(v);return C==="Target"?"Recent":`Recent ${C}s`}function Ct(v){const C=oe(v);return C==="Target"?"Suggestions":`Suggested ${C}s`}async function Qt(v){const C=new URL(u().url);v(C.searchParams),await Aa(`${C.pathname}${C.search}`,{replaceState:!0,keepFocus:!0,noScroll:!0})}function Rt(v){Qt(C=>{v==="records"?C.delete("tab"):C.set("tab",v)})}function Jt(v){return e(re).find(C=>C.id===v)??e(ae).find(C=>C.id===v)}function Xt(v){typeof window>"u"||!e(M)||(So(e(M),v),a(ae,ur(e(M)),!0))}function Ke(v){const C=Ga((v==null?void 0:v.id)??e(de));Qt(ne=>{if(C){const ue=v??Jt(C)??{id:C};Xt(ue),ne.set("instance",C),e(F)&&e(G)==="schema"&&ne.delete("tab")}else ne.delete("instance"),e(F)&&e(G)==="records"&&ne.set("tab","schema")})}function Ee(){a(de,""),Ke()}function st(v){a(de,v.id,!0),Ke(v)}async function ot(v){if(e(M)){if(v==="reuse"&&!e(Se)){lt(e(me)||"Choose an existing Neon project first, or create a new one.");return}v==="create"&&ge(),a(k,v,!0);try{await pt.schemaMutation("integrations/neon/upgrade",{method:"POST",body:{namespace:e(M),projectId:v==="reuse"?e(Se):void 0,projectName:v==="create"?ge():void 0,mode:v,...e(W)?{envKey:ze()}:{}}}),await qt.loadSchema({silent:!0}),a(pe,!1),Et(`"${e(M)}" upgraded from D1 to Postgres`)}catch(C){const ne=C instanceof Error?C.message:"Failed to upgrade database block.";lt(ne)}finally{a(k,null)}}}function Ne(){return!e(b)&&e(fe).length>0&&!!e(Se)}function f(){return e(k)==="reuse"?"Migrating Database Block to Postgres":e(k)==="create"?"Creating Neon Project and Migrating Database Block":"Database Block Migration"}function g(v){return v<e(j)?"done":v===e(j)?"active":"pending"}function K(){return[{label:`Export every table in the "${e(M)}" database block from D1`,state:g(0)},{label:e(k)==="create"?`Create the Neon project "${ge()}" and write the Postgres env key`:"Connect the selected Neon project and write the Postgres env key",state:g(1)},{label:"Restart the dev worker on Postgres",state:g(2)},{label:`Restore all rows back into the "${e(M)}" database block`,state:g(3)}]}function E(){var v;return((v=K()[e(j)])==null?void 0:v.label)??"Preparing migration..."}let J=A(()=>{const v=new Set(e(ae).map(C=>C.id));return e(re).filter(C=>!v.has(C.id))});const X=[{id:"records",label:"Records"},{id:"query",label:"Query"},{id:"schema",label:"Schema"},{id:"rules",label:"Rules"},{id:"sdk",label:"SDK"}];var V=Ho(),se=s(V),he=s(se),Ie=s(he),Ue=s(Ie,!0);r(Ie);var Ut=d(Ie,2),Lt=s(Ut),it=s(Lt,!0);r(Lt);var mt=d(Lt,2),Mt=s(mt,!0);r(mt);var ca=d(mt,2);let va;var ya=s(ca,!0);r(ca),r(Ut),r(he);var ma=d(he,2),ua=s(ma);{var wa=v=>{ct(v,{variant:"secondary",size:"sm",onclick:()=>a(pe,!0),children:(C,ne)=>{Ae();var ue=Qe("Upgrade to Postgres");l(C,ue)},$$slots:{default:!0}})},_a=A(()=>Me()),aa=v=>{var C=Oo(),ne=s(C);ct(ne,{variant:"secondary",size:"sm",disabled:!0,children:(ue,Le)=>{Ae();var te=Qe("Upgrade to Postgres");l(ue,te)},$$slots:{default:!0}}),r(C),y(ue=>Ce(C,"title",ue),[Re]),l(v,C)},Kt=A(()=>De());D(ua,v=>{e(_a)?v(wa):e(Kt)&&v(aa,1)})}var zt=d(ua,2),Wt=d(zt,2),ha=d(Wt,2);{var ra=v=>{var C=Co();l(v,C)},oa=A(()=>Re());D(ha,v=>{e(oa)&&v(ra)})}r(ma),r(se);var ka=d(se,2);pr(ka,{title:"Migrate Database Block to Postgres",maxWidth:"560px",get open(){return e(pe)},set open(C){a(pe,C,!0)},footer:C=>{{let ne=A(()=>e(k)!==null);ct(C,{variant:"secondary",get disabled(){return e(ne)},onclick:()=>a(pe,!1),children:(ue,Le)=>{Ae();var te=Qe("Cancel");l(ue,te)},$$slots:{default:!0}})}},children:(C,ne)=>{var ue=jo(),Le=s(ue),te=d(s(Le)),le=s(te,!0);r(te),Ae(),r(Le);var Oe=d(Le,4),_t=d(s(Oe),2),Ze=s(_t),kt=s(Ze,!0);r(Ze),r(_t);var He=d(_t,4),ht=s(He);{let we=A(()=>e(k)!==null);ct(ht,{variant:"ghost",onclick:We,get disabled(){return e(we)},children:(Te,ut)=>{Ae();var et=Qe();y(()=>I(et,e(W)?"Hide Env Key Override":"Customize Env Key")),l(Te,et)},$$slots:{default:!0}})}r(He);var bt=d(He,2);{var xt=we=>{var Te=No(),ut=Ve(Te);Ft(ut),Ae(2),y(et=>Ce(ut,"placeholder",et),[()=>q(e(M))]),$t(ut,()=>e(T),et=>a(T,et)),l(we,Te)};D(bt,we=>{e(W)&&we(xt)})}r(Oe);var dt=d(Oe,2),Je=d(s(dt),2),vt=s(Je),Be=d(s(vt),4),Nt=s(Be);{var Zt=we=>{var Te=Io(),ut=s(Te,!0);r(Te),Te.value=Te.__value="",y(()=>I(ut,e(b)?"Loading Neon projects...":"No Neon projects found")),l(we,Te)},It=we=>{var Te=Yt(),ut=Ve(Te);tt(ut,17,()=>e(fe),et=>et.projectId,(et,jt)=>{var Gt=Po(),qa=s(Gt);r(Gt);var xa={};y(()=>{I(qa,`${e(jt).projectName??""} (${e(jt).orgName??""})`),xa!==(xa=e(jt).projectId)&&(Gt.value=(Gt.__value=e(jt).projectId)??"")}),l(et,Gt)}),l(we,Te)};D(Nt,we=>{e(fe).length===0?we(Zt):we(It,!1)})}r(Be);var gt=d(Be,2),Pe=s(gt);ct(Pe,{variant:"ghost",onclick:()=>at(!0),get loading(){return e(b)},children:(we,Te)=>{Ae();var ut=Qe("Refresh Projects");l(we,ut)},$$slots:{default:!0}}),r(gt);var qe=d(gt,2);{var yt=we=>{var Te=Eo(),ut=s(Te,!0);r(Te),y(()=>I(ut,e(me))),l(we,Te)},Ht=we=>{var Te=To();l(we,Te)},Xe=we=>{var Te=Ro();l(we,Te)};D(qe,we=>{e(me)?we(yt):!e(b)&&e(fe).length===0?we(Ht,1):e(b)||we(Xe,2)})}var Ge=d(qe,2),St=s(Ge);{let we=A(()=>!Ne()||e(k)!==null);ct(St,{variant:"secondary",get disabled(){return e(we)},onclick:()=>ot("reuse"),children:(Te,ut)=>{Ae();var et=Qe();y(()=>I(et,e(k)==="reuse"?"Connecting Existing Neon...":"Connect Existing Neon")),l(Te,et)},$$slots:{default:!0}})}r(Ge),r(vt);var sa=d(vt,2),Dt=d(s(sa),4);Ft(Dt);var Ye=d(Dt,4),$e=s(Ye);{let we=A(()=>e(k)!==null);ct($e,{variant:"primary",get disabled(){return e(we)},onclick:()=>ot("create"),children:(Te,ut)=>{Ae();var et=Qe();y(()=>I(et,e(k)==="create"?"Creating Neon Project...":"Create New Neon Project")),l(Te,et)},$$slots:{default:!0}})}r(Ye),r(sa),r(Je),r(dt);var Pt=d(dt,2);{var ia=we=>{var Te=Do(),ut=s(Te),et=s(ut,!0);r(ut);var jt=d(ut,2),Gt=d(s(jt)),qa=s(Gt,!0);r(Gt),Ae(),r(jt);var xa=d(jt,2),Nr=s(xa);r(xa);var Za=d(xa,2);tt(Za,21,K,Bt,(Qa,Pa)=>{var Ea=zo(),Ir=s(Ea,!0);r(Ea),y(()=>{Tt(Ea,1,`upgrade-modal__step upgrade-modal__step--${e(Pa).state}`,"svelte-11vdap9"),I(Ir,e(Pa).label)}),l(Qa,Ea)}),r(Za),r(Te),y((Qa,Pa)=>{I(et,Qa),I(qa,e(M)),I(Nr,`Current step: ${Pa??""}`)},[f,E]),l(we,Te)};D(Pt,we=>{e(k)&&we(ia)})}r(ue),y((we,Te)=>{I(le,e(M)),I(kt,we),Be.disabled=e(b)||e(fe).length===0,Ce(Dt,"placeholder",Te),Dt.disabled=e(k)!==null},[ze,()=>Q(e(M))]),da(Be,()=>e(Se),we=>a(Se,we)),$t(Dt,()=>e($),we=>a($,we)),l(C,ue)},$$slots:{footer:!0,default:!0}});var fa=d(ka,2);{var i=v=>{var C=Jo(),ne=s(C),ue=s(ne),Le=s(ue,!0);r(ue);var te=d(ue,2),le=s(te,!0);r(te),r(ne);var Oe=d(ne,2),_t=s(Oe),Ze=s(_t),kt=s(Ze,!0);r(Ze);var He=d(Ze,2);Ft(He),r(_t);var ht=d(_t,2),bt=s(ht,!0);r(ht);var xt=d(ht,2);{var dt=Be=>{var Nt=qo();ie("click",Nt,Ee),l(Be,Nt)};D(xt,Be=>{e(ve)&&Be(dt)})}r(Oe);var Je=d(Oe,2);{var vt=Be=>{var Nt=Vo(),Zt=s(Nt);{var It=Xe=>{var Ge=Lo(),St=s(Ge),sa=s(St,!0);r(St);var Dt=d(St,2);tt(Dt,21,()=>e(ae),Ye=>Ye.id,(Ye,$e)=>{var Pt=Uo(),ia=s(Pt),we=s(ia,!0);r(ia);var Te=d(ia,2);{var ut=et=>{var jt=Qo(),Gt=s(jt,!0);r(jt),y(()=>I(Gt,e($e).id)),l(et,jt)};D(Te,et=>{e($e).label&&et(ut)})}r(Pt),y(()=>I(we,e($e).label??e($e).id)),ie("click",Pt,()=>st(e($e))),l(Ye,Pt)}),r(Dt),r(Ge),y(Ye=>I(sa,Ye),[()=>je(e(U))]),l(Xe,Ge)};D(Zt,Xe=>{e(ae).length>0&&Xe(It)})}var gt=d(Zt,2);{var Pe=Xe=>{var Ge=Ao(),St=s(Ge),sa=s(St,!0);r(St);var Dt=d(St,2);tt(Dt,21,()=>e(J),Ye=>Ye.id,(Ye,$e)=>{var Pt=Fo(),ia=s(Pt),we=s(ia,!0);r(ia);var Te=d(ia,2);{var ut=et=>{var jt=Bo(),Gt=s(jt,!0);r(jt),y(()=>I(Gt,e($e).description??e($e).id)),l(et,jt)};D(Te,et=>{(e($e).label||e($e).description)&&et(ut)})}r(Pt),y(()=>I(we,e($e).label??e($e).id)),ie("click",Pt,()=>st(e($e))),l(Ye,Pt)}),r(Dt),r(Ge),y(Ye=>I(sa,Ye),[()=>Ct(e(U))]),l(Xe,Ge)};D(gt,Xe=>{e(J).length>0&&Xe(Pe)})}var qe=d(gt,2);{var yt=Xe=>{var Ge=Mo();l(Xe,Ge)},Ht=Xe=>{var Ge=Ko(),St=s(Ge,!0);r(Ge),y(()=>I(St,e(Y))),l(Xe,Ge)};D(qe,Xe=>{e(S)?Xe(yt):e(Y)&&Xe(Ht,1)})}r(Nt),l(Be,Nt)};D(Je,Be=>{(e(ae).length>0||e(J).length>0||e(S)||e(Y))&&Be(vt)})}r(C),y((Be,Nt,Zt,It,gt,Pe)=>{I(Le,Be),I(le,Nt),I(kt,Zt),Ce(He,"aria-label",It),Ce(He,"placeholder",gt),I(bt,Pe)},[()=>w(e(U)),()=>m(e(U)),()=>z(e(U)),()=>z(e(U)),()=>{var Be;return((Be=e(U))==null?void 0:Be.placeholder)??Fe(e(U))},()=>xe(e(U))]),ie("keydown",He,Be=>{Be.key==="Enter"&&Ke()}),$t(He,()=>e(de),Be=>a(de,Be)),ie("click",ht,()=>Ke()),l(v,C)};D(fa,v=>{e(F)&&v(i)})}var p=d(fa,2);tt(p,21,()=>X,Bt,(v,C)=>{var ne=Xo();let ue;var Le=s(ne,!0);r(ne),y(()=>{ue=Tt(ne,1,"tab-btn svelte-11vdap9",null,ue,{"tab-btn--active":e(G)===e(C).id}),I(Le,e(C).label)}),ie("click",ne,()=>Rt(e(C).id)),l(v,ne)}),r(p);var O=d(p,2),H=s(O);{var ye=v=>{var C=Yt(),ne=Ve(C);{var ue=te=>{var le=Wo(),Oe=s(le),_t=s(Oe,!0);r(Oe);var Ze=d(Oe,2),kt=s(Ze,!0);r(Ze),r(le),y((He,ht)=>{I(_t,He),I(kt,ht)},[()=>B(e(U)),()=>_e(e(U),"records")]),l(te,le)},Le=te=>{Qn(te,{get tableName(){return e(x)},get instanceId(){return e(ve)}})};D(ne,te=>{e(F)&&!e(ve)?te(ue):te(Le,!1)})}l(v,C)},ce=v=>{var C=Yt(),ne=Ve(C);{var ue=te=>{var le=Zo(),Oe=s(le),_t=s(Oe,!0);r(Oe);var Ze=d(Oe,2),kt=s(Ze,!0);r(Ze),r(le),y((He,ht)=>{I(_t,He),I(kt,ht)},[()=>B(e(U)),()=>_e(e(U),"query")]),l(te,le)},Le=te=>{Ql(te,{get tableName(){return e(x)},get namespace(){return e(M)},get instanceId(){return e(ve)}})};D(ne,te=>{e(F)&&!e(ve)?te(ue):te(Le,!1)})}l(v,C)},rt=v=>{oo(v,{get tableName(){return e(x)}})},At=v=>{_o(v,{get tableName(){return e(x)}})},Vt=v=>{yo(v,{get tableName(){return e(x)}})};D(H,v=>{e(G)==="records"?v(ye):e(G)==="query"?v(ce,1):e(G)==="schema"?v(rt,2):e(G)==="rules"?v(At,3):e(G)==="sdk"&&v(Vt,4)})}r(O),r(V),y((v,C)=>{I(Ue,e(x)),I(it,e(M)),I(Mt,v),va=Tt(ca,1,"table-badge svelte-11vdap9",null,va,{"table-badge--dynamic":e(F)}),I(ya,C),Ce(zt,"href",`${Ra??""}/database/erd`),Ce(Wt,"href",cs)},[()=>Z(e(ee)),()=>be(e(F))]),l(n,V),ta(),P()}la(["keydown","click"]);export{Oi as component};
|